有没有人做到这一点?
大局是从 filemaker 开发整个星号 GUI,但现在我要求您帮助连接两者。
Asterisk 控制着我们的整个呼叫中心。我希望将来自来电和队列的信息写入 FileMaker 数据库。
免责声明:我首先不了解 FileMaker。但是,如果它像任何其他编程语言(据我所知,我不确定这是不是真的),那么让我们看看我们如何使用其他编程语言实现这一点的选项......
如果您只想要呼叫的结果,即 CDR(呼叫详细记录),您可以配置 Asterisk 以输出自定义 CDR cdr_custom.conf
(如果您生成了示例配置,请查看它)
这是一个例子cdr_custom.conf
:
[mappings]
Simple.csv => ${CSV_QUOTE(${EPOCH})},${CSV_QUOTE(${CDR(src)})},${CSV_QUOTE(${CDR(dst)})}
/var/log/asterisk/
如果您没有在配置中更改文件,它通常会将文件放入其中。
然后,重新启动星号,或者更优雅地重新加载 cdr 模块:
asterisk*CLI> cdr show status
asterisk*CLI> module reload cdr_custom.so
使用生成的文件,解析 CSV 并以适合 Filemaker/“您选择的语言”的方式对其进行格式化。
如果您正在寻找有关呼叫的实时信息,它确实会变得更加复杂。可能仅出于报告目的,您可以使用Asterisk AMI(Asterisk Manager Interface)。(链接的规范维基页面)
这是一个 TCP IP 应用程序,打开一个套接字到它,你就可以开始了。还有AJAM 接口(异步 Javascript Asterisk Manger)。您可以对其进行 HTTP 调用。
最后,如果您想在通过拨号方案路由呼叫期间进行进一步处理,您需要使用从拨号方案调用的 AGI(Asterisk 网关接口),并且遍布 STDIO。
实际上,您可以创建到星号数据库的 ODBC 连接并使用 filemaker 直接访问表。它将为您提供“实时”连接,并为您节省所有导入 <-> 导出的麻烦。如果你在 filemaker odbc 上搜索,你会得到设置的结果,它工作起来很容易(根据你的查询并不总是很快,但肯定比手动方法快很多)