假设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/[email protected]${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),
在sofia_glue_on_invite里,FS向1002发送invite消息。
1002的CS_ROUTING
1002的CS_EXECUTE:
由于是bleg,execute状态里不再有application了。