9444f7a79fd19c4b8a4526100fe88c4f33a0af9b
[sip-router] / modules_k / presence / utils_func.h
1 /*
2  * $Id$
3  *
4  * presence module - presence server implementation
5  *
6  * Copyright (C) 2006 Voice Sistem S.R.L.
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  *  2006-08-15  initial version (anca)
27  */
28
29 /*! \file
30  * \brief OpenSER presence module :: Utility functions
31  * \ref utils_func.c
32  * \ingroup presence 
33  */
34
35
36
37 #ifndef UTILS_FUNC_H
38 #define UTILS_FUNC_H
39 #include <stdio.h>
40 #include <stdlib.h>
41 #include <string.h>
42 #include "../../mem/mem.h"
43 #include "../../dprint.h"
44 #include "../../str.h"
45 #include "../../parser/msg_parser.h"
46
47 #define LCONTACT_BUF_SIZE 1024
48 #define BAD_EVENT_CODE 489
49
50 static inline int uandd_to_uri(str user,  str domain, str *out)
51 {
52         int size;
53
54         if(out==0)
55                 return -1;
56
57         size = user.len + domain.len+7;
58
59         out->s = (char*)pkg_malloc(size*sizeof(char));
60         if(out->s == NULL)
61         {
62                 LM_ERR("no more memory\n");
63                 return -1;
64         }
65         out->len = 0;
66         strcpy(out->s,"sip:");
67         out->len = 4;
68         strncpy(out->s+out->len, user.s, user.len);
69         out->len += user.len;
70         out->s[out->len] = '@';
71         out->len+= 1;
72         strncpy(out->s + out->len, domain.s, domain.len);
73         out->len += domain.len;
74
75         out->s[out->len] = 0;
76         
77         return 0;
78 }
79
80 static inline str* get_local_contact(struct sip_msg* msg)
81 {
82         str ip;
83         char* proto;
84         int port;
85         int len;
86         str* contact;
87
88         contact= (str*)pkg_malloc(sizeof(str));
89         if(contact== NULL)
90         {
91                 LM_ERR("No more memory\n");
92                 return NULL;
93         }
94         contact->s= (char*)pkg_malloc(LCONTACT_BUF_SIZE* sizeof(char));
95         if(contact->s== NULL)
96         {
97                 LM_ERR("No more memory\n");
98                 pkg_free(contact);
99                 return NULL;
100         }
101
102         memset(contact->s, 0, LCONTACT_BUF_SIZE*sizeof(char));
103         contact->len= 0;
104         
105         if(msg->rcv.proto== PROTO_NONE || msg->rcv.proto==PROTO_UDP)
106                 proto= "udp";
107         else
108         if(msg->rcv.proto== PROTO_TLS )
109                         proto= "tls";
110         else    
111         if(msg->rcv.proto== PROTO_TCP)
112                 proto= "tcp";
113         else
114         {
115                 LM_ERR("unsupported proto\n");
116                 pkg_free(contact->s);
117                 pkg_free(contact);
118                 return NULL;
119         }       
120         
121         ip.s= ip_addr2a(&msg->rcv.dst_ip);
122         if(ip.s== NULL)
123         {
124                 LM_ERR("transforming ip_addr to ascii\n");
125                 pkg_free(contact->s);
126                 pkg_free(contact);
127                 return NULL;
128         }
129         ip.len= strlen(ip.s);
130         port = msg->rcv.dst_port;
131
132         if(strncmp(ip.s, "sip:", 4)!=0)
133         {
134                 strncpy(contact->s, "sip:", 4);
135                 contact->len+= 4;
136         }       
137         strncpy(contact->s+contact->len, ip.s, ip.len);
138         contact->len += ip.len;
139         if(contact->len> LCONTACT_BUF_SIZE - 21)
140         {
141                 LM_ERR("buffer overflow\n");
142                 pkg_free(contact->s);
143                 pkg_free(contact);
144                 return NULL;
145
146         }       
147         len= sprintf(contact->s+contact->len, ":%d;transport=" , port);
148         if(len< 0)
149         {
150                 LM_ERR("unsuccessful sprintf\n");
151                 pkg_free(contact->s);
152                 pkg_free(contact);
153                 return NULL;
154         }       
155         contact->len+= len;
156         strncpy(contact->s+ contact->len, proto, 3);
157         contact->len += 3;
158         
159         return contact;
160         
161 }
162
163 //str* int_to_str(long int n);
164
165 int a_to_i (char *s,int len);
166
167 void to64frombits(unsigned char *out, const unsigned char *in, int inlen);
168
169 int send_error_reply(struct sip_msg* msg, int reply_code, str reply_str);
170
171 #endif
172