Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
F
freeswitch
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
张华
freeswitch
Commits
755be330
提交
755be330
authored
1月 09, 2012
作者:
Anthony Minessale
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add list support for which vars/api to expand in httapi
上级
1ee46a36
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
270 行增加
和
44 行删除
+270
-44
switch_channel.h
src/include/switch_channel.h
+4
-1
switch_event.h
src/include/switch_event.h
+5
-3
httapi.conf.xml
src/mod/applications/mod_httapi/httapi.conf.xml
+35
-2
mod_httapi.c
src/mod/applications/mod_httapi/mod_httapi.c
+149
-21
mod_httapi_doc.txt
src/mod/applications/mod_httapi/mod_httapi_doc.txt
+9
-0
switch_channel.c
src/switch_channel.c
+24
-9
switch_event.c
src/switch_event.c
+44
-8
没有找到文件。
src/include/switch_channel.h
浏览文件 @
755be330
...
...
@@ -591,7 +591,10 @@ SWITCH_DECLARE(void) switch_channel_event_set_extended_data(_In_ switch_channel_
\return the original string if no expansion takes place otherwise a new string that must be freed
\note it's necessary to test if the return val is the same as the input and free the string if it is not.
*/
SWITCH_DECLARE
(
char
*
)
switch_channel_expand_variables
(
_In_
switch_channel_t
*
channel
,
_In_
const
char
*
in
);
SWITCH_DECLARE
(
char
*
)
switch_channel_expand_variables_check
(
switch_channel_t
*
channel
,
const
char
*
in
,
switch_event_t
*
var_list
,
switch_event_t
*
api_list
);
#define switch_channel_expand_variables(_channel, _in) switch_channel_expand_variables_check(_channel, _in, NULL, NULL)
SWITCH_DECLARE
(
char
*
)
switch_channel_build_param_string
(
_In_
switch_channel_t
*
channel
,
_In_opt_
switch_caller_profile_t
*
caller_profile
,
_In_opt_
const
char
*
prefix
);
SWITCH_DECLARE
(
switch_status_t
)
switch_channel_set_timestamps
(
_In_
switch_channel_t
*
channel
);
...
...
src/include/switch_event.h
浏览文件 @
755be330
...
...
@@ -104,7 +104,8 @@ struct switch_event {
typedef
enum
{
EF_UNIQ_HEADERS
=
(
1
<<
0
),
EF_NO_CHAT_EXEC
=
(
1
<<
1
)
EF_NO_CHAT_EXEC
=
(
1
<<
1
),
EF_DEFAULT_ALLOW
=
(
1
<<
2
)
}
switch_event_flag_t
;
...
...
@@ -329,7 +330,8 @@ SWITCH_DECLARE(switch_status_t) switch_event_add_body(switch_event_t *event, con
SWITCH_DECLARE
(
switch_status_t
)
switch_event_set_body
(
switch_event_t
*
event
,
const
char
*
body
);
SWITCH_DECLARE
(
char
*
)
switch_event_expand_headers
(
switch_event_t
*
event
,
const
char
*
in
);
SWITCH_DECLARE
(
char
*
)
switch_event_expand_headers_check
(
switch_event_t
*
event
,
const
char
*
in
,
switch_event_t
*
var_list
,
switch_event_t
*
api_list
);
#define switch_event_expand_headers(_event, _in) switch_event_expand_headers_check(_event, _in, NULL, NULL)
SWITCH_DECLARE
(
switch_status_t
)
switch_event_create_pres_in_detailed
(
_In_z_
char
*
file
,
_In_z_
char
*
func
,
_In_
int
line
,
_In_z_
const
char
*
proto
,
_In_z_
const
char
*
login
,
...
...
@@ -399,7 +401,7 @@ SWITCH_DECLARE(void) switch_event_deliver(switch_event_t **event);
#define switch_event_fire_data(event, data) switch_event_fire_detailed(__FILE__, (const char * )__SWITCH_FUNC__, __LINE__, event, data)
SWITCH_DECLARE
(
char
*
)
switch_event_build_param_string
(
switch_event_t
*
event
,
const
char
*
prefix
,
switch_hash_t
*
vars_map
);
SWITCH_DECLARE
(
int
)
switch_event_check_permission_list
(
switch_event_t
*
list
,
const
char
*
name
);
///\}
SWITCH_END_EXTERN_C
...
...
src/mod/applications/mod_httapi/httapi.conf.xml
浏览文件 @
755be330
...
...
@@ -26,7 +26,26 @@
<!-- <permission name="all" value="true"/> -->
<!--<permission name="none" value="true"/> -->
<permission
name=
"set-params"
value=
"true"
/>
<permission
name=
"set-vars"
value=
"false"
/>
<permission
name=
"set-vars"
value=
"false"
>
<!-- default to "deny" or "allow" -->
<!-- type attr can be "deny" or "allow" nothing defaults to opposite of the list default so allow in this case -->
<!--
<variable-list default="deny">
<variable name="caller_id_name"/>
<variable name="hangup"/>
</variable-list>
-->
</permission>
<permission
name=
"get-vars"
value=
"false"
>
<!-- default to "deny" or "allow" -->
<!-- type attr can be "deny" or "allow" nothing defaults to opposite of the list default so allow in this case -->
<!--
<variable-list default="deny">
<variable name="caller_id_name"/>
<variable name="hangup"/>
</variable-list>
-->
</permission>
<permission
name=
"extended-data"
value=
"false"
/>
<permission
name=
"execute-apps"
value=
"true"
>
<!-- default to "deny" or "allow" -->
...
...
@@ -36,7 +55,21 @@
<application
name=
"hangup"
/>
</application-list>
</permission>
<permission
name=
"expand-vars-in-tag-body"
value=
"false"
/>
<permission
name=
"expand-vars-in-tag-body"
value=
"false"
>
<!-- default to "deny" or "allow" -->
<!-- type attr can be "deny" or "allow" nothing defaults to opposite of the list default so allow in this case -->
<!--
<variable-list default="deny">
<variable name="caller_id_name"/>
<variable name="hangup"/>
</variable-list>
<api-list default="deny">
<api name="expr"/>
<api name="lua"/>
</api-list>
-->
</permission>
<permission
name=
"dial"
value=
"true"
/>
<permission
name=
"dial-set-context"
value=
"false"
/>
<permission
name=
"dial-set-dialplan"
value=
"false"
/>
...
...
src/mod/applications/mod_httapi/mod_httapi.c
浏览文件 @
755be330
...
...
@@ -38,6 +38,7 @@ SWITCH_MODULE_DEFINITION(mod_httapi, mod_httapi_load, mod_httapi_shutdown, NULL)
typedef
struct
profile_perms_s
{
switch_byte_t
set_params
;
switch_byte_t
set_vars
;
switch_byte_t
get_vars
;
switch_byte_t
extended_data
;
switch_byte_t
execute_apps
;
switch_byte_t
expand_vars
;
...
...
@@ -99,6 +100,14 @@ typedef struct client_profile_s {
int
default_allow
;
}
dial_params
;
struct
{
switch_event_t
*
expand_var_list
;
switch_event_t
*
set_var_list
;
switch_event_t
*
get_var_list
;
switch_event_t
*
api_list
;
int
default_allow
;
}
var_params
;
}
client_profile_t
;
#define HTTAPI_MAX_API_BYTES 1024 * 1024
...
...
@@ -259,6 +268,26 @@ static void console_clean_log(const char *level_str, const char *msg)
switch_log_printf
(
SWITCH_CHANNEL_LOG_CLEAN
,
level
,
"%s"
,
switch_str_nil
(
msg
));
}
static
switch_status_t
parse_get_var
(
const
char
*
tag_name
,
client_t
*
client
,
switch_xml_t
tag
,
const
char
*
body
)
{
const
char
*
var
=
switch_xml_attr
(
tag
,
"name"
);
const
char
*
perm
=
switch_xml_attr
(
tag
,
"permanent"
);
if
(
switch_event_check_permission_list
(
client
->
profile
->
var_params
.
get_var_list
,
var
))
{
const
char
*
vval
=
switch_channel_get_variable
(
client
->
channel
,
var
);
if
(
vval
)
{
switch_event_add_header_string
(
perm
?
client
->
params
:
client
->
one_time_params
,
SWITCH_STACK_BOTTOM
,
var
,
vval
);
}
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_ERROR
,
"variable %s permission denied!
\n
"
,
var
);
return
SWITCH_STATUS_FALSE
;
}
return
SWITCH_STATUS_SUCCESS
;
}
static
switch_status_t
parse_continue
(
const
char
*
tag_name
,
client_t
*
client
,
switch_xml_t
tag
,
const
char
*
body
)
{
...
...
@@ -648,29 +677,11 @@ static switch_status_t parse_sms(const char *tag_name, client_t *client, switch_
static
int
check_app_perm
(
client_t
*
client
,
const
char
*
app_name
)
{
const
char
*
v
;
int
r
=
0
;
if
(
!
client
->
profile
->
perms
.
execute_apps
)
{
return
0
;
}
if
(
!
client
->
profile
->
dial_params
.
app_list
)
{
return
1
;
}
if
((
v
=
switch_event_get_header
(
client
->
profile
->
dial_params
.
app_list
,
app_name
)))
{
if
(
*
v
==
'd'
)
{
r
=
0
;
}
else
{
r
=
1
;
}
}
else
{
r
=
client
->
profile
->
dial_params
.
default_allow
;
}
return
r
;
return
switch_event_check_permission_list
(
client
->
profile
->
dial_params
.
app_list
,
app_name
);
}
static
switch_status_t
parse_execute
(
const
char
*
tag_name
,
client_t
*
client
,
switch_xml_t
tag
,
const
char
*
body
)
...
...
@@ -997,7 +1008,11 @@ static switch_status_t parse_xml(client_t *client)
if
(
zstr
(
val
))
{
val
=
NULL
;
}
switch_channel_set_variable
(
client
->
channel
,
tag
->
name
,
val
);
if
(
switch_event_check_permission_list
(
client
->
profile
->
var_params
.
set_var_list
,
tag
->
name
))
{
switch_channel_set_variable
(
client
->
channel
,
tag
->
name
,
val
);
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_ERROR
,
"variable %s permission denied!
\n
"
,
tag
->
name
);
}
}
tag
=
tag
->
sibling
;
}
...
...
@@ -1019,7 +1034,8 @@ static switch_status_t parse_xml(client_t *client)
if
(
tag
->
txt
&&
client
->
profile
->
perms
.
expand_vars
)
{
switch_channel_get_variables
(
client
->
channel
,
&
templ_data
);
switch_event_merge
(
templ_data
,
client
->
params
);
expanded
=
switch_event_expand_headers
(
templ_data
,
tag
->
txt
);
expanded
=
switch_event_expand_headers_check
(
templ_data
,
tag
->
txt
,
client
->
profile
->
var_params
.
expand_var_list
,
client
->
profile
->
var_params
.
api_list
);
switch_event_destroy
(
&
templ_data
);
}
...
...
@@ -1639,6 +1655,60 @@ static switch_status_t do_config(void)
profile
->
perms
.
set_params
=
switch_true
(
val
);
}
else
if
(
!
strcasecmp
(
var
,
"set-vars"
))
{
profile
->
perms
.
set_vars
=
switch_true
(
val
);
if
(
profile
->
perms
.
set_vars
)
{
switch_xml_t
x_list
,
x_var
;
if
((
x_list
=
switch_xml_child
(
param
,
"variable-list"
)))
{
char
*
var
=
(
char
*
)
switch_xml_attr_soft
(
param
,
"default"
);
profile
->
var_params
.
default_allow
=
(
var
&&
!
strcasecmp
(
var
,
"allow"
));
switch_event_create
(
&
profile
->
var_params
.
set_var_list
,
SWITCH_EVENT_CLONE
);
profile
->
var_params
.
set_var_list
->
flags
|=
EF_UNIQ_HEADERS
;
if
(
profile
->
var_params
.
default_allow
)
{
profile
->
var_params
.
set_var_list
->
flags
|=
EF_DEFAULT_ALLOW
;
}
for
(
x_var
=
switch_xml_child
(
x_list
,
"variable"
);
x_var
;
x_var
=
x_var
->
next
)
{
const
char
*
name
=
switch_xml_attr
(
x_var
,
"name"
);
const
char
*
type
=
switch_xml_attr
(
x_var
,
"type"
);
if
(
zstr
(
type
))
type
=
profile
->
var_params
.
default_allow
?
"deny"
:
"allow"
;
if
(
name
)
{
switch_event_add_header_string
(
profile
->
var_params
.
set_var_list
,
SWITCH_STACK_BOTTOM
,
name
,
type
);
}
}
}
}
}
else
if
(
!
strcasecmp
(
var
,
"get-vars"
))
{
profile
->
perms
.
get_vars
=
switch_true
(
val
);
if
(
profile
->
perms
.
get_vars
)
{
switch_xml_t
x_list
,
x_var
;
if
((
x_list
=
switch_xml_child
(
param
,
"variable-list"
)))
{
char
*
var
=
(
char
*
)
switch_xml_attr_soft
(
param
,
"default"
);
profile
->
var_params
.
default_allow
=
(
var
&&
!
strcasecmp
(
var
,
"allow"
));
switch_event_create
(
&
profile
->
var_params
.
get_var_list
,
SWITCH_EVENT_CLONE
);
profile
->
var_params
.
get_var_list
->
flags
|=
EF_UNIQ_HEADERS
;
if
(
profile
->
var_params
.
default_allow
)
{
profile
->
var_params
.
get_var_list
->
flags
|=
EF_DEFAULT_ALLOW
;
}
for
(
x_var
=
switch_xml_child
(
x_list
,
"variable"
);
x_var
;
x_var
=
x_var
->
next
)
{
const
char
*
name
=
switch_xml_attr
(
x_var
,
"name"
);
const
char
*
type
=
switch_xml_attr
(
x_var
,
"type"
);
if
(
zstr
(
type
))
type
=
profile
->
var_params
.
default_allow
?
"deny"
:
"allow"
;
if
(
name
)
{
switch_event_add_header_string
(
profile
->
var_params
.
get_var_list
,
SWITCH_STACK_BOTTOM
,
name
,
type
);
}
}
}
}
}
else
if
(
!
strcasecmp
(
var
,
"extended-data"
))
{
profile
->
perms
.
extended_data
=
switch_true
(
val
);
}
else
if
(
!
strcasecmp
(
var
,
"execute-apps"
))
{
...
...
@@ -1652,6 +1722,10 @@ static switch_status_t do_config(void)
profile
->
dial_params
.
default_allow
=
(
var
&&
!
strcasecmp
(
var
,
"allow"
));
switch_event_create
(
&
profile
->
dial_params
.
app_list
,
SWITCH_EVENT_CLONE
);
profile
->
dial_params
.
app_list
->
flags
|=
EF_UNIQ_HEADERS
;
if
(
profile
->
dial_params
.
default_allow
)
{
profile
->
dial_params
.
app_list
->
flags
|=
EF_DEFAULT_ALLOW
;
}
for
(
x_app
=
switch_xml_child
(
x_list
,
"application"
);
x_app
;
x_app
=
x_app
->
next
)
{
const
char
*
name
=
switch_xml_attr
(
x_app
,
"name"
);
...
...
@@ -1668,6 +1742,56 @@ static switch_status_t do_config(void)
}
else
if
(
!
strcasecmp
(
var
,
"expand-vars"
))
{
profile
->
perms
.
expand_vars
=
switch_true
(
val
);
if
(
profile
->
perms
.
expand_vars
)
{
switch_xml_t
x_list
,
x_var
,
x_api
;
if
((
x_list
=
switch_xml_child
(
param
,
"variable-list"
)))
{
char
*
var
=
(
char
*
)
switch_xml_attr_soft
(
param
,
"default"
);
profile
->
var_params
.
default_allow
=
(
var
&&
!
strcasecmp
(
var
,
"allow"
));
switch_event_create
(
&
profile
->
var_params
.
expand_var_list
,
SWITCH_EVENT_CLONE
);
profile
->
var_params
.
expand_var_list
->
flags
|=
EF_UNIQ_HEADERS
;
if
(
profile
->
var_params
.
default_allow
)
{
profile
->
var_params
.
expand_var_list
->
flags
|=
EF_DEFAULT_ALLOW
;
}
for
(
x_var
=
switch_xml_child
(
x_list
,
"variable"
);
x_var
;
x_var
=
x_var
->
next
)
{
const
char
*
name
=
switch_xml_attr
(
x_var
,
"name"
);
const
char
*
type
=
switch_xml_attr
(
x_var
,
"type"
);
if
(
zstr
(
type
))
type
=
profile
->
var_params
.
default_allow
?
"deny"
:
"allow"
;
if
(
name
)
{
switch_event_add_header_string
(
profile
->
var_params
.
expand_var_list
,
SWITCH_STACK_BOTTOM
,
name
,
type
);
}
}
}
if
((
x_list
=
switch_xml_child
(
param
,
"api-list"
)))
{
char
*
api
=
(
char
*
)
switch_xml_attr_soft
(
param
,
"default"
);
profile
->
var_params
.
default_allow
=
(
api
&&
!
strcasecmp
(
api
,
"allow"
));
switch_event_create
(
&
profile
->
var_params
.
api_list
,
SWITCH_EVENT_CLONE
);
profile
->
var_params
.
api_list
->
flags
|=
EF_UNIQ_HEADERS
;
if
(
profile
->
var_params
.
default_allow
)
{
profile
->
var_params
.
api_list
->
flags
|=
EF_DEFAULT_ALLOW
;
}
for
(
x_api
=
switch_xml_child
(
x_list
,
"api"
);
x_api
;
x_api
=
x_api
->
next
)
{
const
char
*
name
=
switch_xml_attr
(
x_api
,
"name"
);
const
char
*
type
=
switch_xml_attr
(
x_api
,
"type"
);
if
(
zstr
(
type
))
type
=
profile
->
var_params
.
default_allow
?
"deny"
:
"allow"
;
if
(
name
)
{
switch_event_add_header_string
(
profile
->
var_params
.
api_list
,
SWITCH_STACK_BOTTOM
,
name
,
type
);
}
}
}
}
}
else
if
(
!
strcasecmp
(
var
,
"dial"
))
{
profile
->
perms
.
dial
.
enabled
=
switch_true
(
val
);
}
else
if
(
!
strcasecmp
(
var
,
"dial-set-context"
))
{
...
...
@@ -2465,6 +2589,7 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_httapi_load)
bind_parser
(
"break"
,
parse_break
);
bind_parser
(
"log"
,
parse_log
);
bind_parser
(
"continue"
,
parse_continue
);
bind_parser
(
"setVar"
,
parse_get_var
);
if
(
do_config
()
!=
SWITCH_STATUS_SUCCESS
)
{
return
SWITCH_STATUS_FALSE
;
...
...
@@ -2498,6 +2623,9 @@ SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_httapi_shutdown)
switch_hash_this
(
hi
,
&
vvar
,
NULL
,
&
val
);
profile
=
(
client_profile_t
*
)
val
;
switch_event_destroy
(
&
profile
->
dial_params
.
app_list
);
switch_event_destroy
(
&
profile
->
var_params
.
expand_var_list
);
switch_event_destroy
(
&
profile
->
var_params
.
set_var_list
);
switch_event_destroy
(
&
profile
->
var_params
.
get_var_list
);
}
...
...
src/mod/applications/mod_httapi/mod_httapi_doc.txt
浏览文件 @
755be330
...
...
@@ -249,6 +249,15 @@ action : Change url to submit to.
temp-action : Change url to submit to. just for the next loop.
<getVar action temp-action permanent/>
: Get a Channel variable (depends on permissions)
ATTRS:
action : Change url to submit to.
temp-action : Change url to submit to. just for the next loop.
permanent : Add as a permanent param or just once.
...
...
src/switch_channel.c
浏览文件 @
755be330
...
...
@@ -151,6 +151,9 @@ struct switch_channel {
opaque_channel_flag_t
opaque_flags
;
switch_originator_type_t
last_profile_type
;
switch_caller_extension_t
*
queued_extension
;
switch_event_t
*
app_list
;
switch_event_t
*
api_list
;
switch_event_t
*
var_list
;
};
...
...
@@ -578,6 +581,9 @@ SWITCH_DECLARE(void) switch_channel_uninit(switch_channel_t *channel)
}
switch_mutex_lock
(
channel
->
profile_mutex
);
switch_event_destroy
(
&
channel
->
variables
);
switch_event_destroy
(
&
channel
->
api_list
);
switch_event_destroy
(
&
channel
->
var_list
);
switch_event_destroy
(
&
channel
->
app_list
);
switch_mutex_unlock
(
channel
->
profile_mutex
);
}
...
...
@@ -3287,7 +3293,7 @@ SWITCH_DECLARE(switch_status_t) switch_channel_perform_answer(switch_channel_t *
memset(c, 0, olen - cpos);\
}} \
SWITCH_DECLARE
(
char
*
)
switch_channel_expand_variables
(
switch_channel_t
*
channel
,
const
char
*
in
)
SWITCH_DECLARE
(
char
*
)
switch_channel_expand_variables
_check
(
switch_channel_t
*
channel
,
const
char
*
in
,
switch_event_t
*
var_list
,
switch_event_t
*
api_list
)
{
char
*
p
,
*
c
=
NULL
;
char
*
data
,
*
indup
,
*
endof_indup
;
...
...
@@ -3425,7 +3431,7 @@ SWITCH_DECLARE(char *) switch_channel_expand_variables(switch_channel_t *channel
char
*
ptr
;
int
idx
=
-
1
;
if
((
expanded
=
switch_channel_expand_variables
(
channel
,
(
char
*
)
vname
))
==
vname
)
{
if
((
expanded
=
switch_channel_expand_variables
_check
(
channel
,
(
char
*
)
vname
,
var_list
,
api_list
))
==
vname
)
{
expanded
=
NULL
;
}
else
{
vname
=
expanded
;
...
...
@@ -3446,6 +3452,10 @@ SWITCH_DECLARE(char *) switch_channel_expand_variables(switch_channel_t *channel
}
if
((
sub_val
=
(
char
*
)
switch_channel_get_variable_dup
(
channel
,
vname
,
SWITCH_TRUE
,
idx
)))
{
if
(
var_list
&&
!
switch_event_check_permission_list
(
var_list
,
vname
))
{
sub_val
=
"INVALID"
;
}
if
(
offset
||
ooffset
)
{
cloned_sub_val
=
strdup
(
sub_val
);
switch_assert
(
cloned_sub_val
);
...
...
@@ -3478,24 +3488,29 @@ SWITCH_DECLARE(char *) switch_channel_expand_variables(switch_channel_t *channel
if
(
stream
.
data
)
{
char
*
expanded_vname
=
NULL
;
if
((
expanded_vname
=
switch_channel_expand_variables
(
channel
,
(
char
*
)
vname
))
==
vname
)
{
if
((
expanded_vname
=
switch_channel_expand_variables
_check
(
channel
,
(
char
*
)
vname
,
var_list
,
api_list
))
==
vname
)
{
expanded_vname
=
NULL
;
}
else
{
vname
=
expanded_vname
;
}
if
((
expanded
=
switch_channel_expand_variables
(
channel
,
vval
))
==
vval
)
{
if
((
expanded
=
switch_channel_expand_variables
_check
(
channel
,
vval
,
var_list
,
api_list
))
==
vval
)
{
expanded
=
NULL
;
}
else
{
vval
=
expanded
;
}
if
(
switch_api_execute
(
vname
,
vval
,
channel
->
session
,
&
stream
)
==
SWITCH_STATUS_SUCCESS
)
{
func_val
=
stream
.
data
;
sub_val
=
func_val
;
if
(
api_list
&&
!
switch_event_check_permission_list
(
api_list
,
vname
)
)
{
func_val
=
"INVALID"
;
sub_val
=
"INVALID"
;
}
else
{
free
(
stream
.
data
);
if
(
switch_api_execute
(
vname
,
vval
,
channel
->
session
,
&
stream
)
==
SWITCH_STATUS_SUCCESS
)
{
func_val
=
stream
.
data
;
sub_val
=
func_val
;
}
else
{
free
(
stream
.
data
);
}
}
switch_safe_free
(
expanded
);
...
...
src/switch_event.c
浏览文件 @
755be330
...
...
@@ -1981,7 +1981,7 @@ if ((dp = realloc(data, olen))) {\
memset(c, 0, olen - cpos);\
}} \
SWITCH_DECLARE
(
char
*
)
switch_event_expand_headers
(
switch_event_t
*
event
,
const
char
*
in
)
SWITCH_DECLARE
(
char
*
)
switch_event_expand_headers
_check
(
switch_event_t
*
event
,
const
char
*
in
,
switch_event_t
*
var_list
,
switch_event_t
*
api_list
)
{
char
*
p
,
*
c
=
NULL
;
char
*
data
,
*
indup
,
*
endof_indup
;
...
...
@@ -2121,7 +2121,7 @@ SWITCH_DECLARE(char *) switch_event_expand_headers(switch_event_t *event, const
char
*
ptr
;
int
idx
=
-
1
;
if
((
expanded
=
switch_event_expand_headers
(
event
,
(
char
*
)
vname
))
==
vname
)
{
if
((
expanded
=
switch_event_expand_headers
_check
(
event
,
(
char
*
)
vname
,
var_list
,
api_list
))
==
vname
)
{
expanded
=
NULL
;
}
else
{
vname
=
expanded
;
...
...
@@ -2145,6 +2145,11 @@ SWITCH_DECLARE(char *) switch_event_expand_headers(switch_event_t *event, const
if
((
gvar
=
switch_core_get_variable_dup
(
vname
)))
{
sub_val
=
gvar
;
}
if
(
var_list
&&
!
switch_event_check_permission_list
(
var_list
,
vname
))
{
sub_val
=
"INVALID"
;
}
}
if
(
offset
||
ooffset
)
{
...
...
@@ -2175,23 +2180,28 @@ SWITCH_DECLARE(char *) switch_event_expand_headers(switch_event_t *event, const
if
(
stream
.
data
)
{
char
*
expanded_vname
=
NULL
;
if
((
expanded_vname
=
switch_event_expand_headers
(
event
,
(
char
*
)
vname
))
==
vname
)
{
if
((
expanded_vname
=
switch_event_expand_headers
_check
(
event
,
(
char
*
)
vname
,
var_list
,
api_list
))
==
vname
)
{
expanded_vname
=
NULL
;
}
else
{
vname
=
expanded_vname
;
}
if
((
expanded
=
switch_event_expand_headers
(
event
,
vval
))
==
vval
)
{
if
((
expanded
=
switch_event_expand_headers
_check
(
event
,
vval
,
var_list
,
api_list
))
==
vval
)
{
expanded
=
NULL
;
}
else
{
vval
=
expanded
;
}
if
(
switch_api_execute
(
vname
,
vval
,
NULL
,
&
stream
)
==
SWITCH_STATUS_SUCCESS
)
{
func_val
=
stream
.
data
;
sub_val
=
func_val
;
if
(
api_list
&&
!
switch_event_check_permission_list
(
api_list
,
vname
)
)
{
func_val
=
"INVALID"
;
sub_val
=
"INVALID"
;
}
else
{
free
(
stream
.
data
);
if
(
switch_api_execute
(
vname
,
vval
,
NULL
,
&
stream
)
==
SWITCH_STATUS_SUCCESS
)
{
func_val
=
stream
.
data
;
sub_val
=
func_val
;
}
else
{
free
(
stream
.
data
);
}
}
switch_safe_free
(
expanded
);
...
...
@@ -2330,6 +2340,32 @@ SWITCH_DECLARE(char *) switch_event_build_param_string(switch_event_t *event, co
return
stream
.
data
;
}
SWITCH_DECLARE
(
int
)
switch_event_check_permission_list
(
switch_event_t
*
list
,
const
char
*
name
)
{
const
char
*
v
;
int
r
=
0
;
int
default_allow
=
switch_test_flag
(
list
,
EF_DEFAULT_ALLOW
);
if
(
!
list
->
headers
)
{
return
default_allow
;
}
if
((
v
=
switch_event_get_header
(
list
,
name
)))
{
if
(
*
v
==
'd'
)
{
r
=
0
;
}
else
{
r
=
1
;
}
}
else
{
r
=
default_allow
;
}
return
r
;
}
/* For Emacs:
* Local Variables:
* mode:c
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论