You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kamailio/modules/cpl-c/cpl_sig.c

124 lines
3.7 KiB

/*
* $Id$
*
* Copyright (C) 2001-2003 FhG Fokus
*
* This file is part of Kamailio, a free SIP server.
*
* Kamailio is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version
*
* Kamailio is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "../../action.h"
#include "../../dset.h"
#include "../../modules/tm/tm_load.h"
#include "loc_set.h"
#include "cpl_sig.h"
#include "cpl_env.h"
/* forwards the msg to the given location set; if flags has set the
* CPL_PROXY_DONE, all locations will be added as branches, otherwise, the
* first one will set as RURI (this is ha case when this is the first proxy
* of the message)
* The given list of location will be freed, returning 0 instead.
* Returns: 0 - OK
* -1 - error */
int cpl_proxy_to_loc_set( struct sip_msg *msg, struct location **locs,
unsigned char flag)
{
struct location *foo;
struct action act;
struct run_act_ctx ra_ctx;
int bflags;
if (!*locs) {
LM_ERR("empty loc set!!\n");
goto error;
}
/* if it's the first time when this sip_msg is proxied, use the first addr
* in loc_set to rewrite the RURI */
if (!(flag&CPL_PROXY_DONE)) {
LM_DBG("rewriting Request-URI with <%s>\n",(*locs)->addr.uri.s);
/* build a new action for setting the URI */
memset(&act, '\0', sizeof(act));
act.type = SET_URI_T;
act.val[0].type = STRING_ST;
act.val[0].u.string = (*locs)->addr.uri.s;
init_run_actions_ctx(&ra_ctx);
/* push the action */
if (do_action(&ra_ctx, &act, msg) < 0) {
LM_ERR("do_action failed\n");
goto error;
}
/* build a new action for setting the DSTURI */
if((*locs)->addr.received.s && (*locs)->addr.received.len) {
LM_DBG("rewriting Destination URI "
"with <%s>\n",(*locs)->addr.received.s);
if (set_dst_uri(msg, &(*locs)->addr.received) < 0) {
LM_ERR("Error while setting the dst uri\n");
goto error;
}
/* dst_uri changes, so it makes sense to re-use the current uri for
forking */
ruri_mark_new(); /* re-use uri for serial forking */
}
/* is the location NATED? */
if ((*locs)->flags&CPL_LOC_NATED)
setbflag( 0, cpl_fct.ulb.nat_flag );
/* free the location and point to the next one */
foo = (*locs)->next;
free_location( *locs );
*locs = foo;
}
/* add the rest of the locations as branches */
while(*locs) {
bflags = ((*locs)->flags&CPL_LOC_NATED) ? cpl_fct.ulb.nat_flag : 0 ;
LM_DBG("appending branch <%.*s>, flags %d\n",
(*locs)->addr.uri.len, (*locs)->addr.uri.s, bflags);
if(append_branch(msg, &(*locs)->addr.uri,
&(*locs)->addr.received, 0,
Q_UNSPECIFIED, bflags, 0, 0, 0, 0, 0)==-1){
LM_ERR("failed when appending branch <%s>\n",
(*locs)->addr.uri.s);
goto error;
}
/* free the location and point to the next one */
foo = (*locs)->next;
free_location( *locs );
*locs = foo;
}
/* run what proxy route is set */
if (cpl_env.proxy_route) {
/* do not alter route type - it might be REQUEST or FAILURE */
run_top_route( main_rt.rlist[cpl_env.proxy_route], msg, 0);
}
/* do t_forward */
if (cpl_fct.tmb.t_relay(msg, 0, 0)==-1) {
LM_ERR("t_relay failed !\n");
goto error;
}
return 0;
error:
return -1;
}