CallerID: Fix parsing regression

This fixes a regression in callerid parsing introduced when another bug
was fixed. This bug occurred when the name was composed entirely of
DTMF keys and quoted without a number section (<>). 

ASTERISK-24406 #close
Reported by: Etienne Lessard
Tested by: Etienne Lessard
Patches:
    callerid_fix.diff uploaded by Kinsey Moore
Review: https://reviewboard.asterisk.org/r/4067/
........

Merged revisions 425152 from http://svn.asterisk.org/svn/asterisk/branches/1.8


git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/11@425153 65c4cc65-6c06-0410-ace0-fbb531ad65f3
changes/61/61/1
Kinsey Moore 11 years ago
parent 3b4fcfe6de
commit e6bd251926

@ -1006,12 +1006,20 @@ int ast_is_shrinkable_phonenumber(const char *exten)
return ast_is_valid_string(exten, "0123456789*#+()-."); return ast_is_valid_string(exten, "0123456789*#+()-.");
} }
int ast_callerid_parse(char *instr, char **name, char **location) int ast_callerid_parse(char *input_str, char **name, char **location)
{ {
char *ls, *le, *name_start; char *ls;
char *le;
char *name_start;
char *instr;
int quotes_stripped = 0;
/* Handle surrounding quotes */ /* Handle surrounding quotes */
instr = ast_strip_quoted(instr, "\"", "\""); input_str = ast_strip(input_str);
instr = ast_strip_quoted(input_str, "\"", "\"");
if (instr != input_str) {
quotes_stripped = 1;
}
/* Try "name" <location> format or name <location> format or with a missing > */ /* Try "name" <location> format or name <location> format or with a missing > */
if ((ls = strrchr(instr, '<'))) { if ((ls = strrchr(instr, '<'))) {
@ -1027,7 +1035,7 @@ int ast_callerid_parse(char *instr, char **name, char **location)
ast_copy_string(tmp, instr, sizeof(tmp)); ast_copy_string(tmp, instr, sizeof(tmp));
ast_shrink_phone_number(tmp); ast_shrink_phone_number(tmp);
if (ast_isphonenumber(tmp)) { /* Assume it's just a location */ if (!quotes_stripped && ast_isphonenumber(tmp)) { /* Assume it's just a location */
name_start = NULL; name_start = NULL;
strcpy(instr, tmp); /* safe, because tmp will always be the same size or smaller than instr */ strcpy(instr, tmp); /* safe, because tmp will always be the same size or smaller than instr */
*location = instr; *location = instr;

@ -56,10 +56,14 @@ AST_TEST_DEFINE(parse_nominal)
{"\"\" <number>", NULL, "number"}, {"\"\" <number>", NULL, "number"},
{"<number>", NULL, "number"}, {"<number>", NULL, "number"},
{"name", "name", NULL}, {"name", "name", NULL},
{" name", "name", NULL},
{"\"name\"", "name", NULL}, {"\"name\"", "name", NULL},
{"\"*10\"", "*10", NULL},
{" \"*10\"", "*10", NULL},
{"\"name\" <>", "name", NULL}, {"\"name\" <>", "name", NULL},
{"name <>", "name", NULL}, {"name <>", "name", NULL},
{"1234", NULL, "1234"}, {"1234", NULL, "1234"},
{" 1234", NULL, "1234"},
{"\"na\\\"me\" <number>", "na\"me", "number"}, {"\"na\\\"me\" <number>", "na\"me", "number"},
}; };
char *name; char *name;

Loading…
Cancel
Save