[Freeswitch-svn] [commit] r6456 - freeswitch/trunk/src/mod/applications/mod_commands
Freeswitch SVN
anthm at freeswitch.org
Fri Nov 30 19:01:56 EST 2007
Author: anthm
Date: Fri Nov 30 19:01:56 2007
New Revision: 6456
Modified:
freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
Log:
add func
Modified: freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
==============================================================================
--- freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c (original)
+++ freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c Fri Nov 30 19:01:56 2007
@@ -97,6 +97,69 @@
}
+SWITCH_STANDARD_API(xml_locate_function)
+{
+ switch_xml_t xml = NULL, obj = NULL;
+ int argc;
+ char *mydata = NULL, *argv[4];
+ char *section, *tag, *tag_attr_name, *tag_attr_val, *params = NULL;
+ char *xmlstr;
+
+ if (!cmd) {
+ stream->write_function(stream, "bad args\n");
+ goto end;
+ }
+
+ mydata = strdup(cmd);
+ assert(mydata);
+
+ argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
+
+ if (argc == 1 && !strcasecmp(argv[0], "root")) {
+ const char *err;
+ xml = switch_xml_open_root(0, &err);
+ obj = xml;
+ goto end;
+ }
+
+ if (argc < 4) {
+ stream->write_function(stream, "bad args\n");
+ goto end;
+ }
+
+ section = argv[0];
+ tag = argv[1];
+ tag_attr_name = argv[2];
+ tag_attr_val = argv[3];
+
+ params = switch_mprintf("section=%s&tag=%s&tag_attr_name=%s&tag_attr_val=%s", section, tag, tag_attr_name, tag_attr_val);
+ assert(params);
+ if (switch_xml_locate(section, tag, tag_attr_name, tag_attr_val, &xml, &obj, params) != SWITCH_STATUS_SUCCESS) {
+ stream->write_function(stream, "can't find anything\n");
+ goto end;
+ }
+
+
+ end:
+
+ switch_safe_free(params);
+
+ if (xml && obj) {
+ xmlstr = switch_xml_toxml(obj, SWITCH_FALSE);
+ assert(xmlstr);
+
+ stream->write_function(stream, "%s", xmlstr);
+ free(xmlstr);
+ switch_xml_free(xml);
+
+ }
+
+ free(mydata);
+ return SWITCH_STATUS_SUCCESS;
+
+}
+
+
SWITCH_STANDARD_API(regex_function)
{
switch_regex_t *re = NULL;
@@ -1838,7 +1901,8 @@
SWITCH_ADD_API(commands_api_interface, "qq", "Eval a conditional", cond_function, "<expr> ? <true val> : <false val>");
SWITCH_ADD_API(commands_api_interface, "regex", "Eval a regex", regex_function, "<data>|<pattern>[|<subst string>]");
SWITCH_ADD_API(commands_api_interface, "uuid_chat", "Send a chat message", uuid_chat, UUID_CHAT_SYNTAX);
- SWITCH_ADD_API(commands_api_interface, "find_user_xml", "find a usere", find_user_function, "<key> <user>@<domain>");
+ SWITCH_ADD_API(commands_api_interface, "find_user_xml", "find a user", find_user_function, "<key> <user>@<domain>");
+ SWITCH_ADD_API(commands_api_interface, "xml_locate", "find some xml", xml_locate_function, "[root | <section> <tag> <tag_attr_name> <tag_attr_val>]");
/* indicate that the module should continue to be loaded */
return SWITCH_STATUS_NOUNLOAD;
More information about the Freeswitch-svn
mailing list