add application and skipurl

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@12998 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Rupa Schomaker 2009-04-11 06:25:05 +00:00
parent 758ffa00cd
commit 077ccaae2d
1 changed files with 65 additions and 4 deletions

View File

@ -48,7 +48,7 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_cidlookup_load);
*/ */
SWITCH_MODULE_DEFINITION(mod_cidlookup, mod_cidlookup_load, mod_cidlookup_shutdown, NULL); SWITCH_MODULE_DEFINITION(mod_cidlookup, mod_cidlookup_load, mod_cidlookup_shutdown, NULL);
static char *SYNTAX = "cidlookup status|number"; static char *SYNTAX = "cidlookup status|number [skipurl]";
static struct { static struct {
char *url; char *url;
@ -385,7 +385,7 @@ static char *do_db_lookup(switch_memory_pool_t *pool, switch_event_t *event, con
} }
#endif #endif
static char *do_lookup(switch_memory_pool_t *pool, switch_event_t *event, const char *num) { static char *do_lookup(switch_memory_pool_t *pool, switch_event_t *event, const char *num, switch_bool_t skipurl) {
char *number = NULL; char *number = NULL;
char *name = NULL; char *name = NULL;
@ -400,7 +400,7 @@ static char *do_lookup(switch_memory_pool_t *pool, switch_event_t *event, const
name = do_db_lookup(pool, event, number); name = do_db_lookup(pool, event, number);
} }
#endif #endif
if (!name && globals.url) { if (!skipurl && !name && globals.url) {
name = do_lookup_url(pool, event, number); name = do_lookup_url(pool, event, number);
if (globals.cache && name) { if (globals.cache && name) {
set_cache(pool, number, name); set_cache(pool, number, name);
@ -409,7 +409,61 @@ static char *do_lookup(switch_memory_pool_t *pool, switch_event_t *event, const
return name; return name;
} }
SWITCH_STANDARD_APP(cidlookup_app_function)
{
switch_status_t status = SWITCH_STATUS_SUCCESS;
char *argv[3] = { 0 };
int argc;
char *mydata = NULL;
switch_memory_pool_t *pool = NULL;
switch_event_t *event = NULL;
switch_channel_t *channel = switch_core_session_get_channel(session);
switch_caller_profile_t *profile = switch_channel_get_caller_profile(channel);
char *name = NULL;
const char *number = NULL;
switch_bool_t skipurl = SWITCH_FALSE;
if (session) {
pool = switch_core_session_get_pool(session);
} else {
switch_core_new_memory_pool(&pool);
}
switch_event_create(&event, SWITCH_EVENT_MESSAGE);
if (!(mydata = switch_core_session_strdup(session, data))) {
return;
}
if ((argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0]))))) {
if (argc > 0) { /* && strcmp("skipurl", argv[0])) { */
skipurl = SWITCH_TRUE;
}
}
if (profile) {
number = switch_caller_get_field_by_name(profile, "caller_id_number");
}
if (number) {
name = do_lookup(pool, event, number, skipurl);
}
if (name) {
if (channel) {
switch_channel_set_variable(channel, "effective_caller_id_name", name);
}
}
switch_goto_status(SWITCH_STATUS_SUCCESS, done);
done:
switch_event_destroy(&event);
if (!session) {
switch_core_destroy_memory_pool(&pool);
}
}
SWITCH_STANDARD_API(cidlookup_function) SWITCH_STANDARD_API(cidlookup_function)
{ {
switch_status_t status; switch_status_t status;
@ -420,6 +474,7 @@ SWITCH_STANDARD_API(cidlookup_function)
switch_memory_pool_t *pool = NULL; switch_memory_pool_t *pool = NULL;
switch_event_t *event = NULL; switch_event_t *event = NULL;
switch_bool_t skipurl = SWITCH_FALSE;
if (switch_strlen_zero(cmd)) { if (switch_strlen_zero(cmd)) {
switch_goto_status(SWITCH_STATUS_SUCCESS, usage); switch_goto_status(SWITCH_STATUS_SUCCESS, usage);
@ -455,8 +510,11 @@ SWITCH_STANDARD_API(cidlookup_function)
switch_goto_status(SWITCH_STATUS_SUCCESS, done); switch_goto_status(SWITCH_STATUS_SUCCESS, done);
} }
if (argc > 1 && !strcmp("skipurl", argv[1])) {
skipurl = SWITCH_TRUE;
}
name = do_lookup(pool, event, argv[0]); name = do_lookup(pool, event, argv[0], skipurl);
if (name) { if (name) {
stream->write_function(stream, name); stream->write_function(stream, name);
} else { } else {
@ -482,6 +540,7 @@ done:
SWITCH_MODULE_LOAD_FUNCTION(mod_cidlookup_load) SWITCH_MODULE_LOAD_FUNCTION(mod_cidlookup_load)
{ {
switch_api_interface_t *api_interface; switch_api_interface_t *api_interface;
switch_application_interface_t *app_interface;
/* connect my internal structure to the blank pointer passed to me */ /* connect my internal structure to the blank pointer passed to me */
*module_interface = switch_loadable_module_create_module_interface(pool, modname); *module_interface = switch_loadable_module_create_module_interface(pool, modname);
@ -505,6 +564,8 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_cidlookup_load)
} }
SWITCH_ADD_API(api_interface, "cidlookup", "cidlookup API", cidlookup_function, SYNTAX); SWITCH_ADD_API(api_interface, "cidlookup", "cidlookup API", cidlookup_function, SYNTAX);
SWITCH_ADD_APP(app_interface, "cidlookup", "Perform a CID lookup", "Perform a CID lookup",
cidlookup_app_function, "number [skipurl]", SAF_SUPPORT_NOMEDIA);
/* indicate that the module should continue to be loaded */ /* indicate that the module should continue to be loaded */
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;