svn commit: samba r20291 - in branches/SAMBA_4_0/source: libnet torture/libnet

metze at samba.org metze at samba.org
Wed Dec 20 21:14:45 GMT 2006


Author: metze
Date: 2006-12-20 21:14:44 +0000 (Wed, 20 Dec 2006)
New Revision: 20291

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=20291

Log:
implement prepare_db hook of libnet_BecomeDC()

metze
Modified:
   branches/SAMBA_4_0/source/libnet/libnet_become_dc.c
   branches/SAMBA_4_0/source/libnet/libnet_become_dc.h
   branches/SAMBA_4_0/source/torture/libnet/libnet_BecomeDC.c


Changeset:
Modified: branches/SAMBA_4_0/source/libnet/libnet_become_dc.c
===================================================================
--- branches/SAMBA_4_0/source/libnet/libnet_become_dc.c	2006-12-20 19:05:07 UTC (rev 20290)
+++ branches/SAMBA_4_0/source/libnet/libnet_become_dc.c	2006-12-20 21:14:44 UTC (rev 20291)
@@ -90,6 +90,7 @@
 	struct becomeDC_fsmo rid_manager_fsmo;
 
 	struct libnet_BecomeDC_CheckOptions _co;
+	struct libnet_BecomeDC_PrepareDB _pp;
 	struct libnet_BecomeDC_Callbacks callbacks;
 };
 
@@ -1481,7 +1482,12 @@
 {
 	if (!s->callbacks.prepare_db) return NT_STATUS_OK;
 
-	return s->callbacks.prepare_db(s->callbacks.private_data, NULL);
+	s->_pp.domain		= &s->domain;
+	s->_pp.forest		= &s->forest;
+	s->_pp.source_dsa	= &s->source_dsa;
+	s->_pp.dest_dsa		= &s->dest_dsa;
+
+	return s->callbacks.prepare_db(s->callbacks.private_data, &s->_pp);
 }
 
 static void becomeDC_drsuapi2_bind_recv(struct rpc_request *req);

Modified: branches/SAMBA_4_0/source/libnet/libnet_become_dc.h
===================================================================
--- branches/SAMBA_4_0/source/libnet/libnet_become_dc.h	2006-12-20 19:05:07 UTC (rev 20290)
+++ branches/SAMBA_4_0/source/libnet/libnet_become_dc.h	2006-12-20 21:14:44 UTC (rev 20291)
@@ -75,11 +75,19 @@
 	uint32_t user_account_control;
 };
 
+struct libnet_BecomeDC_PrepareDB {
+	const struct libnet_BecomeDC_Domain *domain;
+	const struct libnet_BecomeDC_Forest *forest;
+	const struct libnet_BecomeDC_SourceDSA *source_dsa;
+	const struct libnet_BecomeDC_DestDSA *dest_dsa;
+};
+
 struct libnet_BecomeDC_Callbacks {
 	void *private_data;
 	NTSTATUS (*check_options)(void *private_data,
-				  const struct libnet_BecomeDC_CheckOptions *options);
-	NTSTATUS (*prepare_db)(void *private_data, void *todo);
+				  const struct libnet_BecomeDC_CheckOptions *info);
+	NTSTATUS (*prepare_db)(void *private_data,
+			       const struct libnet_BecomeDC_PrepareDB *info);
 	NTSTATUS (*schema_chunk)(void *private_data, void *todo);
 	NTSTATUS (*config_chunk)(void *private_data, void *todo);
 	NTSTATUS (*domain_chunk)(void *private_data, void *todo);

Modified: branches/SAMBA_4_0/source/torture/libnet/libnet_BecomeDC.c
===================================================================
--- branches/SAMBA_4_0/source/torture/libnet/libnet_BecomeDC.c	2006-12-20 19:05:07 UTC (rev 20290)
+++ branches/SAMBA_4_0/source/torture/libnet/libnet_BecomeDC.c	2006-12-20 21:14:44 UTC (rev 20291)
@@ -30,7 +30,7 @@
 #define TORTURE_NETBIOS_NAME "smbtorturedc"
 
 static NTSTATUS test_become_dc_check_options(void *private_data,
-					    const struct libnet_BecomeDC_CheckOptions *o)
+					     const struct libnet_BecomeDC_CheckOptions *o)
 {
 	DEBUG(0,("Become DC of Domain[%s]/[%s]\n",
 		o->domain->netbios_name, o->domain->dns_name));
@@ -50,6 +50,33 @@
 	return NT_STATUS_OK;
 }
 
+static NTSTATUS test_become_dc_prepare_db(void *private_data,
+					  const struct libnet_BecomeDC_PrepareDB *p)
+{
+	struct test_join *tj = talloc_get_type(private_data, struct test_join);
+
+	DEBUG(0,("New Server[%s] in Site[%s]\n",
+		p->dest_dsa->dns_name, p->dest_dsa->site_name));
+
+	DEBUG(0,("DSA Instance [%s]\n"
+		"\tobjectGUID[%s]\n"
+		"\tinvocationId[%s]\n",
+		p->dest_dsa->ntds_dn_str,
+		GUID_string(tj, &p->dest_dsa->ntds_guid),
+		GUID_string(tj, &p->dest_dsa->invocation_id)));
+
+	DEBUG(0,("Schema Partition[%s]\n",
+		p->forest->schema_dn_str));
+
+	DEBUG(0,("Config Partition[%s]\n",
+		p->forest->config_dn_str));
+
+	DEBUG(0,("Domain Partition[%s]\n",
+		p->domain->dn_str));
+
+	return NT_STATUS_OK;
+}
+
 BOOL torture_net_become_dc(struct torture_context *torture)
 {
 	BOOL ret = True;
@@ -80,7 +107,9 @@
 	b.in.source_dsa_address		= lp_parm_string(-1, "torture", "host");
 	b.in.dest_dsa_netbios_name	= TORTURE_NETBIOS_NAME;
 
+	b.in.callbacks.private_data	= tj;
 	b.in.callbacks.check_options	= test_become_dc_check_options;
+	b.in.callbacks.prepare_db	= test_become_dc_prepare_db;
 
 	status = libnet_BecomeDC(ctx, ctx, &b);
 	if (!NT_STATUS_IS_OK(status)) {



More information about the samba-cvs mailing list