the default dialplan is aware of more than one domain now

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@9701 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Brian West 2008-09-28 21:30:02 +00:00
parent 50991cd833
commit ce5d245f6c
3 changed files with 47 additions and 26 deletions

View File

@ -9,6 +9,15 @@
<action application="deflect" data="${destination_number}"/> <action application="deflect" data="${destination_number}"/>
</condition> </condition>
</extension> </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. --> <!-- Example of doing things based on time of day. -->
<extension name="tod_example" continue="true"> <extension name="tod_example" continue="true">
<condition field="${strftime(%H%M)}" expression="^((09|1[0-7])[0-5][0-9]|1800)$"> <condition field="${strftime(%H%M)}" expression="^((09|1[0-7])[0-5][0-9]|1800)$">
@ -19,7 +28,7 @@
<extension name="intercept"> <extension name="intercept">
<condition field="destination_number" expression="^886$"> <condition field="destination_number" expression="^886$">
<action application="answer"/> <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"/> <action application="sleep" data="2000"/>
</condition> </condition>
</extension> </extension>
@ -27,14 +36,14 @@
<extension name="intercept-ext"> <extension name="intercept-ext">
<condition field="destination_number" expression="^\*\*(\d+)$"> <condition field="destination_number" expression="^\*\*(\d+)$">
<action application="answer"/> <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"/> <action application="sleep" data="2000"/>
</condition> </condition>
</extension> </extension>
<extension name="redial"> <extension name="redial">
<condition field="destination_number" expression="^870$"> <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> </condition>
</extension> </extension>
@ -58,9 +67,9 @@
<!-- <action application="export" data="sip_secure_media=true"/> --> <!-- <action application="export" data="sip_secure_media=true"/> -->
</condition> </condition>
<condition> <condition>
<action application="db" data="insert/spymap/${caller_id_number}/${uuid}"/> <action application="db" data="insert/${target_domain}-spymap/${caller_id_number}/${uuid}"/>
<action application="db" data="insert/last_dial/${caller_id_number}/${destination_number}"/> <action application="db" data="insert/${target_domain}-last_dial/${caller_id_number}/${destination_number}"/>
<action application="db" data="insert/last_dial/global/${uuid}"/> <action application="db" data="insert/${target_domain}-last_dial/global/${uuid}"/>
</condition> </condition>
</extension> </extension>
@ -97,7 +106,7 @@
<extension name="eavesdrop"> <extension name="eavesdrop">
<condition field="destination_number" expression="^88(.*)$|^\*0(.*)$"> <condition field="destination_number" expression="^88(.*)$|^\*0(.*)$">
<action application="answer"/> <action application="answer"/>
<action application="eavesdrop" data="${db(select/spymap/$1)}"/> <action application="eavesdrop" data="${db(select/${target_domain}-spymap/$1)}"/>
</condition> </condition>
</extension> </extension>
@ -113,14 +122,14 @@
<extension name="call_return"> <extension name="call_return">
<condition field="destination_number" expression="^\*69$|^869$"> <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> </condition>
</extension> </extension>
<extension name="del-group"> <extension name="del-group">
<condition field="destination_number" expression="^80(\d{2})$"> <condition field="destination_number" expression="^80(\d{2})$">
<action application="answer"/> <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)"/> <action application="gentones" data="%(1000, 0, 320)"/>
</condition> </condition>
</extension> </extension>
@ -128,21 +137,21 @@
<extension name="add-group"> <extension name="add-group">
<condition field="destination_number" expression="^81(\d{2})$"> <condition field="destination_number" expression="^81(\d{2})$">
<action application="answer"/> <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)"/> <action application="gentones" data="%(1000, 0, 640)"/>
</condition> </condition>
</extension> </extension>
<extension name="call-group-simo"> <extension name="call-group-simo">
<condition field="destination_number" expression="^82(\d{2})$"> <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> </condition>
</extension> </extension>
<extension name="call-group-order"> <extension name="call-group-order">
<condition field="destination_number" expression="^83(\d{2})$"> <condition field="destination_number" expression="^83(\d{2})$">
<action application="set" data="call_timeout=10"/> <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> </condition>
</extension> </extension>
@ -151,11 +160,11 @@
<condition field="destination_number" expression="^8(10[01][0-9])$"> <condition field="destination_number" expression="^8(10[01][0-9])$">
<action application="set" data="dialed_ext=$1"/> <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. --> <!-- 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[alert_info=<sip:${target_domain}>;Ring;Answer]]></action>-->
<action application="export"><![CDATA[sip_h_Call-Info=<sip:$${domain}>;answer-after=0]]></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_invite_params=intercom=true"/>
<action application="export" data="sip_auto_answer=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> </condition>
</extension> </extension>
@ -175,7 +184,7 @@
<action application="set" data="voicemail_authorized=${sip_authorized}"/> <action application="set" data="voicemail_authorized=${sip_authorized}"/>
<action application="answer"/> <action application="answer"/>
<action application="sleep" data="1000"/> <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> --> <!-- 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="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"/> <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="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=NORMAL_TEMPORARY_FAILURE,USER_BUSY,NO_ANSWER,TIMEOUT,NO_ROUTE_DESTINATION"/> -->
<anti-action application="set" data="continue_on_fail=true"/> <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/${target_domain}-call_return/${dialed_ext}/${caller_id_number}"/>
<anti-action application="db" data="insert/last_dial_ext/${dialed_ext}/${uuid}"/> <anti-action application="db" data="insert/${target_domain}-last_dial_ext/${dialed_ext}/${uuid}"/>
<anti-action application="bridge" data="user/${dialed_ext}@$${domain}"/> <anti-action application="bridge" data="user/${dialed_ext}@${target_domain}"/>
<anti-action application="answer"/> <anti-action application="answer"/>
<!--<anti-action application="send_display" data="Voicemail for ${dialed_ext}"/>--> <!--<anti-action application="send_display" data="Voicemail for ${dialed_ext}"/>-->
<anti-action application="sleep" data="1000"/> <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> </condition>
</extension> </extension>
@ -286,7 +295,7 @@
<extension name="park"> <extension name="park">
<condition field="destination_number" expression="^5900$"> <condition field="destination_number" expression="^5900$">
<action application="set" data="fifo_music=$${hold_music}"/> <action application="set" data="fifo_music=$${hold_music}"/>
<action application="fifo" data="5900@$${domain} in"/> <action application="fifo" data="5900@${target_domain} in"/>
</condition> </condition>
</extension> </extension>
@ -296,7 +305,7 @@
<extension name="unpark"> <extension name="unpark">
<condition field="destination_number" expression="^5901$"> <condition field="destination_number" expression="^5901$">
<action application="answer"/> <action application="answer"/>
<action application="fifo" data="5900@$${domain} out nowait"/> <action application="fifo" data="5900@${target_domain} out nowait"/>
</condition> </condition>
</extension> </extension>
@ -310,7 +319,7 @@
<extension name="park"> <extension name="park">
<condition field="source" expression="mod_sofia"/> <condition field="source" expression="mod_sofia"/>
<condition field="destination_number" expression="park\+(\d+)"> <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> </condition>
</extension> </extension>
<!-- <!--
@ -322,7 +331,7 @@
<condition field="destination_number" expression="^parking$"/> <condition field="destination_number" expression="^parking$"/>
<condition field="${sip_to_params}" expression="fifo\=(\d+)"> <condition field="${sip_to_params}" expression="fifo\=(\d+)">
<action application="answer"/> <action application="answer"/>
<action application="fifo" data="$1@$${domain} out nowait"/> <action application="fifo" data="$1@${target_domain} out nowait"/>
</condition> </condition>
</extension> </extension>
@ -429,7 +438,7 @@
<!-- <!--
<extension name="refer"> <extension name="refer">
<condition field="${sip_refer_to}"> <condition field="${sip_refer_to}">
<expression><![CDATA[<sip:${destination_number}@$${domain}>]]></expression> <expression><![CDATA[<sip:${destination_number}@${target_domain}>]]></expression>
</condition> </condition>
<condition field="${sip_refer_to}"> <condition field="${sip_refer_to}">
<expression><![CDATA[<sip:(.*)@(.*)>]]></expression> <expression><![CDATA[<sip:(.*)@(.*)>]]></expression>
@ -454,7 +463,7 @@
<condition field="destination_number" expression="^7004$"> <condition field="destination_number" expression="^7004$">
<action application="set" data="ruri_profile=default"/> <action application="set" data="ruri_profile=default"/>
<action application="set" data="ruri_user=2000"/> <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"/> <action application="execute_extension" data="ruri"/>
</condition> </condition>
</extension> </extension>

View File

@ -30,6 +30,8 @@
</extension> </extension>
<extension name="is_secure"> <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$"> <condition field="${sip_secure_media_confirmed}" expression="^true$">
<action application="sleep" data="1000"/> <action application="sleep" data="1000"/>
<!--<action application="send_display" data="Secure Music On Hold "/>--> <!--<action application="send_display" data="Secure Music On Hold "/>-->

View File

@ -1,6 +1,16 @@
<include> <include>
<extension name="public_did"> <extension name="public_did">
<condition field="destination_number" expression="^(5551212)$"> <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 --> <!-- This example maps the DID 5551212 to ring 1000 in the default context -->
<action application="transfer" data="1000 XML default"/> <action application="transfer" data="1000 XML default"/>
</condition> </condition>