From c59714fbfc71fd94cf7f0c04d1af83b131a540d3 Mon Sep 17 00:00:00 2001 From: Tilghman Lesher <tilghman@meg.abyt.es> Date: Sat, 3 Feb 2007 22:05:02 +0000 Subject: [PATCH] Add CALLERPRES dialplan function and deprecate SetCallerPres application git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@53141 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- apps/app_setcallerid.c | 7 ++++++- funcs/func_callerid.c | 46 +++++++++++++++++++++++++++++++++++++++--- 2 files changed, 49 insertions(+), 4 deletions(-) diff --git a/apps/app_setcallerid.c b/apps/app_setcallerid.c index 9596b88976..59b4d9af8c 100644 --- a/apps/app_setcallerid.c +++ b/apps/app_setcallerid.c @@ -68,9 +68,14 @@ static int setcallerid_pres_exec(struct ast_channel *chan, void *data) { struct ast_module_user *u; int pres = -1; + static int deprecated = 0; u = ast_module_user_add(chan); - + + if (!deprecated) { + deprecated = 1; + ast_log(LOG_WARNING, "SetCallerPres is deprecated. Please use Set(CALLERPRES()=%s) instead.\n", (char *)data); + } pres = ast_parse_caller_presentation(data); if (pres < 0) { diff --git a/funcs/func_callerid.c b/funcs/func_callerid.c index 6efb84f9c5..e026d67a9b 100644 --- a/funcs/func_callerid.c +++ b/funcs/func_callerid.c @@ -39,6 +39,22 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #include "asterisk/options.h" #include "asterisk/callerid.h" +static int callerpres_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len) +{ + ast_copy_string(buf, ast_named_caller_presentation(chan->cid.cid_pres), len); + return 0; +} + +static int callerpres_write(struct ast_channel *chan, const char *cmd, char *data, const char *value) +{ + int pres = ast_parse_caller_presentation(value); + if (pres < 0) + ast_log(LOG_WARNING, "'%s' is not a valid presentation (see 'show function CALLERPRES')\n", value); + else + chan->cid.cid_pres = pres; + return 0; +} + static int callerid_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len) { @@ -173,14 +189,38 @@ static struct ast_custom_function callerid_function = { .write = callerid_write, }; +static struct ast_custom_function callerpres_function = { + .name = "CALLERPRES", + .synopsis = "Gets or sets Caller*ID presentation on the channel.", + .syntax = "CALLERPRES()", + .desc = +"Gets or sets Caller*ID presentation on the channel. The following values\n" +"are valid:\n" +" allowed_not_screened : Presentation Allowed, Not Screened\n" +" allowed_passed_screen : Presentation Allowed, Passed Screen\n" +" allowed_failed_screen : Presentation Allowed, Failed Screen\n" +" allowed : Presentation Allowed, Network Number\n" +" prohib_not_screened : Presentation Prohibited, Not Screened\n" +" prohib_passed_screen : Presentation Prohibited, Passed Screen\n" +" prohib_failed_screen : Presentation Prohibited, Failed Screen\n" +" prohib : Presentation Prohibited, Network Number\n" +" unavailable : Number Unavailable\n", + .read = callerpres_read, + .write = callerpres_write, +}; + static int unload_module(void) { - return ast_custom_function_unregister(&callerid_function); + int res = ast_custom_function_unregister(&callerpres_function); + res |= ast_custom_function_unregister(&callerid_function); + return res; } static int load_module(void) { - return ast_custom_function_register(&callerid_function); + int res = ast_custom_function_register(&callerpres_function); + res |= ast_custom_function_register(&callerid_function); + return res; } -AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Caller ID related dialplan function"); +AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Caller ID related dialplan functions"); -- GitLab