s4-cldap: fixed the CLDAP response for IPv6 clients
authorAndrew Tridgell <tridge@samba.org>
Tue, 7 Jun 2011 05:46:17 +0000 (15:46 +1000)
committerAndrew Tridgell <tridge@samba.org>
Tue, 7 Jun 2011 06:57:48 +0000 (08:57 +0200)
Autobuild-User: Andrew Tridgell <tridge@samba.org>
Autobuild-Date: Tue Jun  7 08:57:48 CEST 2011 on sn-devel-104

source4/cldap_server/netlogon.c

index 92f7a4a752f7ef64c950f8e78e72896b2e4069d5..77f50ff3e6668b8c62635fd62edc090fc1e8952c 100644 (file)
@@ -37,6 +37,7 @@
 #include "param/param.h"
 #include "../lib/tsocket/tsocket.h"
 #include "libds/common/flag_mapping.h"
+#include "lib/util/util_net.h"
 
 /*
   fill in the cldap netlogon union for a given version
@@ -292,16 +293,17 @@ NTSTATUS fill_netlogon_samlogon_response(struct ldb_context *sam_ctx,
                                                  src_address, NULL);
        NT_STATUS_HAVE_NO_MEMORY(client_site);
        load_interface_list(mem_ctx, lp_ctx, &ifaces);
-       /*
-        * TODO: the caller should pass the address which the client
-        * used to trigger this call, as the client is able to reach
-        * this ip.
-        */
+
        if (src_address) {
                pdc_ip = iface_list_best_ip(ifaces, src_address);
        } else {
                pdc_ip = iface_list_first_v4(ifaces);
        }
+       if (pdc_ip == NULL || !is_ipaddress_v4(pdc_ip)) {
+               /* this matches windows behaviour */
+               pdc_ip = "127.0.0.1";
+       }
+
        ZERO_STRUCTP(netlogon);
 
        /* check if either of these bits is present */
@@ -325,7 +327,7 @@ NTSTATUS fill_netlogon_samlogon_response(struct ldb_context *sam_ctx,
                netlogon->data.nt5_ex.server_site  = server_site;
                netlogon->data.nt5_ex.client_site  = client_site;
                if (version & NETLOGON_NT_VERSION_5EX_WITH_IP) {
-                       /* Clearly this needs to be fixed up for IPv6 */
+                       /* note that this is always a IPV4 address */
                        extra_flags = NETLOGON_NT_VERSION_5EX_WITH_IP;
                        netlogon->data.nt5_ex.sockaddr.sockaddr_family    = 2;
                        netlogon->data.nt5_ex.sockaddr.pdc_ip       = pdc_ip;