#define SWITCH_COPY_XML_CDR_VARIABLE "copy_xml_cdr"
#define SWITCH_CURRENT_APPLICATION_VARIABLE "current_application"
#define SWITCH_PROTO_SPECIFIC_HANGUP_CAUSE_VARIABLE "proto_specific_hangup_cause"
+
#define SWITCH_CHANNEL_EXECUTE_ON_ANSWER_VARIABLE "execute_on_answer"
#define SWITCH_CHANNEL_EXECUTE_ON_PRE_ANSWER_VARIABLE "execute_on_pre_answer"
#define SWITCH_CHANNEL_EXECUTE_ON_MEDIA_VARIABLE "execute_on_media"
-#define SWITCH_CHANNEL_API_ON_ANSWER_VARIABLE "api_on_answer"
#define SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE "execute_on_ring"
#define SWITCH_CHANNEL_EXECUTE_ON_TONE_DETECT_VARIABLE "execute_on_tone_detect"
+#define SWITCH_CHANNEL_EXECUTE_ON_ORIGINATE_VARIABLE "execute_on_originate"
+
+#define SWITCH_CHANNEL_API_ON_ANSWER_VARIABLE "api_on_answer"
+#define SWITCH_CHANNEL_API_ON_PRE_ANSWER_VARIABLE "api_on_pre_answer"
+#define SWITCH_CHANNEL_API_ON_MEDIA_VARIABLE "api_on_media"
+#define SWITCH_CHANNEL_API_ON_RING_VARIABLE "api_on_ring"
+#define SWITCH_CHANNEL_API_ON_TONE_DETECT_VARIABLE "api_on_tone_detect"
+#define SWITCH_CHANNEL_API_ON_ORIGINATE_VARIABLE "api_on_originate"
+
#define SWITCH_CALL_TIMEOUT_VARIABLE "call_timeout"
#define SWITCH_HOLDING_UUID_VARIABLE "holding_uuid"
#define SWITCH_SOFT_HOLDING_UUID_VARIABLE "soft_holding_uuid"
{
switch_t38_options_t *t38_options = switch_channel_get_private(tech_pvt->channel, "t38_options");
sdp_attribute_t *attr;
- const char *var;
if (!t38_options) {
t38_options = switch_core_session_alloc(tech_pvt->session, sizeof(switch_t38_options_t));
switch_channel_set_private(tech_pvt->channel, "t38_options", t38_options);
switch_channel_set_app_flag_key("T38", tech_pvt->channel, CF_APP_T38);
- if ((var = switch_channel_get_variable(tech_pvt->channel, "sip_execute_on_image"))) {
- char *app, *arg = NULL;
- app = switch_core_session_strdup(tech_pvt->session, var);
-
- if (strstr(app, "::")) {
- switch_core_session_execute_application_async(tech_pvt->session, app, arg);
- } else {
- if ((arg = strchr(app, ' '))) {
- *arg++ = '\0';
- }
-
- switch_core_session_execute_application(tech_pvt->session, app, arg);
- }
- }
+ switch_channel_execute_on(tech_pvt->channel, "sip_execute_on_image");
+ switch_channel_api_on(tech_pvt->channel, "sip_api_on_image");
return t38_options;
}
}
switch_channel_execute_on(channel, SWITCH_CHANNEL_EXECUTE_ON_RING_VARIABLE);
+ switch_channel_api_on(channel, SWITCH_CHANNEL_API_ON_RING_VARIABLE);
return SWITCH_STATUS_SUCCESS;
}
switch_channel_execute_on(channel, SWITCH_CHANNEL_EXECUTE_ON_PRE_ANSWER_VARIABLE);
switch_channel_execute_on(channel, SWITCH_CHANNEL_EXECUTE_ON_MEDIA_VARIABLE);
-
+ switch_channel_api_on(channel, SWITCH_CHANNEL_API_ON_PRE_ANSWER_VARIABLE);
+ switch_channel_api_on(channel, SWITCH_CHANNEL_API_ON_MEDIA_VARIABLE);
if ((var = switch_channel_get_variable(channel, SWITCH_PASSTHRU_PTIME_MISMATCH_VARIABLE))) {
switch_channel_set_flag(channel, CF_PASSTHRU_PTIME_MISMATCH);
return status;
}
-SWITCH_DECLARE(switch_status_t) switch_channel_execute_on(switch_channel_t *channel, const char *variable_prefix)
+static void do_api_on(switch_channel_t *channel, const char *variable)
{
- switch_event_header_t *hi;
+ char *app;
+ char *arg = NULL;
+ switch_stream_handle_t stream = { 0 };
+
+ app = switch_core_session_strdup(channel->session, variable);
+
+ if ((arg = strchr(app, ' '))) {
+ *arg++ = '\0';
+ }
+
+ SWITCH_STANDARD_STREAM(stream);
+ switch_log_printf(SWITCH_CHANNEL_CHANNEL_LOG(channel), SWITCH_LOG_DEBUG, "%s process %s: %s(%s)\n%s\n",
+ channel->name, variable, app, switch_str_nil(arg), (char *) stream.data);
+ switch_api_execute(app, arg, NULL, &stream);
+ free(stream.data);
+}
+
+
+SWITCH_DECLARE(switch_status_t) switch_channel_api_on(switch_channel_t *channel, const char *variable_prefix)
+{
+ switch_event_header_t *hp;
switch_event_t *event;
int x = 0;
+
switch_channel_get_variables(channel, &event);
- for (hi = event->headers; hi; hi = hi->next) {
- char *var = hi->name;
- char *val = hi->value;
- char *app;
-
- if (!strncasecmp(var, variable_prefix, strlen(variable_prefix))) {
- char *arg = NULL;
- char *p;
- int bg = 0;
- x++;
+ for (hp = event->headers; hp; hp = hp->next) {
+ char *var = hp->name;
+ char *val = hp->value;
- app = switch_core_session_strdup(channel->session, val);
-
- for(p = app; p && *p; p++) {
- if (*p == ' ') {
- *p++ = '\0';
- arg = p;
- break;
- } else if (*p == ':' && (*(p+1) == ':')) {
- bg++;
- break;
+ if (!strncasecmp(var, variable_prefix, strlen(variable_prefix))) {
+ if (hp->idx) {
+ int i;
+ for (i = 0; i < hp->idx; i++) {
+ x++;
+ do_api_on(channel, hp->array[i]);
}
+ } else {
+ x++;
+ do_api_on(channel, val);
}
+ }
+ }
+
+ switch_event_destroy(&event);
-
- if (bg) {
- switch_core_session_execute_application_async(channel->session, app, arg);
+ return x ? SWITCH_STATUS_SUCCESS : SWITCH_STATUS_FALSE;
+}
+
+static void do_execute_on(switch_channel_t *channel, const char *variable)
+{
+ char *arg = NULL;
+ char *p;
+ int bg = 0;
+ char *app;
+
+ app = switch_core_session_strdup(channel->session, variable);
+
+ for(p = app; p && *p; p++) {
+ if (*p == ' ') {
+ *p++ = '\0';
+ arg = p;
+ break;
+ } else if (*p == ':' && (*(p+1) == ':')) {
+ bg++;
+ break;
+ }
+ }
+
+
+ if (bg) {
+ switch_core_session_execute_application_async(channel->session, app, arg);
+ } else {
+ switch_core_session_execute_application(channel->session, app, arg);
+ }
+}
+
+SWITCH_DECLARE(switch_status_t) switch_channel_execute_on(switch_channel_t *channel, const char *variable_prefix)
+{
+ switch_event_header_t *hp;
+ switch_event_t *event;
+ int x = 0;
+
+ switch_channel_get_variables(channel, &event);
+
+ for (hp = event->headers; hp; hp = hp->next) {
+ char *var = hp->name;
+ char *val = hp->value;
+
+ if (!strncasecmp(var, variable_prefix, strlen(variable_prefix))) {
+ if (hp->idx) {
+ int i;
+ for (i = 0; i < hp->idx; i++) {
+ x++;
+ do_execute_on(channel, hp->array[i]);
+ }
} else {
- switch_core_session_execute_application(channel->session, app, arg);
+ x++;
+ do_execute_on(channel, val);
}
}
}
const char *uuid;
switch_core_session_t *other_session;
const char *var;
- char *app;
switch_assert(channel != NULL);
if (!switch_channel_test_flag(channel, CF_EARLY_MEDIA)) {
switch_channel_execute_on(channel, SWITCH_CHANNEL_EXECUTE_ON_MEDIA_VARIABLE);
+ switch_channel_api_on(channel, SWITCH_CHANNEL_API_ON_MEDIA_VARIABLE);
}
- if ((var = switch_channel_get_variable(channel, SWITCH_CHANNEL_API_ON_ANSWER_VARIABLE)) && !zstr(var)) {
- switch_stream_handle_t stream = { 0 };
- char *arg = NULL;
-
- app = switch_core_session_strdup(channel->session, var);
- if ((arg = strchr(app, ' '))) {
- *arg++ = '\0';
- }
-
- SWITCH_STANDARD_STREAM(stream);
- switch_api_execute(app, arg, NULL, &stream);
-
- switch_log_printf(SWITCH_CHANNEL_CHANNEL_LOG(channel), SWITCH_LOG_DEBUG, "%s api on answer: %s(%s)\n%s\n",
- channel->name, app, switch_str_nil(arg), (char *) stream.data);
- free(stream.data);
- }
+ switch_channel_api_on(channel, SWITCH_CHANNEL_API_ON_ANSWER_VARIABLE);
switch_channel_presence(channel, "unknown", "answered", NULL);