mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-02 19:16:15 +00:00
app_bridgewait: Add option to not answer channel.
Adds the n option to not answer the channel when calling BridgeWait, so the application can be used without forcing answer supervision. ASTERISK-30216 #close Change-Id: I6b85ef300b1f7b5170f8537e2b10889cc2e6605a
This commit is contained in:
committed by
Friendly Automation
parent
fd5683f74b
commit
999b162786
@@ -100,6 +100,9 @@
|
|||||||
<para>Automatically exit the bridge and return to the PBX after
|
<para>Automatically exit the bridge and return to the PBX after
|
||||||
<emphasis>duration</emphasis> seconds.</para>
|
<emphasis>duration</emphasis> seconds.</para>
|
||||||
</option>
|
</option>
|
||||||
|
<option name="n">
|
||||||
|
<para>Do not automatically answer the channel.</para>
|
||||||
|
</option>
|
||||||
</optionlist>
|
</optionlist>
|
||||||
</parameter>
|
</parameter>
|
||||||
</syntax>
|
</syntax>
|
||||||
@@ -108,7 +111,7 @@
|
|||||||
The channel will then wait in the holding bridge until some event occurs
|
The channel will then wait in the holding bridge until some event occurs
|
||||||
which removes it from the holding bridge.</para>
|
which removes it from the holding bridge.</para>
|
||||||
<note><para>This application will answer calls which haven't already
|
<note><para>This application will answer calls which haven't already
|
||||||
been answered.</para></note>
|
been answered, unless the n option is provided.</para></note>
|
||||||
</description>
|
</description>
|
||||||
</application>
|
</application>
|
||||||
***/
|
***/
|
||||||
@@ -186,6 +189,7 @@ enum bridgewait_flags {
|
|||||||
MUXFLAG_MOHCLASS = (1 << 0),
|
MUXFLAG_MOHCLASS = (1 << 0),
|
||||||
MUXFLAG_ENTERTAINMENT = (1 << 1),
|
MUXFLAG_ENTERTAINMENT = (1 << 1),
|
||||||
MUXFLAG_TIMEOUT = (1 << 2),
|
MUXFLAG_TIMEOUT = (1 << 2),
|
||||||
|
MUXFLAG_NOANSWER = (1 << 3),
|
||||||
};
|
};
|
||||||
|
|
||||||
enum bridgewait_args {
|
enum bridgewait_args {
|
||||||
@@ -199,6 +203,7 @@ AST_APP_OPTIONS(bridgewait_opts, {
|
|||||||
AST_APP_OPTION_ARG('e', MUXFLAG_ENTERTAINMENT, OPT_ARG_ENTERTAINMENT),
|
AST_APP_OPTION_ARG('e', MUXFLAG_ENTERTAINMENT, OPT_ARG_ENTERTAINMENT),
|
||||||
AST_APP_OPTION_ARG('m', MUXFLAG_MOHCLASS, OPT_ARG_MOHCLASS),
|
AST_APP_OPTION_ARG('m', MUXFLAG_MOHCLASS, OPT_ARG_MOHCLASS),
|
||||||
AST_APP_OPTION_ARG('S', MUXFLAG_TIMEOUT, OPT_ARG_TIMEOUT),
|
AST_APP_OPTION_ARG('S', MUXFLAG_TIMEOUT, OPT_ARG_TIMEOUT),
|
||||||
|
AST_APP_OPTION('n', MUXFLAG_NOANSWER),
|
||||||
});
|
});
|
||||||
|
|
||||||
static int bridgewait_timeout_callback(struct ast_bridge_channel *bridge_channel, void *hook_pvt)
|
static int bridgewait_timeout_callback(struct ast_bridge_channel *bridge_channel, void *hook_pvt)
|
||||||
@@ -458,7 +463,7 @@ static int bridgewait_exec(struct ast_channel *chan, const char *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Answer the channel if needed */
|
/* Answer the channel if needed */
|
||||||
if (ast_channel_state(chan) != AST_STATE_UP) {
|
if (ast_channel_state(chan) != AST_STATE_UP && !ast_test_flag(&flags, MUXFLAG_NOANSWER)) {
|
||||||
ast_answer(chan);
|
ast_answer(chan);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
4
doc/CHANGES-staging/app_bridgewait.txt
Normal file
4
doc/CHANGES-staging/app_bridgewait.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
Subject: app_bridgewait
|
||||||
|
|
||||||
|
Adds the n option to not answer the channel when
|
||||||
|
the BridgeWait application is called.
|
Reference in New Issue
Block a user