<div dir="ltr">the problem with doing the sip traces how you have, is that you dont have the RTP Stream.<div><br></div><div>id be using tcpdump on your boxes, so you can see does the RTP ( that appears to be cut off ) even get to your FS node.</div>

<div><meta http-equiv="content-type" content="text/html; charset=utf-8"><font class="" color="#000000" face="monospace"><span class="" style="border-collapse:separate;font-size:14px"><meta http-equiv="content-type" content="text/html; charset=utf-8"><a href="http://wiki.freeswitch.org/wiki/Packet_Capture">http://wiki.freeswitch.org/wiki/Packet_Capture</a><br>

</span></font></div><div><font class="" color="#000000" face="monospace"><br></font></div><div><font class="" color="#000000" face="monospace">do something like</font></div><div><font class="" color="#000000" face="monospace"><meta http-equiv="content-type" content="text/html; charset=utf-8"><span class="" style="font-family:sans-serif;font-size:13px;line-height:19px;border-collapse:separate"><pre style="padding-top:1em;padding-right:1em;padding-bottom:1em;padding-left:1em;border-top-width:1px;border-right-width:1px;border-bottom-width:1px;border-left-width:1px;border-top-style:dashed;border-right-style:dashed;border-bottom-style:dashed;border-left-style:dashed;border-top-color:rgb(47,111,171);border-right-color:rgb(47,111,171);border-bottom-color:rgb(47,111,171);border-left-color:rgb(47,111,171);color:black;background-color:rgb(249,249,249);line-height:1.1em">

 tcpdump -nq -s 0 -i eth0 -w /tmp/dump.pcap</pre></span></font></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On 17 January 2013 12:58, <a href="mailto:support@ecn.net.au">support@ecn.net.au</a> <span dir="ltr">&lt;<a href="mailto:support@ecn.net.au" target="_blank">support@ecn.net.au</a>&gt;</span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">




<div>
<div dir="ltr"><font face="tahoma">Hi</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">This sounds quite posible.</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">I&#39;ve tcpdumped sip headers on both the freeswitch and the backend PBX.</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">The only significant difference I can see between our old SBC and FS is that the old SBC</font></div>
<div dir="ltr"><font face="tahoma">asserted a media attribute fmtp:18 annexb=no  where  as FS doesn&#39;t forward this.</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">To test it out we have set dtmf_mode to none on both contexts (the context facing the telco</font></div>
<div dir="ltr"><font face="tahoma">and the context facing the pbx), and set
</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">&lt;param name=&quot;rfc2833-pt&quot; value=&quot;0&quot;/&gt;</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">(this may not be needed).</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">then in the dialplan we have</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">&lt;action application=&quot;export&quot; data=&quot;sip_append_audio_sdp=a=fmtp:18 annexb=no&quot;/&gt;</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">set prior to the bridge.</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">--</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">When we sip trace however we are not appending the attribute to the SDP on the INVITE.</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">Logs and sip headers below:</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">EXECUTE <a href="mailto:sofia/aapt/0731111111@X.Y.Z.A:5060" target="_blank">
sofia/aapt/0731111111@X.Y.Z.A:5060</a> export(sip_append_audio_sdp=a=fmtp:18 annexb=no)</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_channel.c:1135 EXPORT (export_vars) [sip_append_audio_sdp]=[a=fmtp:18 annexb=no]</font></div>
<div dir="ltr"><font face="tahoma">EXECUTE <a href="mailto:sofia/aapt/0731111111@X.Y.Z.A:5060" target="_blank">
sofia/aapt/0731111111@X.Y.Z.A:5060</a> bridge(<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a>)</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_channel.c:1089
<a href="mailto:sofia/aapt/0731111111@X.Y.Z.A:5060" target="_blank">sofia/aapt/0731111111@X.Y.Z.A:5060</a> EXPORTING[export_vars] [sip_append_audio_sdp]=[a=fmtp:18 annexb=no] to eve</font></div>
<div dir="ltr"><font face="tahoma">nt</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_ivr_originate.c:2022 Parsing global variables</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [NOTICE] switch_channel.c:968 New Channel
<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a> [a30c650a-87d3-4027-9010-213547d698aa]</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] mod_sofia.c:4977 (<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a>) State Change CS_NEW -&gt; CS_INIT</font></div>


<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_core_session.c:1283 Send signal
<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a> [BREAK]</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_core_state_machine.c:415 (<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a>) Running State Change CS_INIT</font></div>


<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] switch_core_state_machine.c:454 (<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a>) State INIT</font></div>


<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] mod_sofia.c:86
<a href="mailto:sofia/external/0737111111@A.B.C.X:5060" target="_blank">sofia/external/0737111111@A.B.C.X:5060</a> SOFIA INIT</font></div>
<div dir="ltr"><font face="tahoma">2013-01-17 12:34:19.702102 [DEBUG] sofia_glue.c:2647 Local SDP:</font></div>
<div dir="ltr"><font face="tahoma">v=0</font></div>
<div dir="ltr"><font face="tahoma">o=FreeSWITCH 1358365507 1358365508 IN IP4 A.B.C.D</font></div>
<div dir="ltr"><font face="tahoma">s=FreeSWITCH</font></div>
<div dir="ltr"><font face="tahoma">c=IN IP4 A.B.C.D</font></div>
<div dir="ltr"><font face="tahoma">t=0 0</font></div>
<div dir="ltr"><font face="tahoma">m=audio 24552 RTP/AVP 8 0 3 13</font></div>
<div dir="ltr"><font face="tahoma">a=fmtp:18 annexb=no</font></div>
<div dir="ltr"><font face="tahoma">a=ptime:20</font></div>
<div dir="ltr"><font face="tahoma">a=sendrecv</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">But then the actual Invite doesn&#39;t contain the attribute in the SDP</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">send 1036 bytes to udp/[A.B.C.X]:5060 at 02:34:19.718385:</font></div>
<div dir="ltr"><font face="tahoma">   ------------------------------------------------------------------------</font></div>
<div dir="ltr"><font face="tahoma">   INVITE sip:0737111111@A.B.C.X:5060 SIP/2.0</font></div>
<div dir="ltr"><font face="tahoma">   Via: SIP/2.0/UDP A.B.C.D:5080;rport;branch=z9hG4bKpUvH6K1ppUSNp</font></div>
<div dir="ltr"><font face="tahoma">   Max-Forwards: 69</font></div>
<div dir="ltr"><font face="tahoma">   From: &quot;0731111111&quot; &lt;sip:0731111111@A.B.C.D&gt;;tag=mH93ZHryv4H2g</font></div>
<div dir="ltr"><font face="tahoma">   To: &lt;sip:0737111111@A.B.C.X:5060&gt;</font></div>
<div dir="ltr"><font face="tahoma">   Call-ID: 3ca1df3f-daf1-1230-f389-002219a7c712</font></div>
<div dir="ltr"><font face="tahoma">   CSeq: 38858965 INVITE</font></div>
<div dir="ltr"><font face="tahoma">   Contact: &lt;sip:mod_sofia@A.B.C.D:5080&gt;</font></div>
<div dir="ltr"><font face="tahoma">   User-Agent: FreeSWITCH-mod_sofia/<a href="http://1.2.5.3" target="_blank">1.2.5.3</a>+git~20121229T001759Z~e04eab7902</font></div>
<div dir="ltr"><font face="tahoma">   Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY</font></div>
<div dir="ltr"><font face="tahoma">   Supported: timer, precondition, path, replaces</font></div>
<div dir="ltr"><font face="tahoma">   Allow-Events: talk, hold, conference, refer</font></div>
<div dir="ltr"><font face="tahoma">   Content-Type: application/sdp</font></div>
<div dir="ltr"><font face="tahoma">   Content-Disposition: session</font></div>
<div dir="ltr"><font face="tahoma">   Content-Length: 155</font></div>
<div dir="ltr"><font face="tahoma">   X-Nortel-Profile: DEFAULT</font></div>
<div dir="ltr"><font face="tahoma">   X-FS-Support: update_display,send_info</font></div>
<div dir="ltr"><font face="tahoma">   Remote-Party-ID: &quot;0731111111&quot; &lt;sip:0731111111@A.B.C.D&gt;;party=calling;screen=yes;privacy=off</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">   v=0</font></div>
<div dir="ltr"><font face="tahoma">   o=FreeSWITCH 1358365507 1358365508 IN IP4 A.B.C.D</font></div>
<div dir="ltr"><font face="tahoma">   s=FreeSWITCH</font></div>
<div dir="ltr"><font face="tahoma">   c=IN IP4 A.B.C.D</font></div>
<div dir="ltr"><font face="tahoma">   t=0 0</font></div>
<div dir="ltr"><font face="tahoma">   m=audio 24552 RTP/AVP 8 0 3 13</font></div>
<div dir="ltr"><font face="tahoma">   a=ptime:20</font></div>
<div dir="ltr"><font face="tahoma">   ------------------------------------------------------------------------</font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma"> </font></div>
<div dir="ltr"><font face="tahoma">Are we missing something do you think?</font></div>
<div dir="ltr"><font face="tahoma"></font> </div>
<div dir="ltr"><font face="tahoma"></font> </div>
<div dir="ltr"><font face="tahoma"></font> </div>
<div>
<div><font face="Tahoma">Kind Regards,</font></div>
<div><font face="tahoma"></font> </div>
<div>
<hr>
<font face="Tahoma"><b>From:</b> Steven Ayre [<a href="mailto:steveayre@gmail.com" target="_blank">steveayre@gmail.com</a>]<br>
<b>Sent:</b> Thursday, 17 January 2013 4:14 AM<div class="im"><br>
<b>To:</b> FreeSWITCH Users Help<br>
<b>Subject:</b> Re: [Freeswitch-users] SBC In-band DTMF<br>
</div></font><br>
</div>
</div><div><div class="h5">
<div></div>
<div>
<blockquote style="BORDER-LEFT:rgb(204,204,204) 1px solid;MARGIN:0px 0px 0px 0.8ex;PADDING-LEFT:1ex" class="gmail_quote">
However under freeswitch if we don&#39;t start_dtmf before the bridge the backend PBX boxes don&#39;t recognise<br>
the DTMF inband (even though the tones are audible ie you can hear them on a call recording on the<br>
PBX).<br>
 <br>
Have we missed something here?  We would have thought with inband DTMF on non compressed codec (no<br>
transcoding) that the tones would just work with the media stream?</blockquote>
<br>
start_dtmf will detect inband DTMF, and then send out of band on the outgoing leg of the bridge. This is expected. You&#39;ll will need to call start_dtmf from dialplan, which can easily be done from dialplan by checking for some condition identifying calls requiring
 it. If they&#39;re authenticating to FS then it&#39;d be trivial to set a variable in their user directory entry that you can test in the dialplan.
<div><br>
</div>
<div>Now this is just a guess... During the codec negotiation FS will tell your PBX that it supports telephone-event (RFC2833). It may be that because the PBX sees that in the SDP that it doesn&#39;t look for inband DTMF, while when it received the SDP direct from
 the customer it didn&#39;t contain telephone-event and so did check for inband DTMF. Indeed it&#39;d probably be a good idea for them to do so, since if you receive the same DTMF digit both inband and through RFC2833 then you&#39;d be  duplicating digits. So my guess
 is that the PBX doesn&#39;t bother check for inband because FS tells it it&#39;s sending out-of-band, which&#39;d differ from before.</div>
<div><br>
</div>
<div>-Steve</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div>-Steve</div>
<div><br>
</div>
<div><br>
<br>
<br>
On 16 January 2013 04:02, <a href="mailto:support@ecn.net.au" target="_blank">support@ecn.net.au</a> &lt;<a href="mailto:support@ecn.net.au" target="_blank">support@ecn.net.au</a>&gt; wrote:<br>
&gt; Hi All<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; We&#39;re quite new to Freeswitch and are in the process of migrating from<br>
&gt; OpenSer (as an SBC) to Freeswitch.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Mostly all is working well, except an oddity on DTMF.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Our scenario:<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Telco/SIP Provider A is passing us calls using DTMF inband.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; We have a freeswitch configured as a SBC using 2 sip profiles (telco and<br>
&gt; internal) to topology hide and manage<br>
&gt;<br>
&gt; distribution of calls to the PBX servers located behind the SBC.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; The freeswitch will be handling up to a few hundred calls so we&#39;re trying to<br>
&gt; keep it lightweight.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Behind the SBC is a series of Asterisk and Freeswitch PBX boxes handling<br>
&gt; customer needs.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; An example inbound call profile looks like this:<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; &lt;extension name=&quot;Inbound 124356&quot;&gt;<br>
&gt;<br>
&gt;         &lt;condition field=&quot;destination_number&quot; expression=&quot;^(123456)$&quot;&gt;<br>
&gt;<br>
&gt;                 &lt;action application=&quot;pre_answer&quot;/&gt;<br>
&gt;<br>
&gt;                 &lt;action application=&quot;start_dtmf&quot; /&gt;<br>
&gt;<br>
&gt;                 &lt;action application=&quot;bridge&quot;<br>
&gt; data=&quot;sofia/external/123456@INTERNAL.PBX.IP:5060&quot;/&gt;<br>
&gt;<br>
&gt;         &lt;/condition&gt;<br>
&gt;<br>
&gt; &lt;/extension&gt;<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Initially when calling into the platform IVR type applications runinng on<br>
&gt; our PBX boxes would not<br>
&gt;<br>
&gt; work (you could hear the DTMF but the platform did not recognise the tones).<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; We have had to add the appliation start_dtmf in order for Freeswitch to pass<br>
&gt; the DTMF to the Asterisk<br>
&gt;<br>
&gt; PBX behind the SBC.   Interestingly on our OpenSer platform we just proxied<br>
&gt; the media (rtpproxy) with<br>
&gt;<br>
&gt; inband DTMF from the Telco and our PBX boxes recognised the inband DTMF<br>
&gt; tones on the PBX platforms and<br>
&gt;<br>
&gt; IVR type applications just worked.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; However under freeswitch if we don&#39;t start_dtmf before the bridge the<br>
&gt; backend PBX boxes don&#39;t recognise<br>
&gt;<br>
&gt; the DTMF inband (even though the tones are audible ie you can hear them on a<br>
&gt; call recording on the<br>
&gt;<br>
&gt; PBX).<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Have we missed something here?  We would have thought with inband DTMF on<br>
&gt; non compressed codec (no<br>
&gt;<br>
&gt; transcoding) that the tones would just work with the media stream?<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; We have confirmed both legs are PCMA and when using start_dtmf the first<br>
&gt; second of the call is clipped.<br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt;  <br>
&gt;<br>
&gt; Kind Regards,<br>
&gt;  <br>
&gt;<br>
&gt; _________________________________________________________________________<br>
&gt; Professional FreeSWITCH Consulting Services:<br>
&gt; <a href="mailto:consulting@freeswitch.org" target="_blank">consulting@freeswitch.org</a><br>
&gt; <a href="http://www.freeswitchsolutions.com" target="_blank">http://www.freeswitchsolutions.com</a><br>
&gt;<br>
&gt; FreeSWITCH-powered IP PBX: The CudaTel Communication Server<br>
&gt; <a href="http://www.cudatel.com" target="_blank">http://www.cudatel.com</a><br>
&gt;<br>
&gt; Official FreeSWITCH Sites<br>
&gt; <a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
&gt; <a href="http://wiki.freeswitch.org" target="_blank">http://wiki.freeswitch.org</a><br>
&gt; <a href="http://www.cluecon.com" target="_blank">http://www.cluecon.com</a><br>
&gt;<br>
&gt; FreeSWITCH-users mailing list<br>
&gt; <a href="mailto:FreeSWITCH-users@lists.freeswitch.org" target="_blank">FreeSWITCH-users@lists.freeswitch.org</a><br>
&gt; <a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">
http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
&gt; UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
&gt; <a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
&gt;<br>
</div>
</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-users mailing list<br>
<a href="mailto:FreeSWITCH-users@lists.freeswitch.org">FreeSWITCH-users@lists.freeswitch.org</a><br>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><br>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users" target="_blank">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><br>
<a href="http://www.freeswitch.org" target="_blank">http://www.freeswitch.org</a><br>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br>Sincerely<br><br>Jay
</div>