提交 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,27 +45,18 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -45,27 +45,18 @@ 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);
switch_assert(mydata);
argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0])));
if (argc < 3) { if ((argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0])))) < 3) {
err = "bad args"; goto end;
goto end; }
}
user = argv[0]; user = argv[0];
type = argv[1]; type = argv[1];
...@@ -76,56 +67,39 @@ SWITCH_STANDARD_API(user_data_function) ...@@ -76,56 +67,39 @@ SWITCH_STANDARD_API(user_data_function)
} else { } else {
domain = "cluecon.com"; domain = "cluecon.com";
} }
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 (!strcmp(type, "var")) {
container = "variables";
elem = "variable";
}
if (switch_xml_locate_user("id", user, domain, NULL, &xml, &x_domain, &x_user, params) != SWITCH_STATUS_SUCCESS) { if ((x_params = switch_xml_child(x_user, container))) {
err = "can't find user"; for (x_param = switch_xml_child(x_params, elem); x_param; x_param = x_param->next) {
goto end; const char *var = switch_xml_attr(x_param, "name");
} const char *val = switch_xml_attr(x_param, "value");
end:
switch_event_destroy(&params);
if (xml) {
if (err) {
//stream->write_function(stream, "-Error %s\n", err);
} else {
if (!strcmp(type, "var")) {
container = "variables";
elem = "variable";
}
if ((x_params = switch_xml_child(x_user, container))) { if (var && val && !strcasecmp(var, key)) {
for (x_param = switch_xml_child(x_params, elem); x_param; x_param = x_param->next) { stream->write_function(stream, "%s", val);
const char *var = switch_xml_attr(x_param, "name"); break;
const char *val = switch_xml_attr(x_param, "value");
if (!strcasecmp(var, key)) {
stream->write_function(stream, "%s", val);
break;
}
} }
} }
} }
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 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论