Use a deep copy on strings that come from ast_events. Otherwise it is
authorMark Michelson <mmichelson@digium.com>
Fri, 23 May 2008 19:57:40 +0000 (19:57 +0000)
committerMark Michelson <mmichelson@digium.com>
Fri, 23 May 2008 19:57:40 +0000 (19:57 +0000)
likely that after the event is freed, we no longer refer to valid memory.

(closes issue #12712)
Reported by: tomo1657
Patches:
      12712.patch uploaded by putnopvut (license 60)
Tested by: tomo1657

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@118157 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_voicemail.c

index 4bbcd8d..2ba0a3c 100644 (file)
@@ -9166,6 +9166,8 @@ static int handle_subscribe(void *datap)
        AST_RWLIST_WRLOCK(&mwi_subs);
        AST_RWLIST_INSERT_TAIL(&mwi_subs, mwi_sub, entry);
        AST_RWLIST_UNLOCK(&mwi_subs);
+       ast_free(p->mailbox);
+       ast_free(p->context);
        ast_free(p);    
        return 0;
 }
@@ -9200,8 +9202,8 @@ static void mwi_sub_event_cb(const struct ast_event *event, void *userdata)
                ast_log(LOG_ERROR, "could not allocate a mwi_sub_task\n");
                return;
        }
-       mwist->mailbox = ast_event_get_ie_str(event, AST_EVENT_IE_MAILBOX);
-       mwist->context = ast_event_get_ie_str(event, AST_EVENT_IE_CONTEXT);
+       mwist->mailbox = ast_strdup(ast_event_get_ie_str(event, AST_EVENT_IE_MAILBOX));
+       mwist->context = ast_strdup(ast_event_get_ie_str(event, AST_EVENT_IE_CONTEXT));
        mwist->uniqueid = ast_event_get_ie_uint(event, AST_EVENT_IE_UNIQUEID);
        
        if (ast_taskprocessor_push(mwi_subscription_tps, handle_subscribe, mwist) < 0) {