123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304 |
- /*
- * Copyright: JessMA Open Source (ldcsaa@gmail.com)
- *
- * Version : 3.6.1
- * Author : Bruce Liang
- * Website : http://www.jessma.org
- * Project : https://github.com/ldcsaa
- * Blog : http://www.cnblogs.com/ldcsaa
- * Wiki : http://www.oschina.net/p/hp-socket
- * QQ Group : 75375912
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
- #pragma once
- /*****************************************************************************************************************************************************/
- /**************************************************************** Base Type Definitions **************************************************************/
- /*****************************************************************************************************************************************************/
- /************************************************************************
- 名称:连接 ID 数据类型
- 描述:应用程序可以把 CONNID 定义为自身需要的类型(如:ULONG / ULONGLONG)
- ************************************************************************/
- typedef ULONG_PTR CONNID;
- typedef CONNID HP_CONNID;
- /************************************************************************
- 名称:通信组件服务状态
- 描述:应用程序可以通过通信组件的 GetState() 方法获取组件当前服务状态
- ************************************************************************/
- typedef enum EnServiceState
- {
- SS_STARTING = 0, // 正在启动
- SS_STARTED = 1, // 已经启动
- SS_STOPPING = 2, // 正在停止
- SS_STOPPED = 3, // 已经停止
- } En_HP_ServiceState;
- /************************************************************************
- 名称:Socket 操作类型
- 描述:应用程序的 OnClose() 事件中通过该参数标识是哪种操作导致的错误
- ************************************************************************/
- typedef enum EnSocketOperation
- {
- SO_UNKNOWN = 0, // Unknown
- SO_ACCEPT = 1, // Acccept
- SO_CONNECT = 2, // Connect
- SO_SEND = 3, // Send
- SO_RECEIVE = 4, // Receive
- SO_CLOSE = 5, // Close
- } En_HP_SocketOperation;
- /************************************************************************
- 名称:事件处理结果
- 描述:事件的返回值,不同的返回值会影响通信组件的后续行为
- ************************************************************************/
- typedef enum EnHandleResult
- {
- HR_OK = 0, // 成功
- HR_IGNORE = 1, // 忽略
- HR_ERROR = 2, // 错误
- } En_HP_HandleResult;
- /************************************************************************
- 名称:数据抓取结果
- 描述:数据抓取操作的返回值
- ************************************************************************/
- typedef enum EnFetchResult
- {
- FR_OK = 0, // 成功
- FR_LENGTH_TOO_LONG = 1, // 抓取长度过大
- FR_DATA_NOT_FOUND = 2, // 找不到 ConnID 对应的数据
- } En_HP_FetchResult;
- /************************************************************************
- 名称:数据发送策略
- 描述:Server 组件和 Agent 组件的数据发送策略
- * 打包模式(默认) :尽量把多个发送操作的数据组合在一起发送,增加传输效率
- * 安全模式 :尽量把多个发送操作的数据组合在一起发送,并控制传输速度,避免缓冲区溢出
- * 直接模式 :对每一个发送操作都直接投递,适用于负载不高但要求实时性较高的场合
- ************************************************************************/
- typedef enum EnSendPolicy
- {
- SP_PACK = 0, // 打包模式(默认)
- SP_SAFE = 1, // 安全模式
- SP_DIRECT = 2, // 直接模式
- } En_HP_SendPolicy;
- /************************************************************************
- 名称:操作结果代码
- 描述:组件 Start() / Stop() 方法执行失败时,可通过 GetLastError() 获取错误代码
- ************************************************************************/
- typedef enum EnSocketError
- {
- SE_OK = NO_ERROR, // 成功
- SE_ILLEGAL_STATE = 1, // 当前状态不允许操作
- SE_INVALID_PARAM = 2, // 非法参数
- SE_SOCKET_CREATE = 3, // 创建 SOCKET 失败
- SE_SOCKET_BIND = 4, // 绑定 SOCKET 失败
- SE_SOCKET_PREPARE = 5, // 设置 SOCKET 失败
- SE_SOCKET_LISTEN = 6, // 监听 SOCKET 失败
- SE_CP_CREATE = 7, // 创建完成端口失败
- SE_WORKER_THREAD_CREATE = 8, // 创建工作线程失败
- SE_DETECT_THREAD_CREATE = 9, // 创建监测线程失败
- SE_SOCKE_ATTACH_TO_CP = 10, // 绑定完成端口失败
- SE_CONNECT_SERVER = 11, // 连接服务器失败
- SE_NETWORK = 12, // 网络错误
- SE_DATA_PROC = 13, // 数据处理错误
- SE_DATA_SEND = 14, // 数据发送失败
- /***** SSL Socket 扩展操作结果代码 *****/
- SE_SSL_ENV_NOT_READY = 101, // SSL 环境未就绪
- } En_HP_SocketError;
- /************************************************************************
- 名称:播送模式
- 描述:UDP 组件的播送模式(组播或广播)
- ************************************************************************/
- typedef enum EnCastMode
- {
- CM_MULTICAST = 0, // 组播
- CM_BROADCAST = 1, // 广播
- } En_HP_CastMode;
- /*****************************************************************************************************************************************************/
- /**************************************************************** SSL Type Definitions ***************************************************************/
- /*****************************************************************************************************************************************************/
- #ifdef _SSL_SUPPORT
- /************************************************************************
- 名称:SSL 工作模式
- 描述:标识 SSL 的工作模式,客户端模式或服务端模式
- ************************************************************************/
- typedef enum EnSSLSessionMode
- {
- SSL_SM_CLIENT = 0, // 客户端模式
- SSL_SM_SERVER = 1, // 服务端模式
- } En_HP_SSLSessionMode;
- /************************************************************************
- 名称:SSL 验证模式
- 描述:SSL 验证模式选项,SSL_VM_PEER 可以和后面两个选项组合一起
- ************************************************************************/
- typedef enum EnSSLVerifyMode
- {
- SSL_VM_NONE = 0x00, // SSL_VERIFY_NONE
- SSL_VM_PEER = 0x01, // SSL_VERIFY_PEER
- SSL_VM_FAIL_IF_NO_PEER_CERT = 0x02, // SSL_VERIFY_FAIL_IF_NO_PEER_CERT
- SSL_VM_CLIENT_ONCE = 0x04, // SSL_VERIFY_CLIENT_ONCE
- } En_HP_SSLVerifyMode;
- #endif
- /*****************************************************************************************************************************************************/
- /**************************************************************** HTTP Type Definitions **************************************************************/
- /*****************************************************************************************************************************************************/
- /************************************************************************
- 名称:HTTP 版本
- 描述:低字节:主版本号,高字节:次版本号
- ************************************************************************/
- typedef enum EnHttpVersion
- {
- HV_1_0 = MAKEWORD(1, 0), // HTTP/1.0
- HV_1_1 = MAKEWORD(1, 1) // HTTP/1.1
- } En_HP_HttpVersion;
- /************************************************************************
- 名称:URL 域
- 描述:HTTP 请求行中 URL 段位的域定义
- ************************************************************************/
- typedef enum EnHttpUrlField
- {
- HUF_SCHEMA = 0, // Schema
- HUF_HOST = 1, // Host
- HUF_PORT = 2, // Port
- HUF_PATH = 3, // Path
- HUF_QUERY = 4, // Query String
- HUF_FRAGMENT = 5, // Fragment
- HUF_USERINFO = 6, // User Info
- HUF_MAX = 7, // (Field Count)
- } En_HP_HttpUrlField;
- /************************************************************************
- 名称:HTTP 解析结果标识
- 描述:指示 HTTP 解析器是否继续执行解析操作
- ************************************************************************/
- typedef enum EnHttpParseResult
- {
- HPR_OK = 0, // 继续解析
- HPR_SKIP_BODY = 1, // 跳过当前请求 BODY(仅用于 OnHeadersComplete 事件)
- HPR_UPGRADE = 2, // 升级协议(仅用于 OnHeadersComplete 事件)
- HPR_ERROR = -1, // 终止解析,断开连接
- } En_HP_HttpParseResult;
- /************************************************************************
- 名称:HTTP 协议升级类型
- 描述:标识 HTTP 升级为哪种协议
- ************************************************************************/
- typedef enum EnHttpUpgradeType
- {
- HUT_NONE = 0, // 没有升级
- HUT_WEB_SOCKET = 1, // WebSocket
- HUT_HTTP_TUNNEL = 2, // HTTP 隧道
- HUT_UNKNOWN = -1, // 未知类型
- } En_HP_HttpUpgradeType;
- /************************************************************************
- 名称:HTTP 状态码
- 描述:HTTP 标准状态码
- ************************************************************************/
- typedef enum EnHttpStatusCode
- {
- HSC_CONTINUE = 100,
- HSC_SWITCHING_PROTOCOLS = 101,
- HSC_PROCESSING = 102,
- HSC_OK = 200,
- HSC_CREATED = 201,
- HSC_ACCEPTED = 202,
- HSC_NON_AUTHORITATIVE_INFORMATION = 203,
- HSC_NO_CONTENT = 204,
- HSC_RESET_CONTENT = 205,
- HSC_PARTIAL_CONTENT = 206,
- HSC_MULTI_STATUS = 207,
- HSC_MULTIPLE_CHOICES = 300,
- HSC_MOVED_PERMANENTLY = 301,
- HSC_MOVED_TEMPORARILY = 302,
- HSC_SEE_OTHER = 303,
- HSC_NOT_MODIFIED = 304,
- HSC_USE_PROXY = 305,
- HSC_SWITCH_PROXY = 306,
- HSC_TEMPORARY_REDIRECT = 307,
- HSC_BAD_REQUEST = 400,
- HSC_UNAUTHORIZED = 401,
- HSC_PAYMENT_REQUIRED = 402,
- HSC_FORBIDDEN = 403,
- HSC_NOT_FOUND = 404,
- HSC_METHOD_NOT_ALLOWED = 405,
- HSC_NOT_ACCEPTABLE = 406,
- HSC_PROXY_AUTHENTICATION_REQUIRED = 407,
- HSC_REQUEST_TIMEOUT = 408,
- HSC_CONFLICT = 409,
- HSC_GONE = 410,
- HSC_LENGTH_REQUIRED = 411,
- HSC_PRECONDITION_FAILED = 412,
- HSC_REQUEST_ENTITY_TOO_LARGE = 413,
- HSC_REQUEST_URI_TOO_LONG = 414,
- HSC_UNSUPPORTED_MEDIA_TYPE = 415,
- HSC_REQUESTED_RANGE_NOT_SATISFIABLE = 416,
- HSC_EXPECTATION_FAILED = 417,
- HSC_UNPROCESSABLE_ENTITY = 422,
- HSC_LOCKED = 423,
- HSC_FAILED_DEPENDENCY = 424,
- HSC_UNORDERED_COLLECTION = 425,
- HSC_UPGRADE_REQUIRED = 426,
- HSC_RETRY_WITH = 449,
- HSC_INTERNAL_SERVER_ERROR = 500,
- HSC_NOT_IMPLEMENTED = 501,
- HSC_BAD_GATEWAY = 502,
- HSC_SERVICE_UNAVAILABLE = 503,
- HSC_GATEWAY_TIMEOUT = 504,
- HSC_HTTP_VERSION_NOT_SUPPORTED = 505,
- HSC_VARIANT_ALSO_NEGOTIATES = 506,
- HSC_INSUFFICIENT_STORAGE = 507,
- HSC_BANDWIDTH_LIMIT_EXCEEDED = 509,
- HSC_NOT_EXTENDED = 510,
- HSC_UNPARSEABLE_RESPONSE_HEADERS = 600
- } En_HP_HttpStatusCode;
- /************************************************************************
- 名称:Name/Value 结构体
- 描述:字符串名值对结构体
- ************************************************************************/
- typedef struct TNVPair
- {
- LPCSTR name;
- LPCSTR value;
- } HP_TNVPair,
- TParam, HP_TParam, *LPPARAM, *HP_LPPARAM,
- THeader, HP_THeader, *LPHEADER, *HP_LPHEADER,
- TCookie, HP_TCookie, *LPCOOKIE, *HP_LPCOOKIE;
|