mirror of
https://gitee.com/acl-dev/acl.git
synced 2024-12-05 05:18:53 +08:00
109 lines
3.1 KiB
C
109 lines
3.1 KiB
C
#ifndef __HTTP_PLUGIN_INCLUDE_H__
|
||
#define __HTTP_PLUGIN_INCLUDE_H__
|
||
|
||
#include "lib_acl.h"
|
||
#include "lib_protocol.h"
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
/**
|
||
* HTTP 初始化注册函数, 该函数如果非空,则由主程序在刚开始运行时调用
|
||
* @param dll_env {ACL_DLL_ENV*} DLL 环境变量, dll_env->logfp 日志文件句柄,
|
||
* 如果不希望将日志记在主程序日志文件中,则可以将此值置空
|
||
* @param dmptr {ACL_DEBUG_MEM*} 用于内存调试的句柄
|
||
* @param cfg_dir {const char*} 配置文件所在路径,该路径下存放所有动态库的配置文件
|
||
*/
|
||
void http_plugin_init(ACL_DLL_ENV *dll_env, const char *cfg_dir);
|
||
|
||
/**
|
||
* HTTP 请求过滤注册函数,该函数如果非空,则由主程序在收到HTTP请求头时调用
|
||
* @param client {ACL_VSTREAM*} 客户端流
|
||
* @param hdr_req {HTTP_HDR_REQ*} HTTP请求头
|
||
* @param ctx_ptr {void**} 该指针可以用来存储用户的动态数据
|
||
* @return {int} < 0: 表示禁止该HTTP请求, 该值表示错误号,可以为:-5xx/-4xx;
|
||
* 0: 表示该HTTP请求继续由主程序处理; > 0: 表示该HTTP请求可以由外挂模块的单独
|
||
* 线程处理
|
||
*/
|
||
int http_request_filter(ACL_VSTREAM *client, HTTP_HDR_REQ *hdr_req, void **ctx_ptr);
|
||
|
||
/**
|
||
* HTTP 请求接管处理注册函数,该函数如果非空,且 http_request_filter() > 0,则由
|
||
* 主程序调用此函数完全接管该HTTP请求及响应,主程序不再处理该HTTP请求及HTTP响应
|
||
* @param client {ACL_VSTREAM*} HTTP客户端数据连接流
|
||
* @param hdr_req {HTTP_HDR_REQ*} 客户端HTTP请求头
|
||
* @param ctx {void*} 过滤器的参数,该动态参数是由 http_request_filter 中的 ctx_ptr
|
||
* 参数返回的
|
||
*/
|
||
void http_request_forward(ACL_VSTREAM *client, HTTP_HDR_REQ *hdr_req, void *ctx);
|
||
|
||
/*----------------------------------------------------------------------------*/
|
||
|
||
#define DEBUG_BASE 500
|
||
#define DBG_REQ (DEBUG_BASE + 1)
|
||
#define DBG_RES (DEBUG_BASE + 2)
|
||
|
||
#define STR acl_vstring_str
|
||
#define LEN ACL_VSTRING_LEN
|
||
|
||
typedef struct {
|
||
char *alias;
|
||
char *cgi;
|
||
HTTP_HDR_REQ *hdr_req;
|
||
HTTP_REQ *req;
|
||
HTTP_HDR_RES *hdr_res;
|
||
ACL_VSTREAM *client;
|
||
} CGI;
|
||
|
||
/* 全局配置变量 */
|
||
|
||
extern char *var_cfg_log_name;
|
||
extern char *var_cfg_cgi_bin;
|
||
extern int var_cfg_data_clone;
|
||
|
||
/* in http_conf.c */
|
||
|
||
/**
|
||
* 加载配置文件
|
||
* @param cfg_dir {const char*} 配置文件所在的目录位置
|
||
*/
|
||
void http_conf_load(const char *cfg_dir);
|
||
|
||
/* in http_plugin.c */
|
||
|
||
/**
|
||
* 创建半难留线程池
|
||
* @param threads_limit {int} 线程池中最大线程个数
|
||
* @param threads_idle {int} 线程程中每个线程的最大空闲时间(秒)
|
||
*/
|
||
void http_plugin_pool_create(int threads_limit, int threads_idle);
|
||
|
||
/**
|
||
* 向线程池中添加任务,用户添加的任务由线程池中的某个线程接管
|
||
* @param start_routine {void (*)(void*)} 用户添加的任务回调函数
|
||
* @param arg {void*} 线程池中的某个线程回调 start_routine 时的回调参数
|
||
*/
|
||
void http_plugin_pool_append(void (*start_routine)(void *), void *arg);
|
||
|
||
/**
|
||
* 当需要调试内存分配状态时的函数
|
||
* @param level {int} 调试级别,可用的级别为: 1, 2, 3
|
||
*/
|
||
void http_plugin_debug_memory(int level);
|
||
|
||
/* in http_cgi.c */
|
||
|
||
void http_cgi_init(void);
|
||
void http_cgi_end(void);
|
||
void http_cgi_add2(const char *alias, const char *cgi);
|
||
void http_cgi_add1(const ACL_ARGV *args);
|
||
CGI *http_cgi_path(const char *alias);
|
||
void http_cgi_thread(void *ctx);
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|
||
|
||
#endif
|