From: Joshua Colp Date: Wed, 2 Jan 2008 20:26:25 +0000 (+0000) Subject: Merged revisions 95946 via svnmerge from X-Git-Tag: 1.6.0-beta1~3^2~216 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=70071915e19d261449408c3d05abaebd3d7a7819;p=thirdparty%2Fasterisk.git Merged revisions 95946 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r95946 | file | 2008-01-02 16:24:09 -0400 (Wed, 02 Jan 2008) | 4 lines Allocate a SIP refer structure when performing a transfer using BYE with Also so that the transfer information is properly stored. (AST-2008-001) (closes issue #11637) Reported by: greyvoip ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@95947 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 2c6aa54819..a2135a21de 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -10034,9 +10034,14 @@ static int get_also_info(struct sip_pvt *p, struct sip_request *oreq) { char tmp[256] = "", *c, *a; struct sip_request *req = oreq ? oreq : &p->initreq; - struct sip_refer *referdata = p->refer; + struct sip_refer *referdata = NULL; const char *transfer_context = NULL; + if (!p->refer && !sip_refer_allocate(p)) + return -1; + + referdata = p->refer; + ast_copy_string(tmp, get_header(req, "Also"), sizeof(tmp)); c = get_in_brackets(tmp);