[Asterisk-code-review] app_confbridge: New ConfKick() application (asterisk[18])
N A
asteriskteam at digium.com
Sun May 23 20:19:46 CDT 2021
N A has uploaded this change for review. ( https://gerrit.asterisk.org/c/asterisk/+/15929 )
Change subject: app_confbridge: New ConfKick() application
......................................................................
app_confbridge: New ConfKick() application
Adds a new ConfKick() application, which may
be used to kick a specific channel, all channels,
or all non-admin channels from a specified
conference bridge, similar to existing CLI and
AMI commands.
ASTERISK-29446
Change-Id: I5d96b683880bfdd27b2ab1c3f2e897c5046ded9b
---
M apps/app_confbridge.c
A doc/CHANGES-staging/app_confkick.txt
2 files changed, 89 insertions(+), 0 deletions(-)
git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/29/15929/1
diff --git a/apps/app_confbridge.c b/apps/app_confbridge.c
index 8ad188a..daf795e 100644
--- a/apps/app_confbridge.c
+++ b/apps/app_confbridge.c
@@ -126,6 +126,39 @@
</description>
<see-also>
<ref type="application">ConfBridge</ref>
+ <ref type="application">ConfKick</ref>
+ <ref type="function">CONFBRIDGE</ref>
+ <ref type="function">CONFBRIDGE_INFO</ref>
+ </see-also>
+ </application>
+ <application name="ConfKick" language="en_US">
+ <synopsis>
+ Kicks channel(s) from the requested ConfBridge.
+ </synopsis>
+ <syntax>
+ <parameter name="conference" required="true" />
+ <parameter name="channel">
+ <para>The channel to kick, <literal>all</literal>
+ to kick all users, or <literal>participants</literal>
+ to kick all non-admin participants. Default is all.</para>
+ </parameter>
+ </syntax>
+ <description>
+ <para>Kicks the requested channel(s) from a conference bridge.</para>
+ <variablelist>
+ <variable name="CONFKICKSTATUS">
+ <value name="FAILURE">
+ Could not kick any users with the provided arguments.
+ </value>
+ <value name="SUCCESS">
+ Successfully kicked users from specified conference bridge.
+ </value>
+ </variable>
+ </variablelist>
+ </description>
+ <see-also>
+ <ref type="application">ConfBridge</ref>
+ <ref type="application">ConfKick</ref>
<ref type="function">CONFBRIDGE</ref>
<ref type="function">CONFBRIDGE_INFO</ref>
</see-also>
@@ -426,6 +459,7 @@
*/
static const char app[] = "ConfBridge";
+static const char app2[] = "ConfKick";
/*! Number of buckets our conference bridges container can have */
#define CONFERENCE_BRIDGE_BUCKETS 53
@@ -4220,6 +4254,53 @@
return 0;
}
+static int confkick_exec(struct ast_channel *chan, const char *data)
+{
+ char *parse;
+ struct confbridge_conference *conference;
+ int not_found;
+
+ AST_DECLARE_APP_ARGS(args,
+ AST_APP_ARG(confbridge);
+ AST_APP_ARG(channel);
+ );
+
+ if (ast_strlen_zero(data)) {
+ ast_log(LOG_WARNING, "No conference bridge specified.\n");
+ pbx_builtin_setvar_helper(chan, "CONFKICKSTATUS", "FAILURE");
+ return 0;
+ }
+
+ parse = ast_strdupa(data);
+ AST_STANDARD_APP_ARGS(args, parse);
+
+ conference = ao2_find(conference_bridges, args.confbridge, OBJ_KEY);
+ if (!conference) {
+ ast_log(LOG_WARNING, "No conference bridge named '%s' found!\n", args.confbridge);
+ pbx_builtin_setvar_helper(chan, "CONFKICKSTATUS", "FAILURE");
+ return 0;
+ }
+ if (ast_strlen_zero(args.channel)) {
+ not_found = kick_conference_participant(conference, "all");
+ } else {
+ not_found = kick_conference_participant(conference, args.channel);
+ }
+
+ ao2_ref(conference, -1);
+ if (not_found) {
+ if (ast_strlen_zero(args.channel) || !strcasecmp("all", args.channel) || !strcasecmp("participants", args.channel)) {
+ ast_log(LOG_WARNING, "No participants found in conference bridge '%s'!\n", args.confbridge);
+ } else {
+ ast_log(LOG_WARNING, "No participant named '%s' found in conference bridge '%s'!\n", args.channel, args.confbridge);
+ }
+ pbx_builtin_setvar_helper(chan, "CONFKICKSTATUS", "FAILURE");
+ return 0;
+ }
+ ast_debug(1, "Kicked '%s' out of conference '%s'\n", args.channel, args.confbridge);
+ pbx_builtin_setvar_helper(chan, "CONFKICKSTATUS", "SUCCESS");
+ return 0;
+}
+
void conf_add_user_active(struct confbridge_conference *conference, struct confbridge_user *user)
{
AST_LIST_INSERT_TAIL(&conference->active_list, user, list);
@@ -4313,6 +4394,7 @@
static int unload_module(void)
{
ast_unregister_application(app);
+ ast_unregister_application(app2);
ast_custom_function_unregister(&confbridge_function);
ast_custom_function_unregister(&confbridge_info_function);
@@ -4383,6 +4465,7 @@
res |= manager_confbridge_init();
res |= ast_register_application_xml(app, confbridge_exec);
+ res |= ast_register_application_xml(app2, confkick_exec);
res |= ast_custom_function_register_escalating(&confbridge_function, AST_CFE_WRITE);
res |= ast_custom_function_register(&confbridge_info_function);
diff --git a/doc/CHANGES-staging/app_confkick.txt b/doc/CHANGES-staging/app_confkick.txt
new file mode 100644
index 0000000..4250c7d
--- /dev/null
+++ b/doc/CHANGES-staging/app_confkick.txt
@@ -0,0 +1,6 @@
+Subject: New ConfKick application
+
+Adds a ConfKick() application, which allows
+a specific channel, all users, or all non-admin
+users to be kicked from a conference bridge.
+
--
To view, visit https://gerrit.asterisk.org/c/asterisk/+/15929
To unsubscribe, or for help writing mail filters, visit https://gerrit.asterisk.org/settings
Gerrit-Project: asterisk
Gerrit-Branch: 18
Gerrit-Change-Id: I5d96b683880bfdd27b2ab1c3f2e897c5046ded9b
Gerrit-Change-Number: 15929
Gerrit-PatchSet: 1
Gerrit-Owner: N A <mail at interlinked.x10host.com>
Gerrit-MessageType: newchange
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-code-review/attachments/20210523/97bb890a/attachment-0001.html>
More information about the asterisk-code-review
mailing list