FreeSwitch ESL——Event Object,Connect Object(事件套接字的事件对象及连接对象)

2024-05-11 13:08

本文主要是介绍FreeSwitch ESL——Event Object,Connect Object(事件套接字的事件对象及连接对象),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Event Object

 

new

语法:

new($event_type [, $event_subclass])

作用:实例化一个新的事件对象,以便于使用以下的方法。

 

serialize

语法:

serialize([$format])

作用:将事件转化为冒号分割形如”name:value”的键对。$format的值可以为:

1.      “xml“

2.      “json”

3.      “plain”(default)

 

setPriority

语法:

setPriority([$number])

作用:设置事件的优先级

 

getHeader

语法:

getHeader($header_name)

作用:根据一个事件对象中的$header_name来获取头部值

 

getBody

语法:

getBody()

作用:获得事件对象的正文

 

getType

语法:

getType()

作用:获得事件对象的类型

 

addBody

语法:

addBody($value)

 

作用:将$value添加到事件对象的正文中。该对象可能在同一个事件对象中被多次调用

 

addHeader

语法:

addHeader($header_name, $value)

作用:向事件对象中添加一对值到头域中。该对象可能在同一个事件对象中被多次调用

 

delHeader

语法:

delHeader($header_name)

作用:在事件对象中删除名字叫$header_name的头域

 

firstHeader

语法:

firstHeader()

作用:将指针设置为指向事件对象的一个头域,并且返回第一个头域的键值。该函数必须在nextHeader对象调用前调用

 

nextHeader

语法:

nextHeader()

作用:将指针指向事件对象的下一个头域,并返回它的键值。调用它之前必须先调用firstHeader来设置指针!若当前位置已经是头域的最后一个节点,则调用该函数后将指向NULL

 

 

Connection Object

new

语法1:

new($host, $port, $password)

语法2:

new($fd)

作用:根据一个已存在的套接字句柄初始化一个ESL连接对象实例。

仅在Outbound(FreeSwitch作为客户端)模式下有效。即使在inbound模式下传递一个有效的套接字句柄也是无效的。

作用:初始化一个ESL连接对象实例。后面三个参数分别为主机名、端口号、密码。

 

该函数仅在inbound模式(FreeSwitch作为服务端)下有效。换而言之,该函数的目的是创建一个连接至FreeSWITCH的对象,并且它并未绑定到任何的呼叫或者信道上。

它并没有初始化通道信息(因为inbound连接并未绑定到任一个信道上)。简单来说,如果调用getInfo()函数永远返回NULL。

 

socketDescriptor

语法:

socketDescriptor()

作用:如果连接对象已连接,则返回该连接对象的UNIX文件描述句柄(FD)。

 

connected

语法:

connected()

作用:测试连接对象是否已连接。已连接则返回1,否则返回0

 

getInfo

语法:

getInfo()

作用:当FreeSwitch在outbound模式下连接时,它将在初始化阶段首先发送”CHANNEL_DATE”事件。该函数将返回跟该对象相关的信道信息。

当FreeSwitch在inbound模式下,将返回NULL

 

send

语法:

send($command)

作用:发送一个命令至FreeSwitch

它不会等待一个应答,而需要调用recvEvent或者recvEventTimed来循环等待接受事件。该应答将包含一个叫“content-type”的头域,该头域包含”api/response”或者“command/reply”的值。

为了自动等待应答事件,可以使用sendRecv()代替。

 

sendRecv

语法:

sendRecv($command)

作用:sendRecv($command)在调用的时候,会先调用send($command),然后在调用recvEvent(),然后返回一个ESL事件的实例。

recvEvent()会在一个循环中调用并一直阻塞知道收到一个头域包含”api/response”或者“command/reply”的值,然后再返回ESL事件对象实例。

在此期间收到的所有事件将保存到一个内部队列中,这些事件可以在后续的recvEvent()中取到。

 

api

语法:

api($command[, $arguments])

作用:向FreeSWITCH服务器发送一个API命令,这个命令将处于阻塞状态直到命令执行结束。

api($command,$args)等效于sendRecv(“api$command $args)

 

bgapi

语法:

bgapi($command[, $arguments][,$custom_job_uuid])

作用:向FreeSWITCH服务器发送一个后台API命令,该命令将在它自己的线程中执行。

bgapi($command,$args)等效于sendRecv(“bgapi$command $args)。

 

sendEvent

语法:

sendEvent($send_me)

作用:向FreeSwitch发送一个事件。

 

recvEvent

语法:

recvEvent()

作用:向FreeSwitch返回一个接收到的事件。如果接收到事件,该函数在处于阻塞状态,知道新事件来临。

如果在呼叫期间sendRecv()队列中有事件,那么队列中的第一个事件将被返回,并从队列中删除。换句话说,在连接中事件可以被读取。

 

recvEventTimed

语法:

recvEventTimed($milliseconds)

作用:类似于recvEvent(),但是它会阻塞$milliseconds毫秒.

如果将参数设置为0那么它将会立即返回,这个特性在轮询中特别有用。

 

filter

语法:

filter($header, $value)

作用:用于安装一个过滤器。该过滤器是对输入过滤,而不是对输出过滤。即符合条件的才能进入系统。

 

events

语法:

events($event_type,$value)

作用:$event_type的值可以为”plain“或者”xml”,其他任何输入都将被解释为”plain”

如果要调用myevents(event的一个特殊情况,用于outbound模式中)必须使用sendRecv(“myevents”)来调用,千万用events来调用。

 

execute

语法:

execute($app[, $arg][, $uuid])

作用:执行一个拨号计划的应用,并且等到从服务器发送过来的应答。套接字的连接不是固定在一个信道上(大部分情况下为inbound模式),三个参数都是必要的,其中uuid指明了为app指明了信道信息。

该函数将返回一个包含应答的ESL事件对象。通过getHeader(‘Reply-Text”)可以取出应答值。如果应答值为”+OK[Success Message]则表示成功,“-ERR [Error Message]表示失败。

可以通过以下的例子看看当调用excuse()命令后如何获取uuid。

 

在inbound模式下,可以根据以下命令获得一个新的uuid

$uuid = $esl->api("create_uuid")->getBody();

在outbound模式下,可以根据以下命令获得

$uuid = $esl->getInfo()->getHeader("unique-id")

 

 

executeAsync

语法:

executeAsync($app[, $arg][, $uuid])

作用:和execute一样,但是它在等待服务器应答的时候不会阻塞。其实这个函数本质上也是调用了execute()函数,只不过增加了”async:true”的头而已。

 

setAsyncExecute

语法:

setAsyncExecute($value)

作用:强制将套接字连接设置为异步模式。该命令在outbound模式下不起作用。

$value为1表示强制开启异步模式,0为同步模式。

特别要注意的是,调用setAsysncExecute(1)的本质就是调用带“asysnc:true”头的execute()函数。其他套接字路由不受此设置的影响。

 

setEventLock

语法:

setEventLock($value)

作用:强制让套接字连接打开同步模式。这个命令在outbound模式不起作用,因为在dialplan中没有将它设置为异步模式,因为这些连接已经处于同步模式了。

$value为1表示打开同步模式,0表示不强制打开。

要注意的是,调用setEventLock(1)的操作等价于调用带”event-lock:true”头的execute()函数。其他的事件套接字路由不受此设置的影响。

 

disconnect

语法:

disconnect()

作用:关闭连接

 

freeSwitch1.4版本(2014-02-16后的master版本)的C语言调用示例如下

 

int main(void)
{char *private_data = "some private string or struct ...";esl_global_set_default_logger(7);esl_listen_threaded("localhost", 8040, mycallback, private_data, 100000);return 0;}

Event Socket Command翻译出处:http://wiki.freeswitch.org/wiki/Event_Socket

其他翻译出处:https://freeswitch.org/confluence/display/FREESWITCH/Event+Socket+Library

这篇关于FreeSwitch ESL——Event Object,Connect Object(事件套接字的事件对象及连接对象)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979616

相关文章

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数