2006-04-04 22:03:59 +00:00
|
|
|
/*
|
|
|
|
* FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
* Copyright (C) 2005/2006, Anthony Minessale II <anthmct@yahoo.com>
|
|
|
|
*
|
|
|
|
* Version: MPL 1.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Anthony Minessale II <anthmct@yahoo.com>
|
|
|
|
* Portions created by the Initial Developer are Copyright (C)
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Anthony Minessale II <anthmct@yahoo.com>
|
2006-06-15 06:02:08 +00:00
|
|
|
* Michael Jerris <mike@jerris.com>
|
|
|
|
* Johny Kadarisman <jkr888@gmail.com>
|
2006-04-04 22:03:59 +00:00
|
|
|
*
|
2006-04-07 03:57:03 +00:00
|
|
|
*
|
|
|
|
* mod_commands.c -- Misc. Command Module
|
2006-04-04 22:03:59 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
#include <switch.h>
|
|
|
|
|
|
|
|
static const char modname[] = "mod_commands";
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t status_function(char *cmd, switch_core_session_t *session, switch_stream_handle_t *stream)
|
2006-05-10 15:47:54 +00:00
|
|
|
{
|
2006-05-10 18:04:17 +00:00
|
|
|
uint8_t html = 0;
|
2006-05-10 15:47:54 +00:00
|
|
|
switch_core_time_duration_t duration;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2006-05-10 15:47:54 +00:00
|
|
|
switch_core_measure_time(switch_core_uptime(), &duration);
|
2006-04-04 22:03:59 +00:00
|
|
|
|
2006-05-10 16:47:02 +00:00
|
|
|
if (cmd && strstr(cmd, "html")) {
|
|
|
|
html = 1;
|
|
|
|
stream->write_function(stream, "<h1>FreeSWITCH Status</h1>\n<b>");
|
|
|
|
}
|
|
|
|
|
|
|
|
stream->write_function(stream, "UP %u year%s, %u day%s, %u hour%s, %u minute%s, %u second%s, %u millisecond%s, %u microsecond%s\n",
|
2006-05-10 16:35:42 +00:00
|
|
|
duration.yr, duration.yr == 1 ? "" : "s",
|
|
|
|
duration.day, duration.day == 1 ? "" : "s",
|
|
|
|
duration.hr, duration.hr == 1 ? "" : "s",
|
|
|
|
duration.min, duration.min == 1 ? "" : "s",
|
|
|
|
duration.sec, duration.sec == 1 ? "" : "s",
|
|
|
|
duration.ms, duration.ms == 1 ? "" : "s",
|
|
|
|
duration.mms, duration.mms == 1 ? "" : "s"
|
2006-05-10 15:47:54 +00:00
|
|
|
);
|
2006-05-10 16:35:42 +00:00
|
|
|
|
2006-05-10 16:47:02 +00:00
|
|
|
if (html) {
|
|
|
|
stream->write_function(stream, "</b>\n");
|
|
|
|
}
|
|
|
|
|
2006-05-10 16:35:42 +00:00
|
|
|
if (cmd && strstr(cmd, "refresh=")) {
|
|
|
|
char *refresh = strchr(cmd, '=');
|
|
|
|
if (refresh) {
|
|
|
|
int r;
|
|
|
|
refresh++;
|
|
|
|
r = atoi(refresh);
|
|
|
|
if (r > 0) {
|
2006-05-10 16:56:07 +00:00
|
|
|
stream->write_function(stream, "<META HTTP-EQUIV=REFRESH CONTENT=\"%d; URL=/api/status?refresh=%d%s\">\n", r, r, html ? "html=1" : "");
|
2006-05-10 16:35:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-05-10 15:47:54 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t load_function(char *mod, switch_core_session_t *session, switch_stream_handle_t *stream)
|
2006-04-20 00:58:06 +00:00
|
|
|
{
|
2006-07-26 20:12:49 +00:00
|
|
|
|
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2006-04-20 00:58:06 +00:00
|
|
|
switch_loadable_module_load_module((char *) SWITCH_GLOBAL_dirs.mod_dir, (char *) mod);
|
2006-07-26 20:12:49 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
2006-04-20 00:58:06 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t reload_function(char *mod, switch_core_session_t *session, switch_stream_handle_t *stream)
|
2006-05-26 17:27:09 +00:00
|
|
|
{
|
|
|
|
const char *err;
|
|
|
|
switch_xml_t xml_root;
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
if ((xml_root = switch_xml_open_root(1, &err))) {
|
|
|
|
switch_xml_free(xml_root);
|
|
|
|
}
|
|
|
|
|
|
|
|
stream->write_function(stream, "OK [%s]\n", err);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t kill_function(char *dest, switch_core_session_t *isession, switch_stream_handle_t *stream)
|
2006-04-04 22:03:59 +00:00
|
|
|
{
|
2006-04-29 06:05:03 +00:00
|
|
|
switch_core_session_t *session = NULL;
|
2006-04-04 22:03:59 +00:00
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
if (isession) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2006-09-02 07:31:18 +00:00
|
|
|
if (dest && (session = switch_core_session_locate(dest))) {
|
2006-04-29 06:05:03 +00:00
|
|
|
switch_channel_t *channel = switch_core_session_get_channel(session);
|
2006-04-04 22:03:59 +00:00
|
|
|
switch_core_session_kill_channel(session, SWITCH_SIG_KILL);
|
2006-04-22 03:05:25 +00:00
|
|
|
switch_channel_hangup(channel, SWITCH_CAUSE_NORMAL_CLEARING);
|
2006-04-28 19:46:57 +00:00
|
|
|
switch_core_session_rwunlock(session);
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
2006-04-04 22:03:59 +00:00
|
|
|
} else {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
2006-04-04 22:03:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t transfer_function(char *cmd, switch_core_session_t *isession, switch_stream_handle_t *stream)
|
2006-04-28 19:46:57 +00:00
|
|
|
{
|
2006-04-29 06:05:03 +00:00
|
|
|
switch_core_session_t *session = NULL;
|
2006-04-28 19:46:57 +00:00
|
|
|
char *argv[4] = {0};
|
|
|
|
int argc = 0;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
|
|
|
if (isession) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2006-04-28 19:46:57 +00:00
|
|
|
|
|
|
|
argc = switch_separate_string(cmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
|
|
|
|
if (argc < 2 || argc > 4) {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "Invalid Parameters\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
} else {
|
|
|
|
char *uuid = argv[0];
|
|
|
|
char *dest = argv[1];
|
|
|
|
char *dp = argv[2];
|
|
|
|
char *context = argv[3];
|
|
|
|
|
|
|
|
if ((session = switch_core_session_locate(uuid))) {
|
|
|
|
|
|
|
|
if (switch_ivr_session_transfer(session, dest, dp, context) == SWITCH_STATUS_SUCCESS) {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
} else {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "ERROR\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
switch_core_session_rwunlock(session);
|
|
|
|
|
|
|
|
} else {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t pause_function(char *cmd, switch_core_session_t *isession, switch_stream_handle_t *stream)
|
2006-04-28 19:46:57 +00:00
|
|
|
{
|
2006-04-29 06:05:03 +00:00
|
|
|
switch_core_session_t *session = NULL;
|
2006-04-28 19:46:57 +00:00
|
|
|
char *argv[4] = {0};
|
|
|
|
int argc = 0;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
|
|
|
if (isession) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2006-04-28 19:46:57 +00:00
|
|
|
|
|
|
|
argc = switch_separate_string(cmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
|
|
|
|
if (argc < 2) {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "Invalid Parameters\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
} else {
|
|
|
|
char *uuid = argv[0];
|
|
|
|
char *dest = argv[1];
|
|
|
|
|
|
|
|
if ((session = switch_core_session_locate(uuid))) {
|
2006-04-29 06:05:03 +00:00
|
|
|
switch_channel_t *channel = switch_core_session_get_channel(session);
|
2006-04-28 19:46:57 +00:00
|
|
|
|
|
|
|
if (!strcasecmp(dest, "on")) {
|
|
|
|
switch_channel_set_flag(channel, CF_HOLD);
|
|
|
|
} else {
|
|
|
|
switch_channel_clear_flag(channel, CF_HOLD);
|
|
|
|
}
|
|
|
|
|
|
|
|
switch_core_session_rwunlock(session);
|
|
|
|
|
|
|
|
} else {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-08-17 00:53:09 +00:00
|
|
|
static switch_status_t originate_function(char *cmd, switch_core_session_t *isession, switch_stream_handle_t *stream)
|
|
|
|
{
|
|
|
|
switch_channel_t *caller_channel;
|
|
|
|
switch_core_session_t *caller_session;
|
|
|
|
char *argv[7] = {0};
|
|
|
|
int x, argc = 0;
|
|
|
|
char *aleg, *exten, *dp, *context, *cid_name, *cid_num;
|
|
|
|
uint32_t timeout = 60;
|
|
|
|
|
|
|
|
if (isession) {
|
|
|
|
stream->write_function(stream, "Illegal Usage\n");
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (switch_strlen_zero(cmd)) {
|
|
|
|
stream->write_function(stream, "Usage: originate <call url> <exten> [<dialplan>] [<context>] [<cid_name>] [<cid_num>] [<timeout_sec>]\n");
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
argc = switch_separate_string(cmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
|
|
|
|
for(x = 0; x < argc; x++) {
|
|
|
|
if (!strcasecmp(argv[x], "undef")) {
|
|
|
|
argv[x] = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
aleg = argv[0];
|
|
|
|
exten = argv[1];
|
|
|
|
dp = argv[2];
|
|
|
|
context = argv[3];
|
|
|
|
cid_name = argv[4];
|
|
|
|
cid_num = argv[5];
|
|
|
|
|
|
|
|
if (!dp) {
|
|
|
|
dp = "XML";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!context) {
|
|
|
|
context = "default";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argv[6]) {
|
|
|
|
timeout = atoi(argv[6]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!aleg && exten) {
|
|
|
|
stream->write_function(stream, "Invalid Arguements\n");
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-08-21 19:14:51 +00:00
|
|
|
if (switch_ivr_originate(NULL, &caller_session, aleg, timeout, NULL, cid_name, cid_num, NULL) != SWITCH_STATUS_SUCCESS) {
|
2006-08-17 00:53:09 +00:00
|
|
|
stream->write_function(stream, "Cannot Create Outgoing Channel! [%s]\n", aleg);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
caller_channel = switch_core_session_get_channel(caller_session);
|
|
|
|
assert(caller_channel != NULL);
|
|
|
|
switch_channel_clear_state_handler(caller_channel, NULL);
|
|
|
|
switch_core_session_rwunlock(caller_session);
|
|
|
|
|
|
|
|
switch_ivr_session_transfer(caller_session, exten, dp, context);
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;;
|
|
|
|
}
|
|
|
|
|
2006-07-19 19:16:42 +00:00
|
|
|
struct holder {
|
|
|
|
switch_stream_handle_t *stream;
|
2006-07-20 03:55:07 +00:00
|
|
|
char *http;
|
2006-07-19 19:16:42 +00:00
|
|
|
uint32_t count;
|
|
|
|
};
|
|
|
|
|
2006-05-04 16:04:04 +00:00
|
|
|
static int show_callback(void *pArg, int argc, char **argv, char **columnNames){
|
2006-07-19 19:16:42 +00:00
|
|
|
struct holder *holder = (struct holder *) pArg;
|
2006-07-20 03:55:07 +00:00
|
|
|
int x;
|
|
|
|
|
|
|
|
|
|
|
|
if (holder->count == 0) {
|
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "\n<tr>");
|
|
|
|
}
|
|
|
|
|
|
|
|
for(x = 0; x < argc; x++) {
|
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<td>");
|
|
|
|
holder->stream->write_function(holder->stream, "<b>%s</b>%s", columnNames[x], x == (argc - 1) ? "</td></tr>\n" : "</td><td>");
|
|
|
|
} else {
|
|
|
|
holder->stream->write_function(holder->stream, "%s%s", columnNames[x], x == (argc - 1) ? "\n" : ",");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<tr bgcolor=%s>", holder->count % 2 == 0 ? "eeeeee" : "ffffff");
|
|
|
|
}
|
|
|
|
|
|
|
|
for(x = 0; x < argc; x++) {
|
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<td>");
|
|
|
|
holder->stream->write_function(holder->stream, "%s%s", argv[x], x == (argc - 1) ? "</td></tr>\n" : "</td><td>");
|
|
|
|
} else {
|
|
|
|
holder->stream->write_function(holder->stream, "%s%s", argv[x], x == (argc - 1) ? "\n" : ",");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2006-05-04 16:04:04 +00:00
|
|
|
|
2006-07-19 19:16:42 +00:00
|
|
|
holder->count++;
|
2006-05-04 16:04:04 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
static switch_status_t show_function(char *cmd, switch_core_session_t *session, switch_stream_handle_t *stream)
|
2006-05-04 16:04:04 +00:00
|
|
|
{
|
|
|
|
char sql[1024];
|
|
|
|
char *errmsg;
|
|
|
|
switch_core_db_t *db = switch_core_db_handle();
|
2006-07-20 03:55:07 +00:00
|
|
|
struct holder holder = {0};
|
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2006-07-20 03:55:07 +00:00
|
|
|
if (stream->event) {
|
|
|
|
holder.http = switch_event_get_header(stream->event, "http-host");
|
|
|
|
}
|
|
|
|
|
2006-06-15 06:02:08 +00:00
|
|
|
if (!cmd) {
|
|
|
|
sprintf (sql, "select * from interfaces");
|
|
|
|
}
|
|
|
|
else if ( !strcmp(cmd,"codec") || !strcmp(cmd,"application") ||
|
|
|
|
!strcmp(cmd,"api") || !strcmp(cmd,"dialplan") ||
|
|
|
|
!strcmp(cmd,"file") || !strcmp(cmd,"timer")
|
|
|
|
) {
|
|
|
|
sprintf (sql, "select * from interfaces where type = '%s'", cmd);
|
|
|
|
}
|
2006-07-14 19:55:55 +00:00
|
|
|
else if ( !strcmp(cmd,"calls")) {
|
2006-07-14 21:16:01 +00:00
|
|
|
sprintf (sql, "select * from calls");
|
2006-07-14 19:55:55 +00:00
|
|
|
}
|
|
|
|
else if ( !strcmp(cmd,"channels")) {
|
2006-07-14 21:16:01 +00:00
|
|
|
sprintf (sql, "select * from channels");
|
2006-07-14 19:55:55 +00:00
|
|
|
}
|
2006-06-15 06:02:08 +00:00
|
|
|
else {
|
|
|
|
stream->write_function(stream, "Invalid interfaces type!\n");
|
|
|
|
stream->write_function(stream, "Example:\n");
|
2006-07-14 19:55:55 +00:00
|
|
|
stream->write_function(stream, "show <blank>|codec|application|api|dialplan|file|timer|calls|channels\n");
|
2006-06-15 06:02:08 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-07-19 19:16:42 +00:00
|
|
|
holder.stream = stream;
|
|
|
|
holder.count = 0;
|
|
|
|
|
2006-07-20 03:55:07 +00:00
|
|
|
if (holder.http) {
|
|
|
|
holder.stream->write_function(holder.stream, "<table cellpadding=1 cellspacing=4 border=1>\n");
|
|
|
|
}
|
|
|
|
|
2006-07-19 19:16:42 +00:00
|
|
|
switch_core_db_exec(db, sql, show_callback, &holder, &errmsg);
|
2006-05-04 16:04:04 +00:00
|
|
|
|
2006-07-20 03:55:07 +00:00
|
|
|
if (holder.http) {
|
|
|
|
holder.stream->write_function(holder.stream, "</table>");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-05-04 16:04:04 +00:00
|
|
|
if (errmsg) {
|
2006-05-10 15:47:54 +00:00
|
|
|
stream->write_function(stream, "SQL ERR [%s]\n",errmsg);
|
2006-05-04 16:04:04 +00:00
|
|
|
switch_core_db_free(errmsg);
|
|
|
|
errmsg = NULL;
|
2006-07-19 19:16:42 +00:00
|
|
|
} else {
|
2006-07-20 03:55:07 +00:00
|
|
|
stream->write_function(stream, "\n%u total.\n", holder.count);
|
2006-05-04 16:04:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
switch_core_db_close(db);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-05-10 03:23:05 +00:00
|
|
|
static switch_api_interface_t status_api_interface = {
|
|
|
|
/*.interface_name */ "status",
|
|
|
|
/*.desc */ "status",
|
|
|
|
/*.function */ status_function,
|
|
|
|
/*.next */ NULL
|
|
|
|
};
|
|
|
|
|
2006-05-04 16:04:04 +00:00
|
|
|
static switch_api_interface_t show_api_interface = {
|
|
|
|
/*.interface_name */ "show",
|
|
|
|
/*.desc */ "Show",
|
|
|
|
/*.function */ show_function,
|
2006-05-10 03:23:05 +00:00
|
|
|
/*.next */ &status_api_interface
|
2006-05-04 16:04:04 +00:00
|
|
|
};
|
2006-05-10 03:23:05 +00:00
|
|
|
|
2006-04-29 23:43:28 +00:00
|
|
|
static switch_api_interface_t pause_api_interface = {
|
2006-04-28 19:46:57 +00:00
|
|
|
/*.interface_name */ "pause",
|
|
|
|
/*.desc */ "Pause",
|
|
|
|
/*.function */ pause_function,
|
2006-05-04 16:04:04 +00:00
|
|
|
/*.next */ &show_api_interface
|
2006-04-28 19:46:57 +00:00
|
|
|
};
|
|
|
|
|
2006-04-29 23:43:28 +00:00
|
|
|
static switch_api_interface_t transfer_api_interface = {
|
2006-04-28 19:46:57 +00:00
|
|
|
/*.interface_name */ "transfer",
|
|
|
|
/*.desc */ "Transfer",
|
|
|
|
/*.function */ transfer_function,
|
|
|
|
/*.next */ &pause_api_interface
|
|
|
|
};
|
|
|
|
|
2006-04-29 23:43:28 +00:00
|
|
|
static switch_api_interface_t load_api_interface = {
|
2006-04-20 00:58:06 +00:00
|
|
|
/*.interface_name */ "load",
|
2006-08-17 00:53:09 +00:00
|
|
|
/*.desc */ "Load Module",
|
2006-04-20 00:58:06 +00:00
|
|
|
/*.function */ load_function,
|
2006-04-28 19:46:57 +00:00
|
|
|
/*.next */ &transfer_api_interface
|
2006-04-20 00:58:06 +00:00
|
|
|
};
|
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
static switch_api_interface_t reload_api_interface = {
|
|
|
|
/*.interface_name */ "reloadxml",
|
|
|
|
/*.desc */ "Reload XML",
|
|
|
|
/*.function */ reload_function,
|
|
|
|
/*.next */ &load_api_interface,
|
|
|
|
|
|
|
|
};
|
2006-04-20 00:58:06 +00:00
|
|
|
|
2006-04-29 23:43:28 +00:00
|
|
|
static switch_api_interface_t commands_api_interface = {
|
2006-04-04 22:03:59 +00:00
|
|
|
/*.interface_name */ "killchan",
|
|
|
|
/*.desc */ "Kill Channel",
|
|
|
|
/*.function */ kill_function,
|
2006-05-26 17:27:09 +00:00
|
|
|
/*.next */ &reload_api_interface
|
2006-04-04 22:03:59 +00:00
|
|
|
};
|
|
|
|
|
2006-08-17 00:53:09 +00:00
|
|
|
static switch_api_interface_t originate_api_interface = {
|
|
|
|
/*.interface_name */ "originate",
|
|
|
|
/*.desc */ "Originate a Call",
|
|
|
|
/*.function */ originate_function,
|
|
|
|
/*.next */ &commands_api_interface
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2006-04-29 23:43:28 +00:00
|
|
|
static const switch_loadable_module_interface_t mod_commands_module_interface = {
|
2006-04-04 22:03:59 +00:00
|
|
|
/*.module_name */ modname,
|
|
|
|
/*.endpoint_interface */ NULL,
|
|
|
|
/*.timer_interface */ NULL,
|
|
|
|
/*.dialplan_interface */ NULL,
|
|
|
|
/*.codec_interface */ NULL,
|
|
|
|
/*.application_interface */ NULL,
|
2006-08-17 00:53:09 +00:00
|
|
|
/*.api_interface */ &originate_api_interface
|
2006-04-04 22:03:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2006-04-30 18:24:24 +00:00
|
|
|
SWITCH_MOD_DECLARE(switch_status_t) switch_module_load(const switch_loadable_module_interface_t **module_interface, char *filename)
|
2006-04-04 22:03:59 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
/* connect my internal structure to the blank pointer passed to me */
|
2006-04-30 18:24:24 +00:00
|
|
|
*module_interface = &mod_commands_module_interface;
|
2006-04-04 22:03:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* indicate that the module should continue to be loaded */
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|