扩展Asterisk1.8.7的CLI接口

  我之前有一篇文章(http://www.cnblogs.com/MikeZhang/archive/2012/04/14/asteriskCLIAppTest20120414.html)介绍过如何扩展asterisk的cli接口,本篇是它的继续,总结下,也方便我以后查阅。

  大部分情况下,配置asterisk的拨号方案,用CLI、AMI之类的就可以满足我们的需求。可有些情况下涉及到业务的东东,需要数据库的参与(比如用sqlserve存储asterisk的录音记录等等),拨号方案那种静态的做法完全不用考虑,而原始的CLI、AMI已经不能满足需求。这时就需要考虑从源码入手,扩展asterisk了。

  asterisk是基于插件的,很容易扩展。手动编译过asterisk源码的朋友应该知道,在asterisk源码目录里有一个addons的目录,里面就是asterisk的插件(其实apps下也可以看做是插件)。

  这里有个小例子,主要演示怎么从源码扩展asterisk的CLI接口。

一、建立目录结构,配置Makefile

1、为了方便代码的管理,我决定新建立一个叫addons_test的文件夹;

2、将apps下的Makefile复制到该目录;

3、打开asterisk主目录下的Makefile文件,在MOD_SUBDIRS变量中加入addons_test(我的Makefile是在266行)。

二、编写CLI插件代码

1、在addons_test目录添加文件app_testApp20120605.c和文件app_testApp20120605.exports

说明:

app_testApp20120605.c为程序代码

app_testApp20120605.exports 为动态库导出配置

2、编写文件内容

  app_testApp20120605.exports文件简单,可以将apps目录下的任一”.exports”文件copy至本目录改名即可,这里主要介绍app_testApp20120605.c的书写。 

2.1 首先需要添加头文件: 

#include "asterisk.h"
#include "asterisk/module.h"
#include "asterisk/cli.h"

2.2 定义Application名称:

static char *app_testApp = "testApp20120605";

2.3 写模块加载函数:

static int testApp_exec(struct ast_channel *chan, const char *data)
{
        ast_verb(2,"testApp_exec : %s\r\n",data);
        return0;
}
说明:这个要用此格式,尽管chan变量没有用到,但加载模块的函数指针是这种格式。 

2.4 编写CLI接口函数:

View Code
 1 static char *handle_cli_testApp(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
 2 {
 3         struct ast_channel *chan=NULL;
 4 
 5         if(CLI_INIT == cmd) {
 6                 e->command = "testApp20120605 {print}";
 7                 e->usage =
 8                         "Usage: testApp20120605 <print> <something2print>\n"
 9                         "       Print something to test application\n"
10                         "       application when the 'print' command is used.\n";
11                 returnNULL;
12         }
13 
14         if (a->argc < 2)
15                 return CLI_SHOWUSAGE;
16 
17         if (!strcasecmp(a->argv[1], "print")) {
18                 testApp_exec(chan, a->argv[2]);
19         }else{
20                 return CLI_SHOWUSAGE;
21         }
22 
23         return CLI_SUCCESS;
24 }

2.5 编写模块加载函数:

View Code
1 static int load_module(void)
2 {
3         int res;
4         ast_cli_register_multiple(cli_testApp, ARRAY_LEN(cli_testApp));
5         res = ast_register_application_xml(app_testApp,testApp_exec);
6         return res;
7 }

2.6 编写模块卸载函数:

View Code
static int unload_module(void)
{
        int res;
        ast_cli_unregister_multiple(cli_testApp, ARRAY_LEN(cli_testApp));
        res = ast_unregister_application(app_testApp);
        return res;
}

三、测试CLI插件 

1、编译运行

执行如下命令:

make && make install && asterisk && asterisk -rvvvvvvvv 

2、测试 

启动后,执行如下命令: 

testApp20120605 print "Just a test"

运行效果: 

posted on 2012-06-05 23:56  Mike_Zhang  阅读(2548)  评论(0编辑  收藏  举报