[Freeswitch-svn] [commit] r9701 - in freeswitch/trunk/conf/dialplan: . public

Freeswitch SVN brian at freeswitch.org
Sun Sep 28 17:30:02 EDT 2008


Author: brian
Date: Sun Sep 28 17:30:02 2008
New Revision: 9701

Modified:
   freeswitch/trunk/conf/dialplan/default.xml
   freeswitch/trunk/conf/dialplan/features.xml
   freeswitch/trunk/conf/dialplan/public/00_inbound_did.xml

Log:
the default dialplan is aware of more than one domain now

Modified: freeswitch/trunk/conf/dialplan/default.xml
==============================================================================
--- freeswitch/trunk/conf/dialplan/default.xml	(original)
+++ freeswitch/trunk/conf/dialplan/default.xml	Sun Sep 28 17:30:02 2008
@@ -9,6 +9,15 @@
 	<action application="deflect" data="${destination_number}"/>
       </condition>
     </extension>
+
+    <extension name="set_domain" continue="true">
+      <condition field="${target_domain}" expression="^$" break="never"/>
+      <condition field="source" expression="mod_sofia" break="never">
+	<action application="set" data="target_domain=${sip_auth_realm}"/>
+	<anti-action application="set" data="target_domain=$${domain}"/>
+      </condition>
+    </extension>
+
     <!-- Example of doing things based on time of day. -->
     <extension name="tod_example" continue="true">
       <condition field="${strftime(%H%M)}" expression="^((09|1[0-7])[0-5][0-9]|1800)$">
@@ -19,7 +28,7 @@
     <extension name="intercept">
       <condition field="destination_number" expression="^886$">
 	<action application="answer"/>
-	<action application="intercept" data="${db(select/last_dial/global)}"/>
+	<action application="intercept" data="${db(select/${target_domain}-last_dial/global)}"/>
 	<action application="sleep" data="2000"/>
       </condition>
     </extension>
@@ -27,14 +36,14 @@
     <extension name="intercept-ext">
       <condition field="destination_number" expression="^\*\*(\d+)$">
 	<action application="answer"/>
-	<action application="intercept" data="${db(select/last_dial_ext/$1)}"/>
+	<action application="intercept" data="${db(select/${target_domain}-last_dial_ext/$1)}"/>
 	<action application="sleep" data="2000"/>
       </condition>
     </extension>
 
     <extension name="redial">
       <condition field="destination_number" expression="^870$">
-	<action application="transfer" data="${db(select/last_dial/${caller_id_number})}"/>
+	<action application="transfer" data="${db(select/${target_domain}-last_dial/${caller_id_number})}"/>
       </condition>
     </extension>
 
@@ -58,9 +67,9 @@
 	<!-- <action application="export" data="sip_secure_media=true"/> -->
       </condition>
       <condition>
-	<action application="db" data="insert/spymap/${caller_id_number}/${uuid}"/>
-	<action application="db" data="insert/last_dial/${caller_id_number}/${destination_number}"/>
-	<action application="db" data="insert/last_dial/global/${uuid}"/>
+	<action application="db" data="insert/${target_domain}-spymap/${caller_id_number}/${uuid}"/>
+	<action application="db" data="insert/${target_domain}-last_dial/${caller_id_number}/${destination_number}"/>
+	<action application="db" data="insert/${target_domain}-last_dial/global/${uuid}"/>
       </condition>
     </extension>
 
@@ -97,7 +106,7 @@
     <extension name="eavesdrop">
       <condition field="destination_number" expression="^88(.*)$|^\*0(.*)$">
 	<action application="answer"/>
-	<action application="eavesdrop" data="${db(select/spymap/$1)}"/>
+	<action application="eavesdrop" data="${db(select/${target_domain}-spymap/$1)}"/>
       </condition>
     </extension>
 
@@ -113,14 +122,14 @@
 
     <extension name="call_return">
       <condition field="destination_number" expression="^\*69$|^869$">
-	<action application="transfer" data="${db(select/call_return/${caller_id_number})}"/>
+	<action application="transfer" data="${db(select/${target_domain}-call_return/${caller_id_number})}"/>
       </condition>
     </extension>
 
     <extension name="del-group">
       <condition field="destination_number" expression="^80(\d{2})$">
 	<action application="answer"/>
-	<action application="group" data="delete:$1:${sofia_contact(${sip_from_user}@${domain})}"/>
+	<action application="group" data="delete:$1@${target_domain}:${sofia_contact(${sip_from_user}@${target_domain})}"/>
 	<action application="gentones" data="%(1000, 0, 320)"/>
       </condition>
     </extension>
@@ -128,21 +137,21 @@
     <extension name="add-group">
       <condition field="destination_number" expression="^81(\d{2})$">
 	<action application="answer"/>
-	<action application="group" data="insert:$1:${sofia_contact(${sip_from_user}@${domain})}"/>
+	<action application="group" data="insert:$1@${target_domain}:${sofia_contact(${sip_from_user}@${target_domain})}"/>
 	<action application="gentones" data="%(1000, 0, 640)"/>
       </condition>
     </extension>
 
     <extension name="call-group-simo">
       <condition field="destination_number" expression="^82(\d{2})$">
-	<action application="bridge" data="{ignore_early_media=true}${group(call:$1)}"/>
+	<action application="bridge" data="{ignore_early_media=true}${group(call:$1@${target_domain})}"/>
       </condition>
     </extension>
 
     <extension name="call-group-order">
       <condition field="destination_number" expression="^83(\d{2})$">
 	<action application="set" data="call_timeout=10"/>
-	<action application="bridge" data="{ignore_early_media=true}${group(call:$1:order)}"/>
+	<action application="bridge" data="{ignore_early_media=true}${group(call:$1@${target_domain}:order)}"/>
       </condition>
     </extension>
 
@@ -151,11 +160,11 @@
       <condition field="destination_number" expression="^8(10[01][0-9])$">
 	<action application="set" data="dialed_ext=$1"/>
 	<!-- This Alert-Info seems to be a case for Intercom for Polycom which sip_auto_answer=true covers already. -->
-	<!--<action application="export"><![CDATA[alert_info=<sip:$${domain}>;Ring;Answer]]></action>-->
-	<action application="export"><![CDATA[sip_h_Call-Info=<sip:$${domain}>;answer-after=0]]></action>
+	<!--<action application="export"><![CDATA[alert_info=<sip:${target_domain}>;Ring;Answer]]></action>-->
+	<action application="export"><![CDATA[sip_h_Call-Info=<sip:${target_domain}>;answer-after=0]]></action>
 	<action application="export" data="sip_invite_params=intercom=true"/>
 	<action application="export" data="sip_auto_answer=true"/>
-	<action application="bridge" data="user/${dialed_ext}@$${domain}"/>
+	<action application="bridge" data="user/${dialed_ext}@${target_domain}"/>
       </condition>
     </extension>
 
@@ -175,7 +184,7 @@
 	<action application="set" data="voicemail_authorized=${sip_authorized}"/>
 	<action application="answer"/>
 	<action application="sleep" data="1000"/>
-	<action application="voicemail" data="check default $${domain} ${dialed_ext}"/>
+	<action application="voicemail" data="check default ${target_domain} ${dialed_ext}"/>
 	<!-- bind_meta_app can have these args <key> [a|b|ab] [a|b|o|s] <app> -->
 	<anti-action application="bind_meta_app" data="1 b s execute_extension::dx XML features"/>
 	<anti-action application="bind_meta_app" data="2 b s record_session::$${base_dir}/recordings/${caller_id_number}.${strftime(%Y-%m-%d-%H-%M-%S)}.wav"/>
@@ -186,13 +195,13 @@
 	<anti-action application="set" data="hangup_after_bridge=true"/>
 	<!--<anti-action application="set" data="continue_on_fail=NORMAL_TEMPORARY_FAILURE,USER_BUSY,NO_ANSWER,TIMEOUT,NO_ROUTE_DESTINATION"/> -->
 	<anti-action application="set" data="continue_on_fail=true"/>
-	<anti-action application="db" data="insert/call_return/${dialed_ext}/${caller_id_number}"/>
-	<anti-action application="db" data="insert/last_dial_ext/${dialed_ext}/${uuid}"/>
-	<anti-action application="bridge" data="user/${dialed_ext}@$${domain}"/>
+	<anti-action application="db" data="insert/${target_domain}-call_return/${dialed_ext}/${caller_id_number}"/>
+	<anti-action application="db" data="insert/${target_domain}-last_dial_ext/${dialed_ext}/${uuid}"/>
+	<anti-action application="bridge" data="user/${dialed_ext}@${target_domain}"/>
 	<anti-action application="answer"/>
 	<!--<anti-action application="send_display" data="Voicemail for ${dialed_ext}"/>-->
 	<anti-action application="sleep" data="1000"/>
-	<anti-action application="voicemail" data="default $${domain} ${dialed_ext}"/>
+	<anti-action application="voicemail" data="default ${target_domain} ${dialed_ext}"/>
       </condition>
     </extension>
 
@@ -286,7 +295,7 @@
     <extension name="park">
       <condition field="destination_number" expression="^5900$">
 	<action application="set" data="fifo_music=$${hold_music}"/>
-	<action application="fifo" data="5900@$${domain} in"/>
+	<action application="fifo" data="5900@${target_domain} in"/>
       </condition>
     </extension>
 
@@ -296,7 +305,7 @@
     <extension name="unpark">
       <condition field="destination_number" expression="^5901$">
 	<action application="answer"/>
-	<action application="fifo" data="5900@$${domain} out nowait"/>
+	<action application="fifo" data="5900@${target_domain} out nowait"/>
       </condition>
     </extension>
 
@@ -310,7 +319,7 @@
     <extension name="park">
       <condition field="source" expression="mod_sofia"/>
       <condition field="destination_number" expression="park\+(\d+)">
-	<action application="fifo" data="$1@$${domain} in undef $${hold_music}"/>
+	<action application="fifo" data="$1@${target_domain} in undef $${hold_music}"/>
       </condition>
     </extension> 
     <!--
@@ -322,7 +331,7 @@
       <condition field="destination_number" expression="^parking$"/>
       <condition field="${sip_to_params}" expression="fifo\=(\d+)">
 	<action application="answer"/>
-	<action application="fifo" data="$1@$${domain} out nowait"/>
+	<action application="fifo" data="$1@${target_domain} out nowait"/>
       </condition>
     </extension>
 
@@ -429,7 +438,7 @@
     <!--
     <extension name="refer">
       <condition field="${sip_refer_to}">
-	<expression><![CDATA[<sip:${destination_number}@$${domain}>]]></expression>
+	<expression><![CDATA[<sip:${destination_number}@${target_domain}>]]></expression>
       </condition>
       <condition field="${sip_refer_to}">
 	<expression><![CDATA[<sip:(.*)@(.*)>]]></expression>
@@ -454,7 +463,7 @@
       <condition field="destination_number" expression="^7004$">
 	<action application="set" data="ruri_profile=default"/>
 	<action application="set" data="ruri_user=2000"/>
-	<action application="set" data="ruri_contact=1001@$${domain}"/>
+	<action application="set" data="ruri_contact=1001@${target_domain}"/>
 	<action application="execute_extension" data="ruri"/>
       </condition>
     </extension>

Modified: freeswitch/trunk/conf/dialplan/features.xml
==============================================================================
--- freeswitch/trunk/conf/dialplan/features.xml	(original)
+++ freeswitch/trunk/conf/dialplan/features.xml	Sun Sep 28 17:30:02 2008
@@ -30,6 +30,8 @@
     </extension>
 
     <extension name="is_secure">
+      <!-- Only Truly consider it secure if its TLS and SRTP --> 
+      <condition field="${sip_req_params}" expression="tls"/>
       <condition field="${sip_secure_media_confirmed}" expression="^true$">
 	<action application="sleep" data="1000"/>
 	<!--<action application="send_display" data="Secure Music On Hold "/>-->

Modified: freeswitch/trunk/conf/dialplan/public/00_inbound_did.xml
==============================================================================
--- freeswitch/trunk/conf/dialplan/public/00_inbound_did.xml	(original)
+++ freeswitch/trunk/conf/dialplan/public/00_inbound_did.xml	Sun Sep 28 17:30:02 2008
@@ -1,6 +1,16 @@
 <include>
   <extension name="public_did">
     <condition field="destination_number" expression="^(5551212)$">
+      <!--
+	  If you're hosting multiple domains you will want to set the
+	  target_domain on these calls so they hit the proper domain after you
+	  transfer the caller into the default context. 
+	  
+	  $${domain} is the default domain set from vars.xml but you can set it
+	  to any domain you have setup in your user directory.
+
+      --> 
+      <action application="set" data="target_domain=$${domain}"/>
       <!-- This example maps the DID 5551212 to ring 1000 in the default context -->
       <action application="transfer" data="1000 XML default"/>
     </condition>



More information about the Freeswitch-svn mailing list