Merge "pbx_realtime: Prevent premature extension matching" into 13

changes/68/5068/1
zuul 8 years ago committed by Gerrit Code Review
commit 726e3945c3

@ -143,6 +143,13 @@ static void *cleanup(void *unused)
return NULL; return NULL;
} }
static int extension_length_comparator(struct ast_category *p, struct ast_category *q)
{
const char *extenp = S_OR(ast_variable_find(p, "exten"), "");
const char *extenq = S_OR(ast_variable_find(q, "exten"), "");
return strlen(extenp) - strlen(extenq);
}
/* Realtime switch looks up extensions in the supplied realtime table. /* Realtime switch looks up extensions in the supplied realtime table.
@ -193,6 +200,9 @@ static struct ast_variable *realtime_switch_common(const char *table, const char
if (cfg) { if (cfg) {
char *cat = NULL; char *cat = NULL;
/* Sort so that longer patterns are checked first */
ast_config_sort_categories(cfg, 1, extension_length_comparator);
while ((cat = ast_category_browse(cfg, cat))) { while ((cat = ast_category_browse(cfg, cat))) {
const char *realtime_exten = ast_variable_retrieve(cfg, cat, "exten"); const char *realtime_exten = ast_variable_retrieve(cfg, cat, "exten");

Loading…
Cancel
Save