diff options
-rw-r--r-- | source4/librpc/idl/dssetup.idl | 24 | ||||
-rw-r--r-- | source4/param/loadparm.c | 2 | ||||
-rw-r--r-- | source4/rpc_server/config.mk | 14 | ||||
-rw-r--r-- | source4/rpc_server/dssetup/dcesrv_dssetup.c | 177 |
4 files changed, 204 insertions, 13 deletions
diff --git a/source4/librpc/idl/dssetup.idl b/source4/librpc/idl/dssetup.idl index 17288e5791..dc57e86a11 100644 --- a/source4/librpc/idl/dssetup.idl +++ b/source4/librpc/idl/dssetup.idl @@ -25,23 +25,23 @@ } ds_DomainBasicInformation; typedef union { - [case(1)] ds_DomainBasicInformation info1; + [case(1)] ds_DomainBasicInformation basic; } ds_DomainInformation; - NTSTATUS ds_RolerGetPrimaryDomainInformation( + WERROR ds_RolerGetPrimaryDomainInformation( [in] uint16 level, [out,switch_is(level)] ds_DomainInformation *info ); - NTSTATUS ds_RolerDnsNameToFlatName(); - NTSTATUS ds_RolerDcAsDc(); - NTSTATUS ds_RolerDcAsReplica(); - NTSTATUS ds_RolerDemoteDc(); - NTSTATUS ds_RolerGetDcOperationProgress(); - NTSTATUS ds_RolerGetDcOperationResults(); - NTSTATUS ds_RolerCancel(); - NTSTATUS ds_RolerServerSaveStateForUpgrade(); - NTSTATUS ds_RolerUpgradeDownlevelServer(); - NTSTATUS ds_RolerAbortDownlevelServerUpgrade(); + WERROR ds_RolerDnsNameToFlatName(); + WERROR ds_RolerDcAsDc(); + WERROR ds_RolerDcAsReplica(); + WERROR ds_RolerDemoteDc(); + WERROR ds_RolerGetDcOperationProgress(); + WERROR ds_RolerGetDcOperationResults(); + WERROR ds_RolerCancel(); + WERROR ds_RolerServerSaveStateForUpgrade(); + WERROR ds_RolerUpgradeDownlevelServer(); + WERROR ds_RolerAbortDownlevelServerUpgrade(); } diff --git a/source4/param/loadparm.c b/source4/param/loadparm.c index 405caf6fc4..70caf62ff2 100644 --- a/source4/param/loadparm.c +++ b/source4/param/loadparm.c @@ -926,7 +926,7 @@ static void init_globals(void) do_parameter("ntvfs handler", "unixuid default"); do_parameter("max connections", "-1"); - do_parameter("dcerpc endpoint servers", "epmapper srvsvc wkssvc rpcecho samr netlogon lsarpc spoolss drsuapi winreg IOXIDResolver IRemoteActivation"); + do_parameter("dcerpc endpoint servers", "epmapper srvsvc wkssvc rpcecho samr netlogon lsarpc spoolss drsuapi winreg IOXIDResolver IRemoteActivation dssetup"); do_parameter("server services", "smb rpc"); do_parameter("auth methods", "anonymous sam_ignoredomain"); do_parameter("smb passwd file", dyn_SMB_PASSWD_FILE); diff --git a/source4/rpc_server/config.mk b/source4/rpc_server/config.mk index 21c63282fe..929cc52db6 100644 --- a/source4/rpc_server/config.mk +++ b/source4/rpc_server/config.mk @@ -184,6 +184,20 @@ REQUIRED_SUBSYSTEMS = \ ################################################ ################################################ +# Start MODULE dcerpc_dssetup +[MODULE::dcerpc_dssetup] +INIT_FUNCTION = dcerpc_server_dssetup_init +SUBSYSTEM = DCERPC +INIT_OBJ_FILES = \ + rpc_server/dssetup/dcesrv_dssetup.o +REQUIRED_SUBSYSTEMS = \ + SAMDB \ + DCERPC_COMMON \ + NDR_DSSETUP +# End MODULE dcerpc_dssetup +################################################ + +################################################ # Start SUBSYSTEM DCERPC [SUBSYSTEM::DCERPC] INIT_OBJ_FILES = \ diff --git a/source4/rpc_server/dssetup/dcesrv_dssetup.c b/source4/rpc_server/dssetup/dcesrv_dssetup.c new file mode 100644 index 0000000000..4bc28bc475 --- /dev/null +++ b/source4/rpc_server/dssetup/dcesrv_dssetup.c @@ -0,0 +1,177 @@ +/* + Unix SMB/CIFS implementation. + + endpoint server for the dssetup pipe + + Copyright (C) Andrew Tridgell 2004 + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +*/ + +#include "includes.h" +#include "rpc_server/dcerpc_server.h" +#include "librpc/gen_ndr/ndr_dssetup.h" +#include "rpc_server/common/common.h" + + +/* + ds_RolerGetPrimaryDomainInformation +*/ +static WERROR ds_RolerGetPrimaryDomainInformation(struct dcesrv_call_state *dce_call, + TALLOC_CTX *mem_ctx, + struct ds_RolerGetPrimaryDomainInformation *r) +{ + WERROR err = WERR_OK; + void *sam_ctx; + const char * const attrs[] = { "dnsDomain", "objectGUID", "name", NULL }; + int ret; + struct ldb_message **res; + + sam_ctx = samdb_connect(mem_ctx); + if (sam_ctx == NULL) { + return WERR_SERVER_UNAVAILABLE; + } + + ret = samdb_search(sam_ctx, mem_ctx, NULL, &res, attrs, + "(&(objectClass=domainDNS)(!(objectClass=builtinDomain)))"); + if (ret != 1) { + return WERR_SERVER_UNAVAILABLE; + } + + switch (r->in.level) { + case 1: + r->out.info = talloc_p(mem_ctx, union ds_DomainInformation); + if (r->out.info == NULL) { + return WERR_NOMEM; + } + r->out.info->basic.role = 5; + r->out.info->basic.flags = 0x01000003; + r->out.info->basic.domain = samdb_result_string(res[0], "name", NULL); + r->out.info->basic.dns_domain = samdb_result_string(res[0], "dnsDomain", NULL); + r->out.info->basic.forest = samdb_result_string(res[0], "dnsDomain", NULL); + r->out.info->basic.domain_guid = samdb_result_guid(res[0], "objectGUID"); + break; + + default: + err = WERR_INVALID_PARAM; + break; + } + + return err; +} + + +/* + ds_RolerDnsNameToFlatName +*/ +static WERROR ds_RolerDnsNameToFlatName(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerDnsNameToFlatName *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerDcAsDc +*/ +static WERROR ds_RolerDcAsDc(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerDcAsDc *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerDcAsReplica +*/ +static WERROR ds_RolerDcAsReplica(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerDcAsReplica *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerDemoteDc +*/ +static WERROR ds_RolerDemoteDc(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerDemoteDc *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerGetDcOperationProgress +*/ +static WERROR ds_RolerGetDcOperationProgress(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerGetDcOperationProgress *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerGetDcOperationResults +*/ +static WERROR ds_RolerGetDcOperationResults(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerGetDcOperationResults *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerCancel +*/ +static WERROR ds_RolerCancel(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerCancel *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerServerSaveStateForUpgrade +*/ +static WERROR ds_RolerServerSaveStateForUpgrade(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerServerSaveStateForUpgrade *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerUpgradeDownlevelServer +*/ +static WERROR ds_RolerUpgradeDownlevelServer(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerUpgradeDownlevelServer *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* + ds_RolerAbortDownlevelServerUpgrade +*/ +static WERROR ds_RolerAbortDownlevelServerUpgrade(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, + struct ds_RolerAbortDownlevelServerUpgrade *r) +{ + DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); +} + + +/* include the generated boilerplate */ +#include "librpc/gen_ndr/ndr_dssetup_s.c" |