mirror of
https://github.com/Netflix/dial-reference.git
synced 2026-06-08 10:59:59 +00:00
161 lines
6.3 KiB
C
161 lines
6.3 KiB
C
// 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 <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/ip.h>
|
|
|
|
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
|