<p><a href="https://gerrit.asterisk.org/9558">View Change</a></p><p>1 comment:</p><ul style="list-style: none; padding: 0;"><li style="margin: 0; padding: 0;"><p><a href="https://gerrit.asterisk.org/#/c/9558/2/main/bridge_basic.c">File main/bridge_basic.c:</a></p><ul style="list-style: none; padding: 0;"><li style="margin: 0; padding: 0 0 0 16px;"><p style="margin-bottom: 4px;"><a href="https://gerrit.asterisk.org/#/c/9558/2/main/bridge_basic.c@3433">Patch Set #2, Line 3433:</a> </p><p><blockquote style="border-left: 1px solid #aaa; margin: 10px 0; padding: 0 10px;"><pre style="font-family: monospace,monospace; white-space: pre-wrap;"> /* We increase the refcount of the transfer target because ast_bridge_impart() will<br> * steal the reference we already have. We need to keep a reference, so the only<br> * choice is to give it a bump<br> */<br> ast_channel_ref(props->transfer_target);<br> if (ast_bridge_impart(props->target_bridge, props->transfer_target, NULL, NULL,<br> AST_BRIDGE_IMPART_CHAN_INDEPENDENT)) {<br> ast_log(LOG_ERROR, "Channel %s: Unable to place transfer target into bridge.\n",<br> ast_channel_name(bridge_channel->chan));<br> stream_failsound(props->transferer);<br> ast_bridge_channel_write_unhold(bridge_channel);<br> ast_hangup(props->transfer_target);<br> props->transfer_target = NULL;<br> attended_transfer_properties_shutdown(props);<br> return 0;<br> }<br></pre></blockquote></p><p><blockquote style="border-left: 1px solid #aaa; margin: 10px 0; padding: 0 10px;">> You need to redo this patch to *only* suppress the *initial* […]</blockquote></p><p style="white-space: pre-wrap; word-wrap: break-word;">It suppresses *more* than just the initial connected line update. There are two transitions into the TRANSFER_CALLING_TARGET state. The initial entry into the attended transfer state machine where we can suppress the connected line update and a transition from the TRANSFER_HESITANT state where we must not suppress the connected line update.</p><p style="white-space: pre-wrap; word-wrap: break-word;">We must not suppress it when transitioning from the TRANSFER_HESITANT state to the TRANSFER_CALLING_TARGET state because there is a possible window of opportunity where we could loose the connected line update from Charlie to Alice if Charlie answers during the transition.</p><p style="white-space: pre-wrap; word-wrap: break-word;">All this discussion is really pointing to the fragility of your dialplan. Just the suppression of the *initial* connected line update is an accommodation for that fragile dialplan. If nothing else happens then when Alice eventually completes the attended transfer of Bob to Charlie there will be a connected line update exchange between Bob and Charlie.</p></li></ul></li></ul><p>To view, visit <a href="https://gerrit.asterisk.org/9558">change 9558</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/9558"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: 13 </div>
<div style="display:none"> Gerrit-MessageType: comment </div>
<div style="display:none"> Gerrit-Change-Id: I346652661949b6611c23e431ede0dbea1be3017a </div>
<div style="display:none"> Gerrit-Change-Number: 9558 </div>
<div style="display:none"> Gerrit-PatchSet: 2 </div>
<div style="display:none"> Gerrit-Owner: Alexei Gradinari <alex2grad@gmail.com> </div>
<div style="display:none"> Gerrit-Reviewer: Alexei Gradinari <alex2grad@gmail.com> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins2 </div>
<div style="display:none"> Gerrit-Reviewer: Richard Mudgett <rmudgett@digium.com> </div>
<div style="display:none"> Gerrit-Comment-Date: Thu, 02 Aug 2018 21:41:59 +0000 </div>
<div style="display:none"> Gerrit-HasComments: Yes </div>
<div style="display:none"> Gerrit-HasLabels: No </div>