mirror of
https://github.com/nginx/nginx.git
synced 2025-01-06 14:13:00 -06:00
nginx-0.3.7-RELEASE import
*) Feature: the "access_log" supports the "buffer=" parameter. *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.3.2.
This commit is contained in:
parent
968b2a868b
commit
697d1aea0c
@ -50,7 +50,7 @@ case $USE_THREADS in
|
|||||||
CORE_LIBS="$CORE_LIBS -pthread"
|
CORE_LIBS="$CORE_LIBS -pthread"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FreeBSD:[567]*)
|
FreeBSD:[56]*)
|
||||||
have=NGX_THREADS . auto/have
|
have=NGX_THREADS . auto/have
|
||||||
CORE_SRCS="$CORE_SRCS $PTHREAD_SRCS"
|
CORE_SRCS="$CORE_SRCS $PTHREAD_SRCS"
|
||||||
CORE_LIBS="$CORE_LIBS -lc_r"
|
CORE_LIBS="$CORE_LIBS -lc_r"
|
||||||
|
@ -9,6 +9,31 @@
|
|||||||
<title lang="en">nginx changelog</title>
|
<title lang="en">nginx changelog</title>
|
||||||
|
|
||||||
|
|
||||||
|
<changes ver="0.3.7" date="27.10.2005">
|
||||||
|
|
||||||
|
<change type="feature">
|
||||||
|
<para lang="ru">
|
||||||
|
ÄÉÒÅËÔÉ×Á access_log ÐÏÄÄÅÒÖÉ×ÁÅÔ ÐÁÒÁÍÅÔÒ buffer=.
|
||||||
|
</para>
|
||||||
|
<para lang="en">
|
||||||
|
the "access_log" supports the "buffer=" parameter.
|
||||||
|
</para>
|
||||||
|
</change>
|
||||||
|
|
||||||
|
<change type="bugfix">
|
||||||
|
<para lang="ru">
|
||||||
|
nginx ÎÅ ÓÏÂÉÒÁÌÓÑ ÎÁ ÐÌÁÔÆÏÒÍÁÈ, ÏÔÌÉÞÎÙÈ ÏÔ i386, amd64, sparc É ppc;
|
||||||
|
ÏÛÉÂËÁ ÐÏÑ×ÉÌÁÓØ × 0.3.2.
|
||||||
|
</para>
|
||||||
|
<para lang="en">
|
||||||
|
nginx could not be built on platforms different from i386, amd64, sparc É ppc;
|
||||||
|
bug appeared in 0.3.2.
|
||||||
|
</para>
|
||||||
|
</change>
|
||||||
|
|
||||||
|
</changes>
|
||||||
|
|
||||||
|
|
||||||
<changes ver="0.3.6" date="24.10.2005">
|
<changes ver="0.3.6" date="24.10.2005">
|
||||||
|
|
||||||
<change type="change">
|
<change type="change">
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
#define _NGINX_H_INCLUDED_
|
#define _NGINX_H_INCLUDED_
|
||||||
|
|
||||||
|
|
||||||
#define NGINX_VER "nginx/0.3.6"
|
#define NGINX_VER "nginx/0.3.7"
|
||||||
|
|
||||||
#define NGINX_VAR "NGINX"
|
#define NGINX_VAR "NGINX"
|
||||||
#define NGX_OLDPID_EXT ".oldbin"
|
#define NGX_OLDPID_EXT ".oldbin"
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
static ngx_int_t ngx_conf_handler(ngx_conf_t *cf, ngx_int_t last);
|
static ngx_int_t ngx_conf_handler(ngx_conf_t *cf, ngx_int_t last);
|
||||||
static ngx_int_t ngx_conf_read_token(ngx_conf_t *cf);
|
static ngx_int_t ngx_conf_read_token(ngx_conf_t *cf);
|
||||||
static char *ngx_conf_include(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
|
static char *ngx_conf_include(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
|
||||||
|
static void ngx_conf_flush_files(ngx_cycle_t *cycle);
|
||||||
|
|
||||||
|
|
||||||
static ngx_command_t ngx_conf_commands[] = {
|
static ngx_command_t ngx_conf_commands[] = {
|
||||||
@ -36,7 +37,7 @@ ngx_module_t ngx_conf_module = {
|
|||||||
NULL, /* init process */
|
NULL, /* init process */
|
||||||
NULL, /* init thread */
|
NULL, /* init thread */
|
||||||
NULL, /* exit thread */
|
NULL, /* exit thread */
|
||||||
NULL, /* exit process */
|
ngx_conf_flush_files, /* exit process */
|
||||||
NULL, /* exit master */
|
NULL, /* exit master */
|
||||||
NGX_MODULE_V1_PADDING
|
NGX_MODULE_V1_PADDING
|
||||||
};
|
};
|
||||||
@ -742,10 +743,44 @@ ngx_conf_open_file(ngx_cycle_t *cycle, ngx_str_t *name)
|
|||||||
file->name.data = NULL;
|
file->name.data = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
file->buffer = NULL;
|
||||||
|
|
||||||
return file;
|
return file;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
ngx_conf_flush_files(ngx_cycle_t *cycle)
|
||||||
|
{
|
||||||
|
ngx_uint_t i;
|
||||||
|
ngx_list_part_t *part;
|
||||||
|
ngx_open_file_t *file;
|
||||||
|
|
||||||
|
ngx_log_debug0(NGX_LOG_DEBUG_CORE, cycle->log, 0, "flush files");
|
||||||
|
|
||||||
|
part = &cycle->open_files.part;
|
||||||
|
file = part->elts;
|
||||||
|
|
||||||
|
for (i = 0; /* void */ ; i++) {
|
||||||
|
|
||||||
|
if (i >= part->nelts) {
|
||||||
|
if (part->next == NULL) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
part = part->next;
|
||||||
|
file = part->elts;
|
||||||
|
i = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file[i].buffer == NULL || file[i].pos - file[i].buffer == 0) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
ngx_write_fd(file[i].fd, file[i].buffer, file[i].pos - file[i].buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void ngx_cdecl
|
void ngx_cdecl
|
||||||
ngx_conf_log_error(ngx_uint_t level, ngx_conf_t *cf, ngx_err_t err,
|
ngx_conf_log_error(ngx_uint_t level, ngx_conf_t *cf, ngx_err_t err,
|
||||||
char *fmt, ...)
|
char *fmt, ...)
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
|
|
||||||
#define NGX_CONF_TAKE23 (NGX_CONF_TAKE2|NGX_CONF_TAKE3)
|
#define NGX_CONF_TAKE23 (NGX_CONF_TAKE2|NGX_CONF_TAKE3)
|
||||||
|
|
||||||
|
#define NGX_CONF_TAKE123 (NGX_CONF_TAKE1|NGX_CONF_TAKE2|NGX_CONF_TAKE3)
|
||||||
#define NGX_CONF_TAKE1234 (NGX_CONF_TAKE1|NGX_CONF_TAKE2|NGX_CONF_TAKE3 \
|
#define NGX_CONF_TAKE1234 (NGX_CONF_TAKE1|NGX_CONF_TAKE2|NGX_CONF_TAKE3 \
|
||||||
|NGX_CONF_TAKE4)
|
|NGX_CONF_TAKE4)
|
||||||
|
|
||||||
@ -87,6 +88,11 @@ struct ngx_command_s {
|
|||||||
struct ngx_open_file_s {
|
struct ngx_open_file_s {
|
||||||
ngx_fd_t fd;
|
ngx_fd_t fd;
|
||||||
ngx_str_t name;
|
ngx_str_t name;
|
||||||
|
|
||||||
|
u_char *buffer;
|
||||||
|
u_char *pos;
|
||||||
|
u_char *last;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
/* e.g. append mode, error_log */
|
/* e.g. append mode, error_log */
|
||||||
ngx_uint_t flags;
|
ngx_uint_t flags;
|
||||||
@ -121,10 +127,10 @@ struct ngx_module_s {
|
|||||||
|
|
||||||
ngx_int_t (*init_process)(ngx_cycle_t *cycle);
|
ngx_int_t (*init_process)(ngx_cycle_t *cycle);
|
||||||
ngx_int_t (*init_thread)(ngx_cycle_t *cycle);
|
ngx_int_t (*init_thread)(ngx_cycle_t *cycle);
|
||||||
ngx_int_t (*exit_thread)(ngx_cycle_t *cycle);
|
void (*exit_thread)(ngx_cycle_t *cycle);
|
||||||
ngx_int_t (*exit_process)(ngx_cycle_t *cycle);
|
void (*exit_process)(ngx_cycle_t *cycle);
|
||||||
|
|
||||||
ngx_int_t (*exit_master)(ngx_cycle_t *cycle);
|
void (*exit_master)(ngx_cycle_t *cycle);
|
||||||
|
|
||||||
uintptr_t spare_hook0;
|
uintptr_t spare_hook0;
|
||||||
uintptr_t spare_hook1;
|
uintptr_t spare_hook1;
|
||||||
|
@ -724,6 +724,12 @@ ngx_reopen_files(ngx_cycle_t *cycle, ngx_uid_t user)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (file[i].buffer && file[i].pos - file[i].buffer != 0) {
|
||||||
|
ngx_write_fd(file[i].fd, file[i].buffer,
|
||||||
|
file[i].pos - file[i].buffer);
|
||||||
|
file[i].pos = file[i].buffer;
|
||||||
|
}
|
||||||
|
|
||||||
fd = ngx_open_file(file[i].name.data, NGX_FILE_RDWR,
|
fd = ngx_open_file(file[i].name.data, NGX_FILE_RDWR,
|
||||||
NGX_FILE_CREATE_OR_OPEN|NGX_FILE_APPEND);
|
NGX_FILE_CREATE_OR_OPEN|NGX_FILE_APPEND);
|
||||||
|
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
#include <ngx_core.h>
|
#include <ngx_core.h>
|
||||||
|
|
||||||
|
|
||||||
static void ngx_log_write(ngx_log_t *log, u_char *errstr, size_t len);
|
|
||||||
static char *ngx_set_error_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
|
static char *ngx_set_error_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
|
||||||
|
|
||||||
|
|
||||||
@ -152,42 +151,13 @@ ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
|||||||
p = log->handler(log, p, last - p);
|
p = log->handler(log, p, last - p);
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_write(log, errstr, p - errstr);
|
if (p > last - NGX_LINEFEED_SIZE) {
|
||||||
}
|
p = last - NGX_LINEFEED_SIZE;
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
ngx_log_write(ngx_log_t *log, u_char *errstr, size_t len)
|
|
||||||
{
|
|
||||||
#if (NGX_WIN32)
|
|
||||||
u_long written;
|
|
||||||
|
|
||||||
if (len >= NGX_MAX_ERROR_STR - 1) {
|
|
||||||
len = NGX_MAX_ERROR_STR - 2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
errstr[len++] = CR;
|
ngx_linefeed(p);
|
||||||
errstr[len++] = LF;
|
|
||||||
|
|
||||||
WriteFile(log->file->fd, errstr, len, &written, NULL);
|
ngx_write_fd(log->file->fd, errstr, p - errstr);
|
||||||
|
|
||||||
#if 0
|
|
||||||
if (WriteFile(log->file->fd, errstr, len, &written, NULL) == 0) {
|
|
||||||
ngx_message_box("nginx", MB_OK, ngx_errno, "WriteFile() failed");
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
if (len == NGX_MAX_ERROR_STR) {
|
|
||||||
len--;
|
|
||||||
}
|
|
||||||
|
|
||||||
errstr[len++] = LF;
|
|
||||||
|
|
||||||
(void) write(log->file->fd, errstr, len);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ static void ngx_ssl_connection_error(ngx_connection_t *c, int sslerr,
|
|||||||
ngx_err_t err, char *text);
|
ngx_err_t err, char *text);
|
||||||
static void *ngx_openssl_create_conf(ngx_cycle_t *cycle);
|
static void *ngx_openssl_create_conf(ngx_cycle_t *cycle);
|
||||||
static char *ngx_openssl_init_conf(ngx_cycle_t *cycle, void *conf);
|
static char *ngx_openssl_init_conf(ngx_cycle_t *cycle, void *conf);
|
||||||
|
static void ngx_openssl_exit(ngx_cycle_t *cycle);
|
||||||
|
|
||||||
#if !(NGX_SSL_ENGINE)
|
#if !(NGX_SSL_ENGINE)
|
||||||
static char *ngx_openssl_noengine(ngx_conf_t *cf, ngx_command_t *cmd,
|
static char *ngx_openssl_noengine(ngx_conf_t *cf, ngx_command_t *cmd,
|
||||||
@ -64,7 +65,7 @@ ngx_module_t ngx_openssl_module = {
|
|||||||
NULL, /* init thread */
|
NULL, /* init thread */
|
||||||
NULL, /* exit thread */
|
NULL, /* exit thread */
|
||||||
NULL, /* exit process */
|
NULL, /* exit process */
|
||||||
NULL, /* exit master */
|
ngx_openssl_exit, /* exit master */
|
||||||
NGX_MODULE_V1_PADDING
|
NGX_MODULE_V1_PADDING
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -951,3 +952,12 @@ ngx_openssl_noengine(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
ngx_openssl_exit(ngx_cycle_t *cycle)
|
||||||
|
{
|
||||||
|
#if (NGX_SSL_ENGINE)
|
||||||
|
ENGINE_cleanup();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
@ -96,7 +96,7 @@ static ngx_command_t ngx_http_log_commands[] = {
|
|||||||
NULL },
|
NULL },
|
||||||
|
|
||||||
{ ngx_string("access_log"),
|
{ ngx_string("access_log"),
|
||||||
NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE12,
|
NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE123,
|
||||||
ngx_http_log_set_log,
|
ngx_http_log_set_log,
|
||||||
NGX_HTTP_LOC_CONF_OFFSET,
|
NGX_HTTP_LOC_CONF_OFFSET,
|
||||||
0,
|
0,
|
||||||
@ -190,11 +190,9 @@ ngx_http_log_handler(ngx_http_request_t *r)
|
|||||||
u_char *line, *p;
|
u_char *line, *p;
|
||||||
size_t len;
|
size_t len;
|
||||||
ngx_http_log_t *log;
|
ngx_http_log_t *log;
|
||||||
|
ngx_open_file_t *file;
|
||||||
ngx_http_log_op_t *op;
|
ngx_http_log_op_t *op;
|
||||||
ngx_http_log_loc_conf_t *lcf;
|
ngx_http_log_loc_conf_t *lcf;
|
||||||
#if (NGX_WIN32)
|
|
||||||
u_long written;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
|
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
|
||||||
"http log handler");
|
"http log handler");
|
||||||
@ -219,11 +217,34 @@ ngx_http_log_handler(ngx_http_request_t *r)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_WIN32)
|
len += NGX_LINEFEED_SIZE;
|
||||||
len += 2;
|
|
||||||
#else
|
file = log[l].file;
|
||||||
len++;
|
|
||||||
#endif
|
if (file->buffer) {
|
||||||
|
|
||||||
|
if (len > (size_t) (file->last - file->pos)) {
|
||||||
|
|
||||||
|
ngx_write_fd(file->fd, file->buffer, file->pos - file->buffer);
|
||||||
|
|
||||||
|
file->pos = file->buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (len <= (size_t) (file->last - file->pos)) {
|
||||||
|
|
||||||
|
p = file->pos;
|
||||||
|
|
||||||
|
for (i = 0; i < log[l].ops->nelts; i++) {
|
||||||
|
p = op[i].run(r, p, &op[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
ngx_linefeed(p);
|
||||||
|
|
||||||
|
file->pos = p;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
line = ngx_palloc(r->pool, len);
|
line = ngx_palloc(r->pool, len);
|
||||||
if (line == NULL) {
|
if (line == NULL) {
|
||||||
@ -236,13 +257,9 @@ ngx_http_log_handler(ngx_http_request_t *r)
|
|||||||
p = op[i].run(r, p, &op[i]);
|
p = op[i].run(r, p, &op[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_WIN32)
|
ngx_linefeed(p);
|
||||||
*p++ = CR; *p++ = LF;
|
|
||||||
WriteFile(log[l].file->fd, line, p - line, &written, NULL);
|
ngx_write_fd(file->fd, line, p - line);
|
||||||
#else
|
|
||||||
*p++ = LF;
|
|
||||||
write(log[l].file->fd, line, p - line);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -942,6 +959,7 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
{
|
{
|
||||||
ngx_http_log_loc_conf_t *llcf = conf;
|
ngx_http_log_loc_conf_t *llcf = conf;
|
||||||
|
|
||||||
|
ssize_t buf;
|
||||||
ngx_uint_t i;
|
ngx_uint_t i;
|
||||||
ngx_str_t *value, name;
|
ngx_str_t *value, name;
|
||||||
ngx_http_log_t *log;
|
ngx_http_log_t *log;
|
||||||
@ -974,7 +992,7 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cf->args->nelts == 3) {
|
if (cf->args->nelts >= 3) {
|
||||||
name = value[2];
|
name = value[2];
|
||||||
} else {
|
} else {
|
||||||
name.len = sizeof("combined") - 1;
|
name.len = sizeof("combined") - 1;
|
||||||
@ -987,14 +1005,51 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
|
|||||||
&& ngx_strcasecmp(fmt[i].name.data, name.data) == 0)
|
&& ngx_strcasecmp(fmt[i].name.data, name.data) == 0)
|
||||||
{
|
{
|
||||||
log->ops = fmt[i].ops;
|
log->ops = fmt[i].ops;
|
||||||
return NGX_CONF_OK;
|
goto buffer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
"unknown log format \"%V\"", &name);
|
"unknown log format \"%V\"", &name);
|
||||||
|
|
||||||
return NGX_CONF_ERROR;
|
return NGX_CONF_ERROR;
|
||||||
|
|
||||||
|
buffer:
|
||||||
|
|
||||||
|
if (cf->args->nelts == 4) {
|
||||||
|
if (ngx_strncmp(value[3].data, "buffer=", 7) != 0) {
|
||||||
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
|
"invalid parameter \"%V\"", &value[3]);
|
||||||
|
return NGX_CONF_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
name.len = value[3].len - 7;
|
||||||
|
name.data = value[3].data + 7;
|
||||||
|
|
||||||
|
buf = ngx_parse_size(&name);
|
||||||
|
|
||||||
|
if (buf == NGX_ERROR) {
|
||||||
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
|
"invalid parameter \"%V\"", &value[3]);
|
||||||
|
return NGX_CONF_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (log->file->buffer && log->file->last - log->file->pos != buf) {
|
||||||
|
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
|
||||||
|
"access_log \"%V\" already defined "
|
||||||
|
"with different buffer size", &value[1]);
|
||||||
|
return NGX_CONF_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
log->file->buffer = ngx_palloc(cf->pool, buf);
|
||||||
|
if (log->file->buffer == NULL) {
|
||||||
|
return NGX_CONF_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
log->file->pos = log->file->buffer;
|
||||||
|
log->file->last = log->file->buffer + buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NGX_CONF_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,6 +36,8 @@ static ngx_http_variable_value_t *
|
|||||||
ngx_http_variable_request_method(ngx_http_request_t *r, uintptr_t data);
|
ngx_http_variable_request_method(ngx_http_request_t *r, uintptr_t data);
|
||||||
static ngx_http_variable_value_t *
|
static ngx_http_variable_value_t *
|
||||||
ngx_http_variable_remote_user(ngx_http_request_t *r, uintptr_t data);
|
ngx_http_variable_remote_user(ngx_http_request_t *r, uintptr_t data);
|
||||||
|
static ngx_http_variable_value_t *
|
||||||
|
ngx_http_variable_sent(ngx_http_request_t *r, uintptr_t data);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -44,8 +46,7 @@ static ngx_http_variable_value_t *
|
|||||||
* REMOTE_HOST (null), REMOTE_IDENT (null),
|
* REMOTE_HOST (null), REMOTE_IDENT (null),
|
||||||
* SERVER_SOFTWARE
|
* SERVER_SOFTWARE
|
||||||
*
|
*
|
||||||
* Apache SSI: DATE_GMT, DOCUMENT_NAME, LAST_MODIFIED,
|
* Apache SSI: DOCUMENT_NAME, LAST_MODIFIED, USER_NAME (file owner)
|
||||||
* USER_NAME (file owner)
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static ngx_http_variable_t ngx_http_core_variables[] = {
|
static ngx_http_variable_t ngx_http_core_variables[] = {
|
||||||
@ -116,6 +117,10 @@ static ngx_http_variable_t ngx_http_core_variables[] = {
|
|||||||
|
|
||||||
{ ngx_string("remote_user"), ngx_http_variable_remote_user, 0, 0, 0 },
|
{ ngx_string("remote_user"), ngx_http_variable_remote_user, 0, 0, 0 },
|
||||||
|
|
||||||
|
{ ngx_string("sent"), ngx_http_variable_sent, 0, 0, 0 },
|
||||||
|
|
||||||
|
{ ngx_string("apache_sent"), ngx_http_variable_sent, 1, 0, 0 },
|
||||||
|
|
||||||
{ ngx_null_string, NULL, 0, 0, 0 }
|
{ ngx_null_string, NULL, 0, 0, 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -699,6 +704,41 @@ ngx_http_variable_remote_user(ngx_http_request_t *r, uintptr_t data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static ngx_http_variable_value_t *
|
||||||
|
ngx_http_variable_sent(ngx_http_request_t *r, uintptr_t data)
|
||||||
|
{
|
||||||
|
off_t sent;
|
||||||
|
u_char *p;
|
||||||
|
ngx_http_variable_value_t *vv;
|
||||||
|
|
||||||
|
vv = ngx_palloc(r->pool, sizeof(ngx_http_variable_value_t));
|
||||||
|
if (vv == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
sent = r->connection->sent;
|
||||||
|
|
||||||
|
if (data) {
|
||||||
|
sent -= r->header_size;
|
||||||
|
|
||||||
|
if (sent < 0) {
|
||||||
|
sent = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p = ngx_palloc(r->pool, NGX_OFF_T_LEN);
|
||||||
|
if (p == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
vv->value = 0;
|
||||||
|
vv->text.len = ngx_sprintf(p, "%O", sent) - p;
|
||||||
|
vv->text.data = p;
|
||||||
|
|
||||||
|
return vv;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
ngx_int_t
|
ngx_int_t
|
||||||
ngx_http_variables_add_core_vars(ngx_conf_t *cf)
|
ngx_http_variables_add_core_vars(ngx_conf_t *cf)
|
||||||
{
|
{
|
||||||
|
@ -157,10 +157,6 @@ typedef struct {
|
|||||||
#define NGX_IMAP_PARSE_INVALID_COMMAND 20
|
#define NGX_IMAP_PARSE_INVALID_COMMAND 20
|
||||||
|
|
||||||
|
|
||||||
#define NGX_IMAP_PROXY_INVALID 10
|
|
||||||
#define NGX_IMAP_PROXY_ERROR 11
|
|
||||||
|
|
||||||
|
|
||||||
#define NGX_IMAP_MODULE 0x50414D49 /* "IMAP" */
|
#define NGX_IMAP_MODULE 0x50414D49 /* "IMAP" */
|
||||||
|
|
||||||
#define NGX_IMAP_MAIN_CONF 0x02000000
|
#define NGX_IMAP_MAIN_CONF 0x02000000
|
||||||
|
@ -156,7 +156,6 @@ ngx_imap_proxy_block_read(ngx_event_t *rev)
|
|||||||
static void
|
static void
|
||||||
ngx_imap_proxy_imap_handler(ngx_event_t *rev)
|
ngx_imap_proxy_imap_handler(ngx_event_t *rev)
|
||||||
{
|
{
|
||||||
char *action;
|
|
||||||
u_char *p;
|
u_char *p;
|
||||||
ngx_int_t rc;
|
ngx_int_t rc;
|
||||||
ngx_str_t line;
|
ngx_str_t line;
|
||||||
@ -194,21 +193,11 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == NGX_ERROR || rc == NGX_IMAP_PROXY_INVALID) {
|
if (rc == NGX_ERROR) {
|
||||||
ngx_imap_proxy_internal_server_error(s);
|
ngx_imap_proxy_internal_server_error(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == NGX_IMAP_PROXY_ERROR) {
|
|
||||||
s->connection->read->handler = ngx_imap_proxy_handler;
|
|
||||||
s->connection->write->handler = ngx_imap_proxy_handler;
|
|
||||||
rev->handler = ngx_imap_proxy_handler;
|
|
||||||
c->write->handler = ngx_imap_proxy_handler;
|
|
||||||
|
|
||||||
ngx_imap_proxy_handler(c->read);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (s->imap_state) {
|
switch (s->imap_state) {
|
||||||
|
|
||||||
case ngx_imap_start:
|
case ngx_imap_start:
|
||||||
@ -294,10 +283,8 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
|
|||||||
ngx_add_timer(s->connection->read, pcf->timeout);
|
ngx_add_timer(s->connection->read, pcf->timeout);
|
||||||
ngx_del_timer(c->read);
|
ngx_del_timer(c->read);
|
||||||
|
|
||||||
action = c->log->action;
|
|
||||||
c->log->action = NULL;
|
c->log->action = NULL;
|
||||||
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
|
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
|
||||||
c->log->action = action;
|
|
||||||
|
|
||||||
c->log->action = "proxying";
|
c->log->action = "proxying";
|
||||||
}
|
}
|
||||||
@ -307,7 +294,6 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
|
|||||||
static void
|
static void
|
||||||
ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
|
ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
|
||||||
{
|
{
|
||||||
char *action;
|
|
||||||
u_char *p;
|
u_char *p;
|
||||||
ngx_int_t rc;
|
ngx_int_t rc;
|
||||||
ngx_str_t line;
|
ngx_str_t line;
|
||||||
@ -344,21 +330,11 @@ ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == NGX_ERROR || rc == NGX_IMAP_PROXY_INVALID) {
|
if (rc == NGX_ERROR) {
|
||||||
ngx_imap_proxy_internal_server_error(s);
|
ngx_imap_proxy_internal_server_error(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == NGX_IMAP_PROXY_ERROR) {
|
|
||||||
s->connection->read->handler = ngx_imap_proxy_handler;
|
|
||||||
s->connection->write->handler = ngx_imap_proxy_handler;
|
|
||||||
rev->handler = ngx_imap_proxy_handler;
|
|
||||||
c->write->handler = ngx_imap_proxy_handler;
|
|
||||||
|
|
||||||
ngx_imap_proxy_handler(c->read);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (s->imap_state) {
|
switch (s->imap_state) {
|
||||||
|
|
||||||
case ngx_pop3_start:
|
case ngx_pop3_start:
|
||||||
@ -425,10 +401,8 @@ ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
|
|||||||
ngx_add_timer(s->connection->read, pcf->timeout);
|
ngx_add_timer(s->connection->read, pcf->timeout);
|
||||||
ngx_del_timer(c->read);
|
ngx_del_timer(c->read);
|
||||||
|
|
||||||
action = c->log->action;
|
|
||||||
c->log->action = NULL;
|
c->log->action = NULL;
|
||||||
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
|
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
|
||||||
c->log->action = action;
|
|
||||||
|
|
||||||
c->log->action = "proxying";
|
c->log->action = "proxying";
|
||||||
}
|
}
|
||||||
@ -474,7 +448,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
|
|||||||
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
|
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
|
||||||
"upstream sent too long response line: \"%s\"",
|
"upstream sent too long response line: \"%s\"",
|
||||||
b->pos);
|
b->pos);
|
||||||
return NGX_IMAP_PROXY_INVALID;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NGX_AGAIN;
|
return NGX_AGAIN;
|
||||||
@ -487,15 +461,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
|
|||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p[0] == '-' && p[1] == 'E' && p[2] == 'R' && p[3] == 'R') {
|
|
||||||
return NGX_IMAP_PROXY_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (p[0] == 'N' && p[1] == 'O') {
|
|
||||||
return NGX_IMAP_PROXY_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (what == NGX_IMAP_WAIT_OK) {
|
if (what == NGX_IMAP_WAIT_OK) {
|
||||||
if (p[0] == '*' && p[1] == ' ' && p[2] == 'O' && p[3] == 'K') {
|
if (p[0] == '*' && p[1] == ' ' && p[2] == 'O' && p[3] == 'K') {
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -512,7 +478,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
|
|||||||
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
|
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
|
||||||
"upstream sent invalid response: \"%s\"", p);
|
"upstream sent invalid response: \"%s\"", p);
|
||||||
|
|
||||||
return NGX_IMAP_PROXY_INVALID;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -154,7 +154,7 @@ static ngx_inline ngx_atomic_uint_t
|
|||||||
ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old,
|
ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old,
|
||||||
ngx_atomic_uint_t set)
|
ngx_atomic_uint_t set)
|
||||||
{
|
{
|
||||||
if (*lock == old {
|
if (*lock == old) {
|
||||||
*lock = set;
|
*lock = set;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -174,8 +174,9 @@ ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add)
|
|||||||
return old;
|
return old;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#define ngx_memory_barrier()
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
void ngx_spinlock(ngx_atomic_t *lock, ngx_uint_t spin);
|
void ngx_spinlock(ngx_atomic_t *lock, ngx_uint_t spin);
|
||||||
|
|
||||||
|
@ -44,7 +44,6 @@ ngx_fd_t ngx_open_tempfile(u_char *name, ngx_uint_t persistent);
|
|||||||
ssize_t ngx_read_file(ngx_file_t *file, u_char *buf, size_t size, off_t offset);
|
ssize_t ngx_read_file(ngx_file_t *file, u_char *buf, size_t size, off_t offset);
|
||||||
#define ngx_read_file_n "read()"
|
#define ngx_read_file_n "read()"
|
||||||
|
|
||||||
|
|
||||||
ssize_t ngx_write_file(ngx_file_t *file, u_char *buf, size_t size,
|
ssize_t ngx_write_file(ngx_file_t *file, u_char *buf, size_t size,
|
||||||
off_t offset);
|
off_t offset);
|
||||||
|
|
||||||
@ -52,6 +51,11 @@ ssize_t ngx_write_chain_to_file(ngx_file_t *file, ngx_chain_t *ce,
|
|||||||
off_t offset, ngx_pool_t *pool);
|
off_t offset, ngx_pool_t *pool);
|
||||||
|
|
||||||
|
|
||||||
|
#define ngx_write_fd write
|
||||||
|
#define ngx_linefeed(p) *p++ = LF;
|
||||||
|
#define NGX_LINEFEED_SIZE 1
|
||||||
|
|
||||||
|
|
||||||
#define ngx_rename_file rename
|
#define ngx_rename_file rename
|
||||||
#define ngx_rename_file_n "rename"
|
#define ngx_rename_file_n "rename"
|
||||||
|
|
||||||
|
@ -276,6 +276,13 @@ ngx_single_process_cycle(ngx_cycle_t *cycle)
|
|||||||
ngx_process_events_and_timers(cycle);
|
ngx_process_events_and_timers(cycle);
|
||||||
|
|
||||||
if (ngx_terminate || ngx_quit) {
|
if (ngx_terminate || ngx_quit) {
|
||||||
|
|
||||||
|
for (i = 0; ngx_modules[i]; i++) {
|
||||||
|
if (ngx_modules[i]->exit_process) {
|
||||||
|
ngx_modules[i]->exit_process(cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ngx_master_exit(cycle);
|
ngx_master_exit(cycle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -623,10 +630,18 @@ ngx_reap_childs(ngx_cycle_t *cycle)
|
|||||||
static void
|
static void
|
||||||
ngx_master_exit(ngx_cycle_t *cycle)
|
ngx_master_exit(ngx_cycle_t *cycle)
|
||||||
{
|
{
|
||||||
|
ngx_uint_t i;
|
||||||
|
|
||||||
ngx_delete_pidfile(cycle);
|
ngx_delete_pidfile(cycle);
|
||||||
|
|
||||||
ngx_log_error(NGX_LOG_NOTICE, cycle->log, 0, "exit");
|
ngx_log_error(NGX_LOG_NOTICE, cycle->log, 0, "exit");
|
||||||
|
|
||||||
|
for (i = 0; ngx_modules[i]; i++) {
|
||||||
|
if (ngx_modules[i]->exit_master) {
|
||||||
|
ngx_modules[i]->exit_master(cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* we do not destroy cycle->pool here because a signal handler
|
* we do not destroy cycle->pool here because a signal handler
|
||||||
* that uses cycle->log can be called at this point
|
* that uses cycle->log can be called at this point
|
||||||
@ -735,6 +750,12 @@ ngx_worker_process_cycle(ngx_cycle_t *cycle, void *data)
|
|||||||
ngx_wakeup_worker_threads(cycle);
|
ngx_wakeup_worker_threads(cycle);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
for (i = 0; ngx_modules[i]; i++) {
|
||||||
|
if (ngx_modules[i]->exit_process) {
|
||||||
|
ngx_modules[i]->exit_process(cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
c = cycle->connections;
|
c = cycle->connections;
|
||||||
for (i = 0; i < cycle->connection_n; i++) {
|
for (i = 0; i < cycle->connection_n; i++) {
|
||||||
if (c[i].fd != -1
|
if (c[i].fd != -1
|
||||||
|
@ -65,6 +65,11 @@ ngx_int_t ngx_file_append_mode(ngx_fd_t fd);
|
|||||||
#define ngx_close_file_n "CloseHandle()"
|
#define ngx_close_file_n "CloseHandle()"
|
||||||
|
|
||||||
|
|
||||||
|
#define ngx_write_fd(fd, buf, size) WriteFile(fd, buf, size, NULL, NULL)
|
||||||
|
#define ngx_linefeed(p) *p++ = CR; *p++ = LF;
|
||||||
|
#define NGX_LINEFEED_SIZE 2
|
||||||
|
|
||||||
|
|
||||||
#define ngx_delete_file(name) DeleteFile((const char *) name)
|
#define ngx_delete_file(name) DeleteFile((const char *) name)
|
||||||
#define ngx_delete_file_n "DeleteFile()"
|
#define ngx_delete_file_n "DeleteFile()"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user