diff options
author | Igor Sysoev <igor@sysoev.ru> | 2007-12-29 16:00:34 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2007-12-29 16:00:34 +0000 |
commit | c7a9b7a990b4ea9bf908402abf090e1bd95b1d9a (patch) | |
tree | 1925f604f61085a6d50a42737c580756f377e4b6 /src/http/ngx_http_variables.c | |
parent | 3f24ae2be259ee1be922ebb65d29c5aea8abb394 (diff) | |
download | nginx-c7a9b7a990b4ea9bf908402abf090e1bd95b1d9a.tar.gz nginx-c7a9b7a990b4ea9bf908402abf090e1bd95b1d9a.zip |
use ngx_http_server_addr()
Diffstat (limited to 'src/http/ngx_http_variables.c')
-rw-r--r-- | src/http/ngx_http_variables.c | 24 |
1 files changed, 7 insertions, 17 deletions
diff --git a/src/http/ngx_http_variables.c b/src/http/ngx_http_variables.c index ebc24a689..971f70522 100644 --- a/src/http/ngx_http_variables.c +++ b/src/http/ngx_http_variables.c @@ -808,32 +808,22 @@ static ngx_int_t ngx_http_variable_server_addr(ngx_http_request_t *r, ngx_http_variable_value_t *v, uintptr_t data) { - socklen_t len; - ngx_connection_t *c; - struct sockaddr_in sin; + ngx_str_t s; - v->data = ngx_palloc(r->pool, INET_ADDRSTRLEN); - if (v->data == NULL) { + s.data = ngx_palloc(r->pool, INET_ADDRSTRLEN); + if (s.data == NULL) { return NGX_ERROR; } - c = r->connection; - - if (r->in_addr == 0) { - len = sizeof(struct sockaddr_in); - if (getsockname(c->fd, (struct sockaddr *) &sin, &len) == -1) { - ngx_connection_error(c, ngx_socket_errno, "getsockname() failed"); - return NGX_ERROR; - } - - r->in_addr = sin.sin_addr.s_addr; + if (ngx_http_server_addr(r, &s) != NGX_OK) { + return NGX_ERROR; } - v->len = ngx_inet_ntop(c->listening->family, &r->in_addr, - v->data, INET_ADDRSTRLEN); + v->len = s.len; v->valid = 1; v->no_cacheable = 0; v->not_found = 0; + v->data = s.data; return NGX_OK; } |