XSwitch用户手册
xtra_config 参数详解
xTra 是 XSwitch XUI 的底层 REST 框架,使用 Lua 语言开发,我们未来将开源核心的框架,也会开放相关的框架文档。在此,我们仅讨论xtra_config.lua
配置文件中的参数。
xtra_config.lua
是一个标准的 Lua 文件,导出一个config
Table,是 xTra 框架的全局配置。修改配置文件会立即生效。基本配置格式为:
local config = {} config.key = "value" return config
xtra_config.lua
配置文件的搜索顺序优先级如下:
/etc/xtra/
vendor
的上一层目录vendor
目录
其中,vendor
是 xTra 框架的目录,一般建议放到vendor
的上层目录。目前,vendor
在 XUI 代码内容,XUI 代码安装位置默认位于 FreeSWITCH 安装目录下,如/usr/local/freeswitch/xui
。如果你拿到的是 XSwitch 发行版的 Docker,xtra_config.lua
一般位于宿主机上,以便在 Docker 容器停止后修改过的内容不失效。可以将该文件挂载到 Docker 容器内上述任意目录。
配置文件中有些参数已没有实际使用,但由于历史原因而存在。有些参数的值也不能改动。总的原则是,如果你不知道参数的细节,就保持原来的默认值。
下面是该配置文件的默认值及解释,先参数,后解释。在 Lua 中,--
代表注释。
-- config.file = debug.getinfo(1).source
该参数是只读的,用于记录xtra_config.lua
文件的实际路径,方便调试。如在同时有多个文件的情况下,可以打印出该路径以判断哪个是实际生效的。该参数在使用luac
编译后的 Lua 中不能正确获取文件路径,可以使用指定的字符串,如:
config.file = '/etc/xtra.lua'
该参数对 XUI 实际运行无影响。
config.dsn = os.getenv("DSN")
配置数据库连接字符串。XUI 早期的版本支持 SQLite,新的版本已不支持,上述配置中从环境变量中获取连接参数,因而你可以使用在.env
中指定的环境变量。
该参数取值如下,推荐使用最后一种:
-- SQLite连接字符串 config.dsn = "sqlite://xui" -- ODBC连接,需要配置odbc.ini config.dsn = "odbc://xui:xui:xui" -- 原始PostgreSQL连接字符串 config.dsn = "pgsql://host=xswitch-pg dbname=xui user=xui password='xui' " -- 现代PostgreSQL连接字符串,需要PostgreSQL 9以上版才支持 -- config.dsn = "pgsql://postgresql://用户名:密码@主机名/数据库名" config.dsn = "pgsql://postgresql://xui:xui@xswitch-pg/xui"
-- config.check_permissions = true
无效。
config.redis_host = "xswitch-redis" config.redis_port = 6379 -- config.redis_pass = nil
Redis 连接参数。XSwitch 支持连接 Redis,可以用作用户登录鉴权的 Session 存储,也可以支持 XSwitch 内部的并发控制等。
config.db_auto_connect = true
是否自动连接数据库,必须为true
。
config.auto_record = false
是否自动录音。目前仅对cti
有效。
config.auto_log = false
是否自动写日志。如果打开,所有的增、删、改等 REST 操作将会写到数据库中,可以在 XUI 上的日志菜单中查看。
config.base_dir = "/usr/local/freeswitch"
FreeSWITCH 安装目录。
config.sounds_dir = config.base_dir .. "/sounds"
系统声音文件目录(只读)。
config.storage_dir = config.base_dir .. "/storage"
系统存储目录。该目录中存储可变的内容,如通话过程中产生的录音等。该目录应该是可写的,在 Docker 容器中应该挂载宿主机上的目录以支持持久化存储。
config.recording_path = config.base_dir .. "/storage/recordings"
录音存储路径。
config.fiforecord_path = config.base_dir .. "/recordings"
mod_fifo
录音存储路径。
config.upload_path = config.base_dir .. "/storage/upload"
上传媒体文件存储路径。
config.upload_script_path = config.base_dir .. "/storage/upload/scripts"
上传脚本路径
config.block_path = config.base_dir .. "/storage/blocks"
积木脚本存储路径。
config.xui_path = config.base_dir .. "/xui"
XUI 后台脚本存储路径。
config.fonts_path = config.base_dir .. "/fonts"
XUI 字体存储路径。
config.audio_extension = "wav"
录音文件默认扩展名。可以是wav
或mp3
。
config.video_extension = "mp4"
录像文件默认扩展名。目前仅支持mp4
。
config.ivr_greeting = "ivr/ivr-generic_greeting.wav" config.ivr_invalid = "ivr/ivr-that_was_an_invalid_entry.wav"
IVR 相关语音。
config.audio_codec = "G722,PCMU,PCMA,GSM,G729,iLBC" config.video_codec = "VP8,H264,G722,PCMU,PCMA,GSM,G729,iLBC"
外呼是使用的默认的音视频编码,目前仅针对会议自动外呼有效。
config.openvpn_path = "/root/keys"
OpenVPN 相关配置。
config.switch_domain = "xswitch.cn"
外呼时使用的域。目前仅对会议有效。
config.switch_port = "8000"
外呼时使用的端口号。目前仅对会议有效。
config.abnormal_instant_conference_timeout = "120"
会议相关。
config.auth = "hash" -- or true | file | hash | redis
HTTP 认证鉴权 Session 的存储方式。
hash
:存在 FreeSWITCH 内部哈希表中,重启后浏览器端所有用户都需要重新登录。true
:跟hash
一致。file
:存储到文件中,可以持久化,FreeSWITCH 重启后无需重新登录。redis
:存储到 Redis 中,比file
更高效,而且可以多台 FreeSWITCH 共享。
config.session_path = "/tmp"
如果开启file
Session 存储,设置 Session 文件的路径。
config.force_domain = 'xswitch.cn'
强制用户的域都是该值。FreeSWITCH 是一个多租户系统,但是在小型应用中使用起来会很复杂。开启该选项后所有用户都属于同一个域。
config.record_answer = true
应答后录音,如果设置为否,录音时则从振铃开始就录音
-- config.password_use_a1_hash = true -- config.password_use_sha1_hash = true
是否开启 A1 哈希加密支持。如果不开启则密码是明文的。A1 哈希跟域有关,如果开启后,以后改变域时必须让所有用户修改密码。
config.view_path = config.base_dir .. "/xui/lua/xui/view"
xTra 是一个 MVC 框架,该选项配置 View 的路径。XUI 是前后端分离的,前后端数据交互使用 JSON 格式,不使用 View。
config.leg_timeout = "50"
呼叫超时设置,目前仅针对呼叫本地分机及本地分机中无应答转接时的超时时长
-- config.prefix_table = "gw"
Todo.
-- config.httpFifoNotificationURL="http://localhost:9999"
特殊应用。在呼叫中心应用中,用于简单的来电弹屏通知。
config.tz = 8
时区,东八区为北京时间。
-- config.cross_domain="http://192.168.3.119:8081" -- config.cross_domain="*"
配置 HTTP 跨域支持(CORS),*
代表接受所有来源(Referer)。
-- config.conferenceForceMatchCID = true
会议安全选项,呼叫会议的主叫号码必须匹配到一个预置的成员才能呼入,详细见会议相关文档。
config.wechat_base_url = "http://example.com" config.wechat_realm = "xyt" config.template_id = "Mu6mySnQiCRdCa5QmJSCBOSIkAxjgm3CuUpp6FqTCnA" -- config.wechat.enable_login = true --微信登录 -- config.wechat.proxy="https://cloud.xswitch.cn/api" -- config.wechat.cloud = {APPID = 'wxxxxx', APPSEC = 'dxxxxxxxx'} -- config.wechat = {} -- config.wechat.xyt = {APPID = 'wx', APPSEC = ''} -- config.ticket_type_wechat_default = 'TICKET_TYPE_0' -- default ticket type from wechat
微信公众号集成,支持简单的工单集成。
config.allow_change_ip = false
是否允许在界面上修改 IP 地址。在 Docker 中不允许。
-- config.qywechat = {} -- config.qywechat.CorpID = '' -- config.qywechat.CorpSecret = '' -- config.qywechat.AgentID = 10001 -- config.xui_url = "https://xswitch.cn" -- config.qywechat_webhookkey = 'f588ba02xxxxxxxxx'
企业微信集成。
-- config.callcenter_bridge_failed_to_break = true
Callcenter 相关设置。
-- config.conference_use_pin = true
会议是否使用密码。
config.upload_max_size = os.getenv("UPLAOD_MAX_SIZE") or "100M"
最大上传文件大小。
config.node_subject_prefix = os.getenv("NODE_SUBJECT_PREFIX") or "cn.xswitch.node"
通过配合mod_xcc
模块使用,默认订阅前缀
config.callcenter = { record_path = config.base_dir .. "/storage/recordings/${strftime(%Y-%m)}", -- track_on = true, -- track_hangup_unavail_agent = true, -- fire_agent_state = true, -- support_acw = true, -- record_template = "$${base_dir}/storage/recordings/${strftime(%Y%m%d)}/cc-${strftime(%H%M%S)}-${create_uuid()}.mp3", -- ticket = true, -- record_type = "mp4" }
record_path
:Callcenter录音存储路径。track_on
:签入Callcenter队列的空闲或示忙状态下坐席外呼时,XSwitch不再向其分配新呼叫。默认关闭。track_hangup_unavail_agent
:不允许非签入状态下的坐席发起外呼,与config.callcenter.track_on = true
同时使用才生效。默认关闭。fire_agent_state
:当坐席状态发生改变时,产生Event-Name
为CUSTOM
,Event-Subclass
为agent_state
的ESL事件。默认关闭。support_acw
:Callcenter坐席开启acw话后处理功能。修改配置完成后,需将目标坐席重新签入、签出一次。默认关闭。record_template
:签入Callcenter坐席发起外呼时自动录音,与config.callcenter.track_on = true
同时使用才生效。默认关闭。ticket
:进入Callcenter的呼叫信息存入工单表内。默认关闭。record_type
:Callcenter录制文件类型。默认关闭(关闭状态下默认文件类型为mp3)。
-- config.enable_stereo = true
是否为立体声录音,默认为单声道
-- config.record_file_replace_prefix = "http://yd.xswitch.cn" -- url or directory
录音文件前缀,暂时不启用
config.custom_about = "xyt" -- config.xui_website = "https://xswitch.cn"
是否显示关于页面中的系统版本等信息,如果不显示则随意修改为其他值即可
-- config.cluster = true -- Kamailio <-> FS cluster -- config.cluster_ik_gateway = "internal_kamailio" -- the gateway name to internal Kamailio -- config.cluster_gk_gateway = "gateway_kamailio" -- the gateway name to gateway Kamailio -- token to send http rpc request to kamailio -- config.with_kamailio = true -- config.kamailio_servers = os.getenv("KAMAILIO_LIST") -- config.kamailio_servers = 'gw-kam:9060' --config.kam_http_token = 'Bearer ' .. os.getenv("KAM_HTTP_TOKEN")
集群相关设置,与 Kamailio 配合部署。
config.forget_password = true
是否允许自助找回密码。
config.free_register = true
是否允许自动注册。
config.register_audit = true
注册是否需要审核。
config.callback_gateway = "callback"
回呼是使用的网关。
config.codec_list = "PCMA,PCMU,G729,G722,OPUS,VP8" -- config.codec_list = os.getenv("GW_CODECS") or "PCMU,PCMA,G729,G722,OPUS,VP8,H264"
默认的编解码列表。
-- config.tts_engine = "tts_baidu" -- config.tts_voice = 'ting-ting'
TTS 相关设置,默认 TTS 引擎。
-- config.with_opensips = true
与 OpenSIPS 配合使用。
-- config.force_jwt = true
接口开启 JWT Token。如果开启,则会强制生成 JWT Token。
config.jwt_secret = 'secret'
JWT token 的密钥。
config.jwt_algorithm = 'HS256'
JWT token 的算法。
config.jwt_expire = 3600
JWT token 的有效时长,单位是秒。
config.refresh_token_expire = 24 * 3600
JWT token 的刷新时长,单位是秒。
config.session_expires = 3600 * 24
XUI Web Cookie 有效的最长空闲时间(即两次请求的间隔时长)或 Rest API 接口 Token 的有效时长,单位是秒。
config.check_contacts = true
呼入时是否检测通讯录,如果设置为 true,那么呼入号码会去通讯录中检查是否存在该用户,如果存在,则修改为通讯录中的名称显示
-- config.callback_onbusy = true
遇忙回呼
config.with_nginx = false
和媒体文件录音文件播放有关,如果与 Nginx 配合使用,可设置为true
。该参数主要是启用 Nginx 的sendfile支持。
config.dtmf_cdr = false
是否在话单中显示 DTMF 按键结果,默认不显示。
-- config.uas_url = "ws://127.0.0.1:9090/stream"
连接 UAS 的 Websocket 地址,该参数仅针对特殊的会议集群使用。
config.idle_timeout = false
是否在超出一定时间后自动退出登陆
config.short_nbr = false
是否开启会议中短号功能,默认不开启。改为 true 后,则在创建预约会议时则会显示短号功能。
config.provision = false
是否开启话机自动配置,默认不开启。改为 true 后,则可使用话机自动配置功能。
config.captcha_png_path = "/tmp"
图形验证码存储位置
config.captcha = false
登录页面是否启用图形验证码,默认不开启,设置为 true 后,登录页面失败两次则会出现图形验证码页面。
-- config.captcha_fail_limit = 2
开启图形验证码后,根据此参数设置的次数决定登录页面何时出现图形验证码,比如默认登录失败 2 次才显示图形验证码。
config.secure_password = true
是否开启用户强密码功能,默认开启,设置为 false 后,用户则会关闭强密码验证。
-- config.disabled_modules = {"xcc","avcodec","avformat"}
忽略指定模块配置动态化,即,使用原始的XML配置文件。
config.secure_extn_password = true
是否开启分机强密码功能,默认开启,设置为 false 后,分机则会关闭强密码验证。
-- config.media_file_types = "wav,mp3,mp4"
该参数限制系统媒体页面上传文件类型,如果开启了,则只有设置的这几种类型文件才可以上传
config.login_with_rsa = false
系统登录是否启用 rsa
-- config.allow_websocket_login_without_extension = true
支持不使用分机也可以websocket登录
-- config.tts_codec = UTF-8
tts编码格式
config.tencent = {} config.tencent.xyt = {SignName = '小樱桃网络科技', SmsSdkAppId = '140xxxx', TemplateId = '191xxx', Region = 'ap-guangzhou', SecretKey = 'DD2qVxxxxx', SecretId = 'AKIDb5Rxxxxxxx'}
腾讯云配置
config.sbc_addr = os.getenv("SBC_ADDR") or "isbc.xswitch.cn:5060"
sbc地址
config.rsa_private_key = xxxxx
rsa 私钥
config.rsa_public_key = xxx
rsa 公钥
-- config.iad = true
分机里是否启用IAD功能
-- config.fifo_ticket = true
fifo队列坐席接听后是否自动创建工单。
-- config.voicemail_ticket = true
语音留言后是否自动创建工单。
-- config.xui_type = "ippbx"
是否设置为IPPBX模式,如果开启,则会有一些更严格的安全检查。
-- config.first_login = false
是否开启首次登录修改密码功能,默认开启,设置为 false 后,分机首次登录则不强制修改密码
-- config.gateway_limit = true
是否开启网关并发限制