[asterisk-commits] mjordan: branch 10 r348211 - /branches/10/apps/app_queue.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Wed Dec 14 15:58:15 CST 2011
Author: mjordan
Date: Wed Dec 14 15:58:12 2011
New Revision: 348211
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=348211
Log:
Fixed Asterisk crash when function QUEUE_MEMBER receives invalid input
The function QUEUE_MEMBER has two required parameters (queuename, option). It
was only checking for the presence of queuename. The patch checks for the
existence of the option parameter and provides better error logging when
invalid values are provided for the option parameter as well.
Modified:
branches/10/apps/app_queue.c
Modified: branches/10/apps/app_queue.c
URL: http://svnview.digium.com/svn/asterisk/branches/10/apps/app_queue.c?view=diff&rev=348211&r1=348210&r2=348211
==============================================================================
--- branches/10/apps/app_queue.c (original)
+++ branches/10/apps/app_queue.c Wed Dec 14 15:58:12 2011
@@ -6309,11 +6309,16 @@
buf[0] = '\0';
if (ast_strlen_zero(data)) {
- ast_log(LOG_ERROR, "%s requires an argument: queuename\n", cmd);
+ ast_log(LOG_ERROR, "Missing required argument. %s(<queuename>,<option>[<interface>])\n", cmd);
return -1;
}
AST_STANDARD_APP_ARGS(args, data);
+
+ if (args.argc < 2) {
+ ast_log(LOG_ERROR, "Missing required argument. %s(<queuename>,<option>[<interface>])\n", cmd);
+ return -1;
+ }
if ((q = find_load_queue_rt_friendly(args.queuename))) {
ao2_lock(q);
@@ -6364,6 +6369,9 @@
((m = interface_exists(q, args.interface)))) {
count = m->ignorebusy;
ao2_ref(m, -1);
+ } else {
+ ast_log(LOG_ERROR, "Unknown option %s provided to %s, valid values are: "
+ "logged, free, ready, count, penalty, paused, ignorebusy\n", args.option, cmd);
}
ao2_unlock(q);
queue_t_unref(q, "Done with temporary reference in QUEUE_MEMBER()");
More information about the asterisk-commits
mailing list