<div>Hi Michael,</div><div> </div><div>Here it is:</div><div> </div><div>2012-01-04 19:25:09.900945 [ERR] switch_cpp.cpp:1227 =============> ...A-Leg is answered<br>2012-01-04 19:25:09.925947 [DEBUG] switch_core_session.c:875 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:09.925947 [DEBUG] switch_core_session.c:875 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:09.925947 [DEBUG] switch_core_session.c:875 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:09.925947 [DEBUG] switch_core_session.c:875 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:09.925947 [DEBUG] sofia.c:5494 Channel <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} entering state [completed][200]<br>
2012-01-04 19:25:09.925947 [DEBUG] sofia.c:5494 Channel <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} entering state [ready][200]<br>
2012-01-04 19:25:09.985953 [DEBUG] switch_core_session.c:875 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.005955 [INFO] sofia.c:819 <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} Update Callee ID to "HW-MIKE-TC01" <{MyOriginatingNumber}><br>
2012-01-04 19:25:10.005955 [DEBUG] sofia.c:7276 dispatched freeswitch event for INFO<br>2012-01-04 19:25:10.125967 [DEBUG] switch_rtp.c:3204 Correct ip/port confirmed.<br>2012-01-04 19:25:10.906045 [INFO] switch_channel.c:2708 <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} Flipping CID from "" <{MyOutboundOriginatingNumber}> to "Outbound Call" <{MyDestinationNumber}><br>
2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:1613 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State Change CS_SOFT_EXECUTE -> CS_HIBERNATE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:1180 Send signal <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:1615 (<a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>}) State Change CS_EXECUTE -> CS_HIBERNATE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_cpp.cpp:1227 AppFunction is in hangupCallback.<br>2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> HandleHangUp();<br>2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> Finalizing call in CDR table<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:362 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) Running State Change CS_HIBERNATE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:432 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State HIBERNATE<br>
2012-01-04 19:25:10.906045 [DEBUG] mod_sofia.c:222 <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} SOFIA HIBERNATE<br>2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:749 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State Change CS_HIBERNATE -> CS_RESET<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:1180 Send signal <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:432 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State HIBERNATE going to sleep<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:362 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) Running State Change CS_RESET<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:413 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State RESET<br>
2012-01-04 19:25:10.906045 [DEBUG] mod_sofia.c:166 <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} SOFIA RESET<br>2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:734 <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} CUSTOM RESET<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:741 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State Change CS_RESET -> CS_SOFT_EXECUTE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:1180 Send signal <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:413 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State RESET going to sleep<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:362 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) Running State Change CS_SOFT_EXECUTE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_state_machine.c:423 (<a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>}) State SOFT_EXECUTE<br>
2012-01-04 19:25:10.906045 [DEBUG] mod_sofia.c:584 SOFIA SOFT_EXECUTE<br>2012-01-04 19:25:10.906045 [DEBUG] switch_ivr_bridge.c:759 <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} CUSTOM SOFT_EXECUTE<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:1180 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:791 Send signal <a href="mailto:sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway">sofia/internal/{MyOriginatingNumber}@{MyOriginatingGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [DEBUG] switch_core_session.c:791 Send signal <a href="mailto:sofia/external/{MyDestinationNumber}@{MyDestinationGateway">sofia/external/{MyDestinationNumber}@{MyDestinationGateway</a>} [BREAK]<br>
2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> apiResult=+OK 29319eca-87df-437b-8e52-92a0427f12b2</div><div>2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> As long as both legs are Ready(), we wait......<br>
2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> There is one leg no longer ready...<br>2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> Session A NO LONGER ready...<br>2012-01-04 19:25:10.906045 [ERR] switch_cpp.cpp:1227 =============> Session B still ready...<br>
<br>this is done with this piece of code:</div><div> private string simpleCall(string route, string orig, int timeout)<br> {<br> string obCause = "ERROR";<br> Debug("Creating the new session...");<br>
ManagedSession leg_b = new ManagedSession("{ignore_early_media=true,origination_caller_id_number=" + orig + ",originate_timeout=20}sofia/external/"+route);<br> if (leg_b.Ready())<br>
{<br> Debug("Session_B ready!");<br> string fsuuid_b = leg_b.GetVariable("uuid");</div><div> Debug("Waiting for B-Leg to answer and A-Leg not to hangup...");<br>
while (!leg_b.answered() && leg_a.Ready() ) { /* Ringing... */ }</div><div> if (leg_b.answered())<br> {<br> Debug("...B-Leg is answered");<br>
AnswerCall(leg_a);<br> while (!leg_a.answered()) { }<br> Debug("...A-Leg is answered");</div><div> leg_a.sleep(1000, 0);<br> string apiResult = fsApi.ExecuteString(string.Format("uuid_bridge {1} {0}", leg_a.GetUuid(), leg_b.GetUuid())); <br>
Debug("apiResult="+apiResult);<br> obCause = "SUCCESS";</div><div> Debug("As long as both legs are Ready(), we wait......");<br> while (leg_b.Ready() && leg_a.Ready()) <br>
{<br> // Play(leg_b, "Test\\dir-no_matching_results.wav");<br> // Play(leg_a, "Test\\dir-no_matching_results.wav");<br> }</div>
<div> Debug("There is one leg no longer ready...");<br> if (leg_a.Ready()) { Debug("Session A still ready..."); } else { Debug("Session A NO LONGER ready...");}<br>
if (leg_b.Ready()) { Debug("Session B still ready..."); } else { Debug("Session B NO LONGER ready...");}<br> }<br> else<br> {<br> Debug("A-Leg aborted while dialing...");<br>
}</div><div> if (leg_b.Ready())<br> {<br> Debug("B-Leg still here, so hanging up B-Leg...");<br> leg_b.Hangup("NORMAL_CALL_CLEARING");<br>
leg_b.destroy();<br> }<br> }<br> else<br> {<br> obCause = leg_b.hangupCause();<br> }<br> Debug("SimpleCall() ended with: " + obCause);<br>
return obCause;<br> }<br></div><div>Thanks,</div><div>Mike.</div><div> </div><div> </div><div> </div><div class="gmail_quote">2012/1/4 Michael Giagnocavo <span dir="ltr"><<a href="mailto:mgg@giagnocavo.net">mgg@giagnocavo.net</a>></span><br>
<blockquote style="margin:0px 0px 0px 0.8ex;padding-left:1ex;border-left-color:rgb(204,204,204);border-left-width:1px;border-left-style:solid" class="gmail_quote"><div lang="EN-US" vlink="purple" link="blue"><div><p class="MsoNormal">
<span style="color:rgb(31,73,125);font-family:"Calibri","sans-serif";font-size:11pt">Can you paste the debug log from FreeSWITCH when this happens?<u></u><u></u></span></p><p class="MsoNormal"><a name="134a9e027d650f90__MailEndCompose"><span style="color:rgb(31,73,125);font-family:"Calibri","sans-serif";font-size:11pt"><u></u> <u></u></span></a></p>
<p class="MsoNormal"><b><span style="font-family:"Tahoma","sans-serif";font-size:10pt">From:</span></b><span style="font-family:"Tahoma","sans-serif";font-size:10pt"> <a href="mailto:freeswitch-dev-bounces@lists.freeswitch.org" target="_blank">freeswitch-dev-bounces@lists.freeswitch.org</a> [mailto:<a href="mailto:freeswitch-dev-bounces@lists.freeswitch.org" target="_blank">freeswitch-dev-bounces@lists.freeswitch.org</a>] <b>On Behalf Of </b>Michael Lutz<br>
<b>Sent:</b> Wednesday, January 04, 2012 10:10 AM<br><b>To:</b> <a href="mailto:freeswitch-dev@lists.freeswitch.org" target="_blank">freeswitch-dev@lists.freeswitch.org</a><br><b>Subject:</b> [Freeswitch-dev] bridging calls using mod_managed<u></u><u></u></span></p>
<div><div class="h5"><p class="MsoNormal"><u></u> <u></u></p><p>Hi, <u></u><u></u></p><div><p class="MsoNormal">I've been working with FS for some time now, and are progressing. I am working on a platform (in/ivr) which is handled by .net managed code completely. I am using just 1 application which is always launched on incomming calls.<br>
This application immedeately connects with my MSSQL server and checks validity of gateways, inbound number etc. Also a cdr is written and updated periodically while the call is active.<br>I have als set the HandleHangUp handler to finalize the cdr and call when the calller disconnects.<br>
This whole mechanism works as a charm. This application then plays voicefiles, getdigits, and everything as I would expect.<br>Hoewever at some point I want to dialout to an external number and connect these two calls together.<br>
I do not want to leave the originating .net app as long as my incomming caller is still online (to update the cdr and finalize the call). While these two are connected I need to update my database periodicaly (keepalive).<br>
I have been looking the internet to find what I need but i can't get it to work 100%. In fact everything works, but when I bridge the two calls together it fails.<u></u><u></u></p></div><div><p class="MsoNormal"><br>I use the following and this whole peace of code actually works, it dials out, aborts when someone hangsup and when the b_leg picks up they both get audiofile turn by turn.... It even checks outbuond status and maps this to the original call. (so really acts like a switch).<u></u><u></u></p>
</div><p> Debug("Got a route=>"+route+", Let the network play the ringtone...");<br> leg_a.Execute("ring_ready", "");<u></u><u></u></p><p> Debug("Creating the new session...");<br>
ManagedSession leg_b = new ManagedSession("sofia/external/"+route); // route holds <a href="mailto:%7bdestinationNumber%7d@%7bmyExternalGateway" target="_blank">{destinationNumber}@{myExternalGateway</a>}<br>
if (leg_b.Ready())<br> {<br> Debug("Session_B ready!");<br> string fsuuid_b = leg_b.GetVariable("uuid");<u></u><u></u></p>
<p> Debug("Waiting for B-Leg to answer and A-Leg not to hangup...");<br> while (!leg_b.answered() && leg_a.Ready() ) { /* Ringing... */ }<u></u><u></u></p><p>
if (leg_b.answered())<br> {<br> Debug("...B-Leg is answered");<br> AnswerCall(leg_a);<br> while (!leg_a.answered()) { }<br>
Debug("...A-Leg is answered");<u></u><u></u></p><p> // ****** BRIDGE SHOULD BE HERE ****** <u></u><u></u></p><p> Debug("As long as both legs are Ready(), we wait......");<br>
while (leg_b.Ready() && leg_a.Ready()) <br> {<br> Play(leg_b, "Test\\dir-no_matching_results.wav"); // REMOVE WHEN BRIDGED<br>
Play(leg_a, "Test\\dir-no_matching_results.wav"); // REMOVE WHEN BRIDGED<br> }<u></u><u></u></p><p> Debug("There is one leg no longer ready...");<br>
if (leg_a.Ready()) { Debug("Session A still ready..."); } else { Debug("Session A NO LONGER ready...");}<br> if (leg_b.Ready()) { Debug("Session B still ready..."); } else { Debug("Session B NO LONGER ready...");}<br>
}<br> else<br> {<br> Debug("A-Leg aborted while dialing...");<br> }<u></u><u></u></p><p> if (leg_b.Ready())<br>
{<br> Debug("B-Leg still here, so hanging up B-Leg...");<br> leg_b.Hangup("NORMAL_CALL_CLEARING");<br> leg_b.destroy();<br>
}<br> }<br> else<br> {<br> string obCause = leg_b.hangupCause();<u></u><u></u></p><p> leg_a.HangUp(obCause);<br>
Debug("Route failed with: "+obCause);<br> } <br> return true;<u></u><u></u></p><p>Of course I need to bridge the two calls together so they can speak to each other.. I am trying to bridge the call at "// ****** BRIDGE SHOULD BE HERE ****** " like this:<u></u><u></u></p>
<p>leg_a.sleep(1000, 0);<br>string apiResult = fsApi.ExecuteString(string.Format("uuid_bridge {1} {0}", leg_a.GetUuid(), leg_b.GetUuid())); <br>Debug("apiResult="+apiResult);<u></u><u></u></p><p>The console log shows "+OK {guid of leg_a} <u></u><u></u></p>
<p>but at the very same moment the incomming calls is beging hung up, (I can see the Debug message of my HandleHangUp() at exactly the as me time as the apiResult of the bridge.<br>I have checked without bridge to check if codecs are the the same and they both are PCMU 8000.<br>
Please any help is appreciated! I have been trying to make this work for over a week now, but it won''t work.<u></u><u></u></p><p>note. I have also tried originate with the api, but gives me the same problem when I try to bridge these two legs together...<u></u><u></u></p>
<div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">Best Regards,<u></u><u></u></p></div><p>Mike.<u></u><u></u></p></div></div></div></div><br>_________________________________________________________________________<br>
Professional FreeSWITCH Consulting Services:<br>
<a href="mailto:consulting@freeswitch.org">consulting@freeswitch.org</a><br>
<a href="http://www.freeswitchsolutions.com" target="_blank">http://www.freeswitchsolutions.com</a><br>
<br>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
<a href="http://www.cudatel.com" target="_blank">http://www.cudatel.com</a><br>
<br>
Official FreeSWITCH Sites<br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<a href="http://wiki.freeswitch.org" target="_blank">http://wiki.freeswitch.org</a><br>
<a href="http://www.cluecon.com" target="_blank">http://www.cluecon.com</a><br>
<br>
FreeSWITCH-dev mailing list<br>
<a href="mailto:FreeSWITCH-dev@lists.freeswitch.org">FreeSWITCH-dev@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-dev" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-dev</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-dev" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-dev</a><br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<br></blockquote></div><br>