Stream: support for $remote_port in proxy_bind.
The following two types of bind addresses are supported in addition to
$remote_addr and address literals:
- $remote_addr:$remote_port
- [$remote_addr]:$remote_port
In both cases client remote address with port is used in upstream socket bind.
diff --git a/src/stream/ngx_stream_proxy_module.c b/src/stream/ngx_stream_proxy_module.c
index 7831c7a..8c37d00 100644
--- a/src/stream/ngx_stream_proxy_module.c
+++ b/src/stream/ngx_stream_proxy_module.c
@@ -13,8 +13,9 @@
typedef struct {
ngx_addr_t *addr;
#if (NGX_HAVE_TRANSPARENT_PROXY)
- ngx_uint_t transparent; /* unsigned transparent:1; */
+ unsigned transparent:1;
#endif
+ unsigned no_port:1;
} ngx_stream_upstream_local_t;
@@ -463,7 +464,7 @@
return NGX_OK;
}
- /* $remote_addr */
+ /* $remote_addr, $remote_addr:$remote_port, [$remote_addr]:$remote_port */
c = s->connection;
@@ -474,13 +475,18 @@
addr->socklen = c->socklen;
- addr->sockaddr = ngx_palloc(c->pool, addr->socklen);
- if (addr->sockaddr == NULL) {
- return NGX_ERROR;
- }
+ if (local->no_port) {
+ addr->sockaddr = ngx_palloc(c->pool, addr->socklen);
+ if (addr->sockaddr == NULL) {
+ return NGX_ERROR;
+ }
- ngx_memcpy(addr->sockaddr, c->sockaddr, c->socklen);
- ngx_inet_set_port(addr->sockaddr, 0);
+ ngx_memcpy(addr->sockaddr, c->sockaddr, c->socklen);
+ ngx_inet_set_port(addr->sockaddr, 0);
+
+ } else {
+ addr->sockaddr = c->sockaddr;
+ }
addr->name = c->addr_text;
u->peer.local = addr;
@@ -1714,7 +1720,12 @@
pscf->local = local;
- if (ngx_strcmp(value[1].data, "$remote_addr") != 0) {
+ if (ngx_strcmp(value[1].data, "$remote_addr") == 0) {
+ local->no_port = 1;
+
+ } else if (ngx_strcmp(value[1].data, "$remote_addr:$remote_port") != 0
+ && ngx_strcmp(value[1].data, "[$remote_addr]:$remote_port") != 0)
+ {
local->addr = ngx_palloc(cf->pool, sizeof(ngx_addr_t));
if (local->addr == NULL) {
return NGX_CONF_ERROR;