diff options
author | Richard Mudgett <rmudgett@digium.com> | 2013-08-22 21:09:52 +0000 |
---|---|---|
committer | Richard Mudgett <rmudgett@digium.com> | 2013-08-22 21:09:52 +0000 |
commit | 477dea46616c0a6b79706f10349aaf9a87832e0e (patch) | |
tree | 50244a0102181406d83928d23e0ce45ff64169cf /include/asterisk/bridge.h | |
parent | 24683444ac07743e202c6f6cae0364ee4057df4c (diff) |
Bridge API: Set a cause code on a channel when it is ejected from a bridge.
The cause code needs to be passed from the disconnecting channel to the
bridge peers if the disconnecting channel dissolves the bridge.
* Made the call to an app_agent_pool agent disconnect with the busy cause
code if the agent does not ack the call in time or hangs up before acking
the call.
(closes issue ASTERISK-22042)
Reported by: Matt Jordan
Review: https://reviewboard.asterisk.org/r/2772/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@397472 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'include/asterisk/bridge.h')
-rw-r--r-- | include/asterisk/bridge.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/include/asterisk/bridge.h b/include/asterisk/bridge.h index 9522962bc..d351b0fea 100644 --- a/include/asterisk/bridge.h +++ b/include/asterisk/bridge.h @@ -304,6 +304,8 @@ struct ast_bridge { * \note Temporary as in try again in a moment. */ unsigned int inhibit_merge; + /*! Cause code of the dissolved bridge. */ + int cause; /*! TRUE if the bridge was reconfigured. */ unsigned int reconfigured:1; /*! TRUE if the bridge has been dissolved. Any channel that now tries to join is immediately ejected. */ @@ -395,6 +397,7 @@ static inline void _ast_bridge_unlock(struct ast_bridge *bridge, const char *fil * \brief Destroy a bridge * * \param bridge Bridge to destroy + * \param cause Cause of bridge being destroyed. (If cause <= 0 then use AST_CAUSE_NORMAL_CLEARING) * * \retval 0 on success * \retval -1 on failure @@ -402,12 +405,12 @@ static inline void _ast_bridge_unlock(struct ast_bridge *bridge, const char *fil * Example usage: * * \code - * ast_bridge_destroy(bridge); + * ast_bridge_destroy(bridge, AST_CAUSE_NORMAL_CLEARING); * \endcode * * This destroys a bridge that was previously created. */ -int ast_bridge_destroy(struct ast_bridge *bridge); +int ast_bridge_destroy(struct ast_bridge *bridge, int cause); /*! * \brief Notify bridging that this channel was just masqueraded. |