
This new function makes it possible to add an entry to the password file without making the plain-text password known to civetweb (in fact, the caller may not even know it). Instead, the HA1 hash that's stored in the password file is passed as a parameter directly.
8.7 KiB
CivetWeb API Reference
CivetWeb is often used as HTTP and HTTPS library inside a larger application. A C API is available to integrate the CivetWeb functionality in a larger codebase. This document describes the public C API. Basic usage examples of the API can be found in Embedding.md, as well as in the examples directory.
A C++ wrapper for some basic features is also available. Note that only a small subset of the functionality available through the C API can be accessed using this C++ wrapper. The C++ wrapper is not unit tested, and there is no C++ API documentation equivalent to this C API documentation.
Macros
Macro | Description |
---|---|
CIVETWEB_VERSION |
The current version of the software as a string with the major and minor version number separated with a dot. For version 1.9, this string will have the value "1.9", for the first patch of this version "1.9.1". |
CIVETWEB_VERSION_MAJOR |
The current major version as number, e.g., (1) for version 1.9. |
CIVETWEB_VERSION_MINOR |
The current minor version as number, e.g., (9) for version 1.9. |
CIVETWEB_VERSION_PATCH |
The current patch version as number, e.g., (0) for version 1.9 or (1) for version 1.9.1. |
Handles
-
struct mg_context *
Handle for one instance of the HTTP(S) server. All functions usingconst struct mg_context *
as an argument do not modify a running server instance, but just query information. Functions using a non-conststruct mg_context *
as an argument may modify a server instance (e.g., register a new URI, stop the server, ...). -
struct mg_connection *
Handle for one individual client-server connection. Functions working withconst struct mg_connection *
operate on data already known to the server without reading data from or sending data to the client. Callbacks using aconst struct mg_connection *
argument are supposed to not call functions from themg_read()
andmg_write()
family. To support a correct application, reading and writing functions require a non-conststruct mg_connection *
connection handle.
The content of both structures is not defined in the interface - they are only used as opaque pointers (handles).
Structures
struct mg_callbacks;
struct mg_client_cert;
struct mg_client_options;
struct mg_error_data;
struct mg_form_data_handler;
struct mg_header;
struct mg_init_data;
struct mg_option;
struct mg_request_info;
struct mg_response_info;
struct mg_server_port;
struct mg_websocket_subprotocols;
Library API Functions
Server API Functions
-
mg_send_digest_access_authentication_request( conn, realm );
-
mg_check_digest_access_authentication( conn, realm, filename );
-
mg_modify_passwords_file( passwords_file_name, realm, user, password );
-
mg_modify_passwords_file_ha1( passwords_file_name, realm, user, ha1 );
-
mg_send_mime_file2( conn, path, mime_type, additional_headers );
Client API Functions
-
mg_connect_client( host, port, use_ssl, error_buffer, error_buffer_size );
-
mg_connect_client_secure( client_options, error_buffer, error_buffer_size );
-
mg_download( host, port, use_ssl, error_buffer, error_buffer_size, fmt, ... );
-
mg_connect_client2( host, protocol, port, path, init, error );
Common API Functions
-
mg_get_var2( data, data_len, var_name, dst, dst_len, occurrence );
-
mg_split_form_urlencoded( data, form_fields, num_form_fields);
-
mg_url_decode( src, src_len, dst, dst_len, is_form_url_encoded );
Diagnosis Functions
mg_get_system_info( buffer, buf_len );
mg_get_context_info( ctx, buffer, buf_len );
mg_get_connection_info( ctx, idx, buffer, buf_len );