欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 锐评 > FreeSWITCH入门到精通系列(五):FreeSWITCH 脚本与自动化

FreeSWITCH入门到精通系列(五):FreeSWITCH 脚本与自动化

2025/10/22 12:25:13 来源:https://blog.csdn.net/hgkgjg/article/details/146495040  浏览:    关键词:FreeSWITCH入门到精通系列(五):FreeSWITCH 脚本与自动化

FreeSWITCH 脚本与自动化

FreeSWITCH 提供了多种脚本语言支持,如 Lua、JavaScript、Python、Perl 等,允许开发者自动化拨号、通话控制、事件处理等操作。本文将介绍 FreeSWITCH 支持的脚本语言如何使用 Lua 进行自动化,并提供一个完整的 自动外呼示例


1. FreeSWITCH 脚本支持

FreeSWITCH 允许使用以下脚本语言编写自动化逻辑:

语言模块适用场景
Luamod_lua轻量级应用、拨号计划控制
JavaScriptmod_v8复杂业务逻辑、事件监听
Pythonmod_python数据处理、AI 集成
Perlmod_perl兼容 Perl 生态
Javamod_java企业应用、Web 集成

其中,Lua(mod_lua) 是最常用的 FreeSWITCH 脚本语言,因其轻量级、高效、易于嵌入的特性,适用于各种自动化需求。


2. Lua 脚本基础

2.1 启用 mod_lua

FreeSWITCH 默认支持 Lua,确保已加载 mod_lua

fs_cli -x "load mod_lua"

如果未加载,可以在 /etc/freeswitch/autoload_configs/modules.conf.xml 中添加:

<load module="mod_lua"/>

然后重启 FreeSWITCH:

systemctl restart freeswitch

2.2 在拨号计划中调用 Lua

FreeSWITCH 拨号计划 (dialplan) 可以直接调用 Lua 脚本:

<extension name="TestLua"><condition field="destination_number" expression="^9001$"><action application="lua" data="hello.lua"/></condition>
</extension>

当用户拨打 9001 时,FreeSWITCH 将执行 hello.lua

2.3 编写 Hello World 脚本

/usr/local/freeswitch/scripts/ 目录下创建 hello.lua

session:answer()
session:sleep(1000)
session:execute("playback", "ivr/ivr-welcome.wav")
session:hangup()

此脚本:

  1. 接听来电
  2. 播放欢迎语音
  3. 挂断通话

3. FreeSWITCH 事件监听

FreeSWITCH 提供 事件系统 (Event Socket Layer, ESL),可以用 Lua 监听并处理事件,例如来电、挂机等。

3.1 监听 FreeSWITCH 事件

创建 event_listener.lua

freeswitch.consoleLog("NOTICE", "Lua Event Listener Started\n")local event = freeswitch.EventConsumer("CHANNEL_CREATE")while true dolocal e = event:pop()if e thenfreeswitch.consoleLog("INFO", "New Call: " .. e:getHeader("Caller-Caller-ID-Number") .. "\n")end
end

运行:

fs_cli -x "luarun event_listener.lua"

这段代码会监听 CHANNEL_CREATE 事件,每当有新通话进入,就打印出主叫号码。


4. 事件驱动的自动外呼 (Auto Dialer)

4.1 自动外呼 Lua 脚本

创建 auto_dial.lua

-- 定义外呼目标
local destination = "1001"
local gateway = "sofia/gateway/mygateway/"-- 构造拨号字符串
local dial_string = gateway .. destination-- 启动会话
session = freeswitch.Session(dial_string)-- 检查是否接通
if session:ready() thensession:execute("playback", "ivr/ivr-welcome.wav")session:sleep(2000)session:hangup()
end

运行:

fs_cli -x "luarun auto_dial.lua"

此脚本会:

  1. 自动拨打 1001
  2. 播放欢迎语音
  3. 挂断电话

4.2 定时批量外呼

可以结合 cron 定时执行:

crontab -e

添加:

0 9 * * * /usr/bin/fs_cli -x "luarun auto_dial.lua"

此任务每天早上 9 点自动外呼。


5. Python 集成 FreeSWITCH

FreeSWITCH 也支持 mod_python,可以用 Python 进行事件监听和自动化任务。

5.1 确保 mod_python 已加载

fs_cli -x "load mod_python"

5.2 编写 Python 监听脚本

创建 event_listener.py

import ESLdef event_handler():con = ESL.ESLconnection("localhost", "8021", "ClueCon")if con.connected():con.events("plain", "CHANNEL_CREATE")while True:e = con.recvEvent()if e:print("New Call from:", e.getHeader("Caller-Caller-ID-Number"))event_handler()

运行:

python3 event_listener.py

该脚本监听 CHANNEL_CREATE 事件,并打印主叫号码。


6. 结合 Fail2Ban 进行安全自动化

FreeSWITCH 可以结合 fail2ban 进行安全自动化,检测异常登录并封禁 IP。

6.1 配置 Fail2Ban

编辑 /etc/fail2ban/jail.local

[freeswitch]
enabled = true
port = 5060,5061
filter = freeswitch
logpath = /var/log/freeswitch/freeswitch.log
maxretry = 3
bantime = 3600

6.2 编写 Fail2Ban 过滤器

创建 /etc/fail2ban/filter.d/freeswitch.conf

[Definition]
failregex = .*sofia_reg_parse_auth.*invalid password.*from ip <HOST>
ignoreregex =

重启 fail2ban

systemctl restart fail2ban

这将自动封禁连续 3 次密码错误的 IP 地址。


7. 总结

  • FreeSWITCH 支持 Lua、Python、JavaScript 等脚本语言,可以进行通话控制、事件监听和自动化任务。
  • Lua 是最常用的脚本语言,可直接在拨号计划 (dialplan) 中执行。
  • 事件监听 允许 FreeSWITCH 监控通话状态,结合 Python 可实现 实时监控
  • 自动外呼 让 FreeSWITCH 能够主动发起通话,结合 cron 可定时拨号。
  • 结合 Fail2Ban 提高系统安全性,自动封禁异常 IP。

掌握 FreeSWITCH 脚本能力,你可以轻松实现 IVR 交互、自动外呼、通话录制、智能路由等功能 🚀

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词