]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
res_ari: Fix create request body parameter parsing.
authorsungtae kim <sungtae@messagebird.com>
Tue, 9 Jun 2020 11:57:24 +0000 (11:57 +0000)
committerJoshua Colp <jcolp@sangoma.com>
Tue, 9 Jun 2020 12:27:25 +0000 (07:27 -0500)
If parameters were passed in the body as JSON to the
create route they were not being parsed before checking
to ensure that required fields were set.

This change moves the parsing so it occurs before
checking.

ASTERISK-28940

Change-Id: I898b4c3c7ae1cde19a6840e59f498822701cf5cf

res/ari/resource_channels.c

index 7cf4137a973bf4d4b9d2763b99d22c9d69046ba7..81944f8386e5d11e240f1a605dbb802e0ea6c90d 100644 (file)
@@ -1790,18 +1790,6 @@ void ast_ari_channels_create(struct ast_variable *headers,
        struct ast_format_cap *request_cap;
        struct ast_channel *originator;
 
-       if (!ast_strlen_zero(args->originator) && !ast_strlen_zero(args->formats)) {
-               ast_ari_response_error(response, 400, "Bad Request",
-                       "Originator and formats can't both be specified");
-               return;
-       }
-
-       if (ast_strlen_zero(args->endpoint)) {
-               ast_ari_response_error(response, 400, "Bad Request",
-                       "Endpoint must be specified");
-               return;
-       }
-
        /* Parse any query parameters out of the body parameter */
        if (args->variables) {
                struct ast_json *json_variables;
@@ -1814,6 +1802,18 @@ void ast_ari_channels_create(struct ast_variable *headers,
                }
        }
 
+       if (!ast_strlen_zero(args->originator) && !ast_strlen_zero(args->formats)) {
+               ast_ari_response_error(response, 400, "Bad Request",
+                       "Originator and formats can't both be specified");
+               return;
+       }
+
+       if (ast_strlen_zero(args->endpoint)) {
+               ast_ari_response_error(response, 400, "Bad Request",
+                       "Endpoint must be specified");
+               return;
+       }
+
        chan_data = ast_calloc(1, sizeof(*chan_data));
        if (!chan_data) {
                ast_ari_response_alloc_failed(response);