SWITCH_DECLARE(uint32_t) switch_channel_del_variable_prefix(switch_channel_t *channel, const char *prefix);
+#define switch_channel_set_variable_safe(_channel, _var, _val) switch_channel_set_variable_var_check(_channel, _var, _val, SWITCH_FALSE)
#define switch_channel_set_variable(_channel, _var, _val) switch_channel_set_variable_var_check(_channel, _var, _val, SWITCH_TRUE)
#define switch_channel_set_variable_partner(_channel, _var, _val) switch_channel_set_variable_partner_var_check(_channel, _var, _val, SWITCH_TRUE)
char *p, *c = NULL;
char *data, *indup, *endof_indup;
size_t sp = 0, len = 0, olen = 0, vtype = 0, br = 0, cpos, block = 128;
- char *cloned_sub_val = NULL, *sub_val = NULL;
+ char *cloned_sub_val = NULL, *sub_val = NULL, *expanded_sub_val = NULL;
char *func_val = NULL, *sb = NULL;
int nv = 0;
int ooffset = 0;
char *ptr;
int idx = -1;
-
+
if ((expanded = switch_channel_expand_variables_check(channel, (char *) vname, var_list, api_list)) == vname) {
expanded = NULL;
} else {
sub_val = "INVALID";
}
+ if ((expanded_sub_val = switch_channel_expand_variables(channel, sub_val)) == sub_val) {
+ expanded_sub_val = NULL;
+ } else {
+ sub_val = expanded_sub_val;
+ }
+
if (offset || ooffset) {
cloned_sub_val = strdup(sub_val);
switch_assert(cloned_sub_val);
switch_safe_free(func_val);
switch_safe_free(cloned_sub_val);
+ switch_safe_free(expanded_sub_val);
sub_val = NULL;
vname = NULL;
vtype = 0;
switch_event_t *e = *event;
char *var_array[1024] = { 0 };
int var_count = 0;
- char *next;
+ char *next = NULL, *vnext = NULL;
if (dup) {
vdatap = strdup(data);
if (check_a) end = check_a;
if (end) {
+ next = end;
vdata++;
*end++ = '\0';
} else {
for (;;) {
- if ((next = strchr(vdata, b))) {
+ if (next) {
char *pnext;
+
*next++ = '\0';
if ((pnext = switch_strchr_strict(next, a, " "))) {
next = pnext + 1;
}
+
+ vnext = switch_find_end_paren(next, a, b);
+ next = NULL;
}
if ((inner_var_count = switch_separate_string(var_array[x], '=',
inner_var_array, (sizeof(inner_var_array) / sizeof(inner_var_array[0])))) == 2) {
- switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Parsing variable [%s]=[%s]\n", inner_var_array[0], inner_var_array[1]);
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "Parsing variable [%s]=[%s]\n", inner_var_array[0], inner_var_array[1]);
switch_event_add_header_string(e, SWITCH_STACK_BOTTOM, inner_var_array[0], inner_var_array[1]);
}
}
}
- if (next) {
- vdata = next;
+ if (vnext) {
+ vdata = vnext;
} else {
break;
}
char *data, *indup, *endof_indup;
size_t sp = 0, len = 0, olen = 0, vtype = 0, br = 0, cpos, block = 128;
const char *sub_val = NULL;
- char *cloned_sub_val = NULL;
+ char *cloned_sub_val = NULL, *expanded_sub_val = NULL;
char *func_val = NULL;
int nv = 0;
char *gvar = NULL, *sb = NULL;
sub_val = "INVALID";
}
- }
- if (offset || ooffset) {
- cloned_sub_val = strdup(sub_val);
- switch_assert(cloned_sub_val);
- sub_val = cloned_sub_val;
- }
+ if ((expanded_sub_val = switch_event_expand_headers(event, sub_val)) == sub_val) {
+ expanded_sub_val = NULL;
+ } else {
+ sub_val = expanded_sub_val;
+ }
+
- if (offset >= 0) {
- sub_val += offset;
- } else if ((size_t) abs(offset) <= strlen(sub_val)) {
- sub_val = cloned_sub_val + (strlen(cloned_sub_val) + offset);
- }
+ if (offset || ooffset) {
+ cloned_sub_val = strdup(sub_val);
+ switch_assert(cloned_sub_val);
+ sub_val = cloned_sub_val;
+ }
+
+ if (offset >= 0) {
+ sub_val += offset;
+ } else if ((size_t) abs(offset) <= strlen(sub_val)) {
+ sub_val = cloned_sub_val + (strlen(cloned_sub_val) + offset);
+ }
- if (ooffset > 0 && (size_t) ooffset < strlen(sub_val)) {
- if ((ptr = (char *) sub_val + ooffset)) {
- *ptr = '\0';
+ if (ooffset > 0 && (size_t) ooffset < strlen(sub_val)) {
+ if ((ptr = (char *) sub_val + ooffset)) {
+ *ptr = '\0';
+ }
}
}
switch_safe_free(func_val);
switch_safe_free(cloned_sub_val);
+ switch_safe_free(expanded_sub_val);
sub_val = NULL;
vname = NULL;
vtype = 0;
int bridge_early_media;
switch_thread_t *ethread;
switch_caller_profile_t *caller_profile_override;
+ switch_bool_t check_vars;
switch_memory_pool_t *pool;
} originate_global_t;
caller_profile_override, ovars, flags, cancel_cause);
}
+ oglobals.check_vars = SWITCH_TRUE;
oglobals.ringback_ok = 1;
oglobals.bridge_early_media = -1;
oglobals.file = NULL;
data++;
}
+ if ((ovars && switch_true(switch_event_get_header(ovars,"origination_nested_vars"))) ||
+ (caller_channel && switch_true(switch_channel_get_variable(caller_channel, "origination_nested_vars")))
+ || switch_true(switch_core_get_variable("origination_nested_vars")) || switch_stristr("origination_nested_vars=true", data)) {
+ oglobals.check_vars = SWITCH_FALSE;
+ }
+
/* extract channel variables, allowing multiple sets of braces */
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Parsing global variables\n");
while (*data == '{') {
switch_event_header_t *header;
/* install the vars from the {} params */
for (header = var_event->headers; header; header = header->next) {
- switch_channel_set_variable(originate_status[i].peer_channel, header->name, header->value);
+ switch_channel_set_variable_var_check(originate_status[i].peer_channel, header->name, header->value, oglobals.check_vars);
}
}
}
if (local_var_event) {
switch_event_header_t *header;
for (header = local_var_event->headers; header; header = header->next) {
- switch_channel_set_variable(originate_status[i].peer_channel, header->name, header->value);
+ switch_channel_set_variable_var_check(originate_status[i].peer_channel, header->name, header->value, oglobals.check_vars);
}
switch_event_destroy(&local_var_event);
}
switch_event_header_t *header;
/* install the vars from the {} params */
for (header = var_event->headers; header; header = header->next) {
- switch_channel_set_variable(originate_status[i].peer_channel, header->name, header->value);
+ switch_channel_set_variable_var_check(originate_status[i].peer_channel, header->name, header->value, oglobals.check_vars);
}
}
}