From 3fc2609468e351c0f3c311425554b7e657b3c202 Mon Sep 17 00:00:00 2001 From: Mark Spencer <markster@digium.com> Date: Wed, 15 Sep 2004 22:06:30 +0000 Subject: [PATCH] Fix app_disa to not ignore ignorepat :) (bug #2451) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3789 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- apps/app_disa.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/apps/app_disa.c b/apps/app_disa.c index 4d91673506..03f13c67c4 100755 --- a/apps/app_disa.c +++ b/apps/app_disa.c @@ -104,7 +104,7 @@ static void play_dialtone(struct ast_channel *chan) static int disa_exec(struct ast_channel *chan, void *data) { - int i,j,k,x; + int i,j,k,x,did_ignore; struct localuser *u; char tmp[256],arg2[256]="",exten[AST_MAX_EXTENSION],acctcode[20]=""; char *ourcontext,*ourcallerid; @@ -152,6 +152,7 @@ static int disa_exec(struct ast_channel *chan, void *data) ast_answer(chan); } i = k = x = 0; /* k is 0 for pswd entry, 1 for ext entry */ + did_ignore = 0; exten[0] = 0; acctcode[0] = 0; /* can we access DISA without password? */ @@ -276,11 +277,21 @@ static int disa_exec(struct ast_channel *chan, void *data) continue; } } + exten[i++] = j; /* save digit */ exten[i] = 0; if (!k) continue; /* if getting password, continue doing it */ /* if this exists */ + if (ast_ignore_pattern(ourcontext, exten)) { + play_dialtone(chan); + did_ignore = 1; + } else + if (did_ignore) { + ast_playtones_stop(chan); + did_ignore = 0; + } + /* if can do some more, do it */ if (!ast_matchmore_extension(chan,ourcontext,exten,1, chan->callerid)) { break; -- GitLab