6 * Copyright (C) 2008 Novell, Inc.
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
28 #include "sipe-backend.h"
29 #include "sipe-sign.h"
31 static gchar
* const empty_string
= "";
33 void sipmsg_breakdown_parse(struct sipmsg_breakdown
* msg
, gchar
* realm
, gchar
* target
)
36 if (msg
== NULL
|| msg
->msg
== NULL
) {
37 SIPE_DEBUG_INFO_NOFORMAT("sipmsg_breakdown_parse msg or msg->msg is NULL");
41 msg
->rand
= msg
->num
= msg
->realm
= msg
->target_name
=
42 msg
->cseq
= msg
->from_url
= msg
->from_tag
= msg
->to_url
= msg
->to_tag
=
43 msg
->p_assertet_identity_sip_uri
= msg
->p_assertet_identity_tel_uri
= empty_string
;
44 msg
->call_id
= msg
->expires
= empty_string
;
46 if ((hdr
= sipmsg_find_header(msg
->msg
, "Proxy-Authorization")) ||
47 (hdr
= sipmsg_find_header(msg
->msg
, "Proxy-Authenticate")) ||
48 (hdr
= sipmsg_find_header(msg
->msg
, "Proxy-Authentication-Info")) ||
49 (hdr
= sipmsg_find_header(msg
->msg
, "Authentication-Info")) ) {
50 msg
->protocol
= sipmsg_find_part_of_header(hdr
, NULL
, " ", empty_string
);
51 msg
->rand
= sipmsg_find_part_of_header(hdr
, "rand=\"", "\"", empty_string
);
52 msg
->num
= sipmsg_find_part_of_header(hdr
, "num=\"", "\"", empty_string
);
53 msg
->realm
= sipmsg_find_part_of_header(hdr
, "realm=\"", "\"", empty_string
);
54 msg
->target_name
= sipmsg_find_part_of_header(hdr
, "targetname=\"", "\"", empty_string
);
56 msg
->protocol
= strstr(target
, "sip/") ? g_strdup("Kerberos") : g_strdup("NTLM");
57 msg
->realm
= g_strdup(realm
);
58 msg
->target_name
= g_strdup(target
);
61 msg
->call_id
= sipmsg_find_header(msg
->msg
, "Call-ID");
63 hdr
= sipmsg_find_header(msg
->msg
, "CSeq");
65 msg
->cseq
= sipmsg_find_part_of_header(hdr
, NULL
, " ", empty_string
);
68 hdr
= sipmsg_find_header(msg
->msg
, "From");
70 msg
->from_url
= sipmsg_find_part_of_header(hdr
, "<", ">", empty_string
);
71 msg
->from_tag
= sipmsg_find_part_of_header(hdr
, ";tag=", ";", empty_string
);
74 hdr
= sipmsg_find_header(msg
->msg
, "To");
76 msg
->to_url
= sipmsg_find_part_of_header(hdr
, "<", ">", empty_string
);
77 msg
->to_tag
= sipmsg_find_part_of_header(hdr
, ";tag=", ";", empty_string
);
80 P-Asserted-Identity: "Cullen Jennings" <sip:fluffy@cisco.com>
81 P-Asserted-Identity: tel:+14085264000
83 hdr
= sipmsg_find_header(msg
->msg
, "P-Asserted-Identity");
85 hdr
= sipmsg_find_header(msg
->msg
, "P-Preferred-Identity");
88 gchar
*tmp
= sipmsg_find_part_of_header(hdr
, "<", ">", empty_string
);
89 if (g_str_has_prefix(tmp
, "sip:")) {
90 msg
->p_assertet_identity_sip_uri
= tmp
;
91 } else if (g_str_has_prefix(tmp
, "tel:")){
92 msg
->p_assertet_identity_tel_uri
= tmp
;
98 msg
->expires
= sipmsg_find_header(msg
->msg
, "Expires");
102 sipmsg_breakdown_free(struct sipmsg_breakdown
* msg
)
104 if (msg
->protocol
!= empty_string
)
105 g_free(msg
->protocol
);
106 if (msg
->rand
!= empty_string
)
108 if (msg
->num
!= empty_string
)
110 if (msg
->realm
!= empty_string
)
112 if (msg
->target_name
!= empty_string
)
113 g_free(msg
->target_name
);
115 // straight from header
116 //g_free(msg->call_id);
118 if (msg
->cseq
!= empty_string
)
120 if (msg
->from_url
!= empty_string
)
121 g_free(msg
->from_url
);
122 if (msg
->from_tag
!= empty_string
)
123 g_free(msg
->from_tag
);
124 if (msg
->to_url
!= empty_string
)
126 if (msg
->to_tag
!= empty_string
)
129 if (msg
->p_assertet_identity_sip_uri
!= empty_string
)
130 g_free(msg
->p_assertet_identity_sip_uri
);
131 if (msg
->p_assertet_identity_tel_uri
!= empty_string
)
132 g_free(msg
->p_assertet_identity_tel_uri
);
134 // straight from header
135 //g_free (msg->expires);
139 sipmsg_breakdown_get_string(int version
,
140 struct sipmsg_breakdown
* msgbd
)
144 if (msgbd
->realm
== empty_string
|| msgbd
->realm
== NULL
) {
145 SIPE_DEBUG_INFO_NOFORMAT("realm NULL, so returning NULL signature string");
149 response_str
= msgbd
->msg
->response
!= 0 ? g_strdup_printf("<%d>", msgbd
->msg
->response
) : empty_string
;
151 msg
= g_strdup_printf(
152 "<%s><%s><%s><%s><%s><%s><%s><%s><%s><%s><%s>" // 1 - 11
154 msgbd
->protocol
, msgbd
->rand
, msgbd
->num
, msgbd
->realm
, msgbd
->target_name
, msgbd
->call_id
, msgbd
->cseq
,
155 msgbd
->msg
->method
, msgbd
->from_url
, msgbd
->from_tag
, msgbd
->to_tag
,
156 msgbd
->expires
? msgbd
->expires
: empty_string
, response_str
159 msg
= g_strdup_printf(
160 "<%s><%s><%s><%s><%s><%s><%s><%s><%s><%s><%s><%s><%s><%s>" // 1 - 14
162 msgbd
->protocol
, msgbd
->rand
, msgbd
->num
, msgbd
->realm
, msgbd
->target_name
, msgbd
->call_id
, msgbd
->cseq
,
163 msgbd
->msg
->method
, msgbd
->from_url
, msgbd
->from_tag
, msgbd
->to_url
, msgbd
->to_tag
,
164 msgbd
->p_assertet_identity_sip_uri
, msgbd
->p_assertet_identity_tel_uri
,
165 msgbd
->expires
? msgbd
->expires
: empty_string
, response_str
169 if (response_str
!= empty_string
) {
170 g_free(response_str
);