aboutsummaryrefslogtreecommitdiff
path: root/src/http/ngx_http_variables.c
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2007-01-07 13:36:56 +0000
committerIgor Sysoev <igor@sysoev.ru>2007-01-07 13:36:56 +0000
commitd5ca16cdd42b7625ba10e64dd45893b1683aaaef (patch)
tree366451f41fbd465355b79118767ef2c82b1e0349 /src/http/ngx_http_variables.c
parente6bf2be77e0cfcd147ee7cf5a289a5efa0d9edb9 (diff)
downloadnginx-d5ca16cdd42b7625ba10e64dd45893b1683aaaef.tar.gz
nginx-d5ca16cdd42b7625ba10e64dd45893b1683aaaef.zip
ngx_http_variable_binary_remote_addr()
Diffstat (limited to 'src/http/ngx_http_variables.c')
-rw-r--r--src/http/ngx_http_variables.c40
1 files changed, 23 insertions, 17 deletions
diff --git a/src/http/ngx_http_variables.c b/src/http/ngx_http_variables.c
index ffa244650..ac4a4a2f8 100644
--- 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_unknown_header(ngx_http_variable_value_t *v,
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_core_variables[] = {
{ 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_t *r, ngx_http_variable_value_t *v,
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 */
- } else {
+ sin = (struct sockaddr_in *) r->connection->sockaddr;
- /* AF_INET only */
+ 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;
- sin = (struct sockaddr_in *) r->connection->sockaddr;
+ return NGX_OK;
+}
- 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;
}