Fix load errors related to the new ari_model_validators.
[asterisk/asterisk.git] / res / res_stasis_http_channels.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 2012 - 2013, Digium, Inc.
5  *
6  * David M. Lee, II <dlee@digium.com>
7  *
8  * See http://www.asterisk.org for more information about
9  * the Asterisk project. Please do not directly contact
10  * any of the maintainers of this project for assistance;
11  * the project provides a web site, mailing lists and IRC
12  * channels for your use.
13  *
14  * This program is free software, distributed under the terms of
15  * the GNU General Public License Version 2. See the LICENSE file
16  * at the top of the source tree.
17  */
18
19 /*
20  * !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
21  * !!!!!                               DO NOT EDIT                        !!!!!
22  * !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
23  * This file is generated by a mustache template. Please see the original
24  * template in rest-api-templates/res_stasis_http_resource.c.mustache
25  */
26
27 /*! \file
28  *
29  * \brief Channel resources
30  *
31  * \author David M. Lee, II <dlee@digium.com>
32  */
33
34 /*** MODULEINFO
35         <depend type="module">res_stasis_http</depend>
36         <depend type="module">res_stasis</depend>
37         <support_level>core</support_level>
38  ***/
39
40 #include "asterisk.h"
41
42 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
43
44 #include "asterisk/module.h"
45 #include "asterisk/stasis_app.h"
46 #include "stasis_http/resource_channels.h"
47 #if defined(AST_DEVMODE)
48 #include "stasis_http/ari_model_validators.h"
49 #endif
50
51 /*!
52  * \brief Parameter parsing callback for /channels.
53  * \param get_params GET parameters in the HTTP request.
54  * \param path_vars Path variables extracted from the request.
55  * \param headers HTTP headers.
56  * \param[out] response Response to the HTTP request.
57  */
58 static void stasis_http_get_channels_cb(
59         struct ast_variable *get_params, struct ast_variable *path_vars,
60         struct ast_variable *headers, struct stasis_http_response *response)
61 {
62 #if defined(AST_DEVMODE)
63         int is_valid;
64         int code;
65 #endif /* AST_DEVMODE */
66
67         struct ast_get_channels_args args = {};
68         stasis_http_get_channels(headers, &args, response);
69 #if defined(AST_DEVMODE)
70         code = response->response_code;
71
72         switch (code) {
73         case 500: /* Internal server error */
74                 is_valid = 1;
75                 break;
76         default:
77                 if (200 <= code && code <= 299) {
78                         is_valid = ari_validate_list(response->message,
79                                 ari_validate_channel_fn());
80                 } else {
81                         ast_log(LOG_ERROR, "Invalid error response %d for /channels\n", code);
82                         is_valid = 0;
83                 }
84         }
85
86         if (!is_valid) {
87                 ast_log(LOG_ERROR, "Response validation failed for /channels\n");
88                 stasis_http_response_error(response, 500,
89                         "Internal Server Error", "Response validation failed");
90         }
91 #endif /* AST_DEVMODE */
92 }
93 /*!
94  * \brief Parameter parsing callback for /channels.
95  * \param get_params GET parameters in the HTTP request.
96  * \param path_vars Path variables extracted from the request.
97  * \param headers HTTP headers.
98  * \param[out] response Response to the HTTP request.
99  */
100 static void stasis_http_originate_cb(
101         struct ast_variable *get_params, struct ast_variable *path_vars,
102         struct ast_variable *headers, struct stasis_http_response *response)
103 {
104 #if defined(AST_DEVMODE)
105         int is_valid;
106         int code;
107 #endif /* AST_DEVMODE */
108
109         struct ast_originate_args args = {};
110         struct ast_variable *i;
111
112         for (i = get_params; i; i = i->next) {
113                 if (strcmp(i->name, "endpoint") == 0) {
114                         args.endpoint = (i->value);
115                 } else
116                 if (strcmp(i->name, "extension") == 0) {
117                         args.extension = (i->value);
118                 } else
119                 if (strcmp(i->name, "context") == 0) {
120                         args.context = (i->value);
121                 } else
122                 if (strcmp(i->name, "priority") == 0) {
123                         args.priority = atol(i->value);
124                 } else
125                 if (strcmp(i->name, "app") == 0) {
126                         args.app = (i->value);
127                 } else
128                 if (strcmp(i->name, "appArgs") == 0) {
129                         args.app_args = (i->value);
130                 } else
131                 if (strcmp(i->name, "callerId") == 0) {
132                         args.caller_id = (i->value);
133                 } else
134                 if (strcmp(i->name, "timeout") == 0) {
135                         args.timeout = atoi(i->value);
136                 } else
137                 {}
138         }
139         stasis_http_originate(headers, &args, response);
140 #if defined(AST_DEVMODE)
141         code = response->response_code;
142
143         switch (code) {
144         case 500: /* Internal server error */
145                 is_valid = 1;
146                 break;
147         default:
148                 if (200 <= code && code <= 299) {
149                         is_valid = ari_validate_void(
150                                 response->message);
151                 } else {
152                         ast_log(LOG_ERROR, "Invalid error response %d for /channels\n", code);
153                         is_valid = 0;
154                 }
155         }
156
157         if (!is_valid) {
158                 ast_log(LOG_ERROR, "Response validation failed for /channels\n");
159                 stasis_http_response_error(response, 500,
160                         "Internal Server Error", "Response validation failed");
161         }
162 #endif /* AST_DEVMODE */
163 }
164 /*!
165  * \brief Parameter parsing callback for /channels/{channelId}.
166  * \param get_params GET parameters in the HTTP request.
167  * \param path_vars Path variables extracted from the request.
168  * \param headers HTTP headers.
169  * \param[out] response Response to the HTTP request.
170  */
171 static void stasis_http_get_channel_cb(
172         struct ast_variable *get_params, struct ast_variable *path_vars,
173         struct ast_variable *headers, struct stasis_http_response *response)
174 {
175 #if defined(AST_DEVMODE)
176         int is_valid;
177         int code;
178 #endif /* AST_DEVMODE */
179
180         struct ast_get_channel_args args = {};
181         struct ast_variable *i;
182
183         for (i = path_vars; i; i = i->next) {
184                 if (strcmp(i->name, "channelId") == 0) {
185                         args.channel_id = (i->value);
186                 } else
187                 {}
188         }
189         stasis_http_get_channel(headers, &args, response);
190 #if defined(AST_DEVMODE)
191         code = response->response_code;
192
193         switch (code) {
194         case 500: /* Internal server error */
195         case 404: /* Channel not found */
196                 is_valid = 1;
197                 break;
198         default:
199                 if (200 <= code && code <= 299) {
200                         is_valid = ari_validate_channel(
201                                 response->message);
202                 } else {
203                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}\n", code);
204                         is_valid = 0;
205                 }
206         }
207
208         if (!is_valid) {
209                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}\n");
210                 stasis_http_response_error(response, 500,
211                         "Internal Server Error", "Response validation failed");
212         }
213 #endif /* AST_DEVMODE */
214 }
215 /*!
216  * \brief Parameter parsing callback for /channels/{channelId}.
217  * \param get_params GET parameters in the HTTP request.
218  * \param path_vars Path variables extracted from the request.
219  * \param headers HTTP headers.
220  * \param[out] response Response to the HTTP request.
221  */
222 static void stasis_http_delete_channel_cb(
223         struct ast_variable *get_params, struct ast_variable *path_vars,
224         struct ast_variable *headers, struct stasis_http_response *response)
225 {
226 #if defined(AST_DEVMODE)
227         int is_valid;
228         int code;
229 #endif /* AST_DEVMODE */
230
231         struct ast_delete_channel_args args = {};
232         struct ast_variable *i;
233
234         for (i = path_vars; i; i = i->next) {
235                 if (strcmp(i->name, "channelId") == 0) {
236                         args.channel_id = (i->value);
237                 } else
238                 {}
239         }
240         stasis_http_delete_channel(headers, &args, response);
241 #if defined(AST_DEVMODE)
242         code = response->response_code;
243
244         switch (code) {
245         case 500: /* Internal server error */
246         case 404: /* Channel not found */
247                 is_valid = 1;
248                 break;
249         default:
250                 if (200 <= code && code <= 299) {
251                         is_valid = ari_validate_void(
252                                 response->message);
253                 } else {
254                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}\n", code);
255                         is_valid = 0;
256                 }
257         }
258
259         if (!is_valid) {
260                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}\n");
261                 stasis_http_response_error(response, 500,
262                         "Internal Server Error", "Response validation failed");
263         }
264 #endif /* AST_DEVMODE */
265 }
266 /*!
267  * \brief Parameter parsing callback for /channels/{channelId}/dial.
268  * \param get_params GET parameters in the HTTP request.
269  * \param path_vars Path variables extracted from the request.
270  * \param headers HTTP headers.
271  * \param[out] response Response to the HTTP request.
272  */
273 static void stasis_http_dial_cb(
274         struct ast_variable *get_params, struct ast_variable *path_vars,
275         struct ast_variable *headers, struct stasis_http_response *response)
276 {
277 #if defined(AST_DEVMODE)
278         int is_valid;
279         int code;
280 #endif /* AST_DEVMODE */
281
282         struct ast_dial_args args = {};
283         struct ast_variable *i;
284
285         for (i = get_params; i; i = i->next) {
286                 if (strcmp(i->name, "endpoint") == 0) {
287                         args.endpoint = (i->value);
288                 } else
289                 if (strcmp(i->name, "extension") == 0) {
290                         args.extension = (i->value);
291                 } else
292                 if (strcmp(i->name, "context") == 0) {
293                         args.context = (i->value);
294                 } else
295                 if (strcmp(i->name, "timeout") == 0) {
296                         args.timeout = atoi(i->value);
297                 } else
298                 {}
299         }
300         for (i = path_vars; i; i = i->next) {
301                 if (strcmp(i->name, "channelId") == 0) {
302                         args.channel_id = (i->value);
303                 } else
304                 {}
305         }
306         stasis_http_dial(headers, &args, response);
307 #if defined(AST_DEVMODE)
308         code = response->response_code;
309
310         switch (code) {
311         case 500: /* Internal server error */
312         case 404: /* Channel not found */
313         case 409: /* Channel not in a Stasis application */
314                 is_valid = 1;
315                 break;
316         default:
317                 if (200 <= code && code <= 299) {
318                         is_valid = ari_validate_dialed(
319                                 response->message);
320                 } else {
321                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/dial\n", code);
322                         is_valid = 0;
323                 }
324         }
325
326         if (!is_valid) {
327                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/dial\n");
328                 stasis_http_response_error(response, 500,
329                         "Internal Server Error", "Response validation failed");
330         }
331 #endif /* AST_DEVMODE */
332 }
333 /*!
334  * \brief Parameter parsing callback for /channels/{channelId}/continue.
335  * \param get_params GET parameters in the HTTP request.
336  * \param path_vars Path variables extracted from the request.
337  * \param headers HTTP headers.
338  * \param[out] response Response to the HTTP request.
339  */
340 static void stasis_http_continue_in_dialplan_cb(
341         struct ast_variable *get_params, struct ast_variable *path_vars,
342         struct ast_variable *headers, struct stasis_http_response *response)
343 {
344 #if defined(AST_DEVMODE)
345         int is_valid;
346         int code;
347 #endif /* AST_DEVMODE */
348
349         struct ast_continue_in_dialplan_args args = {};
350         struct ast_variable *i;
351
352         for (i = get_params; i; i = i->next) {
353                 if (strcmp(i->name, "context") == 0) {
354                         args.context = (i->value);
355                 } else
356                 if (strcmp(i->name, "extension") == 0) {
357                         args.extension = (i->value);
358                 } else
359                 if (strcmp(i->name, "priority") == 0) {
360                         args.priority = atoi(i->value);
361                 } else
362                 {}
363         }
364         for (i = path_vars; i; i = i->next) {
365                 if (strcmp(i->name, "channelId") == 0) {
366                         args.channel_id = (i->value);
367                 } else
368                 {}
369         }
370         stasis_http_continue_in_dialplan(headers, &args, response);
371 #if defined(AST_DEVMODE)
372         code = response->response_code;
373
374         switch (code) {
375         case 500: /* Internal server error */
376         case 404: /* Channel not found */
377         case 409: /* Channel not in a Stasis application */
378                 is_valid = 1;
379                 break;
380         default:
381                 if (200 <= code && code <= 299) {
382                         is_valid = ari_validate_void(
383                                 response->message);
384                 } else {
385                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/continue\n", code);
386                         is_valid = 0;
387                 }
388         }
389
390         if (!is_valid) {
391                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/continue\n");
392                 stasis_http_response_error(response, 500,
393                         "Internal Server Error", "Response validation failed");
394         }
395 #endif /* AST_DEVMODE */
396 }
397 /*!
398  * \brief Parameter parsing callback for /channels/{channelId}/answer.
399  * \param get_params GET parameters in the HTTP request.
400  * \param path_vars Path variables extracted from the request.
401  * \param headers HTTP headers.
402  * \param[out] response Response to the HTTP request.
403  */
404 static void stasis_http_answer_channel_cb(
405         struct ast_variable *get_params, struct ast_variable *path_vars,
406         struct ast_variable *headers, struct stasis_http_response *response)
407 {
408 #if defined(AST_DEVMODE)
409         int is_valid;
410         int code;
411 #endif /* AST_DEVMODE */
412
413         struct ast_answer_channel_args args = {};
414         struct ast_variable *i;
415
416         for (i = path_vars; i; i = i->next) {
417                 if (strcmp(i->name, "channelId") == 0) {
418                         args.channel_id = (i->value);
419                 } else
420                 {}
421         }
422         stasis_http_answer_channel(headers, &args, response);
423 #if defined(AST_DEVMODE)
424         code = response->response_code;
425
426         switch (code) {
427         case 500: /* Internal server error */
428         case 404: /* Channel not found */
429         case 409: /* Channel not in a Stasis application */
430                 is_valid = 1;
431                 break;
432         default:
433                 if (200 <= code && code <= 299) {
434                         is_valid = ari_validate_void(
435                                 response->message);
436                 } else {
437                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/answer\n", code);
438                         is_valid = 0;
439                 }
440         }
441
442         if (!is_valid) {
443                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/answer\n");
444                 stasis_http_response_error(response, 500,
445                         "Internal Server Error", "Response validation failed");
446         }
447 #endif /* AST_DEVMODE */
448 }
449 /*!
450  * \brief Parameter parsing callback for /channels/{channelId}/mute.
451  * \param get_params GET parameters in the HTTP request.
452  * \param path_vars Path variables extracted from the request.
453  * \param headers HTTP headers.
454  * \param[out] response Response to the HTTP request.
455  */
456 static void stasis_http_mute_channel_cb(
457         struct ast_variable *get_params, struct ast_variable *path_vars,
458         struct ast_variable *headers, struct stasis_http_response *response)
459 {
460 #if defined(AST_DEVMODE)
461         int is_valid;
462         int code;
463 #endif /* AST_DEVMODE */
464
465         struct ast_mute_channel_args args = {};
466         struct ast_variable *i;
467
468         for (i = get_params; i; i = i->next) {
469                 if (strcmp(i->name, "direction") == 0) {
470                         args.direction = (i->value);
471                 } else
472                 {}
473         }
474         for (i = path_vars; i; i = i->next) {
475                 if (strcmp(i->name, "channelId") == 0) {
476                         args.channel_id = (i->value);
477                 } else
478                 {}
479         }
480         stasis_http_mute_channel(headers, &args, response);
481 #if defined(AST_DEVMODE)
482         code = response->response_code;
483
484         switch (code) {
485         case 500: /* Internal server error */
486         case 404: /* Channel not found */
487         case 409: /* Channel not in a Stasis application */
488                 is_valid = 1;
489                 break;
490         default:
491                 if (200 <= code && code <= 299) {
492                         is_valid = ari_validate_void(
493                                 response->message);
494                 } else {
495                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/mute\n", code);
496                         is_valid = 0;
497                 }
498         }
499
500         if (!is_valid) {
501                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/mute\n");
502                 stasis_http_response_error(response, 500,
503                         "Internal Server Error", "Response validation failed");
504         }
505 #endif /* AST_DEVMODE */
506 }
507 /*!
508  * \brief Parameter parsing callback for /channels/{channelId}/unmute.
509  * \param get_params GET parameters in the HTTP request.
510  * \param path_vars Path variables extracted from the request.
511  * \param headers HTTP headers.
512  * \param[out] response Response to the HTTP request.
513  */
514 static void stasis_http_unmute_channel_cb(
515         struct ast_variable *get_params, struct ast_variable *path_vars,
516         struct ast_variable *headers, struct stasis_http_response *response)
517 {
518 #if defined(AST_DEVMODE)
519         int is_valid;
520         int code;
521 #endif /* AST_DEVMODE */
522
523         struct ast_unmute_channel_args args = {};
524         struct ast_variable *i;
525
526         for (i = get_params; i; i = i->next) {
527                 if (strcmp(i->name, "direction") == 0) {
528                         args.direction = (i->value);
529                 } else
530                 {}
531         }
532         for (i = path_vars; i; i = i->next) {
533                 if (strcmp(i->name, "channelId") == 0) {
534                         args.channel_id = (i->value);
535                 } else
536                 {}
537         }
538         stasis_http_unmute_channel(headers, &args, response);
539 #if defined(AST_DEVMODE)
540         code = response->response_code;
541
542         switch (code) {
543         case 500: /* Internal server error */
544         case 404: /* Channel not found */
545         case 409: /* Channel not in a Stasis application */
546                 is_valid = 1;
547                 break;
548         default:
549                 if (200 <= code && code <= 299) {
550                         is_valid = ari_validate_void(
551                                 response->message);
552                 } else {
553                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/unmute\n", code);
554                         is_valid = 0;
555                 }
556         }
557
558         if (!is_valid) {
559                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/unmute\n");
560                 stasis_http_response_error(response, 500,
561                         "Internal Server Error", "Response validation failed");
562         }
563 #endif /* AST_DEVMODE */
564 }
565 /*!
566  * \brief Parameter parsing callback for /channels/{channelId}/hold.
567  * \param get_params GET parameters in the HTTP request.
568  * \param path_vars Path variables extracted from the request.
569  * \param headers HTTP headers.
570  * \param[out] response Response to the HTTP request.
571  */
572 static void stasis_http_hold_channel_cb(
573         struct ast_variable *get_params, struct ast_variable *path_vars,
574         struct ast_variable *headers, struct stasis_http_response *response)
575 {
576 #if defined(AST_DEVMODE)
577         int is_valid;
578         int code;
579 #endif /* AST_DEVMODE */
580
581         struct ast_hold_channel_args args = {};
582         struct ast_variable *i;
583
584         for (i = path_vars; i; i = i->next) {
585                 if (strcmp(i->name, "channelId") == 0) {
586                         args.channel_id = (i->value);
587                 } else
588                 {}
589         }
590         stasis_http_hold_channel(headers, &args, response);
591 #if defined(AST_DEVMODE)
592         code = response->response_code;
593
594         switch (code) {
595         case 500: /* Internal server error */
596         case 404: /* Channel not found */
597         case 409: /* Channel not in a Stasis application */
598                 is_valid = 1;
599                 break;
600         default:
601                 if (200 <= code && code <= 299) {
602                         is_valid = ari_validate_void(
603                                 response->message);
604                 } else {
605                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/hold\n", code);
606                         is_valid = 0;
607                 }
608         }
609
610         if (!is_valid) {
611                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/hold\n");
612                 stasis_http_response_error(response, 500,
613                         "Internal Server Error", "Response validation failed");
614         }
615 #endif /* AST_DEVMODE */
616 }
617 /*!
618  * \brief Parameter parsing callback for /channels/{channelId}/unhold.
619  * \param get_params GET parameters in the HTTP request.
620  * \param path_vars Path variables extracted from the request.
621  * \param headers HTTP headers.
622  * \param[out] response Response to the HTTP request.
623  */
624 static void stasis_http_unhold_channel_cb(
625         struct ast_variable *get_params, struct ast_variable *path_vars,
626         struct ast_variable *headers, struct stasis_http_response *response)
627 {
628 #if defined(AST_DEVMODE)
629         int is_valid;
630         int code;
631 #endif /* AST_DEVMODE */
632
633         struct ast_unhold_channel_args args = {};
634         struct ast_variable *i;
635
636         for (i = path_vars; i; i = i->next) {
637                 if (strcmp(i->name, "channelId") == 0) {
638                         args.channel_id = (i->value);
639                 } else
640                 {}
641         }
642         stasis_http_unhold_channel(headers, &args, response);
643 #if defined(AST_DEVMODE)
644         code = response->response_code;
645
646         switch (code) {
647         case 500: /* Internal server error */
648         case 404: /* Channel not found */
649         case 409: /* Channel not in a Stasis application */
650                 is_valid = 1;
651                 break;
652         default:
653                 if (200 <= code && code <= 299) {
654                         is_valid = ari_validate_void(
655                                 response->message);
656                 } else {
657                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/unhold\n", code);
658                         is_valid = 0;
659                 }
660         }
661
662         if (!is_valid) {
663                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/unhold\n");
664                 stasis_http_response_error(response, 500,
665                         "Internal Server Error", "Response validation failed");
666         }
667 #endif /* AST_DEVMODE */
668 }
669 /*!
670  * \brief Parameter parsing callback for /channels/{channelId}/play.
671  * \param get_params GET parameters in the HTTP request.
672  * \param path_vars Path variables extracted from the request.
673  * \param headers HTTP headers.
674  * \param[out] response Response to the HTTP request.
675  */
676 static void stasis_http_play_on_channel_cb(
677         struct ast_variable *get_params, struct ast_variable *path_vars,
678         struct ast_variable *headers, struct stasis_http_response *response)
679 {
680 #if defined(AST_DEVMODE)
681         int is_valid;
682         int code;
683 #endif /* AST_DEVMODE */
684
685         struct ast_play_on_channel_args args = {};
686         struct ast_variable *i;
687
688         for (i = get_params; i; i = i->next) {
689                 if (strcmp(i->name, "media") == 0) {
690                         args.media = (i->value);
691                 } else
692                 if (strcmp(i->name, "lang") == 0) {
693                         args.lang = (i->value);
694                 } else
695                 if (strcmp(i->name, "offsetms") == 0) {
696                         args.offsetms = atoi(i->value);
697                 } else
698                 if (strcmp(i->name, "skipms") == 0) {
699                         args.skipms = atoi(i->value);
700                 } else
701                 {}
702         }
703         for (i = path_vars; i; i = i->next) {
704                 if (strcmp(i->name, "channelId") == 0) {
705                         args.channel_id = (i->value);
706                 } else
707                 {}
708         }
709         stasis_http_play_on_channel(headers, &args, response);
710 #if defined(AST_DEVMODE)
711         code = response->response_code;
712
713         switch (code) {
714         case 500: /* Internal server error */
715         case 404: /* Channel not found */
716         case 409: /* Channel not in a Stasis application */
717                 is_valid = 1;
718                 break;
719         default:
720                 if (200 <= code && code <= 299) {
721                         is_valid = ari_validate_playback(
722                                 response->message);
723                 } else {
724                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/play\n", code);
725                         is_valid = 0;
726                 }
727         }
728
729         if (!is_valid) {
730                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/play\n");
731                 stasis_http_response_error(response, 500,
732                         "Internal Server Error", "Response validation failed");
733         }
734 #endif /* AST_DEVMODE */
735 }
736 /*!
737  * \brief Parameter parsing callback for /channels/{channelId}/record.
738  * \param get_params GET parameters in the HTTP request.
739  * \param path_vars Path variables extracted from the request.
740  * \param headers HTTP headers.
741  * \param[out] response Response to the HTTP request.
742  */
743 static void stasis_http_record_channel_cb(
744         struct ast_variable *get_params, struct ast_variable *path_vars,
745         struct ast_variable *headers, struct stasis_http_response *response)
746 {
747 #if defined(AST_DEVMODE)
748         int is_valid;
749         int code;
750 #endif /* AST_DEVMODE */
751
752         struct ast_record_channel_args args = {};
753         struct ast_variable *i;
754
755         for (i = get_params; i; i = i->next) {
756                 if (strcmp(i->name, "name") == 0) {
757                         args.name = (i->value);
758                 } else
759                 if (strcmp(i->name, "format") == 0) {
760                         args.format = (i->value);
761                 } else
762                 if (strcmp(i->name, "maxDurationSeconds") == 0) {
763                         args.max_duration_seconds = atoi(i->value);
764                 } else
765                 if (strcmp(i->name, "maxSilenceSeconds") == 0) {
766                         args.max_silence_seconds = atoi(i->value);
767                 } else
768                 if (strcmp(i->name, "ifExists") == 0) {
769                         args.if_exists = (i->value);
770                 } else
771                 if (strcmp(i->name, "beep") == 0) {
772                         args.beep = ast_true(i->value);
773                 } else
774                 if (strcmp(i->name, "terminateOn") == 0) {
775                         args.terminate_on = (i->value);
776                 } else
777                 {}
778         }
779         for (i = path_vars; i; i = i->next) {
780                 if (strcmp(i->name, "channelId") == 0) {
781                         args.channel_id = (i->value);
782                 } else
783                 {}
784         }
785         stasis_http_record_channel(headers, &args, response);
786 #if defined(AST_DEVMODE)
787         code = response->response_code;
788
789         switch (code) {
790         case 500: /* Internal server error */
791         case 400: /* Invalid parameters */
792         case 404: /* Channel not found */
793         case 409: /* Channel is not in a Stasis application; the channel is currently bridged with other channels; A recording with the same name is currently in progress. */
794                 is_valid = 1;
795                 break;
796         default:
797                 if (200 <= code && code <= 299) {
798                         is_valid = ari_validate_void(
799                                 response->message);
800                 } else {
801                         ast_log(LOG_ERROR, "Invalid error response %d for /channels/{channelId}/record\n", code);
802                         is_valid = 0;
803                 }
804         }
805
806         if (!is_valid) {
807                 ast_log(LOG_ERROR, "Response validation failed for /channels/{channelId}/record\n");
808                 stasis_http_response_error(response, 500,
809                         "Internal Server Error", "Response validation failed");
810         }
811 #endif /* AST_DEVMODE */
812 }
813
814 /*! \brief REST handler for /api-docs/channels.{format} */
815 static struct stasis_rest_handlers channels_channelId_dial = {
816         .path_segment = "dial",
817         .callbacks = {
818                 [AST_HTTP_POST] = stasis_http_dial_cb,
819         },
820         .num_children = 0,
821         .children = {  }
822 };
823 /*! \brief REST handler for /api-docs/channels.{format} */
824 static struct stasis_rest_handlers channels_channelId_continue = {
825         .path_segment = "continue",
826         .callbacks = {
827                 [AST_HTTP_POST] = stasis_http_continue_in_dialplan_cb,
828         },
829         .num_children = 0,
830         .children = {  }
831 };
832 /*! \brief REST handler for /api-docs/channels.{format} */
833 static struct stasis_rest_handlers channels_channelId_answer = {
834         .path_segment = "answer",
835         .callbacks = {
836                 [AST_HTTP_POST] = stasis_http_answer_channel_cb,
837         },
838         .num_children = 0,
839         .children = {  }
840 };
841 /*! \brief REST handler for /api-docs/channels.{format} */
842 static struct stasis_rest_handlers channels_channelId_mute = {
843         .path_segment = "mute",
844         .callbacks = {
845                 [AST_HTTP_POST] = stasis_http_mute_channel_cb,
846         },
847         .num_children = 0,
848         .children = {  }
849 };
850 /*! \brief REST handler for /api-docs/channels.{format} */
851 static struct stasis_rest_handlers channels_channelId_unmute = {
852         .path_segment = "unmute",
853         .callbacks = {
854                 [AST_HTTP_POST] = stasis_http_unmute_channel_cb,
855         },
856         .num_children = 0,
857         .children = {  }
858 };
859 /*! \brief REST handler for /api-docs/channels.{format} */
860 static struct stasis_rest_handlers channels_channelId_hold = {
861         .path_segment = "hold",
862         .callbacks = {
863                 [AST_HTTP_POST] = stasis_http_hold_channel_cb,
864         },
865         .num_children = 0,
866         .children = {  }
867 };
868 /*! \brief REST handler for /api-docs/channels.{format} */
869 static struct stasis_rest_handlers channels_channelId_unhold = {
870         .path_segment = "unhold",
871         .callbacks = {
872                 [AST_HTTP_POST] = stasis_http_unhold_channel_cb,
873         },
874         .num_children = 0,
875         .children = {  }
876 };
877 /*! \brief REST handler for /api-docs/channels.{format} */
878 static struct stasis_rest_handlers channels_channelId_play = {
879         .path_segment = "play",
880         .callbacks = {
881                 [AST_HTTP_POST] = stasis_http_play_on_channel_cb,
882         },
883         .num_children = 0,
884         .children = {  }
885 };
886 /*! \brief REST handler for /api-docs/channels.{format} */
887 static struct stasis_rest_handlers channels_channelId_record = {
888         .path_segment = "record",
889         .callbacks = {
890                 [AST_HTTP_POST] = stasis_http_record_channel_cb,
891         },
892         .num_children = 0,
893         .children = {  }
894 };
895 /*! \brief REST handler for /api-docs/channels.{format} */
896 static struct stasis_rest_handlers channels_channelId = {
897         .path_segment = "channelId",
898         .is_wildcard = 1,
899         .callbacks = {
900                 [AST_HTTP_GET] = stasis_http_get_channel_cb,
901                 [AST_HTTP_DELETE] = stasis_http_delete_channel_cb,
902         },
903         .num_children = 9,
904         .children = { &channels_channelId_dial,&channels_channelId_continue,&channels_channelId_answer,&channels_channelId_mute,&channels_channelId_unmute,&channels_channelId_hold,&channels_channelId_unhold,&channels_channelId_play,&channels_channelId_record, }
905 };
906 /*! \brief REST handler for /api-docs/channels.{format} */
907 static struct stasis_rest_handlers channels = {
908         .path_segment = "channels",
909         .callbacks = {
910                 [AST_HTTP_GET] = stasis_http_get_channels_cb,
911                 [AST_HTTP_POST] = stasis_http_originate_cb,
912         },
913         .num_children = 1,
914         .children = { &channels_channelId, }
915 };
916
917 static int load_module(void)
918 {
919         int res = 0;
920         stasis_app_ref();
921         res |= stasis_http_add_handler(&channels);
922         return res;
923 }
924
925 static int unload_module(void)
926 {
927         stasis_http_remove_handler(&channels);
928         stasis_app_unref();
929         return 0;
930 }
931
932 AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT, "RESTful API module - Channel resources",
933         .load = load_module,
934         .unload = unload_module,
935         .nonoptreq = "res_stasis_http,res_stasis",
936         );