diff options
author | Joshua Colp <jcolp@digium.com> | 2008-01-02 20:26:25 +0000 |
---|---|---|
committer | Joshua Colp <jcolp@digium.com> | 2008-01-02 20:26:25 +0000 |
commit | 70071915e19d261449408c3d05abaebd3d7a7819 (patch) | |
tree | 1faae2f99de35f68be2e725a94b0a18b3325cc2f /channels/chan_sip.c | |
parent | 80c479f94eb3fb4e24f041afa3f19ea7f6d9db6a (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/chan_sip.c')
-rw-r--r-- | channels/chan_sip.c | 7 |
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); |