<p>Joshua Colp <strong>submitted</strong> this change.</p><p><a href="https://gerrit.asterisk.org/c/asterisk/+/13683">View Change</a></p><div style="white-space:pre-wrap">Approvals:
Kevin Harwell: Looks good to me, but someone else must approve
Joshua Colp: Looks good to me, but someone else must approve; Approved for Submit
George Joseph: Looks good to me, approved
</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">cdr.c: Set event time on party b when leaving a parking bridge<br><br>When Alice calls Bob and Bob does a blind transfer to Charlie,<br>Bob's bridge leave event generates a finalize on both the party_a<br>and party_b CDRs but while the party_a CDR has the correct end time<br>set from the event time, party_b's leg did not. This caused that<br>CDR's end time to be equal to the answered time and resulted in a<br>billsec of 0.<br><br>* We now pass the bridge leave message event time to<br>cdr_object_party_b_left_bridge_cb() and set it on that CDR before<br>calling cdr_object_finalize() on it.<br><br>NOTE: This issue affected transfers using chan_sip most of the<br>time but also occasionally affected chan_pjsip probably due to<br>message timing.<br><br>ASTERISK-28677<br>Reported by: Maciej Michno<br><br>Change-Id: I790720f1e7326f9b8ce8293028743b0ef0fb2cca<br>---<br>M main/cdr.c<br>1 file changed, 10 insertions(+), 5 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/main/cdr.c b/main/cdr.c</span><br><span>index 74ee779..93ba32f 100644</span><br><span>--- a/main/cdr.c</span><br><span>+++ b/main/cdr.c</span><br><span>@@ -1465,7 +1465,7 @@</span><br><span> }</span><br><span> </span><br><span> /* tv_usec is suseconds_t, which could be int or long */</span><br><span style="color: hsl(0, 100%, 40%);">- ast_debug(1, "Finalized CDR for %s - start %ld.%06ld answer %ld.%06ld end %ld.%06ld dispo %s\n",</span><br><span style="color: hsl(120, 100%, 40%);">+ ast_debug(1, "Finalized CDR for %s - start %ld.%06ld answer %ld.%06ld end %ld.%06ld dur %.3f bill %.3f dispo %s\n",</span><br><span> cdr->party_a.snapshot->name,</span><br><span> (long)cdr->start.tv_sec,</span><br><span> (long)cdr->start.tv_usec,</span><br><span>@@ -1473,6 +1473,8 @@</span><br><span> (long)cdr->answer.tv_usec,</span><br><span> (long)cdr->end.tv_sec,</span><br><span> (long)cdr->end.tv_usec,</span><br><span style="color: hsl(120, 100%, 40%);">+ (double)ast_tvdiff_ms(cdr->end, cdr->start) / 1000.0,</span><br><span style="color: hsl(120, 100%, 40%);">+ (double)ast_tvdiff_ms(cdr->end, cdr->answer) / 1000.0,</span><br><span> ast_cdr_disp2str(cdr->disposition));</span><br><span> }</span><br><span> </span><br><span>@@ -2370,6 +2372,7 @@</span><br><span> struct bridge_leave_data {</span><br><span> struct ast_bridge_snapshot *bridge;</span><br><span> struct ast_channel_snapshot *channel;</span><br><span style="color: hsl(120, 100%, 40%);">+ const struct timeval *lastevent;</span><br><span> };</span><br><span> </span><br><span> /*! \brief Callback used to notify CDRs of a Party B leaving the bridge */</span><br><span>@@ -2388,9 +2391,10 @@</span><br><span> ast_assert(cdr->party_b.snapshot</span><br><span> && !strcasecmp(cdr->party_b.snapshot->name, leave_data->channel->name));</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">- /* It is our Party B, in our bridge. Set the end time and let the handler</span><br><span style="color: hsl(120, 100%, 40%);">+ /* It is our Party B, in our bridge. Set the last event and let the handler</span><br><span> * transition our CDR appropriately when we leave the bridge.</span><br><span> */</span><br><span style="color: hsl(120, 100%, 40%);">+ cdr->lastevent = *leave_data->lastevent;</span><br><span> cdr_object_finalize(cdr);</span><br><span> }</span><br><span> return 0;</span><br><span>@@ -2426,6 +2430,7 @@</span><br><span> struct bridge_leave_data leave_data = {</span><br><span> .bridge = bridge,</span><br><span> .channel = channel,</span><br><span style="color: hsl(120, 100%, 40%);">+ .lastevent = stasis_message_timestamp(message)</span><br><span> };</span><br><span> int left_bridge = 0;</span><br><span> </span><br><span>@@ -2439,8 +2444,8 @@</span><br><span> </span><br><span> CDR_DEBUG("Bridge Leave message for %s: %u.%08u\n",</span><br><span> channel->name,</span><br><span style="color: hsl(0, 100%, 40%);">- (unsigned int)stasis_message_timestamp(message)->tv_sec,</span><br><span style="color: hsl(0, 100%, 40%);">- (unsigned int)stasis_message_timestamp(message)->tv_usec);</span><br><span style="color: hsl(120, 100%, 40%);">+ (unsigned int)leave_data.lastevent->tv_sec,</span><br><span style="color: hsl(120, 100%, 40%);">+ (unsigned int)leave_data.lastevent->tv_usec);</span><br><span> </span><br><span> cdr = ao2_find(active_cdrs_master, channel->uniqueid, OBJ_SEARCH_KEY);</span><br><span> if (!cdr) {</span><br><span>@@ -2452,7 +2457,7 @@</span><br><span> /* Party A */</span><br><span> ao2_lock(cdr);</span><br><span> for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {</span><br><span style="color: hsl(0, 100%, 40%);">- it_cdr->lastevent = *stasis_message_timestamp(message);</span><br><span style="color: hsl(120, 100%, 40%);">+ it_cdr->lastevent = *leave_data.lastevent;</span><br><span> if (!it_cdr->fn_table->process_bridge_leave) {</span><br><span> continue;</span><br><span> }</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/c/asterisk/+/13683">change 13683</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/c/asterisk/+/13683"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: 16 </div>
<div style="display:none"> Gerrit-Change-Id: I790720f1e7326f9b8ce8293028743b0ef0fb2cca </div>
<div style="display:none"> Gerrit-Change-Number: 13683 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Friendly Automation </div>
<div style="display:none"> Gerrit-Reviewer: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Gerrit-Reviewer: Kevin Harwell <kharwell@digium.com> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>