lighttpd 1.4.x https://www.lighttpd.net/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

77 lines
3.2 KiB

#ifndef _PLUGIN_H_
#define _PLUGIN_H_
#include "first.h"
#include "base_decls.h"
#include "plugin_config.h"
#define SERVER_FUNC(x) \
static handler_t x(server *srv, void *p_d)
#define CONNECTION_FUNC(x) \
static handler_t x(connection *con, void *p_d)
#define REQUEST_FUNC(x) \
static handler_t x(request_st *r, void *p_d)
#define INIT_FUNC(x) \
__attribute_cold__ \
static void *x(void)
#define FREE_FUNC(x) \
__attribute_cold__ \
static void x(void *p_d)
#define SETDEFAULTS_FUNC __attribute_cold__ SERVER_FUNC
#define SIGHUP_FUNC __attribute_cold__ SERVER_FUNC
#define TRIGGER_FUNC SERVER_FUNC
#define SUBREQUEST_FUNC REQUEST_FUNC
#define PHYSICALPATH_FUNC REQUEST_FUNC
#define REQUESTDONE_FUNC REQUEST_FUNC
#define URIHANDLER_FUNC REQUEST_FUNC
#define PLUGIN_DATA int id; \
int nconfig; \
config_plugin_value_t *cvlist; \
struct plugin *self
typedef struct {
PLUGIN_DATA;
} plugin_data_base;
struct plugin {
void *data;
/* is called ... */
handler_t (* handle_uri_raw) (request_st *r, void *p_d); /* after uri_raw is set */
handler_t (* handle_uri_clean) (request_st *r, void *p_d); /* after uri is set */
handler_t (* handle_docroot) (request_st *r, void *p_d); /* getting the document-root */
handler_t (* handle_physical) (request_st *r, void *p_d); /* mapping url to physical path */
handler_t (* handle_request_env) (request_st *r, void *p_d); /* (deferred env populate) */
handler_t (* handle_request_done) (request_st *r, void *p_d); /* at the end of a request */
handler_t (* handle_subrequest_start) (request_st *r, void *p_d); /* when handler for request not found yet */
handler_t (* handle_subrequest) (request_st *r, void *p_d); /* handler for request (max one per request) */
handler_t (* handle_response_start) (request_st *r, void *p_d); /* before response headers are written */
handler_t (* handle_request_reset) (request_st *r, void *p_d); /* after request done or request abort */
handler_t (* handle_connection_accept) (connection *con, void *p_d); /* after accept() socket */
handler_t (* handle_connection_shut_wr)(connection *con, void *p_d); /* done writing to socket */
handler_t (* handle_connection_close) (connection *con, void *p_d); /* before close() of socket */
handler_t (* handle_trigger) (server *srv, void *p_d); /* once a second */
handler_t (* handle_sighup) (server *srv, void *p_d); /* at a sighup */
handler_t (* handle_waitpid) (server *srv, void *p_d, pid_t pid, int status); /* upon a child process exit */
void *(* init) ();
handler_t (* priv_defaults) (server *srv, void *p_d);
handler_t (* set_defaults) (server *srv, void *p_d);
handler_t (* worker_init) (server *srv, void *p_d); /* at server startup (each worker after fork()) */
void (* cleanup) (void *p_d);
const char *name;/* name of the plugin */
size_t version;
void *lib; /* dlopen handle */
};
#endif