// Copyright (c) 2004-2010 Sergey Lyubka // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // NOTE: This is a SEVERELY stripped down version of mongoose, which only // supports GET, POST and DELETE HTTP commands, no CGI, no file or directory // access, no ACLs or authentication, and no proxying and no SSL. HTTP Header // limit is 16 instead of 64, as it's not supposed to be called from standard // browsers. And most options are removed. #ifndef MONGOOSE_HEADER_INCLUDED #define MONGOOSE_HEADER_INCLUDED #ifdef __cplusplus extern "C" { #endif // __cplusplus #include #include #include struct mg_context; // Handle for the HTTP service itself struct mg_connection; // Handle for the individual connection // This structure contains information about the HTTP request. struct mg_request_info { void *user_data; // User-defined pointer passed to mg_start() char *request_method; // "GET", "POST", etc char *uri; // URL-decoded URI char *http_version; // E.g. "1.0", "1.1" char *query_string; // \0 - terminated char *request_body; // \0 - terminated char *log_message; // Mongoose error log message struct sockaddr_in local_addr; // Our server's address for this connection struct sockaddr_in remote_addr; // The remote address for this connection int status_code; // HTTP reply status code int num_headers; // Number of headers struct mg_header { char *name; // HTTP header name char *value; // HTTP header value } http_headers[16]; // Maximum 16 headers }; // Various events on which user-defined function is called by Mongoose. enum mg_event { MG_NEW_REQUEST, // New HTTP request has arrived from the client MG_HTTP_ERROR, // HTTP error must be returned to the client MG_EVENT_LOG, // Mongoose logs an event, request_info.log_message }; // Prototype for the user-defined function. Mongoose calls this function // on every event mentioned above. // // Parameters: // event: which event has been triggered. // conn: opaque connection handler. Could be used to read, write data to the // client, etc. See functions below that accept "mg_connection *". // request_info: Information about HTTP request. // // Return: // If handler returns non-NULL, that means that handler has processed the // request by sending appropriate HTTP reply to the client. Mongoose treats // the request as served. // If callback returns NULL, that means that callback has not processed // the request. Handler must not send any data to the client in this case. // Mongoose proceeds with request handling as if nothing happened. typedef void * (*mg_callback_t)(enum mg_event event, struct mg_connection *conn, const struct mg_request_info *request_info); // Start web server. // // Parameters: // callback: user defined event handling function or NULL. // // Example: // struct mg_context *ctx = mg_start(&my_func, NULL); // // Please refer to http://code.google.com/p/mongoose/wiki/MongooseManual // for the list of valid option and their possible values. // // Return: // web server context, or NULL on error. struct mg_context *mg_start(mg_callback_t callback, void *user_data, int port); // Stop the web server. // // Must be called last, when an application wants to stop the web server and // release all associated resources. This function blocks until all Mongoose // threads are stopped. Context pointer becomes invalid. void mg_stop(struct mg_context *); // Send data to the client. int mg_write(struct mg_connection *, const void *buf, size_t len); // Send data to the browser using printf() semantics. // // Works exactly like mg_write(), but allows to do message formatting. // Note that mg_printf() uses internal buffer of size IO_BUF_SIZE // (8 Kb by default) as temporary message storage for formatting. Do not // print data that is bigger than that, otherwise it will be truncated. int mg_printf(struct mg_connection *, const char *fmt, ...); // Read data from the remote end, return number of bytes read. int mg_read(struct mg_connection *, void *buf, size_t len); // Get the value of particular HTTP header. // // This is a helper function. It traverses request_info->http_headers array, // and if the header is present in the array, returns its value. If it is // not present, NULL is returned. const char *mg_get_header(const struct mg_connection *, const char *name); // Return Mongoose version. const char *mg_version(void); // MD5 hash given strings. // Buffer 'buf' must be 33 bytes long. Varargs is a NULL terminated list of // asciiz strings. When function returns, buf will contain human-readable // MD5 hash. Example: // char buf[33]; // mg_md5(buf, "aa", "bb", NULL); void mg_md5(char *buf, ...); void mg_send_http_error(struct mg_connection *conn, int status, const char *reason, const char *fmt, ...); int mg_get_listen_addr(struct mg_context *ctx, struct sockaddr *addr, socklen_t *addrlen); #ifdef __cplusplus } #endif // __cplusplus #endif // MONGOOSE_HEADER_INCLUDED