diff options
| -rw-r--r-- | file_server/file_server.c | 12 | ||||
| -rw-r--r-- | selftest/target/Samba4.pm | 2 | ||||
| -rw-r--r-- | source3/param/loadparm.c | 13 | 
3 files changed, 14 insertions, 13 deletions
diff --git a/file_server/file_server.c b/file_server/file_server.c index 2b9e48a38b..448894ecbd 100644 --- a/file_server/file_server.c +++ b/file_server/file_server.c @@ -61,15 +61,6 @@ static const char *generate_smb_conf(struct task_server *task)  	fdprintf(fd, "rpc_daemon:spoolssd = disabled\n");  	fdprintf(fd, "rpc_server:tcpip = no\n"); -	/* If we are using xattr_tdb:file or posix:eadb then we need to load another VFS object */ -	if (lpcfg_parm_string(lp_ctx, NULL, "xattr_tdb", "file")) { -		fdprintf(fd, "vfs objects = acl_xattr xattr_tdb\n"); -	} else if (lpcfg_parm_string(lp_ctx, NULL, "posix", "eadb")) { -		fdprintf(fd, "vfs objects = acl_xattr posix_eadb\n"); -	} else { -		fdprintf(fd, "vfs objects = acl_xattr\n"); -	} -  	fdprintf(fd, "map hidden = no\n");  	fdprintf(fd, "map system = no\n");  	fdprintf(fd, "map readonly = no\n"); @@ -77,9 +68,6 @@ static const char *generate_smb_conf(struct task_server *task)  	fdprintf(fd, "include = %s\n", lpcfg_configfile(lp_ctx)); -	fdprintf(fd, "[IPC$]\n"); -	fdprintf(fd, " vfs objects = dfs_samba4\n"); -  	close(fd);  	return path;  } diff --git a/selftest/target/Samba4.pm b/selftest/target/Samba4.pm index 4b6af336b7..248a7259f7 100644 --- a/selftest/target/Samba4.pm +++ b/selftest/target/Samba4.pm @@ -1367,7 +1367,7 @@ sub provision_plugin_s4_dc($$)  	create mask = 755  	dos filemode = yes -        vfs objects = acl_xattr fake_acls xattr_tdb streams_depot +        vfs objects = dfs_samba4 acl_xattr fake_acls xattr_tdb streams_depot          dcerpc endpoint servers = -winreg -srvsvc diff --git a/source3/param/loadparm.c b/source3/param/loadparm.c index 0b5a0e87f0..d9ce4b4b58 100644 --- a/source3/param/loadparm.c +++ b/source3/param/loadparm.c @@ -4902,6 +4902,19 @@ static bool lp_load_ex(const char *pszFname,  	fault_configure(smb_panic_s3); +	if (lp_server_role() == ROLE_ACTIVE_DIRECTORY_DC) { +		const char **vfs_objects = lp_vfs_objects(-1); +		if (!vfs_objects || !vfs_objects[0]) { +			if (lp_parm_const_string(-1, "xattr_tdb", "file", NULL)) { +				lp_do_parameter(-1, "vfs objects", "dfs_samba4 acl_xattr xattr_tdb"); +			} else if (lp_parm_const_string(-1, "posix", "eadb", NULL)) { +				lp_do_parameter(-1, "vfs objects", "dfs_samba4 acl_xattr posix_eadb"); +			} else { +				lp_do_parameter(-1, "vfs objects", "dfs_samba4 acl_xattr"); +			} +		} +	} +  	bAllowIncludeRegistry = true;  	return (bRetval);  | 
