mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-21 12:54:56 +00:00
Change ARI originate to also allow dialing an exten/context/priority.
The old way didn't make much sense, so some of the fields were repurposed. (closes issue ASTERISK-21658) Review: https://reviewboard.asterisk.org/r/2626/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@393144 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -83,11 +83,8 @@ static void stasis_http_originate_cb(
|
||||
if (strcmp(i->name, "context") == 0) {
|
||||
args.context = (i->value);
|
||||
} else
|
||||
if (strcmp(i->name, "callerId") == 0) {
|
||||
args.caller_id = (i->value);
|
||||
} else
|
||||
if (strcmp(i->name, "timeout") == 0) {
|
||||
args.timeout = atoi(i->value);
|
||||
if (strcmp(i->name, "priority") == 0) {
|
||||
args.priority = atol(i->value);
|
||||
} else
|
||||
if (strcmp(i->name, "app") == 0) {
|
||||
args.app = (i->value);
|
||||
@@ -95,6 +92,12 @@ static void stasis_http_originate_cb(
|
||||
if (strcmp(i->name, "appArgs") == 0) {
|
||||
args.app_args = (i->value);
|
||||
} else
|
||||
if (strcmp(i->name, "callerId") == 0) {
|
||||
args.caller_id = (i->value);
|
||||
} else
|
||||
if (strcmp(i->name, "timeout") == 0) {
|
||||
args.timeout = atoi(i->value);
|
||||
} else
|
||||
{}
|
||||
}
|
||||
stasis_http_originate(headers, &args, response);
|
||||
|
@@ -320,14 +320,51 @@ void stasis_http_originate(struct ast_variable *headers,
|
||||
struct ast_originate_args *args,
|
||||
struct stasis_http_response *response)
|
||||
{
|
||||
const char *dialtech = NULL;
|
||||
char *dialtech;
|
||||
char dialdevice[AST_CHANNEL_NAME];
|
||||
char *caller_id = NULL;
|
||||
char *cid_num = NULL;
|
||||
char *cid_name = NULL;
|
||||
int timeout = 30000;
|
||||
|
||||
char *stuff;
|
||||
|
||||
if (ast_strlen_zero(args->endpoint)) {
|
||||
stasis_http_response_error(response, 400, "Bad Request",
|
||||
"Endpoint must be specified");
|
||||
return;
|
||||
}
|
||||
|
||||
dialtech = ast_strdupa(args->endpoint);
|
||||
if ((stuff = strchr(dialtech, '/'))) {
|
||||
*stuff++ = '\0';
|
||||
ast_copy_string(dialdevice, stuff, sizeof(dialdevice));
|
||||
}
|
||||
|
||||
if (ast_strlen_zero(dialtech) || ast_strlen_zero(dialdevice)) {
|
||||
stasis_http_response_error(response, 400, "Bad Request",
|
||||
"Invalid endpoint specified");
|
||||
return;
|
||||
}
|
||||
|
||||
if (args->timeout > 0) {
|
||||
timeout = args->timeout * 1000;
|
||||
} else if (args->timeout == -1) {
|
||||
timeout = -1;
|
||||
}
|
||||
|
||||
if (!ast_strlen_zero(args->caller_id)) {
|
||||
caller_id = ast_strdupa(args->caller_id);
|
||||
ast_callerid_parse(caller_id, &cid_name, &cid_num);
|
||||
|
||||
if (ast_is_shrinkable_phonenumber(cid_num)) {
|
||||
ast_shrink_phone_number(cid_num);
|
||||
}
|
||||
}
|
||||
|
||||
if (!ast_strlen_zero(args->app)) {
|
||||
const char *app = "Stasis";
|
||||
|
||||
RAII_VAR(struct ast_str *, appdata, ast_str_create(64), ast_free);
|
||||
|
||||
if (!appdata) {
|
||||
@@ -340,49 +377,22 @@ void stasis_http_originate(struct ast_variable *headers,
|
||||
ast_str_append(&appdata, 0, ",%s", args->app_args);
|
||||
}
|
||||
|
||||
if (args->timeout > 0) {
|
||||
timeout = args->timeout * 1000;
|
||||
} else if (args->timeout == -1) {
|
||||
timeout = -1;
|
||||
}
|
||||
|
||||
if (!ast_strlen_zero(args->endpoint)) {
|
||||
char *tmp = ast_strdupa(args->endpoint);
|
||||
char *stuff;
|
||||
|
||||
if ((stuff = strchr(tmp, '/'))) {
|
||||
*stuff++ = '\0';
|
||||
dialtech = tmp;
|
||||
ast_copy_string(dialdevice, stuff, sizeof(dialdevice));
|
||||
}
|
||||
} else if (!ast_strlen_zero(args->extension) && !ast_strlen_zero(args->context)) {
|
||||
dialtech = "Local";
|
||||
snprintf(dialdevice, sizeof(dialdevice), "%s@%s", args->extension, args->context);
|
||||
}
|
||||
|
||||
if (ast_strlen_zero(dialtech) || ast_strlen_zero(dialdevice)) {
|
||||
stasis_http_response_error(
|
||||
response, 500, "Internal server error",
|
||||
"Invalid endpoint or extension and context specified");
|
||||
return;
|
||||
}
|
||||
|
||||
if (!ast_strlen_zero(args->caller_id)) {
|
||||
caller_id = ast_strdupa(args->caller_id);
|
||||
ast_callerid_parse(caller_id, &cid_name, &cid_num);
|
||||
|
||||
if (ast_is_shrinkable_phonenumber(cid_num)) {
|
||||
ast_shrink_phone_number(cid_num);
|
||||
}
|
||||
}
|
||||
|
||||
ast_debug(1, "Dialing %s/%s\n", dialtech, dialdevice);
|
||||
|
||||
/* originate a channel, putting it into an application */
|
||||
if (ast_pbx_outgoing_app(dialtech, NULL, dialdevice, timeout, app, ast_str_buffer(appdata), NULL, 0, cid_num, cid_name, NULL, NULL, NULL)) {
|
||||
stasis_http_response_alloc_failed(response);
|
||||
return;
|
||||
}
|
||||
} else if (!ast_strlen_zero(args->extension)) {
|
||||
/* originate a channel, sending it to an extension */
|
||||
if (ast_pbx_outgoing_exten(dialtech, NULL, dialdevice, timeout, S_OR(args->context, "default"), args->extension, args->priority ? args->priority : 1, NULL, 0, cid_num, cid_name, NULL, NULL, NULL, 0)) {
|
||||
stasis_http_response_alloc_failed(response);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
stasis_http_response_error(response, 400, "Bad Request",
|
||||
"Application or extension must be specified");
|
||||
return;
|
||||
}
|
||||
|
||||
stasis_http_response_no_content(response);
|
||||
}
|
||||
|
@@ -52,20 +52,22 @@ struct ast_get_channels_args {
|
||||
void stasis_http_get_channels(struct ast_variable *headers, struct ast_get_channels_args *args, struct stasis_http_response *response);
|
||||
/*! \brief Argument struct for stasis_http_originate() */
|
||||
struct ast_originate_args {
|
||||
/*! \brief Endpoint to call. If not specified, originate is routed via dialplan */
|
||||
/*! \brief Endpoint to call. */
|
||||
const char *endpoint;
|
||||
/*! \brief When routing via dialplan, the extension to dial */
|
||||
/*! \brief The extension to dial after the endpoint answers */
|
||||
const char *extension;
|
||||
/*! \brief When routing via dialplan, the context to use. If omitted, uses 'default' */
|
||||
/*! \brief The context to dial after the endpoint answers. If omitted, uses 'default' */
|
||||
const char *context;
|
||||
/*! \brief The priority to dial after the endpoint answers. If omitted, uses 1 */
|
||||
long priority;
|
||||
/*! \brief The application name to pass to the Stasis application. */
|
||||
const char *app;
|
||||
/*! \brief The application arguments to pass to the Stasis application. */
|
||||
const char *app_args;
|
||||
/*! \brief CallerID to use when dialing the endpoint or extension. */
|
||||
const char *caller_id;
|
||||
/*! \brief Timeout (in seconds) before giving up dialing, or -1 for no timeout. */
|
||||
int timeout;
|
||||
/*! \brief Application name to pass to the Stasis application. */
|
||||
const char *app;
|
||||
/*! \brief Application arguments to pass to the Stasis application. */
|
||||
const char *app_args;
|
||||
};
|
||||
/*!
|
||||
* \brief Create a new channel (originate).
|
||||
|
@@ -25,15 +25,15 @@
|
||||
"parameters": [
|
||||
{
|
||||
"name": "endpoint",
|
||||
"description": "Endpoint to call. If not specified, originate is routed via dialplan",
|
||||
"description": "Endpoint to call.",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"required": true,
|
||||
"allowMultiple": false,
|
||||
"dataType": "string"
|
||||
},
|
||||
{
|
||||
"name": "extension",
|
||||
"description": "When routing via dialplan, the extension to dial",
|
||||
"description": "The extension to dial after the endpoint answers",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
@@ -41,7 +41,31 @@
|
||||
},
|
||||
{
|
||||
"name": "context",
|
||||
"description": "When routing via dialplan, the context to use. If omitted, uses 'default'",
|
||||
"description": "The context to dial after the endpoint answers. If omitted, uses 'default'",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
"dataType": "string"
|
||||
},
|
||||
{
|
||||
"name": "priority",
|
||||
"description": "The priority to dial after the endpoint answers. If omitted, uses 1",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
"dataType": "long"
|
||||
},
|
||||
{
|
||||
"name": "app",
|
||||
"description": "The application name to pass to the Stasis application.",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
"dataType": "string"
|
||||
},
|
||||
{
|
||||
"name": "appArgs",
|
||||
"description": "The application arguments to pass to the Stasis application.",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
@@ -63,22 +87,6 @@
|
||||
"allowMultiple": false,
|
||||
"dataType": "int",
|
||||
"defaultValue": 30
|
||||
},
|
||||
{
|
||||
"name": "app",
|
||||
"description": "Application name to pass to the Stasis application.",
|
||||
"paramType": "query",
|
||||
"required": true,
|
||||
"allowMultiple": false,
|
||||
"dataType": "string"
|
||||
},
|
||||
{
|
||||
"name": "appArgs",
|
||||
"description": "Application arguments to pass to the Stasis application.",
|
||||
"paramType": "query",
|
||||
"required": false,
|
||||
"allowMultiple": false,
|
||||
"dataType": "string"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
Reference in New Issue
Block a user