123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- /*
- * $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;
- }
|