summaryrefslogtreecommitdiffstats
path: root/source4/web_server
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2011-05-12 12:35:02 +0200
committerAndrew Tridgell <tridge@samba.org>2011-06-06 12:26:10 +1000
commitdc8c8fd9e4f85974cd0665e613d4422ba8dd900e (patch)
tree0f1f60584986c4648ace8af742d2023fe5c87dc8 /source4/web_server
parentd510687408c03291df767e0ccacebcd4a360646c (diff)
downloadsamba-dc8c8fd9e4f85974cd0665e613d4422ba8dd900e.tar.gz
samba-dc8c8fd9e4f85974cd0665e613d4422ba8dd900e.tar.xz
samba-dc8c8fd9e4f85974cd0665e613d4422ba8dd900e.zip
s4-ipv6: use iface_list_wildcard() to listen on IPv6
when we need to listen on a wildcard address, we now listen on a list of sockets, usually 0.0.0.0 and ::
Diffstat (limited to 'source4/web_server')
-rw-r--r--source4/web_server/web_server.c24
1 files changed, 17 insertions, 7 deletions
diff --git a/source4/web_server/web_server.c b/source4/web_server/web_server.c
index ab8f63b2ec..c43b2cfc7b 100644
--- a/source4/web_server/web_server.c
+++ b/source4/web_server/web_server.c
@@ -336,13 +336,23 @@ static void websrv_task_init(struct task_server *task)
talloc_free(ifaces);
} else {
- status = stream_setup_socket(task, task->event_ctx,
- task->lp_ctx, model_ops,
- &web_stream_ops,
- "ipv4", lpcfg_socket_address(task->lp_ctx),
- &port, lpcfg_socket_options(task->lp_ctx),
- task);
- if (!NT_STATUS_IS_OK(status)) goto failed;
+ const char **wcard;
+ int i;
+ wcard = iface_list_wildcard(task, task->lp_ctx);
+ if (wcard == NULL) {
+ DEBUG(0,("No wildcard addresses available\n"));
+ goto failed;
+ }
+ for (i=0; wcard[i]; i++) {
+ status = stream_setup_socket(task, task->event_ctx,
+ task->lp_ctx, model_ops,
+ &web_stream_ops,
+ "ip", wcard[i],
+ &port, lpcfg_socket_options(task->lp_ctx),
+ wdata);
+ if (!NT_STATUS_IS_OK(status)) goto failed;
+ }
+ talloc_free(wcard);
}
wdata->tls_params = tls_initialise(wdata, task->lp_ctx);