[asterisk-bugs] [JIRA] (ASTERISK-24237) CDR: FRACK With PJSIP blonde transfer.
Matt Jordan (JIRA)
noreply at issues.asterisk.org
Fri Aug 22 23:31:28 CDT 2014
[ https://issues.asterisk.org/jira/browse/ASTERISK-24237?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=222378#comment-222378 ]
Matt Jordan commented on ASTERISK-24237:
----------------------------------------
The reason why we get the FRACK here is because {{app_dial}} is raising the Dial message incorrectly:
{noformat}
[Aug 14 21:02:50] VERBOSE[15442][C-00000001] app_dial.c: PJSIP/202-00000003 answered PJSIP/100-00000000
[Aug 14 21:02:50] VERBOSE[15342] cdr.c: Dial End message for PJSIP/100-00000000, PJSIP/202-00000003: 1408068170.00131831
[Aug 14 21:02:50] VERBOSE[15342] cdr.c: 0xb4748e0c - Processing Dial End message for channel PJSIP/100-00000000, peer PJSIP/202-00000003
{noformat}
{{app_dial}} is technically "right", but only because PJSIP/100 took the place of PJSIP/200. The Dial End message is thus incorrect for what was previously started:
{noformat}
[Aug 14 21:02:44] VERBOSE[15342] cdr.c: 0x9c6031c - Processing Dial Begin message for channel PJSIP/200-00000002, peer PJSIP/202-00000003
[Aug 14 21:02:44] VERBOSE[15342] cdr.c: 0x9c6031c - Updated Party A PJSIP/200-00000002 snapshot
[Aug 14 21:02:44] VERBOSE[15342] cdr.c: 0x9c6031c - Updated Party B PJSIP/202-00000003 snapshot
[Aug 14 21:02:44] VERBOSE[15342] cdr.c: 0x9c6031c - Transitioning CDR for PJSIP/200-00000002 from state Single to Dial
{noformat}
Every DialBegin must have a corresponding DialEnd. You can't just replace a channel with someone else and raise a DialEnd for a dial operation they didn't start.
This isn't going to be fun to fix :-(
> CDR: FRACK With PJSIP blonde transfer.
> --------------------------------------
>
> Key: ASTERISK-24237
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-24237
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: CDR/General
> Affects Versions: 13.0.0-beta1
> Reporter: Richard Mudgett
> Assignee: Matt Jordan
> Attachments: full_verb4_cdr_debug.txt, full_verb4_debug4_cdr_debug.txt
>
>
> A calls B
> B does a SIP blonde transfer to C
> C answers
> FRACK
> A, B, and C are PJSIP endpoints.
> {noformat}
> (gdb) bt
> #0 0x00f77422 in __kernel_vsyscall ()
> #1 0x0064a681 in *__GI_raise (sig=6) at ../nptl/sysdeps/unix/sysv/linux/raise.c:64
> #2 0x0064dab2 in *__GI_abort () at abort.c:92
> #3 0x0824c086 in ast_do_crash () at utils.c:2537
> #4 0x0824c112 in __ast_assert_failed (condition=0, condition_str=0x8269873 "0", file=0x8269734 "cdr.c", line=1396, function=0x826b579 "base_process_dial_end") at utils.c:2567
> #5 0x080e4514 in _ast_assert (cdr=0xb74c5604, caller=0x9e63374, peer=0x9e4f5c4, dial_status=0x9cb0ab0 "ANSWER") at /home/rmudgett/projects/sa/asterisk/starscream/include/asterisk/utils.h:810
> #6 base_process_dial_end (cdr=0xb74c5604, caller=0x9e63374, peer=0x9e4f5c4, dial_status=0x9cb0ab0 "ANSWER") at cdr.c:1396
> #7 0x080e6399 in handle_dial_message (data=0x0, sub=0xb72cea14, message=0x9ff7994) at cdr.c:1958
> #8 0x0822896d in router_dispatch (data=0xb7569fe4, sub=0xb72cea14, message=0x9ff7994) at stasis_message_router.c:201
> #9 0x08217075 in subscription_invoke (sub=0xb72cea14, message=0x9ff7994) at stasis.c:417
> #10 0x08217c2a in dispatch_exec_async (local=0xb6196250) at stasis.c:666
> #11 0x08232f84 in ast_taskprocessor_execute (tps=0xb752f9ac) at taskprocessor.c:764
> #12 0x08231608 in default_tps_processing_function (data=0xb72215cc) at taskprocessor.c:184
> #13 0x08248b45 in dummy_start (data=0xb755cd60) at utils.c:1178
> #14 0x0087e96e in start_thread (arg=0xb6196b70) at pthread_create.c:300
> #15 0x006f33fe in clone () at ../sysdeps/unix/sysv/linux/i386/clone.S:130
> {noformat}
> I suspect this is a result of recent changes in the DialEnd event ordering. (-r420794). On some investigation that patch wouldn't cause this since it was adding forwarding information.
--
This message was sent by Atlassian JIRA
(v6.2#6252)
More information about the asterisk-bugs
mailing list