Configuring AudioCodes MP-114/118

From FreeSWITCH Wiki
Jump to: navigation, search

Originally I really completely over thought this one and made far it more complex than needed be. Failed, of course. Then I went super simple with it. Worked! I hope I don’t get flamed for poor design, but it works!. I needed to create an unauthenticated extension in the directory (extensions for asterisk users). This could be dicey /unsafe, but it is internal.

We need to allow accept blind registration from the AudioCodes in /usr/local/freeswitch/conf/sip_profiles/internal.xml

<!-- this lets anything register -->
<!--  comment the next line and uncomment one or both of the other 2 lines for call authentication -->
<param name="accept-blind-reg" value="true"/>
<!-- accept any authentication without actually checking (not a good feature for most people) -->
<param name="accept-blind-auth" value="false"/>

Allow our Public Line to connect.


  <user id="pstn"  ip="">             <!—MP-114 IP Address -->
    <!-- params-->
      <!--param name="password" value="1234"/-->
      <variable name="effective_caller_id_number" value="Your Telephone Number"/>

Now for the dialplan settings that make it actually work. There are two place under the dialplan directory I needed to edit public.xml to let FreeSWITCH know we have a number for the public to reach.


<!-- -->
  <context name="public">
   <extension name="public_did">
      <condition field="destination_number" expression="^(Your Telephone Number here)$">
        <action application="transfer" data="$1 XML default"/>

Make sure the DID is in the default dialplan so FreeSWITCH knows how to handle the calls.


First let’s receive calls.

<!-- Inbound calls handled first - You will want to configure one or            -->
      <!-- If you have a number of similar DID's and they get the same call treatment -->
      <extension name="Inbound-PSTN">
    <!-- EDIT: change the DID to your inbound DID (DN) number     -->
    <condition field="destination_number" expression="^Your Telephone Number$">
        <!-- Set the maximum amount of time you want to ring the extensions (seconds) -->
     <action application="set" data="call_timeout=20"/>
     <!-- Sample single extension bridge -->
     <action application="answer" />
     <action application="sleep" data="1000" />
          <action application="bridge" data="sofia/default/1001%FreeSwitch IP address"/>

Now let's make calls. This is for 7 digit calls, but would apply to long distance also.

<!-- Dial any 7 digit number (3334444) as 10 digit dialing  but pass to a local itsp -->
   <extension name="Local Dial">
<!—this is a regular expression for a 7 digit number --> 
    <condition field="destination_number" expression="^([0-9]{7})$">    
     <!-- Set your outgoing caller ID name here -->
     <!-- action application="set" data="effective_caller_id_name=John Freeswitch"/ -->
     <!-- Your SIP provider probably expects a phone number or username
       for this setting. It is used in the from URL -->
     <action application="set" data="effective_caller_id_number=Your Telephone Number"/>
                        <!-- EDIT:  Your Audio Codes IP                          -->
          <action application="bridge" data="sofia/default/$"/>
<!-- action application="bridge" data="openzap/2/2/$1"/ -->

The AudioCodes box requires a continuous RTP stream otherwise it will time out after 10 seconds. Normally this isn't a problem, except when the call gets transferred to voice mail, where FreeSwitch normally doesn't send RTP while the message is being recorded. So if you want voice mails longer than 10 seconds you must add the following to vars.xml:

  <!-- AudioCodes wants us to send RTP even while someone is
       leaving us a VM... So we have to enable this waste resources flag.
  <X-PRE-PROCESS cmd="set" data="record_waste_resources=true"/>

AudioCodes Setup.

Quick Setup ->
IP configuration: ip address
SIP parameters->
Gateway Name: I use it’s IP address so no dns issues.
Working with Proxy = Yes
Proxy IP address= the IP of the Freeswitch box.
Proxy  Name= the IP of the Freeswitch box.
Protocol  Management:
Protocol Definition ->  
General Parameters:  
Channel Select Mode=Ascending
And make sure SIP ports are set for 5060
Proxy and Registration:
 Proxy Name and Proxy IP Address= Freeswitch Server
Enable Registration: I didn’t . 
 Gateway Name and Registration Name:  MP-114 IP address
Subscription and Registration Mode: Per Gateway (don’t remember if this matters).
Coders: make sure ulaw’s there
DTMF & Dialing:  Max digits-> put a high number like  32
Routing Tables:
Tel -> IP routing and IP-> Tel routing = I used 
 Dest IP/Phone Prefix =*      
 Source IP/Phone Prefix =*
 Dest/Source IP Address = Freeswitch  IP  Address
Endpoint Phone Numbers: Match channels to phone numbers.
Channels= 1 -4  
Phone numbers = your phone numbers
Hunt Group Settings:
I used  Cyclical Ascending
End  Point Settings:
Automatic Dialing: Destination Phone Numbers should match the numbers
you have in inbound context in extensions.conf or public.xml  
In our example <condition field="destination_number" expression="^Your Telephone Number$">
Advanced Applications:
FXO Settings:  Dialing Mode should be set to One Stage.

That should get you up and running. Although little differences in setups can cause major headaches and frustrations, I hope that this gives you a good starting reference point.