提交 3046c27b authored 作者: Michael Jerris's avatar Michael Jerris

cleanup

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7420 d0543943-73ff-0310-b7d9-9358b9ac24b2
上级 a8784bbb
...@@ -45,25 +45,16 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -45,25 +45,16 @@ SWITCH_STANDARD_API(user_data_function)
{ {
switch_xml_t x_domain, xml = NULL, x_user = NULL, x_param, x_params; switch_xml_t x_domain, xml = NULL, x_user = NULL, x_param, x_params;
int argc; int argc;
char *mydata = NULL, *argv[3]; char *mydata = NULL, *argv[3], *key = NULL, *type = NULL, *user, *domain;
char *key = NULL, *type = NULL, *user, *domain;
char delim = ' '; char delim = ' ';
const char *err = NULL;
const char *container = "params", *elem = "param"; const char *container = "params", *elem = "param";
switch_event_t *params = NULL; switch_event_t *params = NULL;
if (!cmd) { if (switch_strlen_zero(cmd) || !(mydata = strdup(cmd))) {
err = "bad args";
goto end; goto end;
} }
mydata = strdup(cmd); if ((argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0])))) < 3) {
switch_assert(mydata);
argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0])));
if (argc < 3) {
err = "bad args";
goto end; goto end;
} }
...@@ -78,28 +69,12 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -78,28 +69,12 @@ SWITCH_STANDARD_API(user_data_function)
} }
switch_event_create(&params, SWITCH_EVENT_MESSAGE); switch_event_create(&params, SWITCH_EVENT_MESSAGE);
switch_assert(params);
switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "user", user); switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "user", user);
switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "domain", domain); switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "domain", domain);
switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "type", type); switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "type", type);
switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "key", key); switch_event_add_header_string(params, SWITCH_STACK_BOTTOM, "key", key);
if (key && type && switch_xml_locate_user("id", user, domain, NULL, &xml, &x_domain, &x_user, params) == SWITCH_STATUS_SUCCESS) {
if (switch_xml_locate_user("id", user, domain, NULL, &xml, &x_domain, &x_user, params) != SWITCH_STATUS_SUCCESS) {
err = "can't find user";
goto end;
}
end:
switch_event_destroy(&params);
if (xml) {
if (err) {
//stream->write_function(stream, "-Error %s\n", err);
} else {
if (!strcmp(type, "var")) { if (!strcmp(type, "var")) {
container = "variables"; container = "variables";
elem = "variable"; elem = "variable";
...@@ -110,7 +85,7 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -110,7 +85,7 @@ SWITCH_STANDARD_API(user_data_function)
const char *var = switch_xml_attr(x_param, "name"); const char *var = switch_xml_attr(x_param, "name");
const char *val = switch_xml_attr(x_param, "value"); const char *val = switch_xml_attr(x_param, "value");
if (!strcasecmp(var, key)) { if (var && val && !strcasecmp(var, key)) {
stream->write_function(stream, "%s", val); stream->write_function(stream, "%s", val);
break; break;
} }
...@@ -118,14 +93,13 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -118,14 +93,13 @@ SWITCH_STANDARD_API(user_data_function)
} }
} }
} }
switch_xml_free(xml);
}
end:
switch_xml_free(xml);
free(mydata); free(mydata);
switch_safe_free(params); switch_event_destroy(&params);
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }
...@@ -178,9 +152,7 @@ static switch_status_t _find_user(const char *cmd, switch_core_session_t *sessio ...@@ -178,9 +152,7 @@ static switch_status_t _find_user(const char *cmd, switch_core_session_t *sessio
goto end; goto end;
} }
end:
end:
if (session || tf) { if (session || tf) {
stream->write_function(stream, err ? "false" : "true"); stream->write_function(stream, err ? "false" : "true");
switch_xml_free(xml); switch_xml_free(xml);
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论