Add micro-http server and abstract manager interface, make snmp not die
[asterisk/asterisk.git] / include / asterisk / http.h
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2006, 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 /*
20  * DNS SRV record support
21  */
22
23 #ifndef _ASTERISK_HTTP_H
24 #define _ASTERISK_HTTP_H
25
26 #include "asterisk/config.h"
27
28 /*!
29   \file http.h
30   \brief Support for Private Asterisk HTTP Servers.
31   \note Note: The Asterisk HTTP servers are extremely simple and minimal and
32         only support the "GET" method.
33 */
34
35 /* HTTP Callbacks take the socket, the method and the path as arguments and should
36    return the content, allocated with malloc().  Status should be changed to reflect
37    the status of the request if it isn't 200 and title may be set to a malloc()'d string
38    to an appropriate title for non-200 responses.  Content length may also be specified. 
39    The return value may include additional headers at the front and MUST include a blank 
40    line with \r\n to provide separation between user headers and content (even if no
41    content is specified) */
42 typedef char *(*ast_http_callback)(struct sockaddr_in *requestor, const char *uri, struct ast_variable *params, int *status, char **title, int *contentlength);
43
44 struct ast_http_uri {
45         struct ast_http_uri *next;
46         const char *description;
47         const char *uri;
48         int has_subtree;
49         ast_http_callback callback;
50 };
51
52 /* Link into the Asterisk HTTP server */
53 int ast_http_uri_link(struct ast_http_uri *urihandler);
54
55 /* Return a malloc()'d string containing an HTTP error message */
56 char *ast_http_error(int status, const char *title, const char *extra_header, const char *text);
57
58 /* Destroy an HTTP server */
59 void ast_http_uri_unlink(struct ast_http_uri *urihandler);
60
61 int ast_http_init(void);
62 int ast_http_reload(void);
63
64 #endif /* _ASTERISK_SRV_H */