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-11-28 19:33:54 +00:00
|
|
|
* Paul Tinsley <jackhammer@gmail.com>
|
2007-04-08 03:53:35 +00:00
|
|
|
* Marcel Barbulescu <marcelbarbulescu@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>
|
2006-11-28 19:33:54 +00:00
|
|
|
#include <switch_version.h>
|
2006-04-04 22:03:59 +00:00
|
|
|
|
2007-06-13 16:00:14 +00:00
|
|
|
SWITCH_MODULE_LOAD_FUNCTION(mod_commands_load);
|
|
|
|
SWITCH_MODULE_DEFINITION(mod_commands, mod_commands_load, NULL, NULL);
|
2007-03-03 01:01:37 +00:00
|
|
|
|
2006-10-08 07:11:42 +00:00
|
|
|
static switch_api_interface_t ctl_api_interface;
|
|
|
|
static switch_api_interface_t uuid_bridge_api_interface;
|
2007-01-12 16:05:49 +00:00
|
|
|
static switch_api_interface_t session_record_api_interface;
|
2006-10-08 07:11:42 +00:00
|
|
|
static switch_api_interface_t status_api_interface;
|
|
|
|
static switch_api_interface_t show_api_interface;
|
|
|
|
static switch_api_interface_t pause_api_interface;
|
|
|
|
static switch_api_interface_t transfer_api_interface;
|
|
|
|
static switch_api_interface_t load_api_interface;
|
2007-05-03 16:28:23 +00:00
|
|
|
static switch_api_interface_t unload_api_interface;
|
2006-10-08 07:11:42 +00:00
|
|
|
static switch_api_interface_t reload_api_interface;
|
|
|
|
static switch_api_interface_t kill_api_interface;
|
|
|
|
static switch_api_interface_t originate_api_interface;
|
2006-10-31 21:38:06 +00:00
|
|
|
static switch_api_interface_t media_api_interface;
|
|
|
|
static switch_api_interface_t hold_api_interface;
|
|
|
|
static switch_api_interface_t broadcast_api_interface;
|
2007-03-28 23:37:12 +00:00
|
|
|
static switch_api_interface_t sched_broadcast_api_interface;
|
|
|
|
static switch_api_interface_t sched_transfer_api_interface;
|
|
|
|
static switch_api_interface_t sched_hangup_api_interface;
|
2006-04-04 22:03:59 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(status_function)
|
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-09-19 22:57:25 +00:00
|
|
|
char *http = NULL;
|
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-09-18 22:22:25 +00:00
|
|
|
if (stream->event) {
|
2006-10-31 05:04:47 +00:00
|
|
|
http = switch_event_get_header(stream->event, "http-host");
|
|
|
|
}
|
2006-09-18 22:22:25 +00:00
|
|
|
|
|
|
|
if (http || (cmd && strstr(cmd, "html"))) {
|
2006-05-10 16:47:02 +00:00
|
|
|
html = 1;
|
|
|
|
stream->write_function(stream, "<h1>FreeSWITCH Status</h1>\n<b>");
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
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",
|
|
|
|
duration.yr, duration.yr == 1 ? "" : "s", duration.day, duration.day == 1 ? "" : "s",
|
|
|
|
duration.hr, duration.hr == 1 ? "" : "s", duration.min, duration.min == 1 ? "" : "s",
|
2007-03-30 00:15:25 +00:00
|
|
|
duration.sec, duration.sec == 1 ? "" : "s", duration.ms, duration.ms == 1 ? "" : "s", duration.mms,
|
|
|
|
duration.mms == 1 ? "" : "s");
|
2006-05-10 16:35:42 +00:00
|
|
|
|
2007-04-22 01:25:02 +00:00
|
|
|
stream->write_function(stream, "%"SWITCH_SIZE_T_FMT" sessions since startup\n", switch_core_session_id() - 1 );
|
2006-09-18 22:22:25 +00:00
|
|
|
stream->write_function(stream, "%d sessions\n", switch_core_session_count());
|
2007-03-29 22:31:56 +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);
|
2007-03-29 22:31:56 +00:00
|
|
|
if (r > 0) {
|
2007-03-30 00:13:31 +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;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(ctl_function)
|
2006-09-20 20:25:26 +00:00
|
|
|
{
|
|
|
|
int argc;
|
|
|
|
char *mydata, *argv[5];
|
|
|
|
uint32_t arg = 0;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_strlen_zero(cmd)) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", ctl_api_interface.syntax);
|
2006-09-20 20:25:26 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((mydata = strdup(cmd))) {
|
2006-09-20 20:25:26 +00:00
|
|
|
argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-09-20 20:25:26 +00:00
|
|
|
if (!strcmp(argv[0], "hupall")) {
|
|
|
|
arg = 1;
|
|
|
|
switch_core_session_ctl(SCSC_HUPALL, &arg);
|
|
|
|
} else if (!strcmp(argv[0], "pause")) {
|
|
|
|
arg = 1;
|
|
|
|
switch_core_session_ctl(SCSC_PAUSE_INBOUND, &arg);
|
|
|
|
} else if (!strcmp(argv[0], "resume")) {
|
|
|
|
arg = 0;
|
|
|
|
switch_core_session_ctl(SCSC_PAUSE_INBOUND, &arg);
|
|
|
|
} else if (!strcmp(argv[0], "shutdown")) {
|
|
|
|
arg = 0;
|
|
|
|
switch_core_session_ctl(SCSC_SHUTDOWN, &arg);
|
|
|
|
} else {
|
2007-04-29 03:21:56 +00:00
|
|
|
stream->write_function(stream, "INVALID COMMAND\nUSAGE: fsctl [hupall|pause|resume|shutdown]\n");
|
2006-09-20 20:25:26 +00:00
|
|
|
goto end;
|
2007-03-29 22:31:56 +00:00
|
|
|
}
|
2006-09-20 20:25:26 +00:00
|
|
|
|
|
|
|
stream->write_function(stream, "OK\n");
|
2007-03-29 22:31:56 +00:00
|
|
|
end:
|
2006-09-20 20:25:26 +00:00
|
|
|
free(mydata);
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "MEM ERR\n");
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
|
2006-09-20 20:25:26 +00:00
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(load_function)
|
2006-04-20 00:58:06 +00:00
|
|
|
{
|
2007-05-03 16:28:23 +00:00
|
|
|
const char *err;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_strlen_zero(cmd)) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", load_api_interface.syntax);
|
2006-10-08 04:40:15 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_loadable_module_load_module((char *) SWITCH_GLOBAL_dirs.mod_dir, (char *) cmd, SWITCH_TRUE, &err) == SWITCH_STATUS_SUCCESS) {
|
2007-03-17 19:51:08 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
|
|
|
} else {
|
2007-05-03 16:28:23 +00:00
|
|
|
stream->write_function(stream, "ERROR [%s]\n", err);
|
|
|
|
}
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(unload_function)
|
2007-05-03 16:28:23 +00:00
|
|
|
{
|
|
|
|
const char *err;
|
|
|
|
|
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_strlen_zero(cmd)) {
|
2007-05-03 16:28:23 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", unload_api_interface.syntax);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_loadable_module_unload_module((char *) SWITCH_GLOBAL_dirs.mod_dir, (char *) cmd, &err) == SWITCH_STATUS_SUCCESS) {
|
2007-05-03 16:28:23 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "ERROR [%s]\n", err);
|
2007-03-17 19:51:08 +00:00
|
|
|
}
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2006-04-20 00:58:06 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(reload_function)
|
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;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
if ((xml_root = switch_xml_open_root(1, &err))) {
|
|
|
|
switch_xml_free(xml_root);
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
stream->write_function(stream, "OK [%s]\n", err);
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2006-05-26 17:27:09 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(kill_function)
|
2006-04-04 22:03:59 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *ksession = NULL;
|
2006-04-04 22:03:59 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-07-26 20:12:49 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (!cmd) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", kill_api_interface.syntax);
|
2007-05-12 21:36:15 +00:00
|
|
|
} else if ((ksession = switch_core_session_locate(cmd))) {
|
|
|
|
switch_channel_t *channel = switch_core_session_get_channel(ksession);
|
2006-04-22 03:05:25 +00:00
|
|
|
switch_channel_hangup(channel, SWITCH_CAUSE_NORMAL_CLEARING);
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(ksession);
|
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;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(transfer_function)
|
2006-04-28 19:46:57 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *tsession = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-04-28 19:46:57 +00:00
|
|
|
int argc = 0;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-07-26 20:12:49 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
if (argc >= 2 && argc <= 4) {
|
|
|
|
char *uuid = argv[0];
|
|
|
|
char *dest = argv[1];
|
|
|
|
char *dp = argv[2];
|
|
|
|
char *context = argv[3];
|
2006-04-28 19:46:57 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((tsession = switch_core_session_locate(uuid))) {
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (switch_ivr_session_transfer(tsession, dest, dp, context) == SWITCH_STATUS_SUCCESS) {
|
2007-05-12 14:48:14 +00:00
|
|
|
stream->write_function(stream, "OK\n");
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "ERROR\n");
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(tsession);
|
2006-04-28 19:46:57 +00:00
|
|
|
|
|
|
|
} else {
|
2007-05-12 14:48:14 +00:00
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
2006-04-28 19:46:57 +00:00
|
|
|
}
|
2007-05-12 14:48:14 +00:00
|
|
|
goto done;
|
2006-04-28 19:46:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", transfer_api_interface.syntax);
|
|
|
|
|
|
|
|
done:
|
|
|
|
switch_safe_free(mycmd);
|
2006-04-28 19:46:57 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-03-28 23:37:12 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(sched_transfer_function)
|
2007-03-28 23:37:12 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *tsession = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[6] = { 0 };
|
2007-03-28 23:37:12 +00:00
|
|
|
int argc = 0;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2007-03-28 23:37:12 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2007-03-28 23:37:12 +00:00
|
|
|
|
|
|
|
if (switch_strlen_zero(cmd) || argc < 2 || argc > 5) {
|
|
|
|
stream->write_function(stream, "USAGE: %s\n", sched_transfer_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
char *uuid = argv[1];
|
|
|
|
char *dest = argv[2];
|
|
|
|
char *dp = argv[3];
|
|
|
|
char *context = argv[4];
|
|
|
|
time_t when;
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-03-28 23:37:12 +00:00
|
|
|
if (*argv[0] == '+') {
|
2007-03-29 22:31:56 +00:00
|
|
|
when = time(NULL) + atol(argv[0] + 1);
|
2007-03-28 23:37:12 +00:00
|
|
|
} else {
|
|
|
|
when = atol(argv[0]);
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((tsession = switch_core_session_locate(uuid))) {
|
2007-03-28 23:37:12 +00:00
|
|
|
switch_ivr_schedule_transfer(when, uuid, dest, dp, context);
|
|
|
|
stream->write_function(stream, "OK\n");
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(tsession);
|
2007-03-28 23:37:12 +00:00
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-03-28 23:37:12 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(sched_hangup_function)
|
2007-03-28 23:37:12 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *hsession = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2007-03-28 23:37:12 +00:00
|
|
|
int argc = 0;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2007-03-28 23:37:12 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2007-03-28 23:37:12 +00:00
|
|
|
|
|
|
|
if (switch_strlen_zero(cmd) || argc < 1) {
|
|
|
|
stream->write_function(stream, "USAGE: %s\n", sched_hangup_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
char *uuid = argv[1];
|
|
|
|
char *cause_str = argv[2];
|
|
|
|
time_t when;
|
|
|
|
switch_call_cause_t cause = SWITCH_CAUSE_ALLOTTED_TIMEOUT;
|
|
|
|
|
|
|
|
if (*argv[0] == '+') {
|
2007-03-29 22:31:56 +00:00
|
|
|
when = time(NULL) + atol(argv[0] + 1);
|
2007-03-28 23:37:12 +00:00
|
|
|
} else {
|
|
|
|
when = atol(argv[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause_str) {
|
|
|
|
cause = switch_channel_str2cause(cause_str);
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((hsession = switch_core_session_locate(uuid))) {
|
2007-03-28 23:37:12 +00:00
|
|
|
switch_ivr_schedule_hangup(when, uuid, cause, SWITCH_FALSE);
|
|
|
|
stream->write_function(stream, "OK\n");
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(hsession);
|
2007-03-28 23:37:12 +00:00
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "No Such Channel!\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-03-28 23:37:12 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(uuid_media_function)
|
2006-10-31 21:38:06 +00:00
|
|
|
{
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-10-31 21:38:06 +00:00
|
|
|
int argc = 0;
|
|
|
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-10-31 21:38:06 +00:00
|
|
|
return status;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-10-31 21:38:06 +00:00
|
|
|
|
2006-12-08 16:31:58 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc < 1) {
|
2006-10-31 21:38:06 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", media_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
if (!strcmp(argv[0], "off")) {
|
|
|
|
status = switch_ivr_nomedia(argv[1], SMF_REBRIDGE);
|
|
|
|
} else {
|
|
|
|
status = switch_ivr_media(argv[0], SMF_REBRIDGE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (status == SWITCH_STATUS_SUCCESS) {
|
|
|
|
stream->write_function(stream, "+OK Success\n");
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "-ERR Operation Failed\n");
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-10-31 21:38:06 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(uuid_broadcast_function)
|
2006-10-31 21:38:06 +00:00
|
|
|
{
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-10-31 21:38:06 +00:00
|
|
|
int argc = 0;
|
|
|
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-10-31 21:38:06 +00:00
|
|
|
return status;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-10-31 21:38:06 +00:00
|
|
|
|
2006-12-08 16:31:58 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc < 2) {
|
2006-10-31 21:38:06 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", broadcast_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
switch_media_flag_t flags = SMF_NONE;
|
|
|
|
|
2006-11-10 08:13:01 +00:00
|
|
|
if (argv[2]) {
|
|
|
|
if (!strcmp(argv[2], "both")) {
|
|
|
|
flags |= (SMF_ECHO_ALEG | SMF_ECHO_BLEG);
|
|
|
|
} else if (!strcmp(argv[2], "aleg")) {
|
|
|
|
flags |= SMF_ECHO_ALEG;
|
|
|
|
} else if (!strcmp(argv[2], "bleg")) {
|
|
|
|
flags |= SMF_ECHO_BLEG;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
flags |= SMF_ECHO_ALEG;
|
2006-10-31 21:38:06 +00:00
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-10-31 21:38:06 +00:00
|
|
|
status = switch_ivr_broadcast(argv[0], argv[1], flags);
|
|
|
|
stream->write_function(stream, "+OK Message Sent\n");
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-10-31 21:38:06 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-03-28 23:37:12 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(sched_broadcast_function)
|
2007-03-28 23:37:12 +00:00
|
|
|
{
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2007-03-28 23:37:12 +00:00
|
|
|
int argc = 0;
|
|
|
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2007-03-28 23:37:12 +00:00
|
|
|
return status;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2007-03-28 23:37:12 +00:00
|
|
|
|
|
|
|
if (switch_strlen_zero(cmd) || argc < 3) {
|
|
|
|
stream->write_function(stream, "USAGE: %s\n", sched_broadcast_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
switch_media_flag_t flags = SMF_NONE;
|
|
|
|
time_t when;
|
|
|
|
|
|
|
|
if (*argv[0] == '+') {
|
2007-03-29 22:31:56 +00:00
|
|
|
when = time(NULL) + atol(argv[0] + 1);
|
2007-03-28 23:37:12 +00:00
|
|
|
} else {
|
|
|
|
when = atol(argv[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argv[3]) {
|
|
|
|
if (!strcmp(argv[3], "both")) {
|
|
|
|
flags |= (SMF_ECHO_ALEG | SMF_ECHO_BLEG);
|
|
|
|
} else if (!strcmp(argv[3], "aleg")) {
|
|
|
|
flags |= SMF_ECHO_ALEG;
|
|
|
|
} else if (!strcmp(argv[3], "bleg")) {
|
|
|
|
flags |= SMF_ECHO_BLEG;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
flags |= SMF_ECHO_ALEG;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-03-28 23:37:12 +00:00
|
|
|
status = switch_ivr_schedule_broadcast(when, argv[1], argv[2], flags);
|
|
|
|
stream->write_function(stream, "+OK Message Scheduled\n");
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-03-28 23:37:12 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(uuid_hold_function)
|
2006-10-31 21:38:06 +00:00
|
|
|
{
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-10-31 21:38:06 +00:00
|
|
|
int argc = 0;
|
|
|
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-10-31 21:38:06 +00:00
|
|
|
return status;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-10-31 21:38:06 +00:00
|
|
|
|
2006-12-08 16:31:58 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc < 1) {
|
2006-10-31 21:38:06 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", hold_api_interface.syntax);
|
|
|
|
} else {
|
|
|
|
if (!strcmp(argv[0], "off")) {
|
|
|
|
status = switch_ivr_unhold_uuid(argv[1]);
|
|
|
|
} else {
|
|
|
|
status = switch_ivr_hold_uuid(argv[0]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (status == SWITCH_STATUS_SUCCESS) {
|
|
|
|
stream->write_function(stream, "+OK Success\n");
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "-ERR Operation Failed\n");
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-10-31 21:38:06 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(uuid_bridge_function)
|
2006-09-19 02:18:24 +00:00
|
|
|
{
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-09-19 02:18:24 +00:00
|
|
|
int argc = 0;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-09-19 02:18:24 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-09-19 02:18:24 +00:00
|
|
|
|
2006-12-08 16:31:58 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc != 2) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", uuid_bridge_api_interface.syntax);
|
2006-09-19 02:18:24 +00:00
|
|
|
} else {
|
2006-10-08 04:40:15 +00:00
|
|
|
if (switch_ivr_uuid_bridge(argv[0], argv[1]) != SWITCH_STATUS_SUCCESS) {
|
|
|
|
stream->write_function(stream, "Invalid uuid\n");
|
|
|
|
}
|
2006-09-19 02:18:24 +00:00
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-09-19 02:18:24 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(session_record_function)
|
2007-01-12 16:05:49 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *rsession = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2007-03-29 22:31:56 +00:00
|
|
|
char *uuid = NULL, *action = NULL, *path = NULL;
|
2007-01-12 16:05:49 +00:00
|
|
|
int argc = 0;
|
2007-05-31 14:42:23 +00:00
|
|
|
uint32_t limit = 0;
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2007-01-12 16:05:49 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-01-12 16:05:49 +00:00
|
|
|
if (switch_strlen_zero(cmd)) {
|
2007-03-29 22:31:56 +00:00
|
|
|
goto usage;
|
|
|
|
}
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!(mycmd = strdup(cmd))) {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
2007-06-15 01:47:48 +00:00
|
|
|
if ((argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])))) < 3) {
|
2007-03-29 22:31:56 +00:00
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
uuid = argv[0];
|
|
|
|
action = argv[1];
|
|
|
|
path = argv[2];
|
2007-05-31 14:42:23 +00:00
|
|
|
limit = argv[3] ? atoi(argv[3]) : 0;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (!(rsession = switch_core_session_locate(uuid))) {
|
2007-01-12 16:05:49 +00:00
|
|
|
stream->write_function(stream, "-Error Cannot locate session!\n");
|
2007-03-29 22:31:56 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
2007-05-15 02:21:53 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
if (switch_strlen_zero(action) || switch_strlen_zero(path)) {
|
|
|
|
goto usage;
|
|
|
|
}
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
if (!strcasecmp(action, "start")) {
|
2007-05-31 14:42:23 +00:00
|
|
|
switch_ivr_record_session(rsession, path, limit, NULL);
|
2007-03-29 22:31:56 +00:00
|
|
|
} else if (!strcasecmp(action, "stop")) {
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_ivr_stop_record_session(rsession, path);
|
2007-03-29 22:31:56 +00:00
|
|
|
} else {
|
|
|
|
goto usage;
|
|
|
|
}
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
goto done;
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
usage:
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", session_record_api_interface.syntax);
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-05-15 02:21:53 +00:00
|
|
|
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
done:
|
2007-01-12 16:05:49 +00:00
|
|
|
|
2007-05-15 02:21:53 +00:00
|
|
|
if (rsession) {
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(rsession);
|
2007-03-29 22:31:56 +00:00
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-03-29 22:31:56 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
2007-01-12 16:05:49 +00:00
|
|
|
}
|
|
|
|
|
2007-06-15 01:47:48 +00:00
|
|
|
|
|
|
|
SWITCH_STANDARD_API(session_displace_function)
|
|
|
|
{
|
|
|
|
switch_core_session_t *rsession = NULL;
|
|
|
|
char *mycmd = NULL, *argv[5] = { 0 };
|
|
|
|
char *uuid = NULL, *action = NULL, *path = NULL;
|
|
|
|
int argc = 0;
|
|
|
|
uint32_t limit = 0;
|
|
|
|
char *flags = NULL;
|
|
|
|
|
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (switch_strlen_zero(cmd)) {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(mycmd = strdup(cmd))) {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])))) < 3) {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
uuid = argv[0];
|
|
|
|
action = argv[1];
|
|
|
|
path = argv[2];
|
|
|
|
limit = argv[3] ? atoi(argv[3]) : 0;
|
|
|
|
flags = argv[4];
|
|
|
|
|
|
|
|
if (!(rsession = switch_core_session_locate(uuid))) {
|
|
|
|
stream->write_function(stream, "-Error Cannot locate session!\n");
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (switch_strlen_zero(action) || switch_strlen_zero(path)) {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!strcasecmp(action, "start")) {
|
|
|
|
switch_ivr_displace_session(rsession, path, limit, flags);
|
|
|
|
} else if (!strcasecmp(action, "stop")) {
|
|
|
|
switch_ivr_stop_displace_session(rsession, path);
|
|
|
|
} else {
|
|
|
|
goto usage;
|
|
|
|
}
|
|
|
|
|
|
|
|
goto done;
|
|
|
|
|
|
|
|
usage:
|
|
|
|
|
|
|
|
stream->write_function(stream, "INVALID SYNTAX\n");
|
|
|
|
switch_safe_free(mycmd);
|
|
|
|
|
|
|
|
|
|
|
|
done:
|
|
|
|
|
|
|
|
if (rsession) {
|
|
|
|
switch_core_session_rwunlock(rsession);
|
|
|
|
}
|
|
|
|
|
|
|
|
switch_safe_free(mycmd);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(pause_function)
|
2006-04-28 19:46:57 +00:00
|
|
|
{
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_t *psession = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[4] = { 0 };
|
2006-04-28 19:46:57 +00:00
|
|
|
int argc = 0;
|
2006-07-26 20:12:49 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-07-26 20:12:49 +00:00
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-04-28 19:46:57 +00:00
|
|
|
|
2006-12-08 16:31:58 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc < 2) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", pause_api_interface.syntax);
|
2006-04-28 19:46:57 +00:00
|
|
|
} else {
|
|
|
|
char *uuid = argv[0];
|
|
|
|
char *dest = argv[1];
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((psession = switch_core_session_locate(uuid))) {
|
|
|
|
switch_channel_t *channel = switch_core_session_get_channel(psession);
|
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);
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
switch_core_session_rwunlock(psession);
|
2006-04-28 19:46:57 +00:00
|
|
|
|
|
|
|
} 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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-04-28 19:46:57 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(originate_function)
|
2006-08-17 00:53:09 +00:00
|
|
|
{
|
|
|
|
switch_channel_t *caller_channel;
|
2007-04-13 22:15:58 +00:00
|
|
|
switch_core_session_t *caller_session = NULL;
|
2007-05-12 14:48:14 +00:00
|
|
|
char *mycmd = NULL, *argv[7] = { 0 };
|
2006-11-09 05:39:04 +00:00
|
|
|
int i = 0, x, argc = 0;
|
2006-08-17 00:53:09 +00:00
|
|
|
char *aleg, *exten, *dp, *context, *cid_name, *cid_num;
|
|
|
|
uint32_t timeout = 60;
|
2006-09-12 01:32:04 +00:00
|
|
|
switch_call_cause_t cause = SWITCH_CAUSE_NORMAL_CLEARING;
|
2006-11-09 05:39:04 +00:00
|
|
|
uint8_t machine = 1;
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (session) {
|
2006-08-17 00:53:09 +00:00
|
|
|
stream->write_function(stream, "Illegal Usage\n");
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) {
|
|
|
|
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
|
|
|
}
|
2006-10-08 07:11:42 +00:00
|
|
|
|
2006-10-08 04:40:15 +00:00
|
|
|
if (switch_strlen_zero(cmd) || argc < 2 || argc > 7) {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", originate_api_interface.syntax);
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-08-17 00:53:09 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
for (x = 0; x < argc; x++) {
|
2006-08-17 00:53:09 +00:00
|
|
|
if (!strcasecmp(argv[x], "undef")) {
|
|
|
|
argv[x] = NULL;
|
|
|
|
}
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-11-09 05:39:04 +00:00
|
|
|
if (!strcasecmp(argv[0], "machine")) {
|
|
|
|
machine = 1;
|
|
|
|
i++;
|
|
|
|
}
|
2006-08-17 00:53:09 +00:00
|
|
|
|
2006-11-09 05:39:04 +00:00
|
|
|
aleg = argv[i++];
|
|
|
|
exten = argv[i++];
|
|
|
|
dp = argv[i++];
|
|
|
|
context = argv[i++];
|
|
|
|
cid_name = argv[i++];
|
|
|
|
cid_num = argv[i++];
|
2007-03-29 22:31:56 +00:00
|
|
|
|
2006-08-17 00:53:09 +00:00
|
|
|
if (!dp) {
|
|
|
|
dp = "XML";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!context) {
|
|
|
|
context = "default";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argv[6]) {
|
|
|
|
timeout = atoi(argv[6]);
|
|
|
|
}
|
|
|
|
|
2007-03-30 00:13:31 +00:00
|
|
|
if (switch_ivr_originate(NULL, &caller_session, &cause, aleg, timeout, NULL, cid_name, cid_num, NULL) != SWITCH_STATUS_SUCCESS) {
|
2006-11-09 05:39:04 +00:00
|
|
|
if (machine) {
|
2007-02-27 22:53:57 +00:00
|
|
|
stream->write_function(stream, "fail: %s\n", switch_channel_cause2str(cause));
|
2006-11-09 05:39:04 +00:00
|
|
|
} else {
|
2007-03-30 00:13:31 +00:00
|
|
|
stream->write_function(stream, "Cannot Create Outgoing Channel! [%s] cause: %s\n", aleg, switch_channel_cause2str(cause));
|
2006-11-09 05:39:04 +00:00
|
|
|
}
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-08-17 00:53:09 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
2007-03-29 22:31:56 +00:00
|
|
|
}
|
2006-08-17 00:53:09 +00:00
|
|
|
|
|
|
|
caller_channel = switch_core_session_get_channel(caller_session);
|
|
|
|
assert(caller_channel != NULL);
|
|
|
|
switch_channel_clear_state_handler(caller_channel, NULL);
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
if (*exten == '&' && *(exten + 1)) {
|
2006-09-07 03:58:01 +00:00
|
|
|
switch_caller_extension_t *extension = NULL;
|
|
|
|
char *app_name = switch_core_session_strdup(caller_session, (exten + 1));
|
2007-02-23 21:00:20 +00:00
|
|
|
char *arg = NULL, *e;
|
2006-09-07 03:58:01 +00:00
|
|
|
|
|
|
|
if ((e = strchr(app_name, ')'))) {
|
|
|
|
*e = '\0';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((arg = strchr(app_name, '('))) {
|
|
|
|
*arg++ = '\0';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((extension = switch_caller_extension_new(caller_session, app_name, arg)) == 0) {
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "memory error!\n");
|
|
|
|
switch_channel_hangup(caller_channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2006-09-07 03:58:01 +00:00
|
|
|
return SWITCH_STATUS_MEMERR;
|
|
|
|
}
|
|
|
|
switch_caller_extension_add_application(caller_session, extension, app_name, arg);
|
|
|
|
switch_channel_set_caller_extension(caller_channel, extension);
|
|
|
|
switch_channel_set_state(caller_channel, CS_EXECUTE);
|
|
|
|
} else {
|
|
|
|
switch_ivr_session_transfer(caller_session, exten, dp, context);
|
|
|
|
}
|
2006-11-09 05:39:04 +00:00
|
|
|
|
|
|
|
if (machine) {
|
|
|
|
stream->write_function(stream, "success: %s\n", switch_core_session_get_uuid(caller_session));
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "Created Session: %s\n", switch_core_session_get_uuid(caller_session));
|
|
|
|
}
|
2007-04-13 22:15:58 +00:00
|
|
|
|
|
|
|
if (caller_session) {
|
|
|
|
switch_core_session_rwunlock(caller_session);
|
|
|
|
}
|
2006-11-09 05:39:04 +00:00
|
|
|
|
2007-05-12 14:48:14 +00:00
|
|
|
switch_safe_free(mycmd);
|
2007-05-04 02:09:24 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
2006-08-17 00:53:09 +00:00
|
|
|
}
|
|
|
|
|
2007-03-30 00:10:33 +00:00
|
|
|
static void sch_api_callback(switch_scheduler_task_t *task)
|
|
|
|
{
|
|
|
|
char *cmd, *arg = NULL;
|
|
|
|
switch_stream_handle_t stream = { 0 };
|
|
|
|
|
|
|
|
assert(task);
|
|
|
|
|
|
|
|
cmd = (char *) task->cmd_arg;
|
2007-03-30 00:13:31 +00:00
|
|
|
|
2007-03-30 00:10:33 +00:00
|
|
|
if ((arg = strchr(cmd, ' '))) {
|
|
|
|
*arg++ = '\0';
|
|
|
|
}
|
|
|
|
|
|
|
|
SWITCH_STANDARD_STREAM(stream);
|
|
|
|
switch_api_execute(cmd, arg, NULL, &stream);
|
2007-03-30 00:13:31 +00:00
|
|
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Command %s(%s):\n%s\n", cmd, arg, switch_str_nil((char *) stream.data));
|
2007-03-30 00:10:33 +00:00
|
|
|
switch_safe_free(stream.data);
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(sched_del_function)
|
2007-03-30 14:57:06 +00:00
|
|
|
{
|
|
|
|
uint32_t cnt = 0;
|
|
|
|
|
|
|
|
if (switch_is_digit_string(cmd)) {
|
|
|
|
int64_t tmp;
|
|
|
|
tmp = (uint32_t) atoi(cmd);
|
|
|
|
if (tmp > 0) {
|
|
|
|
cnt = switch_scheduler_del_task_id((uint32_t)tmp);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
cnt = switch_scheduler_del_task_group(cmd);
|
|
|
|
}
|
|
|
|
|
|
|
|
stream->write_function(stream, "DELETED: %u\n", cnt);
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(xml_wrap_api_function)
|
2007-04-07 20:30:28 +00:00
|
|
|
{
|
|
|
|
char *dcommand, *edata = NULL, *send = NULL, *command, *arg = NULL;
|
|
|
|
switch_stream_handle_t mystream = { 0 };
|
|
|
|
int encoded = 0, elen = 0;
|
|
|
|
|
|
|
|
if ((dcommand = strdup(cmd))) {
|
|
|
|
if (!strncasecmp(dcommand, "encoded ", 8)) {
|
|
|
|
encoded++;
|
|
|
|
command = dcommand + 8;
|
|
|
|
} else {
|
|
|
|
command = dcommand;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((arg = strchr(command, ' '))) {
|
|
|
|
*arg++ = '\0';
|
|
|
|
}
|
|
|
|
SWITCH_STANDARD_STREAM(mystream);
|
|
|
|
switch_api_execute(command, arg, NULL, &mystream);
|
|
|
|
|
|
|
|
if (mystream.data) {
|
|
|
|
if (encoded) {
|
|
|
|
elen = (int) strlen(mystream.data) * 3;
|
|
|
|
edata = malloc(elen);
|
|
|
|
assert(edata != NULL);
|
|
|
|
memset(edata, 0, elen);
|
|
|
|
switch_url_encode(mystream.data, edata, elen);
|
|
|
|
send = edata;
|
|
|
|
} else {
|
|
|
|
send = mystream.data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
stream->write_function(stream,
|
|
|
|
"<result>\n"
|
|
|
|
" <row id=\"1\">\n"
|
|
|
|
" <data>%s</data>\n"
|
|
|
|
" </row>\n"
|
|
|
|
"</result>\n",
|
|
|
|
send ? send : "ERROR"
|
|
|
|
);
|
|
|
|
switch_safe_free(mystream.data);
|
|
|
|
switch_safe_free(edata);
|
|
|
|
free(dcommand);
|
|
|
|
}
|
|
|
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(sched_api_function)
|
2007-03-30 00:10:33 +00:00
|
|
|
{
|
2007-03-30 00:36:02 +00:00
|
|
|
char *tm = NULL, *dcmd, *group;
|
2007-03-30 00:10:33 +00:00
|
|
|
time_t when;
|
|
|
|
|
|
|
|
assert(cmd != NULL);
|
|
|
|
tm = strdup(cmd);
|
|
|
|
assert(tm != NULL);
|
2007-03-30 00:13:31 +00:00
|
|
|
|
2007-03-30 00:36:02 +00:00
|
|
|
if ((group = strchr(tm, ' '))) {
|
2007-03-30 00:10:33 +00:00
|
|
|
uint32_t id;
|
|
|
|
|
2007-03-30 00:36:02 +00:00
|
|
|
*group++ = '\0';
|
2007-03-30 00:10:33 +00:00
|
|
|
|
2007-03-30 00:36:02 +00:00
|
|
|
if ((dcmd = strchr(group, ' '))) {
|
|
|
|
*dcmd++ = '\0';
|
|
|
|
|
|
|
|
if (*tm == '+') {
|
|
|
|
when = time(NULL) + atol(tm + 1);
|
|
|
|
} else {
|
|
|
|
when = atol(tm);
|
|
|
|
}
|
|
|
|
|
|
|
|
id = switch_scheduler_add_task(when, sch_api_callback, (char *) __SWITCH_FUNC__, group, 0, strdup(dcmd), SSHF_FREE_ARG);
|
2007-03-30 14:57:06 +00:00
|
|
|
stream->write_function(stream, "ADDED: %u\n", id);
|
2007-03-30 00:36:02 +00:00
|
|
|
goto good;
|
|
|
|
}
|
2007-03-30 00:13:31 +00:00
|
|
|
}
|
2007-03-30 00:10:33 +00:00
|
|
|
|
2007-03-30 00:36:02 +00:00
|
|
|
stream->write_function(stream, "Invalid syntax\n");
|
|
|
|
|
|
|
|
good:
|
|
|
|
|
2007-03-30 00:10:33 +00:00
|
|
|
switch_safe_free(tm);
|
2007-03-30 00:13:31 +00:00
|
|
|
|
2007-03-30 00:10:33 +00:00
|
|
|
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;
|
2007-04-24 01:15:27 +00:00
|
|
|
char *delim;
|
2006-07-19 19:16:42 +00:00
|
|
|
uint32_t count;
|
2006-10-08 08:09:57 +00:00
|
|
|
int print_title;
|
2007-04-07 20:30:28 +00:00
|
|
|
switch_xml_t xml;
|
|
|
|
int rows;
|
2006-07-19 19:16:42 +00:00
|
|
|
};
|
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
static int show_as_xml_callback(void *pArg, int argc, char **argv, char **columnNames)
|
|
|
|
{
|
|
|
|
struct holder *holder = (struct holder *) pArg;
|
|
|
|
switch_xml_t row, field;
|
|
|
|
int x, f_off = 0;
|
|
|
|
char id[50];
|
|
|
|
|
|
|
|
if (holder->count == 0) {
|
|
|
|
if (!(holder->xml = switch_xml_new("result"))) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(row = switch_xml_add_child_d(holder->xml, "row", holder->rows++))) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf(id, sizeof(id), "%d", holder->rows);
|
2007-04-14 01:52:42 +00:00
|
|
|
switch_xml_set_attr_d(row, "row_id", id);
|
2007-04-07 20:30:28 +00:00
|
|
|
|
|
|
|
for(x = 0; x < argc; x++) {
|
2007-04-26 15:02:46 +00:00
|
|
|
char *name = columnNames[x];
|
|
|
|
char *val = switch_str_nil(argv[x]);
|
|
|
|
|
|
|
|
if (!name) {
|
|
|
|
name = "undefined";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((field = switch_xml_add_child_d(row, name, f_off++))) {
|
|
|
|
switch_xml_set_txt_d(field, val);
|
2007-04-07 20:30:28 +00:00
|
|
|
} else {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
holder->count++;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +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;
|
|
|
|
|
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
if (holder->print_title && holder->count == 0) {
|
2006-07-20 03:55:07 +00:00
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "\n<tr>");
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
for (x = 0; x < argc; x++) {
|
2007-04-26 15:02:46 +00:00
|
|
|
char *name = columnNames[x];
|
|
|
|
|
|
|
|
|
|
|
|
if (!name) {
|
|
|
|
name = "undefined";
|
|
|
|
}
|
|
|
|
|
2006-07-20 03:55:07 +00:00
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<td>");
|
2007-04-26 15:02:46 +00:00
|
|
|
holder->stream->write_function(holder->stream, "<b>%s</b>%s", name, x == (argc - 1) ? "</td></tr>\n" : "</td><td>");
|
2006-07-20 03:55:07 +00:00
|
|
|
} else {
|
2007-04-26 15:02:46 +00:00
|
|
|
holder->stream->write_function(holder->stream, "%s%s", name, x == (argc - 1) ? "\n" : holder->delim);
|
2006-07-20 03:55:07 +00:00
|
|
|
}
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
}
|
2006-07-20 03:55:07 +00:00
|
|
|
|
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<tr bgcolor=%s>", holder->count % 2 == 0 ? "eeeeee" : "ffffff");
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:31:56 +00:00
|
|
|
for (x = 0; x < argc; x++) {
|
2007-04-26 15:02:46 +00:00
|
|
|
char *val = switch_str_nil(argv[x]);
|
|
|
|
|
2006-07-20 03:55:07 +00:00
|
|
|
if (holder->http) {
|
|
|
|
holder->stream->write_function(holder->stream, "<td>");
|
2007-04-26 15:02:46 +00:00
|
|
|
holder->stream->write_function(holder->stream, "%s%s", val, x == (argc - 1) ? "</td></tr>\n" : "</td><td>");
|
2006-07-20 03:55:07 +00:00
|
|
|
} else {
|
2007-04-26 15:02:46 +00:00
|
|
|
holder->stream->write_function(holder->stream, "%s%s", val, x == (argc - 1) ? "\n" : holder->delim);
|
2006-07-20 03:55:07 +00:00
|
|
|
}
|
|
|
|
}
|
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;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(show_function)
|
2006-05-04 16:04:04 +00:00
|
|
|
{
|
|
|
|
char sql[1024];
|
|
|
|
char *errmsg;
|
|
|
|
switch_core_db_t *db = switch_core_db_handle();
|
2007-03-29 22:31:56 +00:00
|
|
|
struct holder holder = { 0 };
|
2006-10-08 08:09:57 +00:00
|
|
|
int help = 0;
|
2007-04-24 01:15:27 +00:00
|
|
|
char *mydata = NULL, *argv[6] = {0};
|
2007-04-07 20:30:28 +00:00
|
|
|
int argc;
|
2007-05-12 21:36:15 +00:00
|
|
|
char *command = NULL, *as = NULL;
|
2006-07-20 03:55:07 +00:00
|
|
|
|
2006-07-26 20:12:49 +00:00
|
|
|
if (session) {
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
if (cmd && (mydata = strdup(cmd))) {
|
2007-05-12 14:48:14 +00:00
|
|
|
argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
|
2007-05-12 21:36:15 +00:00
|
|
|
command = argv[0];
|
2007-04-08 03:53:35 +00:00
|
|
|
if (argv[2] && !strcasecmp(argv[1], "as")) {
|
|
|
|
as = argv[2];
|
|
|
|
}
|
2007-04-07 20:30:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!as && stream->event) {
|
2006-10-31 05:04:47 +00:00
|
|
|
holder.http = switch_event_get_header(stream->event, "http-host");
|
2007-03-29 22:31:56 +00:00
|
|
|
}
|
2006-07-20 03:55:07 +00:00
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
holder.print_title = 1;
|
|
|
|
|
2006-10-31 05:04:47 +00:00
|
|
|
// If you changes the field qty or order of any of these select
|
|
|
|
// statmements, you must also change show_callback and friends to match!
|
2007-05-12 21:36:15 +00:00
|
|
|
if (!command) {
|
2007-02-23 20:32:31 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", show_api_interface.syntax);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
2007-05-12 21:36:15 +00:00
|
|
|
} else if (!strcmp(command, "codec") || !strcmp(command, "dialplan") || !strcmp(command, "file") || !strcmp(command, "timer")) {
|
|
|
|
sprintf(sql, "select type, name from interfaces where type = '%s'", command);
|
|
|
|
} else if (!strcmp(command, "tasks")) {
|
|
|
|
sprintf(sql, "select * from %s", command);
|
|
|
|
} else if (!strcmp(command, "application") || !strcmp(command, "api")) {
|
|
|
|
sprintf(sql, "select name, description, syntax from interfaces where type = '%s' and description != ''", command);
|
|
|
|
} else if (!strcmp(command, "calls")) {
|
2007-03-29 22:31:56 +00:00
|
|
|
sprintf(sql, "select * from calls");
|
2007-05-12 21:36:15 +00:00
|
|
|
} else if (!strcmp(command, "channels")) {
|
2007-03-29 22:31:56 +00:00
|
|
|
sprintf(sql, "select * from channels");
|
2007-05-12 21:36:15 +00:00
|
|
|
} else if (!strncasecmp(command, "help", 4)) {
|
2006-10-08 08:09:57 +00:00
|
|
|
char *cmdname = NULL;
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
help = 1;
|
|
|
|
holder.print_title = 0;
|
2007-05-12 21:36:15 +00:00
|
|
|
if ((cmdname = strchr(command, ' ')) != 0) {
|
2006-10-08 08:09:57 +00:00
|
|
|
*cmdname++ = '\0';
|
2007-03-30 00:13:31 +00:00
|
|
|
snprintf(sql, sizeof(sql) - 1, "select name, syntax, description from interfaces where type = 'api' and name = '%s'", cmdname);
|
2006-10-08 08:09:57 +00:00
|
|
|
} else {
|
2007-03-29 22:31:56 +00:00
|
|
|
snprintf(sql, sizeof(sql) - 1, "select name, syntax, description from interfaces where type = 'api'");
|
2006-10-08 08:09:57 +00:00
|
|
|
}
|
2006-10-31 05:04:47 +00:00
|
|
|
} else {
|
2006-10-08 07:11:42 +00:00
|
|
|
stream->write_function(stream, "USAGE: %s\n", show_api_interface.syntax);
|
2006-10-31 05:04:47 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
2007-03-29 22:31:56 +00:00
|
|
|
|
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");
|
|
|
|
}
|
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
if (!as) {
|
2007-04-24 01:15:27 +00:00
|
|
|
as = "delim";
|
|
|
|
holder.delim = ",";
|
2006-07-20 03:55:07 +00:00
|
|
|
}
|
|
|
|
|
2007-04-24 01:15:27 +00:00
|
|
|
if (!strcasecmp(as, "delim") || !strcasecmp(as, "csv")) {
|
|
|
|
if (switch_strlen_zero(holder.delim)) {
|
|
|
|
if (!(holder.delim = argv[3])) {
|
|
|
|
holder.delim = ",";
|
|
|
|
}
|
|
|
|
}
|
2007-04-07 20:30:28 +00:00
|
|
|
switch_core_db_exec(db, sql, show_callback, &holder, &errmsg);
|
|
|
|
if (holder.http) {
|
|
|
|
holder.stream->write_function(holder.stream, "</table>");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (errmsg) {
|
|
|
|
stream->write_function(stream, "SQL ERR [%s]\n", errmsg);
|
|
|
|
switch_core_db_free(errmsg);
|
|
|
|
errmsg = NULL;
|
|
|
|
} else if (help) {
|
|
|
|
if (holder.count == 0)
|
|
|
|
stream->write_function(stream, "No such command.\n");
|
|
|
|
} else {
|
|
|
|
stream->write_function(stream, "\n%u total.\n", holder.count);
|
|
|
|
}
|
|
|
|
} else if (!strcasecmp(as, "xml")) {
|
|
|
|
switch_core_db_exec(db, sql, show_as_xml_callback, &holder, &errmsg);
|
2007-04-26 15:02:46 +00:00
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
if (holder.xml) {
|
2007-04-14 01:52:42 +00:00
|
|
|
char count[50];
|
2007-04-15 01:06:29 +00:00
|
|
|
char *xmlstr;
|
2007-04-14 01:52:42 +00:00
|
|
|
snprintf(count, sizeof(count), "%d", holder.count);
|
|
|
|
switch_xml_set_attr_d(holder.xml, "row_count", count);
|
2007-04-15 01:06:29 +00:00
|
|
|
xmlstr = switch_xml_toxml(holder.xml);
|
2007-04-14 01:52:42 +00:00
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
if (xmlstr) {
|
|
|
|
holder.stream->write_function(holder.stream, "%s", xmlstr);
|
|
|
|
free(xmlstr);
|
|
|
|
} else {
|
2007-04-14 01:52:42 +00:00
|
|
|
holder.stream->write_function(holder.stream, "<result row_count=\"0\"/>\n");
|
2007-04-07 20:30:28 +00:00
|
|
|
}
|
|
|
|
} else {
|
2007-04-14 01:52:42 +00:00
|
|
|
holder.stream->write_function(holder.stream, "<result row_count=\"0\"/>\n");
|
2007-04-07 20:30:28 +00:00
|
|
|
}
|
2006-07-19 19:16:42 +00:00
|
|
|
} else {
|
2007-04-07 20:30:28 +00:00
|
|
|
holder.stream->write_function(holder.stream, "Cannot find format %s\n", as);
|
2006-05-04 16:04:04 +00:00
|
|
|
}
|
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
switch_safe_free(mydata);
|
2006-05-04 16:04:04 +00:00
|
|
|
switch_core_db_close(db);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(version_function)
|
2006-11-28 19:33:54 +00:00
|
|
|
{
|
|
|
|
char version_string[1024];
|
2007-03-29 22:31:56 +00:00
|
|
|
snprintf(version_string, sizeof(version_string) - 1, "FreeSwitch Version %s\n", SWITCH_VERSION_FULL);
|
2006-11-28 19:33:54 +00:00
|
|
|
|
|
|
|
stream->write_function(stream, version_string);
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2007-05-12 21:36:15 +00:00
|
|
|
SWITCH_STANDARD_API(help_function)
|
2006-10-08 08:09:57 +00:00
|
|
|
{
|
|
|
|
char showcmd[1024];
|
|
|
|
int all = 0;
|
|
|
|
if (switch_strlen_zero(cmd)) {
|
2007-03-29 22:31:56 +00:00
|
|
|
sprintf(showcmd, "help");
|
2006-10-08 08:09:57 +00:00
|
|
|
all = 1;
|
|
|
|
} else {
|
2007-03-29 22:31:56 +00:00
|
|
|
snprintf(showcmd, sizeof(showcmd) - 1, "help %s", cmd);
|
2006-10-08 08:09:57 +00:00
|
|
|
}
|
|
|
|
|
2006-10-31 05:04:47 +00:00
|
|
|
if (all) {
|
2006-10-08 08:09:57 +00:00
|
|
|
stream->write_function(stream, "\nValid Commands:\n\n");
|
2006-10-31 05:04:47 +00:00
|
|
|
}
|
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
show_function(showcmd, session, stream);
|
2006-10-31 05:04:47 +00:00
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
}
|
2006-05-04 16:04:04 +00:00
|
|
|
|
2007-04-07 20:30:28 +00:00
|
|
|
|
|
|
|
static switch_api_interface_t xml_wrap_api_interface = {
|
|
|
|
/*.interface_name */ "xml_wrap",
|
|
|
|
/*.desc */ "Wrap another api command in xml",
|
|
|
|
/*.function */ xml_wrap_api_function,
|
|
|
|
/*.syntax */ "<command> <args>",
|
|
|
|
/*.next */ NULL
|
|
|
|
};
|
|
|
|
|
2007-03-30 14:57:06 +00:00
|
|
|
static switch_api_interface_t sched_del_api_interface = {
|
|
|
|
/*.interface_name */ "sched_del",
|
|
|
|
/*.desc */ "Delete a Scheduled task",
|
|
|
|
/*.function */ sched_del_function,
|
|
|
|
/*.syntax */ "<task_id>|<group_id>",
|
2007-04-07 20:30:28 +00:00
|
|
|
/*.next */ &xml_wrap_api_interface
|
2007-03-30 14:57:06 +00:00
|
|
|
};
|
|
|
|
|
2007-03-30 00:10:33 +00:00
|
|
|
static switch_api_interface_t sched_api_api_interface = {
|
|
|
|
/*.interface_name */ "sched_api",
|
|
|
|
/*.desc */ "Schedule an api command",
|
|
|
|
/*.function */ sched_api_function,
|
2007-03-30 00:36:02 +00:00
|
|
|
/*.syntax */ "[+]<time> <group_name> <command_string>",
|
2007-03-30 14:57:06 +00:00
|
|
|
/*.next */ &sched_del_api_interface
|
2007-03-30 00:10:33 +00:00
|
|
|
};
|
|
|
|
|
2007-03-28 23:37:12 +00:00
|
|
|
static switch_api_interface_t sched_transfer_api_interface = {
|
|
|
|
/*.interface_name */ "sched_transfer",
|
|
|
|
/*.desc */ "Schedule a broadcast event to a running call",
|
|
|
|
/*.function */ sched_transfer_function,
|
|
|
|
/*.syntax */ "[+]<time> <uuid> <extension> [<dialplan>] [<context>]",
|
2007-03-30 00:10:33 +00:00
|
|
|
/*.next */ &sched_api_api_interface
|
2007-03-28 23:37:12 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static switch_api_interface_t sched_broadcast_api_interface = {
|
|
|
|
/*.interface_name */ "sched_broadcast",
|
|
|
|
/*.desc */ "Schedule a broadcast event to a running call",
|
|
|
|
/*.function */ sched_broadcast_function,
|
|
|
|
/*.syntax */ "[+]<time> <uuid> <path> [aleg|bleg|both]",
|
|
|
|
/*.next */ &sched_transfer_api_interface
|
|
|
|
};
|
|
|
|
|
|
|
|
static switch_api_interface_t sched_hangup_api_interface = {
|
|
|
|
/*.interface_name */ "sched_hangup",
|
|
|
|
/*.desc */ "Schedule a running call to hangup",
|
|
|
|
/*.function */ sched_hangup_function,
|
|
|
|
/*.syntax */ "[+]<time> <uuid> [<cause>]",
|
|
|
|
/*.next */ &sched_broadcast_api_interface
|
|
|
|
};
|
|
|
|
|
2006-11-28 19:33:54 +00:00
|
|
|
static switch_api_interface_t version_api_interface = {
|
|
|
|
/*.interface_name */ "version",
|
|
|
|
/*.desc */ "Show version of the switch",
|
|
|
|
/*.function */ version_function,
|
|
|
|
/*.syntax */ "",
|
2007-03-28 23:37:12 +00:00
|
|
|
/*.next */ &sched_hangup_api_interface
|
2006-11-28 19:33:54 +00:00
|
|
|
};
|
|
|
|
|
2006-10-08 08:09:57 +00:00
|
|
|
static switch_api_interface_t help_api_interface = {
|
|
|
|
/*.interface_name */ "help",
|
|
|
|
/*.desc */ "Show help for all the api commands",
|
|
|
|
/*.function */ help_function,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "",
|
2006-11-28 19:33:54 +00:00
|
|
|
/*.next */ &version_api_interface,
|
2006-10-08 08:09:57 +00:00
|
|
|
};
|
2006-09-19 02:18:24 +00:00
|
|
|
|
2006-09-20 20:25:26 +00:00
|
|
|
static switch_api_interface_t ctl_api_interface = {
|
|
|
|
/*.interface_name */ "fsctl",
|
|
|
|
/*.desc */ "control messages",
|
|
|
|
/*.function */ ctl_function,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "[hupall|pause|resume|shutdown]",
|
2006-10-08 08:09:57 +00:00
|
|
|
/*.next */ &help_api_interface
|
2006-09-20 20:25:26 +00:00
|
|
|
};
|
|
|
|
|
2006-10-31 21:38:06 +00:00
|
|
|
static switch_api_interface_t media_api_interface = {
|
|
|
|
/*.interface_name */ "media",
|
|
|
|
/*.desc */ "media",
|
|
|
|
/*.function */ uuid_media_function,
|
|
|
|
/*.syntax */ "<uuid>",
|
|
|
|
/*.next */ &ctl_api_interface
|
|
|
|
};
|
|
|
|
|
|
|
|
static switch_api_interface_t hold_api_interface = {
|
|
|
|
/*.interface_name */ "hold",
|
|
|
|
/*.desc */ "hold",
|
|
|
|
/*.function */ uuid_hold_function,
|
|
|
|
/*.syntax */ "<uuid>",
|
|
|
|
/*.next */ &media_api_interface
|
|
|
|
};
|
|
|
|
|
|
|
|
static switch_api_interface_t broadcast_api_interface = {
|
|
|
|
/*.interface_name */ "broadcast",
|
|
|
|
/*.desc */ "broadcast",
|
|
|
|
/*.function */ uuid_broadcast_function,
|
2006-11-10 08:28:16 +00:00
|
|
|
/*.syntax */ "<uuid> <path> [aleg|bleg|both]",
|
2006-10-31 21:38:06 +00:00
|
|
|
/*.next */ &hold_api_interface
|
|
|
|
};
|
|
|
|
|
2007-01-12 16:05:49 +00:00
|
|
|
static switch_api_interface_t session_record_api_interface = {
|
|
|
|
/*.interface_name */ "session_record",
|
|
|
|
/*.desc */ "session record",
|
|
|
|
/*.function */ session_record_function,
|
2007-05-31 14:42:23 +00:00
|
|
|
/*.syntax */ "<uuid> [start|stop] <path> [<limit>]",
|
2007-01-12 16:05:49 +00:00
|
|
|
/*.next */ &broadcast_api_interface
|
|
|
|
};
|
|
|
|
|
2007-06-15 01:47:48 +00:00
|
|
|
static switch_api_interface_t session_displace_api_interface = {
|
|
|
|
/*.interface_name */ "session_displace",
|
|
|
|
/*.desc */ "session displace",
|
|
|
|
/*.function */ session_displace_function,
|
|
|
|
/*.syntax */ "<uuid> [start|stop] <path> [<limit>] [mux]",
|
|
|
|
/*.next */ &broadcast_api_interface
|
|
|
|
};
|
|
|
|
|
2006-09-19 02:18:24 +00:00
|
|
|
static switch_api_interface_t uuid_bridge_api_interface = {
|
|
|
|
/*.interface_name */ "uuid_bridge",
|
|
|
|
/*.desc */ "uuid_bridge",
|
|
|
|
/*.function */ uuid_bridge_function,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "<uuid> <other_uuid>",
|
2007-06-15 01:47:48 +00:00
|
|
|
/*.next */ &session_displace_api_interface
|
2006-09-19 02:18:24 +00:00
|
|
|
};
|
|
|
|
|
2006-05-10 03:23:05 +00:00
|
|
|
static switch_api_interface_t status_api_interface = {
|
|
|
|
/*.interface_name */ "status",
|
|
|
|
/*.desc */ "status",
|
|
|
|
/*.function */ status_function,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "",
|
2006-09-19 02:18:24 +00:00
|
|
|
/*.next */ &uuid_bridge_api_interface
|
2006-05-10 03:23:05 +00:00
|
|
|
};
|
|
|
|
|
2006-05-04 16:04:04 +00:00
|
|
|
static switch_api_interface_t show_api_interface = {
|
|
|
|
/*.interface_name */ "show",
|
|
|
|
/*.desc */ "Show",
|
|
|
|
/*.function */ show_function,
|
2007-02-23 20:32:31 +00:00
|
|
|
/*.syntax */ "codec|application|api|dialplan|file|timer|calls|channels",
|
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-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "<uuid> <on|off>",
|
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,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "<uuid> <dest-exten> [<dialplan>] [<context>]",
|
2006-04-28 19:46:57 +00:00
|
|
|
/*.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-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "<mod_name>",
|
2006-04-28 19:46:57 +00:00
|
|
|
/*.next */ &transfer_api_interface
|
2006-04-20 00:58:06 +00:00
|
|
|
};
|
|
|
|
|
2007-05-03 16:28:23 +00:00
|
|
|
static switch_api_interface_t unload_api_interface = {
|
|
|
|
/*.interface_name */ "unload",
|
|
|
|
/*.desc */ "Unoad Module",
|
|
|
|
/*.function */ unload_function,
|
|
|
|
/*.syntax */ "<mod_name>",
|
|
|
|
/*.next */ &load_api_interface
|
|
|
|
};
|
|
|
|
|
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,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "",
|
2007-05-03 16:28:23 +00:00
|
|
|
/*.next */ &unload_api_interface,
|
2006-05-26 17:27:09 +00:00
|
|
|
|
|
|
|
};
|
2006-04-20 00:58:06 +00:00
|
|
|
|
2006-10-08 07:11:42 +00:00
|
|
|
static switch_api_interface_t kill_api_interface = {
|
2006-04-04 22:03:59 +00:00
|
|
|
/*.interface_name */ "killchan",
|
|
|
|
/*.desc */ "Kill Channel",
|
|
|
|
/*.function */ kill_function,
|
2006-10-10 12:00:22 +00:00
|
|
|
/*.syntax */ "<uuid>",
|
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,
|
2007-03-29 22:31:56 +00:00
|
|
|
/*.syntax */
|
|
|
|
"<call url> <exten>|&<application_name>(<app_args>) [<dialplan>] [<context>] [<cid_name>] [<cid_num>] [<timeout_sec>]",
|
2006-10-08 07:11:42 +00:00
|
|
|
/*.next */ &kill_api_interface
|
2006-08-17 00:53:09 +00:00
|
|
|
};
|
|
|
|
|
2007-06-13 20:40:06 +00:00
|
|
|
static switch_loadable_module_interface_t 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
|
|
|
};
|
|
|
|
|
2007-06-13 16:00:14 +00:00
|
|
|
SWITCH_MODULE_LOAD_FUNCTION(mod_commands_load)
|
2006-04-04 22:03:59 +00:00
|
|
|
{
|
|
|
|
/* connect my internal structure to the blank pointer passed to me */
|
2007-06-13 16:00:14 +00:00
|
|
|
*module_interface = &commands_module_interface;
|
2006-04-04 22:03:59 +00:00
|
|
|
|
|
|
|
/* indicate that the module should continue to be loaded */
|
2007-05-03 16:28:23 +00:00
|
|
|
return SWITCH_STATUS_NOUNLOAD;
|
2006-04-04 22:03:59 +00:00
|
|
|
}
|
2006-11-27 22:30:48 +00:00
|
|
|
|
|
|
|
/* For Emacs:
|
|
|
|
* Local Variables:
|
|
|
|
* mode:c
|
2007-02-09 02:36:03 +00:00
|
|
|
* indent-tabs-mode:t
|
2006-11-27 22:30:48 +00:00
|
|
|
* tab-width:4
|
|
|
|
* c-basic-offset:4
|
|
|
|
* End:
|
|
|
|
* For VIM:
|
|
|
|
* vim:set softtabstop=4 shiftwidth=4 tabstop=4 expandtab:
|
|
|
|
*/
|