asterisk/asterisk.patch.xfersips

Mon, 28 Jan 2013 17:37:18 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Mon, 28 Jan 2013 17:37:18 +0100
changeset 758
a2c6460cfb16
parent 404
b6420eee9bde
child 798
4ef5d37e8bb2
permissions
-rw-r--r--

Correct socket error reporting improvement with IPv6 portable code,
after helpful recommendation by Saúl Ibarra Corretgé on OSips devlist.

michael@311 1 Index: channels/chan_sip.c
michael@311 2 diff -Nau channels/chan_sip.c.orig channels/chan_sip.c
michael@347 3 --- channels/chan_sip.c.orig 2011-05-23 17:35:28.358543497 +0200
michael@347 4 +++ channels/chan_sip.c 2011-05-23 17:57:05.948534524 +0200
michael@552 5 @@ -29733,6 +29733,7 @@
michael@311 6 \todo Fix this function so that we wait for reply to the REFER and
michael@311 7 react to errors, denials or other issues the other end might have.
michael@311 8 */
michael@311 9 +/* MSvB: Paramater dest may be SIPS encoded, having '@' before domain */
michael@311 10 static int sip_sipredirect(struct sip_pvt *p, const char *dest)
michael@311 11 {
michael@311 12 char *cdest;
michael@552 13 @@ -29741,7 +29742,7 @@
michael@311 14 cdest = ast_strdupa(dest);
michael@552 15
michael@311 16 extension = strsep(&cdest, "@");
michael@552 17 - domain = cdest;
michael@311 18 + domain = strsep(&cdest, ":"); /* MSvB: Could begin with '@' if SIPS */
michael@311 19 if (ast_strlen_zero(extension)) {
michael@311 20 ast_log(LOG_ERROR, "Missing mandatory argument: extension\n");
michael@311 21 return 0;
michael@552 22 @@ -29773,7 +29774,14 @@
michael@311 23 }
michael@311 24 }
michael@311 25
michael@311 26 - ast_string_field_build(p, our_contact, "Transfer <sip:%s@%s>", extension, domain);
michael@311 27 + if (domain && *domain == '@') {
michael@311 28 + ast_log(LOG_DEBUG, "Decoding TLS incapable Asterisk SIP URI to a standard SIPS URI before redirecting via 302 Moved Temporarily\n");
michael@311 29 + ast_string_field_build(p, our_contact, "Transfer <sips:%s@%s>", extension, domain);
michael@311 30 +
michael@311 31 + }
michael@311 32 + else
michael@311 33 + ast_string_field_build(p, our_contact, "Transfer <sip:%s@%s>", extension, domain);
michael@311 34 +
michael@311 35 transmit_response_reliable(p, "302 Moved Temporarily", &p->initreq);
michael@311 36
michael@311 37 sip_scheddestroy(p, SIP_TRANS_TIMEOUT); /* Make sure we stop send this reply. */

mercurial