2013-12-10 11:16:25 +00:00
|
|
|
# Mongoose API Reference
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
struct mg_server *mg_create_server(void *server_param);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Creates web server instance. Returns opaque instance pointer, or NULL if
|
|
|
|
there is not enough memory. Note that this function doesn't make the
|
|
|
|
server instance to serve. Serving is done by `mg_poll_server()` function.
|
|
|
|
Web server instance has a list of active connections, initially empty,
|
|
|
|
and a list of URI handlers, initially empty, a list of configuration
|
|
|
|
options that can be modified by `mg_set_option()`.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
`user_param`: Could be any pointer, or NULL. This pointer will be passed
|
|
|
|
to callback functions as `struct mg_connection::server_param` field.
|
|
|
|
A common use case is to pass `this` pointer of the C++ wrapper class
|
|
|
|
as `user_param`, to let the callback get the pointer to the C++
|
|
|
|
object.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Important: Mongoose does not install `SIGCHLD` handler. If CGI is used,
|
|
|
|
`SIGCHLD` handler must be set up to reap CGI zombie processes.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
void mg_destroy_server(struct mg_server **server);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Deallocates web server instance, closes all pending connections, and makes
|
|
|
|
a server pointer a NULL pointer.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
const char mg_set_option(struct mg_server *server, const char *name,
|
|
|
|
const char *value);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Sets a particular server option. Please refer to a separate documentation page
|
|
|
|
that lists all available option names. Note that at least one option,
|
|
|
|
`listening_port`, must be specified. To serve static files, `document_root`
|
|
|
|
needs to be specified too. If `document_root` option is left unset, Mongoose
|
|
|
|
will not access filesystem at all. This function returns NULL if option was
|
|
|
|
set successfully, otherwise it returns human-readable error string. It is
|
|
|
|
allowed to call `mg_set_option()` by the same thread that does
|
|
|
|
`mg_poll_server()` (an IO thread).
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
void mg_poll_server(struct mg_server *server, int milliseconds);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
This function performs one iteration of IO loop. Mongoose iterates over all
|
|
|
|
active connections, and performs a `select()` syscall on all sockets, sleeping
|
|
|
|
for `milliseconds` number of milliseconds. When `select()` returns, Mongoose
|
|
|
|
does an IO for each socket that has data to be sent or received. Application
|
|
|
|
code must call `mg_poll_server()` in a loop. It is an error to have more then
|
|
|
|
one thread calling `mg_poll_server()`, `mg_set_option()` or any other function
|
|
|
|
that take `struct mg_server *` parameter. Mongoose does not
|
|
|
|
mutex-protect `struct mg_server *`, therefore the best practice is
|
|
|
|
to call server management functions from the same thread (an IO thread).
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
void mg_add_uri_handler(struct mg_server *, const char *uri, mg_handler_t);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Adds an URI handler. If Mongoose gets a request and request's URI starts
|
|
|
|
with `uri`, then specified handler is called to serve the request. Thus, an
|
|
|
|
`uri` is a match prefix. For example, if `uri` is "/", then all requests will
|
|
|
|
be routed to the handler, because all URIs start with `/` character.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
void mg_set_http_error_handler(struct mg_server *, mg_handler_t);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Adds HTTP error handler. An actual HTTP error is passed as
|
|
|
|
`struct mg_connection::status_code` parameter. If handler returns 0, it
|
|
|
|
means a handler has not processed the connection, and mongoose proceeds
|
|
|
|
with sending HTTP error to the client. Otherwise, mongoose does nothing.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
const char **mg_get_valid_option_names(void);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Returns a NULL-terminated array of option names and their default values,
|
|
|
|
so two entries per option.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
const char *mg_get_option(const struct mg_server *server, const char *name);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Returns the value of particular configuration parameter. If
|
|
|
|
given parameter name is not valid, NULL is returned. For valid names, return
|
|
|
|
value is guaranteed to be non-NULL. If parameter is not set, zero-length string
|
|
|
|
is returned.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
int mg_iterate_over_connections(struct mg_server *,
|
|
|
|
void (*func)(struct mg_connection *, void *),
|
|
|
|
void *param);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
This is an interface primarily designed to push arbitrary data to websocket
|
|
|
|
connections at any time. This function could be called from any thread. When
|
|
|
|
it returns, an IO thread called `func()` on each active websocket connection,
|
|
|
|
passing `param` as an extra parameter. It is allowed to call `mg_write()` or
|
|
|
|
`mg_websocket_write()` within a callback, cause these write functions are
|
|
|
|
thread-safe.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
int mg_write(struct mg_connection *, const void *buf, int len);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Send data to the client. This function is thread-safe. This function appends
|
|
|
|
given buffer to a send queue of a given connection. It may return 0 if
|
|
|
|
there is not enough memory, in which case the data will not be sent.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
int mg_websocket_write(struct mg_connection* conn, int opcode,
|
|
|
|
const char *data, size_t data_len);
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Similar to `mg_write()`, but wraps the data into a websocket frame with a
|
|
|
|
given websocket `opcode`. This function is available when mongoose is
|
|
|
|
compiled with `-DUSE_WEBSOCKET`.
|
2013-10-19 13:14:16 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
const char *mg_get_header(const struct mg_connection *, const char *name);
|
2013-10-19 13:14:16 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Get the value of particular HTTP header. This is a helper function.
|
|
|
|
It traverses http_headers array, and if the header is present in the array,
|
|
|
|
returns its value. If it is not present, NULL is returned.
|
|
|
|
|
|
|
|
|
|
|
|
int mg_get_var(const struct mg_connection *conn, const char *var_name,
|
|
|
|
char *buf, size_t buf_len);
|
2013-10-19 13:14:16 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
Gets HTTP form variable. Both POST buffer and query string are inspected.
|
|
|
|
Form variable is url-decoded and written to the buffer. On success, this
|
|
|
|
function returns the length of decoded variable. On error, -1 is returned if
|
|
|
|
variable not found, and -2 is returned if destination buffer is too small
|
|
|
|
to hold the variable. Destination buffer is guaranteed to be
|
|
|
|
'\0' - terminated if it is not NULL or zero length.
|
2013-10-19 13:14:16 -07:00
|
|
|
|
2013-12-10 23:34:08 +00:00
|
|
|
int mg_parse_header(const char *hdr, const char *var_name, char *buf,
|
|
|
|
size_t buf_size);
|
|
|
|
|
|
|
|
This function parses HTTP header and fetches given variable's value in a buffer.
|
|
|
|
A header should be like `x=123, y=345, z="other value"`. This function is
|
|
|
|
designed to parse Cookie headers, Authorization headers, and similar. Returns
|
|
|
|
the length of the fetched value, or 0 if variable not found.
|
2013-10-18 08:57:59 -07:00
|
|
|
|
2013-10-19 14:07:46 -07:00
|
|
|
int mg_modify_passwords_file(const char *passwords_file_name,
|
|
|
|
const char *domain,
|
|
|
|
const char *user,
|
|
|
|
const char *password);
|
|
|
|
|
|
|
|
Add, edit or delete the entry in the passwords file.
|
|
|
|
This function allows an application to manipulate .htpasswd files on the
|
|
|
|
fly by adding, deleting and changing user records. This is one of the
|
|
|
|
several ways of implementing authentication on the server side. For another,
|
|
|
|
cookie-based way please refer to the examples/chat.c in the source tree.
|
|
|
|
If password is not NULL, entry is added (or modified if already exists).
|
|
|
|
If password is NULL, entry is deleted.
|
|
|
|
Return: 1 on success, 0 on error.
|