nginx/src/event/ngx_event_openssl.h

58 lines
1.4 KiB
C
Raw Normal View History

/*
* Copyright (C) Igor Sysoev
*/
2004-07-16 00:35:51 +08:00
#ifndef _NGX_EVENT_OPENSSL_H_INCLUDED_
#define _NGX_EVENT_OPENSSL_H_INCLUDED_
#include <ngx_config.h>
#include <ngx_core.h>
#include <openssl/ssl.h>
#include <openssl/err.h>
2004-07-17 01:11:43 +08:00
typedef struct {
SSL *ssl;
ngx_buf_t *buf;
ngx_event_handler_pt saved_handler;
2004-07-19 03:11:20 +08:00
2004-07-23 13:37:29 +08:00
unsigned buffer:1;
2004-07-19 03:11:20 +08:00
unsigned no_rcv_shut:1;
unsigned no_send_shut:1;
2004-07-17 01:11:43 +08:00
} ngx_ssl_t;
2004-07-16 00:35:51 +08:00
typedef SSL_CTX ngx_ssl_ctx_t;
2004-07-17 01:11:43 +08:00
#define NGX_SSL_BUFFER 1
#define NGX_SSL_BUFSIZE 16384
2004-07-16 00:35:51 +08:00
ngx_int_t ngx_ssl_init(ngx_log_t *log);
2004-07-17 01:11:43 +08:00
ngx_int_t ngx_ssl_create_session(ngx_ssl_ctx_t *ctx, ngx_connection_t *c,
ngx_uint_t flags);
2004-07-19 03:11:20 +08:00
#define ngx_ssl_handshake(c) NGX_OK
2004-07-16 00:35:51 +08:00
ngx_int_t ngx_ssl_recv(ngx_connection_t *c, u_char *buf, size_t size);
2004-07-16 14:33:35 +08:00
ngx_chain_t *ngx_ssl_send_chain(ngx_connection_t *c, ngx_chain_t *in,
off_t limit);
ngx_int_t ngx_ssl_shutdown(ngx_connection_t *c);
2004-07-17 01:11:43 +08:00
void ngx_ssl_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
char *fmt, ...);
2004-07-16 00:35:51 +08:00
2004-07-19 03:11:20 +08:00
#define ngx_ssl_set_nosendshut(ssl) \
if (ssl) { \
ssl->no_send_shut = 1; \
}
2004-07-16 00:35:51 +08:00
#endif /* _NGX_EVENT_OPENSSL_H_INCLUDED_ */