假設1003 呼叫 1002
1003向FS發送inivte消息:
sofia模塊收到sip消息後回調sofia_event_callback
進入sofia_handle_sip_i_invite
爲1003建立session與channel,進入1003的channel狀態機。一次執行:
1003的CS_INIT
1003的CS_ROUTING
1003的CS_EXECUTE:
在CS_EXECUTE狀態下,FreeSwitch會執行鍼對於1003設定的Applications,當然是通過dialplan裏的xml配置文件獲取相應APP.
對於B2B情況,1003此時會執行一些列的set和哈希,如下:
<extension name="Local_Extension">
<condition field="destination_number" expression="^(10[01][0-9])|1020$">
<action application="set" data="dialed_extension=$1"/>
<action application="export" data="dialed_extension=$1"/>
<!-- bind_meta_app can have these args <key> [a|b|ab] [a|b|o|s] <app> -->
<action application="bind_meta_app" data="1 b s execute_extension::dx XML features"/>
<action application="bind_meta_app" data="2 b s record_session::$${recordings_dir}/${caller_id_number}.${strftime(%Y-%m-%d-%H-%M-%S)}.wav"/>
<action application="bind_meta_app" data="3 b s execute_extension::cf XML features"/>
<action application="set" data="ringback=${us-ring}"/>
<action application="set" data="transfer_ringback=$${hold_music}"/>
<action application="set" data="call_timeout=30"/>
<!-- <action application="set" data="sip_exclude_contact=${network_addr}"/> -->
<action application="set" data="hangup_after_bridge=true"/>
<!--<action application="set" data="continue_on_fail=NORMAL_TEMPORARY_FAILURE,USER_BUSY,NO_ANSWER,TIMEOUT,NO_ROUTE_DESTINATION"/> -->
<action application="set" data="continue_on_fail=true"/>
<action application="hash" data="insert/${domain_name}-call_return/${dialed_extension}/${caller_id_number}"/>
<action application="hash" data="insert/${domain_name}-last_dial_ext/${dialed_extension}/${uuid}"/>
<action application="set" data="called_party_callgroup=${user_data(${dialed_extension}@${domain_name} var callgroup)}"/>
<!--<action application="export" data="nolocal:sip_secure_media=${user_data(${dialed_extension}@${domain_name} var sip_secure_media)}"/>-->
<action application="hash" data="insert/${domain_name}-last_dial/${called_party_callgroup}/${uuid}"/>
<action application="bridge" data="user/${dialed_extension}@${domain_name}"/>
<!--<action application="bridge" data="user/1010@${domain_name}"/>-->
<!--<action application="transfer" data="1010 XML default"/>-->
<action application="answer"/>
<action application="sleep" data="1000"/>
<action application="voicemail" data="default ${domain_name} ${dialed_extension}"/>
</condition>
</extension>
最後會執行bridge和answer,其中bridge有調用switch_ivr_originate,最終調用sofia_outgoing_channel,爲1002,即b_leg建立session和channel,並啓動1002session
的狀態線程。而answer則是對1003做出應答。
當爲1002建立了狀態循環線程後,1002同樣會進入:
1002的CS_INIT:
在這裏freeswitch會調用1002的終端endpoint_interface的init狀態函數——sofia_on_init(),繼而調用sofia_glue_do_invite(session/*1002的session*/),
在sofia_glue_on_invite裏,FS向1002發送invite消息。
1002的CS_ROUTING
1002的CS_EXECUTE:
由於是bleg,execute狀態裏不再有application了。