diff --git a/README.md b/README.md index e38519f..7fab1d7 100644 --- a/README.md +++ b/README.md @@ -361,6 +361,26 @@ Run the same as scenario, but the referee no longer sends the re-INVITE, thus we retry the bridging after 2.1-4s. +#### 31.refer-unattended-uac-notify-cancel +Run a transfer similar to +[09.refer-unattended-uac-notify-fail](#09refer-unattended-uac-notify-fail), but +the call times out and the referee's call gets canceled. + +#### 32.refer-unattended-uas-notify-cancel +Run a transfer similar to +[10.refer-unattended-uas-notify-fail](#10refer-unattended-uas-notify-fail), but +the call times out and the referee's call gets canceled. + +#### 33.refer-unattended-uac-notify-terminate +Run a transfer similar to +[09.refer-unattended-uac-notify-fail](#09refer-unattended-uac-notify-fail), but +the remaining participant terminates the call during transfer. + +#### 34.refer-unattended-uas-notify-terminate +Run a transfer similar to +[10.refer-unattended-uas-notify-fail](#10refer-unattended-uas-notify-fail), but +the remaining participant terminates the call during transfer. + ### UAC Auth Verifies the behavior of uac_auth module. diff --git a/b2b/31.refer-unattended-uac-notify-cancel/defines.yml b/b2b/31.refer-unattended-uac-notify-cancel/defines.yml new file mode 100644 index 0000000..64e1a68 --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/defines.yml @@ -0,0 +1,3 @@ +--- +transfer_ip: 192.168.52.5 +transfer_port: 5065 diff --git a/b2b/31.refer-unattended-uac-notify-cancel/opensips.cfg b/b2b/31.refer-unattended-uac-notify-cancel/opensips.cfg new file mode 100644 index 0000000..ba95406 --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/opensips.cfg @@ -0,0 +1,113 @@ +# +# OpenSIPS residential configuration script +# by OpenSIPS Solutions +# +# This script was generated via "make menuconfig", from +# the "Residential" scenario. +# You can enable / disable more features / functionalities by +# re-generating the scenario with different options.# +# +# Please refer to the Core CookBook at: +# https://opensips.org/Resources/DocsCookbooks +# for a explanation of possible statements, functions and parameters. +# + + +####### Global Parameters ######### +###################################################################### +/* uncomment the following lines to enable debugging */ +#debug_mode=yes + +log_level=4 +xlog_level=4 +log_stderror=yes + +udp_workers=4 + +####### Modules Section ######## + +#set module path +mpath="/usr/lib/x86_64-linux-gnu/opensips/modules/" + +#### SIGNALING module +loadmodule "signaling.so" + +#### StateLess module +loadmodule "sl.so" + +#### Transaction Module +loadmodule "tm.so" +modparam("tm", "fr_timeout", 3) +modparam("tm", "fr_inv_timeout", 5) +modparam("tm", "restart_fr_on_each_reply", 0) +modparam("tm", "onreply_avp_mode", 1) + +#### SIP MSG OPerationS module +loadmodule "sipmsgops.so" + +#### MAX ForWarD module +loadmodule "maxfwd.so" + +#### Record Route Module +loadmodule "rr.so" +/* do not append from tag to the RR (no need for this script) */ +modparam("rr", "append_fromtag", 0) + +#### B2B modules +loadmodule "b2b_entities.so" +loadmodule "b2b_logic.so" +modparam("b2b_logic", "script_req_route", "b2b_logic_request") + +loadmodule "proto_udp.so" + +####### Routing Logic ######## + +# main request routing logic + +route { + + if (!mf_process_maxfwd_header(10)) { + send_reply(483,"Too Many Hops"); + exit; + } + + if (has_totag()) { + send_reply(481, "Call/Transaction Does Not Exist"); + exit; + } + + # accept just INVITE requests + if (!is_method("INVITE")) { + send_reply(503, "Service Unavailable"); + exit; + } + + # create the server entity + b2b_server_new("caller"); + # create the initial client entity, to connect the caller with the callee + b2b_client_new("callee", $ru); + + # initialize B2B session for the "refer" scenario + b2b_init_request("refer"); + + exit; +} + +route[b2b_logic_request] { + if ($rm != "REFER") { + # for requests other than REFER, no special actions needs to be done, + # just pass the request to the peer + b2b_pass_request(); + exit; + } + + # end dialog with the referrer + b2b_send_reply(202, "Accepted"); + + # create the client entity corresponding to + # the user specified in the 'Refer-To' header + b2b_client_new("referee", $hdr(Refer-To)); + + # bridge the referrer's peer with the referee + b2b_bridge("peer", "referee", ,"notify, no-late-sdp, rollback-failed"); +} diff --git a/b2b/31.refer-unattended-uac-notify-cancel/scenario.yml b/b2b/31.refer-unattended-uac-notify-cancel/scenario.yml new file mode 100644 index 0000000..f0891d4 --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/scenario.yml @@ -0,0 +1,37 @@ +--- +timeout: 20 + +tasks: + - name: OpenSIPS + type: opensips + + - name: SIPP UAS + type: uas-sipp + config_file: scripts/uas.xml + require: OpenSIPS + + - name: SIPP UAC + type: uac-sipp + config_file: scripts/uac.xml + duration: 2000 # before and after transfer + username: {{ username }} + remote: {{ uas_ip }}:{{ uas_port }} + require: + started: + task: SIPP UAS + wait: 0.5 + keys: + transfer: sip:transfer@{{ transfer_ip }}:{{ transfer_port }} + + - name: SIPP Transfer + type: uas-sipp + config_file: scripts/transfer.xml + ip: {{ transfer_ip }} + port: {{ transfer_port }} + require: + - started: + task: SIPP UAC + wait: 0.5 + - after: + task: OpenSIPS + wait: 0.5 diff --git a/b2b/31.refer-unattended-uac-notify-cancel/scripts/transfer.xml b/b2b/31.refer-unattended-uac-notify-cancel/scripts/transfer.xml new file mode 100644 index 0000000..6e821b0 --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/scripts/transfer.xml @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/31.refer-unattended-uac-notify-cancel/scripts/uac.xml b/b2b/31.refer-unattended-uac-notify-cancel/scripts/uac.xml new file mode 100644 index 0000000..1eb5d3d --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/scripts/uac.xml @@ -0,0 +1,240 @@ + + + + + + + + + + + + + + ;tag=[call_number] + To: + Call-ID: [call_id] + CSeq: 1 INVITE + Contact: + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 1 ACK + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Subject: Performance Test + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 2 REFER + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Refer-To: [transfer] + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 2 BYE + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/31.refer-unattended-uac-notify-cancel/scripts/uas.xml b/b2b/31.refer-unattended-uac-notify-cancel/scripts/uas.xml new file mode 100644 index 0000000..ddd2b50 --- /dev/null +++ b/b2b/31.refer-unattended-uac-notify-cancel/scripts/uas.xml @@ -0,0 +1,181 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: [len] + + ]]> + + + + + + + + + + + + + + + diff --git a/b2b/32.refer-unattended-uas-notify-cancel/defines.yml b/b2b/32.refer-unattended-uas-notify-cancel/defines.yml new file mode 100644 index 0000000..64e1a68 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/defines.yml @@ -0,0 +1,3 @@ +--- +transfer_ip: 192.168.52.5 +transfer_port: 5065 diff --git a/b2b/32.refer-unattended-uas-notify-cancel/opensips.cfg b/b2b/32.refer-unattended-uas-notify-cancel/opensips.cfg new file mode 100644 index 0000000..ba95406 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/opensips.cfg @@ -0,0 +1,113 @@ +# +# OpenSIPS residential configuration script +# by OpenSIPS Solutions +# +# This script was generated via "make menuconfig", from +# the "Residential" scenario. +# You can enable / disable more features / functionalities by +# re-generating the scenario with different options.# +# +# Please refer to the Core CookBook at: +# https://opensips.org/Resources/DocsCookbooks +# for a explanation of possible statements, functions and parameters. +# + + +####### Global Parameters ######### +###################################################################### +/* uncomment the following lines to enable debugging */ +#debug_mode=yes + +log_level=4 +xlog_level=4 +log_stderror=yes + +udp_workers=4 + +####### Modules Section ######## + +#set module path +mpath="/usr/lib/x86_64-linux-gnu/opensips/modules/" + +#### SIGNALING module +loadmodule "signaling.so" + +#### StateLess module +loadmodule "sl.so" + +#### Transaction Module +loadmodule "tm.so" +modparam("tm", "fr_timeout", 3) +modparam("tm", "fr_inv_timeout", 5) +modparam("tm", "restart_fr_on_each_reply", 0) +modparam("tm", "onreply_avp_mode", 1) + +#### SIP MSG OPerationS module +loadmodule "sipmsgops.so" + +#### MAX ForWarD module +loadmodule "maxfwd.so" + +#### Record Route Module +loadmodule "rr.so" +/* do not append from tag to the RR (no need for this script) */ +modparam("rr", "append_fromtag", 0) + +#### B2B modules +loadmodule "b2b_entities.so" +loadmodule "b2b_logic.so" +modparam("b2b_logic", "script_req_route", "b2b_logic_request") + +loadmodule "proto_udp.so" + +####### Routing Logic ######## + +# main request routing logic + +route { + + if (!mf_process_maxfwd_header(10)) { + send_reply(483,"Too Many Hops"); + exit; + } + + if (has_totag()) { + send_reply(481, "Call/Transaction Does Not Exist"); + exit; + } + + # accept just INVITE requests + if (!is_method("INVITE")) { + send_reply(503, "Service Unavailable"); + exit; + } + + # create the server entity + b2b_server_new("caller"); + # create the initial client entity, to connect the caller with the callee + b2b_client_new("callee", $ru); + + # initialize B2B session for the "refer" scenario + b2b_init_request("refer"); + + exit; +} + +route[b2b_logic_request] { + if ($rm != "REFER") { + # for requests other than REFER, no special actions needs to be done, + # just pass the request to the peer + b2b_pass_request(); + exit; + } + + # end dialog with the referrer + b2b_send_reply(202, "Accepted"); + + # create the client entity corresponding to + # the user specified in the 'Refer-To' header + b2b_client_new("referee", $hdr(Refer-To)); + + # bridge the referrer's peer with the referee + b2b_bridge("peer", "referee", ,"notify, no-late-sdp, rollback-failed"); +} diff --git a/b2b/32.refer-unattended-uas-notify-cancel/scenario.yml b/b2b/32.refer-unattended-uas-notify-cancel/scenario.yml new file mode 100644 index 0000000..67f6c62 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/scenario.yml @@ -0,0 +1,38 @@ +--- +timeout: 20 + +tasks: + - name: OpenSIPS + type: opensips + + - name: SIPP UAS + type: uas-sipp + config_file: scripts/uas.xml + duration: 2000 # before transfer + require: OpenSIPS + keys: + transfer: sip:transfer@{{ transfer_ip }}:{{ transfer_port }} + + - name: SIPP UAC + type: uac-sipp + config_file: scripts/uac.xml + username: {{ username }} + duration: 5000 # after reINVITE/transfer + remote: {{ uas_ip }}:{{ uas_port }} + require: + started: + task: SIPP UAS + wait: 0.5 + + - name: SIPP Transfer + type: uas-sipp + config_file: scripts/transfer.xml + ip: {{ transfer_ip }} + port: {{ transfer_port }} + require: + - started: + task: SIPP UAS + wait: 0.5 + - after: + task: OpenSIPS + wait: 0.5 diff --git a/b2b/32.refer-unattended-uas-notify-cancel/scripts/transfer.xml b/b2b/32.refer-unattended-uas-notify-cancel/scripts/transfer.xml new file mode 100644 index 0000000..6e821b0 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/scripts/transfer.xml @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/32.refer-unattended-uas-notify-cancel/scripts/uac.xml b/b2b/32.refer-unattended-uas-notify-cancel/scripts/uac.xml new file mode 100644 index 0000000..96632d9 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/scripts/uac.xml @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + ;tag=[call_number] + To: + Call-ID: [call_id] + CSeq: 1 INVITE + Contact: + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 1 ACK + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Subject: Performance Test + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + Content-Length: [len] + + ]]> + + + + + + + + + + + + + diff --git a/b2b/32.refer-unattended-uas-notify-cancel/scripts/uas.xml b/b2b/32.refer-unattended-uas-notify-cancel/scripts/uas.xml new file mode 100644 index 0000000..729fcb3 --- /dev/null +++ b/b2b/32.refer-unattended-uas-notify-cancel/scripts/uas.xml @@ -0,0 +1,292 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + Call-ID: [call_id] + Max-Forwards: 70 + Refer-To: [transfer] + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + + + Call-ID: [call_id] + Max-Forwards: 70 + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/33.refer-unattended-uac-notify-terminate/defines.yml b/b2b/33.refer-unattended-uac-notify-terminate/defines.yml new file mode 100644 index 0000000..64e1a68 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/defines.yml @@ -0,0 +1,3 @@ +--- +transfer_ip: 192.168.52.5 +transfer_port: 5065 diff --git a/b2b/33.refer-unattended-uac-notify-terminate/opensips.cfg b/b2b/33.refer-unattended-uac-notify-terminate/opensips.cfg new file mode 100644 index 0000000..050bec2 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/opensips.cfg @@ -0,0 +1,113 @@ +# +# OpenSIPS residential configuration script +# by OpenSIPS Solutions +# +# This script was generated via "make menuconfig", from +# the "Residential" scenario. +# You can enable / disable more features / functionalities by +# re-generating the scenario with different options.# +# +# Please refer to the Core CookBook at: +# https://opensips.org/Resources/DocsCookbooks +# for a explanation of possible statements, functions and parameters. +# + + +####### Global Parameters ######### +###################################################################### +/* uncomment the following lines to enable debugging */ +#debug_mode=yes + +log_level=4 +xlog_level=4 +log_stderror=yes + +udp_workers=4 + +####### Modules Section ######## + +#set module path +mpath="/usr/lib/x86_64-linux-gnu/opensips/modules/" + +#### SIGNALING module +loadmodule "signaling.so" + +#### StateLess module +loadmodule "sl.so" + +#### Transaction Module +loadmodule "tm.so" +modparam("tm", "fr_timeout", 5) +modparam("tm", "fr_inv_timeout", 30) +modparam("tm", "restart_fr_on_each_reply", 0) +modparam("tm", "onreply_avp_mode", 1) + +#### SIP MSG OPerationS module +loadmodule "sipmsgops.so" + +#### MAX ForWarD module +loadmodule "maxfwd.so" + +#### Record Route Module +loadmodule "rr.so" +/* do not append from tag to the RR (no need for this script) */ +modparam("rr", "append_fromtag", 0) + +#### B2B modules +loadmodule "b2b_entities.so" +loadmodule "b2b_logic.so" +modparam("b2b_logic", "script_req_route", "b2b_logic_request") + +loadmodule "proto_udp.so" + +####### Routing Logic ######## + +# main request routing logic + +route { + + if (!mf_process_maxfwd_header(10)) { + send_reply(483,"Too Many Hops"); + exit; + } + + if (has_totag()) { + send_reply(481, "Call/Transaction Does Not Exist"); + exit; + } + + # accept just INVITE requests + if (!is_method("INVITE")) { + send_reply(503, "Service Unavailable"); + exit; + } + + # create the server entity + b2b_server_new("caller"); + # create the initial client entity, to connect the caller with the callee + b2b_client_new("callee", $ru); + + # initialize B2B session for the "refer" scenario + b2b_init_request("refer"); + + exit; +} + +route[b2b_logic_request] { + if ($rm != "REFER") { + # for requests other than REFER, no special actions needs to be done, + # just pass the request to the peer + b2b_pass_request(); + exit; + } + + # end dialog with the referrer + b2b_send_reply(202, "Accepted"); + + # create the client entity corresponding to + # the user specified in the 'Refer-To' header + b2b_client_new("referee", $hdr(Refer-To)); + + # bridge the referrer's peer with the referee + b2b_bridge("peer", "referee", ,"notify, no-late-sdp, rollback-failed"); +} diff --git a/b2b/33.refer-unattended-uac-notify-terminate/scenario.yml b/b2b/33.refer-unattended-uac-notify-terminate/scenario.yml new file mode 100644 index 0000000..f0891d4 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/scenario.yml @@ -0,0 +1,37 @@ +--- +timeout: 20 + +tasks: + - name: OpenSIPS + type: opensips + + - name: SIPP UAS + type: uas-sipp + config_file: scripts/uas.xml + require: OpenSIPS + + - name: SIPP UAC + type: uac-sipp + config_file: scripts/uac.xml + duration: 2000 # before and after transfer + username: {{ username }} + remote: {{ uas_ip }}:{{ uas_port }} + require: + started: + task: SIPP UAS + wait: 0.5 + keys: + transfer: sip:transfer@{{ transfer_ip }}:{{ transfer_port }} + + - name: SIPP Transfer + type: uas-sipp + config_file: scripts/transfer.xml + ip: {{ transfer_ip }} + port: {{ transfer_port }} + require: + - started: + task: SIPP UAC + wait: 0.5 + - after: + task: OpenSIPS + wait: 0.5 diff --git a/b2b/33.refer-unattended-uac-notify-terminate/scripts/transfer.xml b/b2b/33.refer-unattended-uac-notify-terminate/scripts/transfer.xml new file mode 100644 index 0000000..6e821b0 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/scripts/transfer.xml @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/33.refer-unattended-uac-notify-terminate/scripts/uac.xml b/b2b/33.refer-unattended-uac-notify-terminate/scripts/uac.xml new file mode 100644 index 0000000..d44f194 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/scripts/uac.xml @@ -0,0 +1,206 @@ + + + + + + + + + + + + + + ;tag=[call_number] + To: + Call-ID: [call_id] + CSeq: 1 INVITE + Contact: + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 1 ACK + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Subject: Performance Test + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 2 REFER + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Refer-To: [transfer] + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 2 BYE + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/33.refer-unattended-uac-notify-terminate/scripts/uas.xml b/b2b/33.refer-unattended-uac-notify-terminate/scripts/uas.xml new file mode 100644 index 0000000..ddd2b50 --- /dev/null +++ b/b2b/33.refer-unattended-uac-notify-terminate/scripts/uas.xml @@ -0,0 +1,181 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: [len] + + ]]> + + + + + + + + + + + + + + + diff --git a/b2b/34.refer-unattended-uas-notify-terminate/defines.yml b/b2b/34.refer-unattended-uas-notify-terminate/defines.yml new file mode 100644 index 0000000..64e1a68 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/defines.yml @@ -0,0 +1,3 @@ +--- +transfer_ip: 192.168.52.5 +transfer_port: 5065 diff --git a/b2b/34.refer-unattended-uas-notify-terminate/opensips.cfg b/b2b/34.refer-unattended-uas-notify-terminate/opensips.cfg new file mode 100644 index 0000000..050bec2 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/opensips.cfg @@ -0,0 +1,113 @@ +# +# OpenSIPS residential configuration script +# by OpenSIPS Solutions +# +# This script was generated via "make menuconfig", from +# the "Residential" scenario. +# You can enable / disable more features / functionalities by +# re-generating the scenario with different options.# +# +# Please refer to the Core CookBook at: +# https://opensips.org/Resources/DocsCookbooks +# for a explanation of possible statements, functions and parameters. +# + + +####### Global Parameters ######### +###################################################################### +/* uncomment the following lines to enable debugging */ +#debug_mode=yes + +log_level=4 +xlog_level=4 +log_stderror=yes + +udp_workers=4 + +####### Modules Section ######## + +#set module path +mpath="/usr/lib/x86_64-linux-gnu/opensips/modules/" + +#### SIGNALING module +loadmodule "signaling.so" + +#### StateLess module +loadmodule "sl.so" + +#### Transaction Module +loadmodule "tm.so" +modparam("tm", "fr_timeout", 5) +modparam("tm", "fr_inv_timeout", 30) +modparam("tm", "restart_fr_on_each_reply", 0) +modparam("tm", "onreply_avp_mode", 1) + +#### SIP MSG OPerationS module +loadmodule "sipmsgops.so" + +#### MAX ForWarD module +loadmodule "maxfwd.so" + +#### Record Route Module +loadmodule "rr.so" +/* do not append from tag to the RR (no need for this script) */ +modparam("rr", "append_fromtag", 0) + +#### B2B modules +loadmodule "b2b_entities.so" +loadmodule "b2b_logic.so" +modparam("b2b_logic", "script_req_route", "b2b_logic_request") + +loadmodule "proto_udp.so" + +####### Routing Logic ######## + +# main request routing logic + +route { + + if (!mf_process_maxfwd_header(10)) { + send_reply(483,"Too Many Hops"); + exit; + } + + if (has_totag()) { + send_reply(481, "Call/Transaction Does Not Exist"); + exit; + } + + # accept just INVITE requests + if (!is_method("INVITE")) { + send_reply(503, "Service Unavailable"); + exit; + } + + # create the server entity + b2b_server_new("caller"); + # create the initial client entity, to connect the caller with the callee + b2b_client_new("callee", $ru); + + # initialize B2B session for the "refer" scenario + b2b_init_request("refer"); + + exit; +} + +route[b2b_logic_request] { + if ($rm != "REFER") { + # for requests other than REFER, no special actions needs to be done, + # just pass the request to the peer + b2b_pass_request(); + exit; + } + + # end dialog with the referrer + b2b_send_reply(202, "Accepted"); + + # create the client entity corresponding to + # the user specified in the 'Refer-To' header + b2b_client_new("referee", $hdr(Refer-To)); + + # bridge the referrer's peer with the referee + b2b_bridge("peer", "referee", ,"notify, no-late-sdp, rollback-failed"); +} diff --git a/b2b/34.refer-unattended-uas-notify-terminate/scenario.yml b/b2b/34.refer-unattended-uas-notify-terminate/scenario.yml new file mode 100644 index 0000000..67f6c62 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/scenario.yml @@ -0,0 +1,38 @@ +--- +timeout: 20 + +tasks: + - name: OpenSIPS + type: opensips + + - name: SIPP UAS + type: uas-sipp + config_file: scripts/uas.xml + duration: 2000 # before transfer + require: OpenSIPS + keys: + transfer: sip:transfer@{{ transfer_ip }}:{{ transfer_port }} + + - name: SIPP UAC + type: uac-sipp + config_file: scripts/uac.xml + username: {{ username }} + duration: 5000 # after reINVITE/transfer + remote: {{ uas_ip }}:{{ uas_port }} + require: + started: + task: SIPP UAS + wait: 0.5 + + - name: SIPP Transfer + type: uas-sipp + config_file: scripts/transfer.xml + ip: {{ transfer_ip }} + port: {{ transfer_port }} + require: + - started: + task: SIPP UAS + wait: 0.5 + - after: + task: OpenSIPS + wait: 0.5 diff --git a/b2b/34.refer-unattended-uas-notify-terminate/scripts/transfer.xml b/b2b/34.refer-unattended-uas-notify-terminate/scripts/transfer.xml new file mode 100644 index 0000000..6e821b0 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/scripts/transfer.xml @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/b2b/34.refer-unattended-uas-notify-terminate/scripts/uac.xml b/b2b/34.refer-unattended-uas-notify-terminate/scripts/uac.xml new file mode 100644 index 0000000..96632d9 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/scripts/uac.xml @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + ;tag=[call_number] + To: + Call-ID: [call_id] + CSeq: 1 INVITE + Contact: + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ;tag=[call_number] + To: [peer_tag_param] + [routes] + CSeq: 1 ACK + Contact: + Call-ID: [call_id] + Max-Forwards: 70 + Subject: Performance Test + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + Content-Length: [len] + + ]]> + + + + + + + + + + + + + diff --git a/b2b/34.refer-unattended-uas-notify-terminate/scripts/uas.xml b/b2b/34.refer-unattended-uas-notify-terminate/scripts/uas.xml new file mode 100644 index 0000000..0999f16 --- /dev/null +++ b/b2b/34.refer-unattended-uas-notify-terminate/scripts/uas.xml @@ -0,0 +1,258 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + + ]]> + + + + + + + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + Content-Type: application/sdp + Content-Length: [len] + + v=0 + o=user1 53655765 2353687637 IN IP[local_ip_type] [local_ip] + s=- + c=IN IP[media_ip_type] [media_ip] + t=0 0 + m=audio [media_port] RTP/AVP 0 + a=rtpmap:0 PCMU/8000 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + Call-ID: [call_id] + Max-Forwards: 70 + Refer-To: [transfer] + User-Agent: sipp + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Content-Length: 0 + ]]> + + + + + + + Call-ID: [call_id] + Max-Forwards: 70 + Content-Length: 0 + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +