# HG changeset patch # User Igor Sysoev # Date 1168177016 0 # Node ID 7a8ca436d61141edab3b38e2ddf1e09850d900ba # Parent 664afe2c14806d341dbafad024b412c647534c32 ngx_http_variable_binary_remote_addr() diff --git a/src/http/ngx_http_variables.c b/src/http/ngx_http_variables.c --- a/src/http/ngx_http_variables.c +++ b/src/http/ngx_http_variables.c @@ -28,6 +28,8 @@ static ngx_int_t ngx_http_variable_unkno static ngx_int_t ngx_http_variable_host(ngx_http_request_t *r, ngx_http_variable_value_t *v, uintptr_t data); +static ngx_int_t ngx_http_variable_binary_remote_addr(ngx_http_request_t *r, + ngx_http_variable_value_t *v, uintptr_t data); static ngx_int_t ngx_http_variable_remote_addr(ngx_http_request_t *r, ngx_http_variable_value_t *v, uintptr_t data); static ngx_int_t ngx_http_variable_remote_port(ngx_http_request_t *r, @@ -116,7 +118,7 @@ static ngx_http_variable_t ngx_http_cor { ngx_string("host"), NULL, ngx_http_variable_host, 0, 0, 0 }, { ngx_string("binary_remote_addr"), NULL, - ngx_http_variable_remote_addr, 1, 0, 0 }, + ngx_http_variable_binary_remote_addr, 0, 0, 0 }, { ngx_string("remote_addr"), NULL, ngx_http_variable_remote_addr, 0, 0, 0 }, @@ -699,30 +701,34 @@ ngx_http_variable_host(ngx_http_request_ static ngx_int_t -ngx_http_variable_remote_addr(ngx_http_request_t *r, +ngx_http_variable_binary_remote_addr(ngx_http_request_t *r, ngx_http_variable_value_t *v, uintptr_t data) { struct sockaddr_in *sin; - if (data == 0) { - v->len = r->connection->addr_text.len; - v->valid = 1; - v->no_cachable = 0; - v->not_found = 0; - v->data = r->connection->addr_text.data; + /* AF_INET only */ + + sin = (struct sockaddr_in *) r->connection->sockaddr; - } else { + v->len = sizeof(in_addr_t); + v->valid = 1; + v->no_cachable = 0; + v->not_found = 0; + v->data = (u_char *) &sin->sin_addr.s_addr; - /* AF_INET only */ + return NGX_OK; +} - sin = (struct sockaddr_in *) r->connection->sockaddr; - v->len = sizeof(in_addr_t); - v->valid = 1; - v->no_cachable = 0; - v->not_found = 0; - v->data = (u_char *) &sin->sin_addr.s_addr; - } +static ngx_int_t +ngx_http_variable_remote_addr(ngx_http_request_t *r, + ngx_http_variable_value_t *v, uintptr_t data) +{ + v->len = r->connection->addr_text.len; + v->valid = 1; + v->no_cachable = 0; + v->not_found = 0; + v->data = r->connection->addr_text.data; return NGX_OK; }