registrar(k): gcc 2.95 compile fixes
[sip-router] / modules_k / registrar / common.c
1 /*
2  * $Id$
3  *
4  * Common stuff
5  *
6  * Copyright (C) 2001-2003 FhG Fokus
7  *
8  * This file is part of Kamailio, a free SIP server.
9  *
10  * Kamailio is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version
14  *
15  * Kamailio is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License 
21  * along with this program; if not, write to the Free Software 
22  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
23  *      
24  * History
25  * ------
26  * 2003-02-14 un-escaping added (janakj)
27  * 2006-09-19 AOR may be provided via an AVP instead of being fetched
28  *            from URI (bogdan)
29 */
30
31 /*!
32  * \file
33  * \brief SIP registrar module
34  * \ingroup registrar
35  */
36
37 #include <string.h> 
38 #include "../../dprint.h"
39 #include "../../parser/parse_uri.h"
40 #include "rerrno.h"
41 #include "reg_mod.h"
42 #include "common.h"
43
44
45 #define MAX_AOR_LEN 256
46
47 /*! \brief
48  * Extract Address of Record
49  */
50 int extract_aor(str* _uri, str* _a)
51 {
52         static char aor_buf[MAX_AOR_LEN];
53         str tmp;
54         struct sip_uri puri;
55         int user_len;
56         int_str avp_val;
57         struct usr_avp *avp;
58         str *uri;
59
60         memset(aor_buf, 0, MAX_AOR_LEN);
61         if (aor_avp_name.n!=0) {
62                 avp = search_first_avp( aor_avp_type, aor_avp_name, &avp_val, 0);
63                 if (avp && is_avp_str_val(avp)) {
64                         uri = &avp_val.s;
65                 } else {
66                         uri = _uri;
67                 }
68         } else {
69                 uri=_uri;
70         }
71
72         if (parse_uri(uri->s, uri->len, &puri) < 0) {
73                 rerrno = R_AOR_PARSE;
74                 LM_ERR("failed to parse Address of Record\n");
75                 return -1;
76         }
77         
78         if ( (puri.user.len + puri.host.len + 1) > MAX_AOR_LEN
79         || puri.user.len > USERNAME_MAX_SIZE
80         ||  puri.host.len > DOMAIN_MAX_SIZE ) {
81                 rerrno = R_AOR_LEN;
82                 LM_ERR("Address Of Record too long\n");
83                 return -2;
84         }
85
86         _a->s = aor_buf;
87         _a->len = puri.user.len;
88
89         if (un_escape(&puri.user, _a) < 0) {
90                 rerrno = R_UNESCAPE;
91                 LM_ERR("failed to unescape username\n");
92                 return -3;
93         }
94
95         user_len = _a->len;
96
97         if (reg_use_domain) {
98                 if (user_len)
99                         aor_buf[_a->len++] = '@';
100                 /* strip prefix (if defined) */
101                 if (realm_prefix.len && realm_prefix.len<puri.host.len &&
102                 (memcmp(realm_prefix.s, puri.host.s, realm_prefix.len)==0) ) {
103                         memcpy(aor_buf + _a->len, puri.host.s + realm_prefix.len,
104                                         puri.host.len - realm_prefix.len);
105                         _a->len += puri.host.len - realm_prefix.len;
106                 } else {
107                         memcpy(aor_buf + _a->len, puri.host.s, puri.host.len);
108                         _a->len += puri.host.len;
109                 }
110         }
111
112         if (case_sensitive && user_len) {
113                 tmp.s = _a->s + user_len + 1;
114                 tmp.len = _a->s + _a->len - tmp.s;
115                 strlower(&tmp);
116         } else {
117                 strlower(_a);
118         }
119
120         return 0;
121 }