您的位置:首页 > 运维架构 > Nginx

《深入理解Nginx》笔记之 ngx_mail相关结构体

2015-08-26 13:28 471 查看

Nginx mail相关模块结构体

ngx_mail_module_t

这是mail模块的抽象接口,即ngx_module_t中的ctx成员所指向的mail模块特有接口。每一个mail模块都会实现自己的ngx_mail_module_t结构体。

typedef struct {
// POP3 STMP IMAP邮件模块提取出的通用接口
ngx_mail_protocol_t        *protocol;

// 用于创建main级别配置项的结构体
void                       *(*create_main_conf)(ngx_conf_t *cf);

// 解析完main级别配置项后被回调的函数
char                       *(*init_main_conf)(ngx_conf_t *cf, void *conf);

// 用于创建srv级别配置项的结构体
void                       *(*create_srv_conf)(ngx_conf_t *cf);

// 根据具体模块处理srv下和main下同名的配置项
char                       *(*merge_srv_conf)(ngx_conf_t *cf, void *prev,
void *conf);
} ngx_mail_module_t;


ngx_protocol_s

typedef struct ngx_mail_protocol_s ngx_mail_protocol_t;

// 四个POP3 SMTP IMAP等应用级别的邮件模块所需要实现的接口方法
typedef void (*ngx_mail_init_session_pt)(ngx_mail_session_t *s,
ngx_connection_t *c);
typedef void (*ngx_mail_init_protocol_pt)(ngx_event_t *rev);
typedef void (*ngx_mail_auth_state_pt)(ngx_event_t *rev);
typedef ngx_int_t (*ngx_mail_parse_command_pt)(ngx_mail_session_t *s);

struct ngx_mail_protocol_s {
// 邮件模块名称
ngx_str_t                   name;

// 当前邮件模块中所要监听的最常用4个端口
in_port_t                   port[4];

// 邮件模块类型
ngx_uint_t                  type;

// 与客户端建立起TCP连接后的初始化方法
ngx_mail_init_session_pt    init_session;

// 接收、解析客户端请求的方法
ngx_mail_init_protocol_pt   init_protocol;

// 解析客户端邮件协议的接口方法
ngx_mail_parse_command_pt   parse_command;
ngx_mail_auth_state_pt      auth_state;

// 当处理中没有遇到错误时,返回internal_server_error指定的响应给客户端
ngx_str_t                   internal_server_error;
ngx_str_t                   cert_error;
ngx_str_t                   no_cert;
};


ngx_mail_session_t

Nginx与客户端建立TCP连接后,将会回调ngx_mail_init_connection函数初始化邮件协议。这个时候,会创建一个类似于HTTP请求中的ngx_http_request_t这样的核心结构体:ngx_mail_session_s。

typedef struct {
uint32_t                signature;         /* "MAIL" */

// 下游客户端和Nginx之间的连接
ngx_connection_t       *connection;

// 可存需要向下游客户端发送的内容
ngx_str_t               out;

// 用于接收来自客户端的请求
ngx_buf_t              *buffer;

// 指向一个指针数组,保存着这个请求中各个邮件模块的上下文建构体指针
void                  **ctx;

// main级别配置结构体组成的指针数组
void                  **main_conf;

// srv级别配置结构体组成的指针数组
void                  **srv_conf;

// 解析主机域名
ngx_resolver_ctx_t     *resolver_ctx;

// proxy上下文,用于Nginx双向透传客户端与邮件服务器间的通信
ngx_mail_proxy_ctx_t   *proxy;

// 表示与邮件服务器交互时,当前处于哪种状态
ngx_uint_t              mail_state;

// 邮件协议类型
unsigned                protocol:3;

// 1:表示当前读或写操作需要被阻塞
unsigned                blocked:1;

// 1:请求需要结束
unsigned                quit:1;

// 一下三个标志位仅在解析具体邮件协议时由邮件框架使用
unsigned                quoted:1;
unsigned                backslash:1;
unsigned                no_sync_literal:1;

// 当使用SSL协议时才有意义
unsigned                starttls:1;
unsigned                esmtp:1;

// 表示与认证服务器交互时的记录认证方式
unsigned                auth_method:3;

// 1:表示认证服务器要求暂缓接收响应,Nginx会继续等待认证服务器的后续响应
unsigned                auth_wait:1;

// 验证时的用户名
ngx_str_t               login;

// 验证时的密码
ngx_str_t               passwd;

// 作为Auth-Salt验证的信息
ngx_str_t               salt;

// 一下三个成员仅用于IMAP通信
ngx_str_t               tag;
ngx_str_t               tagged_line;
ngx_str_t               text;

// 当前连接上对应的Nginx服务器地址
ngx_str_t              *addr_text;

// 主机地址
ngx_str_t               host;

//一下四个成员仅用于SMTP通信
ngx_str_t               smtp_helo;
ngx_str_t               smtp_from;
ngx_str_t               smtp_to;

ngx_str_t               cmd;

// 在于邮件服务器交互时,表示解析自邮件服务器的消息类型
ngx_uint_t              command;

// 存放来自下游客户端的邮件协议中的参数
ngx_array_t             args;

// 当前请求尝试访问服务器验证的次数
ngx_uint_t              login_attempt;

/* used to parse POP3/IMAP/SMTP command */

ngx_uint_t              state;
u_char                 *cmd_start;
u_char                 *arg_start;
u_char                 *arg_end;
ngx_uint_t              literal_len;
} ngx_mail_session_t;


ngx_mail_proxy_ctx_t

typedef struct {
// 与上游邮件服务器间的连接
ngx_peer_connection_t   upstream;

// 用于缓存上、下游间TCP消息的内存缓冲区
ngx_buf_t                   *buffer;
} ngx_mail_proxy_ctx_t;


ngx_mail_auth_http_ctx_t

用于Nginx与邮件认证服务器的认证过程。

typedef struct ngx_mail_auth_http_ctx_s  ngx_mail_auth_http_ctx_t;

// 解析认证服务器HTTP响应的函数指针
typedef void (*ngx_mail_auth_http_handler_pt)(ngx_mail_session_t *s,
ngx_mail_auth_http_ctx_t *ctx);

struct ngx_mail_auth_http_ctx_s {
// request缓冲区保存着发往认证服务器的请求
ngx_buf_t                      *request;

// 保存认证服务器返回的响应缓冲区
ngx_buf_t                      *response;

// Nginx与认证服务器间的连接
ngx_peer_connection_t           peer;

// 解析来自认证服务器的响应行、头部的函数
ngx_mail_auth_http_handler_pt   handler;

// 状态机解析认证服务器返回响应时的状态
ngx_uint_t                      state;

// 用于解析返回的响应头部用
u_char                         *header_name_start;
u_char                         *header_name_end;
u_char                         *header_start;
u_char                         *header_end;

// 认证服务器返回的Auth-Server头部
ngx_str_t                       addr;

// 认证服务器返回的Auth-Port头部
ngx_str_t                       port;
ngx_str_t                       err;
ngx_str_t                       errmsg;
ngx_str_t                       errcode;

// 认证服务器返回的Auth-Wait头部时带的时间戳将会被设置到sleep成员中
time_t                          sleep;

ngx_pool_t                     *pool;
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: