mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-05 04:11:08 +00:00
Merge "app_page.c: Simplify dialplan using Page."
This commit is contained in:
@@ -48,7 +48,7 @@
|
|||||||
Page series of phones
|
Page series of phones
|
||||||
</synopsis>
|
</synopsis>
|
||||||
<syntax>
|
<syntax>
|
||||||
<parameter name="Technology/Resource" required="true" argsep="&">
|
<parameter name="Technology/Resource" required="false" argsep="&">
|
||||||
<argument name="Technology/Resource" required="true">
|
<argument name="Technology/Resource" required="true">
|
||||||
<para>Specification of the device(s) to dial. These must be in the format of
|
<para>Specification of the device(s) to dial. These must be in the format of
|
||||||
<literal>Technology/Resource</literal>, where <replaceable>Technology</replaceable>
|
<literal>Technology/Resource</literal>, where <replaceable>Technology</replaceable>
|
||||||
@@ -270,17 +270,12 @@ static int page_exec(struct ast_channel *chan, const char *data)
|
|||||||
AST_APP_ARG(timeout);
|
AST_APP_ARG(timeout);
|
||||||
);
|
);
|
||||||
|
|
||||||
if (ast_strlen_zero(data)) {
|
|
||||||
ast_log(LOG_WARNING, "This application requires at least one argument (destination(s) to page)\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!(app = pbx_findapp("ConfBridge"))) {
|
if (!(app = pbx_findapp("ConfBridge"))) {
|
||||||
ast_log(LOG_WARNING, "There is no ConfBridge application available!\n");
|
ast_log(LOG_WARNING, "There is no ConfBridge application available!\n");
|
||||||
return -1;
|
return -1;
|
||||||
};
|
};
|
||||||
|
|
||||||
parse = ast_strdupa(data);
|
parse = ast_strdupa(data ?: "");
|
||||||
|
|
||||||
AST_STANDARD_APP_ARGS(args, parse);
|
AST_STANDARD_APP_ARGS(args, parse);
|
||||||
|
|
||||||
@@ -301,7 +296,7 @@ static int page_exec(struct ast_channel *chan, const char *data)
|
|||||||
|
|
||||||
/* Count number of extensions in list by number of ampersands + 1 */
|
/* Count number of extensions in list by number of ampersands + 1 */
|
||||||
num_dials = 1;
|
num_dials = 1;
|
||||||
tmp = args.devices;
|
tmp = args.devices ?: "";
|
||||||
while (*tmp) {
|
while (*tmp) {
|
||||||
if (*tmp == '&') {
|
if (*tmp == '&') {
|
||||||
num_dials++;
|
num_dials++;
|
||||||
@@ -334,13 +329,20 @@ static int page_exec(struct ast_channel *chan, const char *data)
|
|||||||
int state = 0;
|
int state = 0;
|
||||||
struct ast_dial *dial = NULL;
|
struct ast_dial *dial = NULL;
|
||||||
|
|
||||||
/* don't call the originating device */
|
tech = ast_strip(tech);
|
||||||
if (!strcasecmp(tech, originator))
|
if (ast_strlen_zero(tech)) {
|
||||||
|
/* No tech/resource in this position. */
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* don't call the originating device */
|
||||||
|
if (!strcasecmp(tech, originator)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* If no resource is available, continue on */
|
/* If no resource is available, continue on */
|
||||||
if (!(resource = strchr(tech, '/'))) {
|
if (!(resource = strchr(tech, '/'))) {
|
||||||
ast_log(LOG_WARNING, "Incomplete destination '%s' supplied.\n", tech);
|
ast_log(LOG_WARNING, "Incomplete destination: '%s' supplied.\n", tech);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -348,9 +350,11 @@ static int page_exec(struct ast_channel *chan, const char *data)
|
|||||||
if (ast_test_flag(&options.flags, PAGE_SKIP)) {
|
if (ast_test_flag(&options.flags, PAGE_SKIP)) {
|
||||||
state = ast_device_state(tech);
|
state = ast_device_state(tech);
|
||||||
if (state == AST_DEVICE_UNKNOWN) {
|
if (state == AST_DEVICE_UNKNOWN) {
|
||||||
ast_log(LOG_WARNING, "Destination '%s' has device state '%s'. Paging anyway.\n", tech, ast_devstate2str(state));
|
ast_verb(3, "Destination '%s' has device state '%s'. Paging anyway.\n",
|
||||||
|
tech, ast_devstate2str(state));
|
||||||
} else if (state != AST_DEVICE_NOT_INUSE) {
|
} else if (state != AST_DEVICE_NOT_INUSE) {
|
||||||
ast_log(LOG_WARNING, "Destination '%s' has device state '%s'.\n", tech, ast_devstate2str(state));
|
ast_verb(3, "Destination '%s' has device state '%s'.\n",
|
||||||
|
tech, ast_devstate2str(state));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -365,7 +369,7 @@ static int page_exec(struct ast_channel *chan, const char *data)
|
|||||||
|
|
||||||
/* Append technology and resource */
|
/* Append technology and resource */
|
||||||
if (ast_dial_append(dial, tech, resource, NULL) == -1) {
|
if (ast_dial_append(dial, tech, resource, NULL) == -1) {
|
||||||
ast_log(LOG_ERROR, "Failed to add %s to outbound dial\n", tech);
|
ast_log(LOG_ERROR, "Failed to add %s/%s to outbound dial\n", tech, resource);
|
||||||
ast_dial_destroy(dial);
|
ast_dial_destroy(dial);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
5
doc/CHANGES-staging/app_page_empty_page_list.txt
Normal file
5
doc/CHANGES-staging/app_page_empty_page_list.txt
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Subject: app_page
|
||||||
|
|
||||||
|
The Page application now tolerates empty positions in the supplied
|
||||||
|
destination list. Dialplan can now be simplified by not having to check
|
||||||
|
for empty positions in the destination list.
|
Reference in New Issue
Block a user