diff --git a/apps/app_disa.c b/apps/app_disa.c index f07e36b0baa66f96172d76a9d3d82701650497f1..081abe60369e6deaaade7288cecb347fa36c3799 100644 --- a/apps/app_disa.c +++ b/apps/app_disa.c @@ -179,6 +179,8 @@ static int disa_exec(struct ast_channel *chan, void *data) play_dialtone(chan, args.mailbox); + ast_set_flag(chan, AST_FLAG_END_DTMF_ONLY); + for (;;) { /* if outa time, give em reorder */ if (ast_tvdiff_ms(ast_tvnow(), lastdigittime) > ((k&2) ? digittimeout : firstdigittimeout)) { @@ -192,11 +194,14 @@ static int disa_exec(struct ast_channel *chan, void *data) continue; } - if (!(f = ast_read(chan))) + if (!(f = ast_read(chan))) { + ast_clear_flag(chan, AST_FLAG_END_DTMF_ONLY); return -1; + } if ((f->frametype == AST_FRAME_CONTROL) && (f->subclass == AST_CONTROL_HANGUP)) { ast_frfree(f); + ast_clear_flag(chan, AST_FLAG_END_DTMF_ONLY); return -1; } @@ -225,6 +230,7 @@ static int disa_exec(struct ast_channel *chan, void *data) fp = fopen(args.passcode,"r"); if (!fp) { ast_log(LOG_WARNING,"DISA password file %s not found on chan %s\n",args.passcode,chan->name); + ast_clear_flag(chan, AST_FLAG_END_DTMF_ONLY); return -1; } pwline[0] = 0; @@ -307,6 +313,8 @@ static int disa_exec(struct ast_channel *chan, void *data) } } + ast_clear_flag(chan, AST_FLAG_END_DTMF_ONLY); + if (k == 3) { int recheck = 0; struct ast_flags flags = { AST_CDR_FLAG_POSTED };