diff --git a/apps/app_setcallerid.c b/apps/app_setcallerid.c index a84c7a036..069c2af98 100755 --- a/apps/app_setcallerid.c +++ b/apps/app_setcallerid.c @@ -19,9 +19,83 @@ #include #include #include +#include #include #include +static char *app2 = "SetCallerPres"; + +static char *synopsis2 = "Set CallerID Presentation"; + +STANDARD_LOCAL_USER; + +LOCAL_USER_DECL; + +static struct { + int val; + char *name; +} preses[] = { + { AST_PRES_ALLOWED_USER_NUMBER_NOT_SCREENED, "allowed_not_screened" }, + { AST_PRES_ALLOWED_USER_NUMBER_PASSED_SCREEN, "allowed_passed_screen" }, + { AST_PRES_ALLOWED_USER_NUMBER_FAILED_SCREEN, "allowed_failed_screen" }, + { AST_PRES_ALLOWED_NETWORK_NUMBER, "allowed" }, + { AST_PRES_PROHIB_USER_NUMBER_NOT_SCREENED , "prohib_not_screened" }, + { AST_PRES_PROHIB_USER_NUMBER_PASSED_SCREEN, "prohib_passed_screen" }, + { AST_PRES_PROHIB_USER_NUMBER_FAILED_SCREEN, "prohib_failed_screen" }, + { AST_PRES_PROHIB_NETWORK_NUMBER, "prohib" }, + { AST_PRES_NUMBER_NOT_AVAILABLE, "unavailable" }, +}; + +static char *descrip2 = +" SetCallerPres(presentation): Set Caller*ID presentation on\n" +"a call to a new value. Sets ANI as well if a flag is used.\n" +"Always returns 0. Valid presentations are:\n" +"\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" +"\n" +; + +static int setcallerid_pres_exec(struct ast_channel *chan, void *data) +{ + int res = 0; + char tmp[256] = ""; + struct localuser *u; + int x; + char *opts; + int pres = -1; + if (data) + strncpy(tmp, (char *)data, sizeof(tmp) - 1); + opts = strchr(tmp, '|'); + if (opts) { + *opts = '\0'; + opts++; + } + for (x=0;xcallingpres = pres; + LOCAL_USER_REMOVE(u); + return res; +} + + + static char *tdesc = "Set CallerID Application"; static char *app = "SetCallerID"; @@ -32,10 +106,6 @@ static char *descrip = " SetCallerID(clid[|a]): Set Caller*ID on a call to a new\n" "value. Sets ANI as well if a flag is used. Always returns 0\n"; -STANDARD_LOCAL_USER; - -LOCAL_USER_DECL; - static int setcallerid_exec(struct ast_channel *chan, void *data) { int res = 0; @@ -61,11 +131,13 @@ static int setcallerid_exec(struct ast_channel *chan, void *data) int unload_module(void) { STANDARD_HANGUP_LOCALUSERS; + ast_unregister_application(app2); return ast_unregister_application(app); } int load_module(void) { + ast_register_application(app2, setcallerid_pres_exec, synopsis2, descrip2); return ast_register_application(app, setcallerid_exec, synopsis, descrip); } diff --git a/include/asterisk/callerid.h b/include/asterisk/callerid.h index 8f8df457f..486c8100a 100755 --- a/include/asterisk/callerid.h +++ b/include/asterisk/callerid.h @@ -168,6 +168,16 @@ static inline float callerid_getcarrier(float *cr, float *ci, int bit) return *cr; } +#define AST_PRES_ALLOWED_USER_NUMBER_NOT_SCREENED 0x00 +#define AST_PRES_ALLOWED_USER_NUMBER_PASSED_SCREEN 0x01 +#define AST_PRES_ALLOWED_USER_NUMBER_FAILED_SCREEN 0x02 +#define AST_PRES_ALLOWED_NETWORK_NUMBER 0x03 +#define AST_PRES_PROHIB_USER_NUMBER_NOT_SCREENED 0x20 +#define AST_PRES_PROHIB_USER_NUMBER_PASSED_SCREEN 0x21 +#define AST_PRES_PROHIB_USER_NUMBER_FAILED_SCREEN 0x22 +#define AST_PRES_PROHIB_NETWORK_NUMBER 0x23 +#define AST_PRES_NUMBER_NOT_AVAILABLE 0x43 + #define PUT_BYTE(a) do { \ *(buf++) = (a); \ bytes++; \