mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-03 11:25:35 +00:00
ARI: Adding a channel to a bridge while a live recording is active blocks
Added the ability to have rules that are checked when adding and/or removing channels to/from a bridge. In this case, if a channel is currently recording and someone attempts to add it to a bridge an "is recording" rule is checked, fails, and a 409 conflict is returned. Also command functions now return an integer value that can be descriptive of what kind of problems, if any, occurred before or during execution. (closes issue ASTERISK-22624) Reported by: Joshua Colp Review: https://reviewboard.asterisk.org/r/2947/ ........ Merged revisions 403749 from http://svn.asterisk.org/svn/asterisk/branches/12 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@403750 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -35,28 +35,25 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
|
||||
#include "asterisk/module.h"
|
||||
#include "asterisk/stasis_app_impl.h"
|
||||
|
||||
static int OK = 0;
|
||||
static int FAIL = -1;
|
||||
|
||||
static void *app_control_answer(struct stasis_app_control *control,
|
||||
static int app_control_answer(struct stasis_app_control *control,
|
||||
struct ast_channel *chan, void *data)
|
||||
{
|
||||
const int delay = 0;
|
||||
ast_debug(3, "%s: Answering",
|
||||
stasis_app_control_get_channel_id(control));
|
||||
return __ast_answer(chan, delay) == 0 ? &OK : &FAIL;
|
||||
return __ast_answer(chan, delay);
|
||||
}
|
||||
|
||||
int stasis_app_control_answer(struct stasis_app_control *control)
|
||||
{
|
||||
int *retval;
|
||||
int retval;
|
||||
|
||||
ast_debug(3, "%s: Sending answer command\n",
|
||||
stasis_app_control_get_channel_id(control));
|
||||
|
||||
retval = stasis_app_send_command(control, app_control_answer, NULL);
|
||||
|
||||
if (retval == NULL || *retval != 0) {
|
||||
if (retval != 0) {
|
||||
ast_log(LOG_WARNING, "%s: Failed to answer channel",
|
||||
stasis_app_control_get_channel_id(control));
|
||||
return -1;
|
||||
|
Reference in New Issue
Block a user