]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Ensure that digits passing through Asterisk have a reasonable minimum length.
authorRussell Bryant <russell@russellbryant.com>
Mon, 23 Apr 2007 17:57:32 +0000 (17:57 +0000)
committerRussell Bryant <russell@russellbryant.com>
Mon, 23 Apr 2007 17:57:32 +0000 (17:57 +0000)
It is currently 100 ms.  If someone thinks this should be different, feel free
to speak up.  (related to issues #8944, #9250, and #9348)

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@61763 65c4cc65-6c06-0410-ace0-fbb531ad65f3

main/channel.c

index 4f0b58536b9dbd80d4005a8f745564f55f08327b..f0215851b61dc6fa78abf76f1b8d8cad9cd0734b 100644 (file)
@@ -2268,7 +2268,7 @@ static struct ast_frame *__ast_read(struct ast_channel *chan, int dropaudio)
                                ast_set_flag(chan, AST_FLAG_EMULATE_DTMF);
                                chan->emulate_dtmf_digit = f->subclass;
                                chan->dtmf_begin_tv = ast_tvnow();
-                               if (f->len)
+                               if (f->len && f->len > AST_DEFAULT_EMULATE_DTMF_DURATION)
                                        chan->emulate_dtmf_duration = f->len;
                                else
                                        chan->emulate_dtmf_duration = AST_DEFAULT_EMULATE_DTMF_DURATION;
@@ -2276,6 +2276,12 @@ static struct ast_frame *__ast_read(struct ast_channel *chan, int dropaudio)
                                ast_clear_flag(chan, AST_FLAG_IN_DTMF);
                                if (!f->len)
                                        f->len = ast_tvdiff_ms(ast_tvnow(), chan->dtmf_begin_tv);
+                               if (f->len < AST_DEFAULT_EMULATE_DTMF_DURATION) {
+                                       ast_set_flag(chan, AST_FLAG_EMULATE_DTMF);
+                                       chan->emulate_dtmf_digit = f->subclass;
+                                       chan->emulate_dtmf_duration = AST_DEFAULT_EMULATE_DTMF_DURATION - f->len;
+                                       f = &ast_null_frame;
+                               }
                        }
                        break;
                case AST_FRAME_DTMF_BEGIN: