FreeSWITCH版本:1.10.9

操作系统:CentOS 7.6.1810

originate经常用于发起呼叫,在实际工作过程中用到的也比较多,今天总结下基本用法,也方便我以后查阅。

一、wiki及源码介绍

该命令在FreeSWITCH官方wiki也有介绍,这里列下wiki地址。

wiki首页:https://developer.signalwire.com/freeswitch/FreeSWITCH-Explained/

originate相关wiki地址:

https://developer.signalwire.com/freeswitch/FreeSWITCH-Explained/Dialplan/Freeswitch-IVR-Originate_9634753/#docusaurus_skipToContent_fallback

https://developer.signalwire.com/freeswitch/FreeSWITCH-Explained/Examples/Originate-Example_10682745/#docusaurus_skipToContent_fallback

源码文件:mod_commands.c

对应函数:originate_function

二、命令格式及解释

命令使用的基础模板:

originate ALEG BLEG

在fs_cli控制台使用的完整语法如下:

originate <call url> <exten>|&<application_name>(<app_args>) [<dialplan>][&lt;context>] [<cid_name>][&lt;cid_num>] [<timeout_sec>]

其中,

originate 为命令关键字,为必选字段,用于定义ALEG的呼叫信息,也就是通常说的呼叫字符串,可以通过通道变量定义很多参数;

|&<application_name>(<app_args>)  为必选字段,用于指定BLEG的分机号码或者用于创建BLEG的app(比如echo、bridge等);

[][<context>]  可选参数,该参数用于指定dialplan的context,默认值:xml default ;

[<timeout_sec>] 可选参数,该参数用于指定originate超时,默认值:60 ;

示例呼叫:

originate user/1000 9196 xml default 'mike' 18612345678 

呼叫效果如下:

三、常见使用方式

1、基础使用

  • echo呼叫

示例如下:

originate user/1000 &echo

先呼叫1000分机,1000分机接听后,将1000分机所在的channel桥接到echo应用(将话筒传入的声音播放到听筒),以下命令具备同样效果:

originate user/1000 9196
  • 分机互相拨打

示例如下:

originate user/1000 1001

先呼叫1000分机,1000分机接听后,再呼叫1001分机,1001分机接听后,将1000分机所在的channel桥接1001的channel,通话建立。

  • bridge到其它终端

这里以分机为例进行演示,具体如下:

originate user/1000 &bridge(user/1001)

和分机互相拨打类似。

  • 分机共振

使用逗号语法关键字,示例如下:

originate user/1000,user/1001 9196

1000分机和1001分机同时响铃,任意一个分机接听后,另外一个分机自动挂机。

  • 分机轮询

使用 | 语法实现,这里需要注意下,有呼叫默认超时时间的设置,示例如下:

originate {originate_timeout=30}[leg_timeout=10]user/1000|[leg_timeout=10]user/1001 9196

1000分机先振铃,10秒超时后呼叫1001分机。

  • 呼叫外线

通过external进行外线呼叫,示例如下:

originate  {origination_caller_id_number=00000000,origination_caller_id_name=000000000}sofia/external/18612345678@192.168.1.100:5060 &echo
  • 播放音频给分机

使用playback命令进行声音播放:

originate user/1000 &playback(/tmp/test1.wav)

播放moh音频:

originate user/1000 &playback(local_stream://moh)

无限循环播放:

originate user/1000 &endless_playback(/tmp/test1.wav)

使用file_string进行多个文件依次顺序播放:

originate user/1000 &playback(file_string:///tmp/test1.wav!/tmp/test2.wav)

2、通道变量的使用

originate字符串里面可以设置很多通道变量来定义呼叫参数,基本使用格式示例如下:

originate {var1=$value1,var2=$value2}/user/1000 9196
originate {var1=$value1}[var2=$value2]/user/1000 9196

其中,大括号用于定义呼叫的通道变量,中括号用来定义某条leg的局部通道变量。

这里列举下常见的通道变量。

  • origination_uuid

发起呼叫时,用于定义leg的uuid,示例如下:

1)在呼叫时,指定A腿的uuid

originate {origination_uuid=xxxxx}user/1000 1001

2)在呼叫时,同时指定A腿和B腿的uuid

originate {origination_uuid=xxxxx}user/1000 &bridge({origination_uuid=yyyyy}user/1001)
  • origination_caller_id_name / origination_caller_id_number

用于设置主叫名称及号码,示例如下:

originate {origination_caller_id_name="mike",origination_caller_id_number=18612345678}user/1000 9196

会在话机及sip协议中体现,具体如下:

  • ignore_early_media

该参数适用于A leg,定义是否忽略B leg的early media。

  • originate_timeout

用于定义originate/bridge过程中的呼叫时长,超过该时间后就呼叫超时。

示例参考分机轮询部分。

  • leg_timeout

用于定义originate/bridge过程中某条leg的呼叫时长,超过该时间后就呼叫超时。

示例参考分机轮询部分。

  • absolute_codec_string

用于指定语音编码,示例如下:

originate {absolute_codec_string=‘^^:PCMA:PCMU’}user/1000 &playback(local_stream://moh)

其中,"^^"为转义符,后面跟冒号表示用冒号替代逗号。

  • 自定义通道变量

在originate字符串中可以自定义通道变量,示例如下:

originate {var123="test123"}user/1000 9196

效果如下:

通道变量名称会自动添加 variable_ 前缀,具体来说就是 variable_var123

  • 更多通道变量

具体参考switch_ivr_originate函数(switch_ivr_originate.c文件)

3、添加自定义sip头

在originate字符串中,可以自定义sip头,通过添加 sip_h_X 前缀来试下,示例如下:

originate {sip_h_X-varTest='123456'}user/1000 &playback(local_stream://moh)

会在sip协议中添加自定义的header,具体效果如下:

4、特殊呼叫

  • loopback呼叫

1)拨号方案自带的loopback

示例呼叫:

originate user/1000 &bridge(loopback/wait)

具体定义如下:

2)自定义loopback

dialplan添加如下内容:

<extension name="loopback_test">
<condition field="destination_number" expression="^loopTest1$">
<action application="answer"/>
<action application="playback" data="local_stream://moh"/>
</condition>
</extension>

呼叫测试:

originate user/1000 &bridge(loopback/loopTest1)
  • null呼叫

呼叫示例:

originate null/1000 &echo

具体效果:

也可以和bridge一起使用:

originate user/1000 &bridge(null/1234)

具体效果:

  • 其它endpoint呼叫

这里以rtc为例,演示其它endpoint呼叫:

bgapi originate {origination_uuid=111222}rtc/test &echo

具体效果如下:

  • 指定sip使用tcp协议呼叫

需要使用 transport=tcp 来指定协议,示例如下:

originate {origination_caller_id_name=1111}user/1000;transport=tcp  &playback(local_stream://moh)

效果如下:

四、资源下载

本文涉及freeswitch源码及使用的测试软电话可从如下渠道获取:

https://pan.baidu.com/s/16-H-ITuXAcPYRsZpa3At-g

关注微信公众号(聊聊博文,文末可扫码)后回复 2023040201 获取。

FreeSWITCH的originate命令解析及示例的更多相关文章

  1. Appium Android Bootstrap源码分析之命令解析执行

    通过上一篇文章<Appium Android Bootstrap源码分析之控件AndroidElement>我们知道了Appium从pc端发送过来的命令如果是控件相关的话,最终目标控件在b ...

  2. (转)Linux命令:使用dig,nslookup命令解析域名

    Linux命令:使用dig命令解析域名 Linux下解析域名除了使用nslookup之外,开可以使用dig命令来解析域名,dig命令可以得到更多的域名信息. dig的全称是 (domain infor ...

  3. angular-cli.json配置参数解析,常用命令解析

    1.angular-cli.json配置参数解析 { "project": { "name": "ng-admin", //项目名称 &qu ...

  4. 邵国际: C 语言对象化设计实例 —— 命令解析器

    本文系转载,著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 作者: 邵国际 来源: 微信公众号linux阅码场(id: linuxdev) 内容简介 单片机工程师常常疑惑为什么 ...

  5. 【转帖】Linux上,最常用的一批命令解析(10年精选)

    Linux上,最常用的一批命令解析(10年精选) https://juejin.im/post/5d134fbfe51d4510727c80d1 写的挺好呢 Linux这么多命令,通常会让初学者望而生 ...

  6. linux mknod命令解析

    linux mknod命令解析 http://www.cnblogs.com/cobbliu/archive/2011/07/05/2389014.html mknod:make node  生成设备 ...

  7. C#基础:命令解析

    1.普通格式命令的解析 例如: RENA<SP>E:\\A.txt<SP>C:\\B.txt<CRLF> (SP -> 空格,CRLF -> 回车加换行 ...

  8. virsh的详细命令解析(一)

    virsh的详细命令解析 virsh 有命令模式和交互模式如果直接在vrish后面添加参数是命令模式,如果直接写virsh,就会进入交互模式 virsh list 列出所有的虚拟机,虚拟机的状态有(8 ...

  9. 【Linux】一步一步学Linux——初识Linux命令解析器(10)

    目录 00. 目录 01. Shell简介 02. Shell分类 03. 交互式shell和非交互式shell 04. 登录shell和非登录shell 05. Shell类型 06. 参考 00. ...

  10. BGP(IBGP“内部路由器”和EBGP“外部路由器”)命令解析

    BGP:基于策略的路径向量路由协议. ①:(attribute)属性描述路径. ②:使用TCP(端口179)作为传输协议——(IBGP多使用loopback端口建立update-source) IBG ...

随机推荐

  1. mysql零基础-2

    更新中的数据完整性错误 UPDATE employees SET department_id = 55 WHERE department_id = 110; 删除数据 删除一条记录 DELETE FR ...

  2. mysql的隔离级别以及存储引擎

    一.隔离级别 1.可序列化:(SERIALIZABLE):如果隔离级别为序列化,则用户之间通过一个接一个顺序地执行当前的事务,这种隔离级别提供了事务之间最大限度的隔离. 2.可重复读(REPEATAB ...

  3. 获取gps

    package com.example.myapplication;import android.Manifest;import android.annotation.SuppressLint;imp ...

  4. iOS Unity 项目解析

    本文旨在记录Unity 导出的iOS 项目笔记,另带接入SDK的终极方案,顺带对比Android 项目 1蓝色的目录 Data 这个就是项目的数据,每个项目不一样也就是这个目录不一样,是不是可以把这个 ...

  5. 记录一次使用locust压测的过程

    1 脚本# encoding: utf-# @Time : 2021/6/21 1:28 下午 # @Author : Sail # @File : main.py # @Software: PyCh ...

  6. Java中的方法增强

    A:在不影响业务情况下,增强一个方法有几种方法呢? B:3种! A:哪三种呀? 一.继承类来重写方法: 1.要可以获取这个类的构造: class Man{ public void run(){ Sys ...

  7. centos 通过yum安装docker-ce报错

    通过yum安装docker-ce报错,是因为本机安装过多次造成的,如下所示,需要解决掉冲突依赖,从新安装 1 从 https://mirrors.aliyun.com/docker-ce/linux/ ...

  8. Jenkins搭建项目过程中遇到的问题解决方法

    1.运行时,报没有权限 报错: rm -rf '/root/jar/*' rm: cannot remove '/root/jar/*': Permission denied 解决方法: 将Jenki ...

  9. 网站下/.git/index查看

    遇见有些网站目录中存在 http://target.com/.git/index 由于index是二进制文件 下载回来本地查看 初始化 下载到.git目录 git checkout-index -a

  10. Java--接口和抽象类有什么区别

    他们都不能实例化对象,都可以包含抽象方法,而且抽象方法必须被继承的类全部实现. 区别: 1.抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实 ...