48de8c95422fc1cc07e18ede037449f280c4ac82
[asterisk/asterisk.git] / include / asterisk / agi.h
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2005, Digium, Inc.
5  *
6  * Mark Spencer <markster@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 /*! \file
20  * \brief AGI Extension interfaces - Asterisk Gateway Interface
21  */
22
23 #ifndef _ASTERISK_AGI_H
24 #define _ASTERISK_AGI_H
25
26 #if defined(__cplusplus) || defined(c_plusplus)
27 extern "C" {
28 #endif
29
30 #include "asterisk/cli.h"
31
32 typedef struct agi_state {
33         int fd;                 /*!< FD for general output */
34         int audio;              /*!< FD for audio output */
35         int ctrl;               /*!< FD for input control */
36         unsigned int fast:1;    /*!< flag for fast agi or not */
37         struct ast_speech *speech; /*!< Speech structure for speech recognition */
38 } AGI;
39
40 typedef struct agi_command {
41         char *cmda[AST_MAX_CMD_LEN];            /*!< Null terminated list of the words of the command */
42         /*! Handler for the command (channel, AGI state, # of arguments, argument list). 
43             Returns RESULT_SHOWUSAGE for improper arguments */
44         int (*handler)(struct ast_channel *chan, AGI *agi, int argc, char *argv[]);
45         /*! Summary of the command (< 60 characters) */
46         char *summary;
47         /*! Detailed usage information */
48         char *usage;
49         /*! Does this application run dead */
50         int dead;
51         /*! AGI command syntax description */
52         char *syntax;
53         /*! See also content */
54         char *seealso;
55         /*! Where the documentation come from. */
56         enum ast_doc_src docsrc;
57         /*! Pointer to module that registered the agi command */
58         struct ast_module *mod;
59         /*! Linked list pointer */
60         AST_LIST_ENTRY(agi_command) list;
61 } agi_command;
62
63 #if defined(ASTERISK_AGI_OPTIONAL)
64 #define AGI_WEAK attribute_weak
65 #else
66 #define AGI_WEAK
67 #endif
68
69 int AGI_WEAK ast_agi_fdprintf(struct ast_channel *chan, int fd, char *fmt, ...);
70 int AGI_WEAK ast_agi_register(struct ast_module *mod, agi_command *cmd);
71 int AGI_WEAK ast_agi_unregister(struct ast_module *mod, agi_command *cmd);
72 void AGI_WEAK ast_agi_register_multiple(struct ast_module *mod, agi_command *cmd, int len);
73 void AGI_WEAK ast_agi_unregister_multiple(struct ast_module *mod, agi_command *cmd, int len);
74
75 #if defined(__cplusplus) || defined(c_plusplus)
76 }
77 #endif
78
79 #endif /* _ASTERISK_AGI_H */