Implement ARI POST to /channels, to originate a call.
[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
48 /*!
49  * \brief Parameter parsing callback for /channels.
50  * \param get_params GET parameters in the HTTP request.
51  * \param path_vars Path variables extracted from the request.
52  * \param headers HTTP headers.
53  * \param[out] response Response to the HTTP request.
54  */
55 static void stasis_http_get_channels_cb(
56     struct ast_variable *get_params, struct ast_variable *path_vars,
57     struct ast_variable *headers, struct stasis_http_response *response)
58 {
59         struct ast_get_channels_args args = {};
60         stasis_http_get_channels(headers, &args, response);
61 }
62 /*!
63  * \brief Parameter parsing callback for /channels.
64  * \param get_params GET parameters in the HTTP request.
65  * \param path_vars Path variables extracted from the request.
66  * \param headers HTTP headers.
67  * \param[out] response Response to the HTTP request.
68  */
69 static void stasis_http_originate_cb(
70     struct ast_variable *get_params, struct ast_variable *path_vars,
71     struct ast_variable *headers, struct stasis_http_response *response)
72 {
73         struct ast_originate_args args = {};
74         struct ast_variable *i;
75
76         for (i = get_params; i; i = i->next) {
77                 if (strcmp(i->name, "endpoint") == 0) {
78                         args.endpoint = (i->value);
79                 } else
80                 if (strcmp(i->name, "extension") == 0) {
81                         args.extension = (i->value);
82                 } else
83                 if (strcmp(i->name, "context") == 0) {
84                         args.context = (i->value);
85                 } else
86                 if (strcmp(i->name, "callerId") == 0) {
87                         args.caller_id = (i->value);
88                 } else
89                 if (strcmp(i->name, "timeout") == 0) {
90                         args.timeout = atoi(i->value);
91                 } else
92                 if (strcmp(i->name, "app") == 0) {
93                         args.app = (i->value);
94                 } else
95                 if (strcmp(i->name, "appArgs") == 0) {
96                         args.app_args = (i->value);
97                 } else
98                 {}
99         }
100         stasis_http_originate(headers, &args, response);
101 }
102 /*!
103  * \brief Parameter parsing callback for /channels/{channelId}.
104  * \param get_params GET parameters in the HTTP request.
105  * \param path_vars Path variables extracted from the request.
106  * \param headers HTTP headers.
107  * \param[out] response Response to the HTTP request.
108  */
109 static void stasis_http_get_channel_cb(
110     struct ast_variable *get_params, struct ast_variable *path_vars,
111     struct ast_variable *headers, struct stasis_http_response *response)
112 {
113         struct ast_get_channel_args args = {};
114         struct ast_variable *i;
115
116         for (i = path_vars; i; i = i->next) {
117                 if (strcmp(i->name, "channelId") == 0) {
118                         args.channel_id = (i->value);
119                 } else
120                 {}
121         }
122         stasis_http_get_channel(headers, &args, response);
123 }
124 /*!
125  * \brief Parameter parsing callback for /channels/{channelId}.
126  * \param get_params GET parameters in the HTTP request.
127  * \param path_vars Path variables extracted from the request.
128  * \param headers HTTP headers.
129  * \param[out] response Response to the HTTP request.
130  */
131 static void stasis_http_delete_channel_cb(
132     struct ast_variable *get_params, struct ast_variable *path_vars,
133     struct ast_variable *headers, struct stasis_http_response *response)
134 {
135         struct ast_delete_channel_args args = {};
136         struct ast_variable *i;
137
138         for (i = path_vars; i; i = i->next) {
139                 if (strcmp(i->name, "channelId") == 0) {
140                         args.channel_id = (i->value);
141                 } else
142                 {}
143         }
144         stasis_http_delete_channel(headers, &args, response);
145 }
146 /*!
147  * \brief Parameter parsing callback for /channels/{channelId}/dial.
148  * \param get_params GET parameters in the HTTP request.
149  * \param path_vars Path variables extracted from the request.
150  * \param headers HTTP headers.
151  * \param[out] response Response to the HTTP request.
152  */
153 static void stasis_http_dial_cb(
154     struct ast_variable *get_params, struct ast_variable *path_vars,
155     struct ast_variable *headers, struct stasis_http_response *response)
156 {
157         struct ast_dial_args args = {};
158         struct ast_variable *i;
159
160         for (i = get_params; i; i = i->next) {
161                 if (strcmp(i->name, "endpoint") == 0) {
162                         args.endpoint = (i->value);
163                 } else
164                 if (strcmp(i->name, "extension") == 0) {
165                         args.extension = (i->value);
166                 } else
167                 if (strcmp(i->name, "context") == 0) {
168                         args.context = (i->value);
169                 } else
170                 {}
171         }
172         for (i = path_vars; i; i = i->next) {
173                 if (strcmp(i->name, "channelId") == 0) {
174                         args.channel_id = (i->value);
175                 } else
176                 {}
177         }
178         stasis_http_dial(headers, &args, response);
179 }
180 /*!
181  * \brief Parameter parsing callback for /channels/{channelId}/continue.
182  * \param get_params GET parameters in the HTTP request.
183  * \param path_vars Path variables extracted from the request.
184  * \param headers HTTP headers.
185  * \param[out] response Response to the HTTP request.
186  */
187 static void stasis_http_continue_in_dialplan_cb(
188     struct ast_variable *get_params, struct ast_variable *path_vars,
189     struct ast_variable *headers, struct stasis_http_response *response)
190 {
191         struct ast_continue_in_dialplan_args args = {};
192         struct ast_variable *i;
193
194         for (i = path_vars; i; i = i->next) {
195                 if (strcmp(i->name, "channelId") == 0) {
196                         args.channel_id = (i->value);
197                 } else
198                 {}
199         }
200         stasis_http_continue_in_dialplan(headers, &args, response);
201 }
202 /*!
203  * \brief Parameter parsing callback for /channels/{channelId}/answer.
204  * \param get_params GET parameters in the HTTP request.
205  * \param path_vars Path variables extracted from the request.
206  * \param headers HTTP headers.
207  * \param[out] response Response to the HTTP request.
208  */
209 static void stasis_http_answer_channel_cb(
210     struct ast_variable *get_params, struct ast_variable *path_vars,
211     struct ast_variable *headers, struct stasis_http_response *response)
212 {
213         struct ast_answer_channel_args args = {};
214         struct ast_variable *i;
215
216         for (i = path_vars; i; i = i->next) {
217                 if (strcmp(i->name, "channelId") == 0) {
218                         args.channel_id = (i->value);
219                 } else
220                 {}
221         }
222         stasis_http_answer_channel(headers, &args, response);
223 }
224 /*!
225  * \brief Parameter parsing callback for /channels/{channelId}/mute.
226  * \param get_params GET parameters in the HTTP request.
227  * \param path_vars Path variables extracted from the request.
228  * \param headers HTTP headers.
229  * \param[out] response Response to the HTTP request.
230  */
231 static void stasis_http_mute_channel_cb(
232     struct ast_variable *get_params, struct ast_variable *path_vars,
233     struct ast_variable *headers, struct stasis_http_response *response)
234 {
235         struct ast_mute_channel_args args = {};
236         struct ast_variable *i;
237
238         for (i = get_params; i; i = i->next) {
239                 if (strcmp(i->name, "direction") == 0) {
240                         args.direction = (i->value);
241                 } else
242                 {}
243         }
244         for (i = path_vars; i; i = i->next) {
245                 if (strcmp(i->name, "channelId") == 0) {
246                         args.channel_id = (i->value);
247                 } else
248                 {}
249         }
250         stasis_http_mute_channel(headers, &args, response);
251 }
252 /*!
253  * \brief Parameter parsing callback for /channels/{channelId}/unmute.
254  * \param get_params GET parameters in the HTTP request.
255  * \param path_vars Path variables extracted from the request.
256  * \param headers HTTP headers.
257  * \param[out] response Response to the HTTP request.
258  */
259 static void stasis_http_unmute_channel_cb(
260     struct ast_variable *get_params, struct ast_variable *path_vars,
261     struct ast_variable *headers, struct stasis_http_response *response)
262 {
263         struct ast_unmute_channel_args args = {};
264         struct ast_variable *i;
265
266         for (i = get_params; i; i = i->next) {
267                 if (strcmp(i->name, "direction") == 0) {
268                         args.direction = (i->value);
269                 } else
270                 {}
271         }
272         for (i = path_vars; i; i = i->next) {
273                 if (strcmp(i->name, "channelId") == 0) {
274                         args.channel_id = (i->value);
275                 } else
276                 {}
277         }
278         stasis_http_unmute_channel(headers, &args, response);
279 }
280 /*!
281  * \brief Parameter parsing callback for /channels/{channelId}/hold.
282  * \param get_params GET parameters in the HTTP request.
283  * \param path_vars Path variables extracted from the request.
284  * \param headers HTTP headers.
285  * \param[out] response Response to the HTTP request.
286  */
287 static void stasis_http_hold_channel_cb(
288     struct ast_variable *get_params, struct ast_variable *path_vars,
289     struct ast_variable *headers, struct stasis_http_response *response)
290 {
291         struct ast_hold_channel_args args = {};
292         struct ast_variable *i;
293
294         for (i = path_vars; i; i = i->next) {
295                 if (strcmp(i->name, "channelId") == 0) {
296                         args.channel_id = (i->value);
297                 } else
298                 {}
299         }
300         stasis_http_hold_channel(headers, &args, response);
301 }
302 /*!
303  * \brief Parameter parsing callback for /channels/{channelId}/unhold.
304  * \param get_params GET parameters in the HTTP request.
305  * \param path_vars Path variables extracted from the request.
306  * \param headers HTTP headers.
307  * \param[out] response Response to the HTTP request.
308  */
309 static void stasis_http_unhold_channel_cb(
310     struct ast_variable *get_params, struct ast_variable *path_vars,
311     struct ast_variable *headers, struct stasis_http_response *response)
312 {
313         struct ast_unhold_channel_args args = {};
314         struct ast_variable *i;
315
316         for (i = path_vars; i; i = i->next) {
317                 if (strcmp(i->name, "channelId") == 0) {
318                         args.channel_id = (i->value);
319                 } else
320                 {}
321         }
322         stasis_http_unhold_channel(headers, &args, response);
323 }
324 /*!
325  * \brief Parameter parsing callback for /channels/{channelId}/play.
326  * \param get_params GET parameters in the HTTP request.
327  * \param path_vars Path variables extracted from the request.
328  * \param headers HTTP headers.
329  * \param[out] response Response to the HTTP request.
330  */
331 static void stasis_http_play_on_channel_cb(
332     struct ast_variable *get_params, struct ast_variable *path_vars,
333     struct ast_variable *headers, struct stasis_http_response *response)
334 {
335         struct ast_play_on_channel_args args = {};
336         struct ast_variable *i;
337
338         for (i = get_params; i; i = i->next) {
339                 if (strcmp(i->name, "media") == 0) {
340                         args.media = (i->value);
341                 } else
342                 if (strcmp(i->name, "lang") == 0) {
343                         args.lang = (i->value);
344                 } else
345                 if (strcmp(i->name, "offsetms") == 0) {
346                         args.offsetms = atoi(i->value);
347                 } else
348                 if (strcmp(i->name, "skipms") == 0) {
349                         args.skipms = atoi(i->value);
350                 } else
351                 {}
352         }
353         for (i = path_vars; i; i = i->next) {
354                 if (strcmp(i->name, "channelId") == 0) {
355                         args.channel_id = (i->value);
356                 } else
357                 {}
358         }
359         stasis_http_play_on_channel(headers, &args, response);
360 }
361 /*!
362  * \brief Parameter parsing callback for /channels/{channelId}/record.
363  * \param get_params GET parameters in the HTTP request.
364  * \param path_vars Path variables extracted from the request.
365  * \param headers HTTP headers.
366  * \param[out] response Response to the HTTP request.
367  */
368 static void stasis_http_record_channel_cb(
369     struct ast_variable *get_params, struct ast_variable *path_vars,
370     struct ast_variable *headers, struct stasis_http_response *response)
371 {
372         struct ast_record_channel_args args = {};
373         struct ast_variable *i;
374
375         for (i = get_params; i; i = i->next) {
376                 if (strcmp(i->name, "name") == 0) {
377                         args.name = (i->value);
378                 } else
379                 if (strcmp(i->name, "format") == 0) {
380                         args.format = (i->value);
381                 } else
382                 if (strcmp(i->name, "maxDurationSeconds") == 0) {
383                         args.max_duration_seconds = atoi(i->value);
384                 } else
385                 if (strcmp(i->name, "maxSilenceSeconds") == 0) {
386                         args.max_silence_seconds = atoi(i->value);
387                 } else
388                 if (strcmp(i->name, "append") == 0) {
389                         args.append = atoi(i->value);
390                 } else
391                 if (strcmp(i->name, "beep") == 0) {
392                         args.beep = atoi(i->value);
393                 } else
394                 if (strcmp(i->name, "terminateOn") == 0) {
395                         args.terminate_on = (i->value);
396                 } else
397                 {}
398         }
399         for (i = path_vars; i; i = i->next) {
400                 if (strcmp(i->name, "channelId") == 0) {
401                         args.channel_id = (i->value);
402                 } else
403                 {}
404         }
405         stasis_http_record_channel(headers, &args, response);
406 }
407
408 /*! \brief REST handler for /api-docs/channels.{format} */
409 static struct stasis_rest_handlers channels_channelId_dial = {
410         .path_segment = "dial",
411         .callbacks = {
412                 [AST_HTTP_POST] = stasis_http_dial_cb,
413         },
414         .num_children = 0,
415         .children = {  }
416 };
417 /*! \brief REST handler for /api-docs/channels.{format} */
418 static struct stasis_rest_handlers channels_channelId_continue = {
419         .path_segment = "continue",
420         .callbacks = {
421                 [AST_HTTP_POST] = stasis_http_continue_in_dialplan_cb,
422         },
423         .num_children = 0,
424         .children = {  }
425 };
426 /*! \brief REST handler for /api-docs/channels.{format} */
427 static struct stasis_rest_handlers channels_channelId_answer = {
428         .path_segment = "answer",
429         .callbacks = {
430                 [AST_HTTP_POST] = stasis_http_answer_channel_cb,
431         },
432         .num_children = 0,
433         .children = {  }
434 };
435 /*! \brief REST handler for /api-docs/channels.{format} */
436 static struct stasis_rest_handlers channels_channelId_mute = {
437         .path_segment = "mute",
438         .callbacks = {
439                 [AST_HTTP_POST] = stasis_http_mute_channel_cb,
440         },
441         .num_children = 0,
442         .children = {  }
443 };
444 /*! \brief REST handler for /api-docs/channels.{format} */
445 static struct stasis_rest_handlers channels_channelId_unmute = {
446         .path_segment = "unmute",
447         .callbacks = {
448                 [AST_HTTP_POST] = stasis_http_unmute_channel_cb,
449         },
450         .num_children = 0,
451         .children = {  }
452 };
453 /*! \brief REST handler for /api-docs/channels.{format} */
454 static struct stasis_rest_handlers channels_channelId_hold = {
455         .path_segment = "hold",
456         .callbacks = {
457                 [AST_HTTP_POST] = stasis_http_hold_channel_cb,
458         },
459         .num_children = 0,
460         .children = {  }
461 };
462 /*! \brief REST handler for /api-docs/channels.{format} */
463 static struct stasis_rest_handlers channels_channelId_unhold = {
464         .path_segment = "unhold",
465         .callbacks = {
466                 [AST_HTTP_POST] = stasis_http_unhold_channel_cb,
467         },
468         .num_children = 0,
469         .children = {  }
470 };
471 /*! \brief REST handler for /api-docs/channels.{format} */
472 static struct stasis_rest_handlers channels_channelId_play = {
473         .path_segment = "play",
474         .callbacks = {
475                 [AST_HTTP_POST] = stasis_http_play_on_channel_cb,
476         },
477         .num_children = 0,
478         .children = {  }
479 };
480 /*! \brief REST handler for /api-docs/channels.{format} */
481 static struct stasis_rest_handlers channels_channelId_record = {
482         .path_segment = "record",
483         .callbacks = {
484                 [AST_HTTP_POST] = stasis_http_record_channel_cb,
485         },
486         .num_children = 0,
487         .children = {  }
488 };
489 /*! \brief REST handler for /api-docs/channels.{format} */
490 static struct stasis_rest_handlers channels_channelId = {
491         .path_segment = "channelId",
492         .is_wildcard = 1,
493         .callbacks = {
494                 [AST_HTTP_GET] = stasis_http_get_channel_cb,
495                 [AST_HTTP_DELETE] = stasis_http_delete_channel_cb,
496         },
497         .num_children = 9,
498         .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, }
499 };
500 /*! \brief REST handler for /api-docs/channels.{format} */
501 static struct stasis_rest_handlers channels = {
502         .path_segment = "channels",
503         .callbacks = {
504                 [AST_HTTP_GET] = stasis_http_get_channels_cb,
505                 [AST_HTTP_POST] = stasis_http_originate_cb,
506         },
507         .num_children = 1,
508         .children = { &channels_channelId, }
509 };
510
511 static int load_module(void)
512 {
513         stasis_app_ref();
514         return stasis_http_add_handler(&channels);
515 }
516
517 static int unload_module(void)
518 {
519         stasis_http_remove_handler(&channels);
520         stasis_app_unref();
521         return 0;
522 }
523
524 AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT,
525         "RESTful API module - Channel resources",
526         .load = load_module,
527         .unload = unload_module,
528         .nonoptreq = "res_stasis_http,res_stasis",
529         );