summaryrefslogtreecommitdiff
path: root/channels
diff options
context:
space:
mode:
authorJoshua Colp <jcolp@digium.com>2008-01-02 20:26:25 +0000
committerJoshua Colp <jcolp@digium.com>2008-01-02 20:26:25 +0000
commit70071915e19d261449408c3d05abaebd3d7a7819 (patch)
tree1faae2f99de35f68be2e725a94b0a18b3325cc2f /channels
parent80c479f94eb3fb4e24f041afa3f19ea7f6d9db6a (diff)
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
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_sip.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c
index 2c6aa5481..a2135a21d 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);