dcesrv_drsuapi.c

来自「samba最新软件」· C语言 代码 · 共 816 行 · 第 1/2 页

C
816
字号
				r->out.res.res1.status = WERR_OK;				return WERR_OK;			}						/* construct mods */			for (i = 0; i < count; i++) {				samdb_msg_add_string(b_state->sam_ctx, 						     msg, msg, "servicePrincipalName",						     req->spn_names[i].str);			}			for (i=0;i<msg->num_elements;i++) {				switch (req->operation) {				case DRSUAPI_DS_SPN_OPERATION_ADD: 					msg->elements[i].flags = LDB_FLAG_MOD_ADD;					break;				case DRSUAPI_DS_SPN_OPERATION_REPLACE:					msg->elements[i].flags = LDB_FLAG_MOD_REPLACE;					break;				case DRSUAPI_DS_SPN_OPERATION_DELETE:					msg->elements[i].flags = LDB_FLAG_MOD_DELETE;					break;				}			}   			/* Apply to database */			ret = ldb_modify(b_state->sam_ctx, msg);			if (ret != 0) {				DEBUG(0,("Failed to modify SPNs on %s: %s\n",					 ldb_dn_get_linearized(msg->dn), 					 ldb_errstring(b_state->sam_ctx)));				r->out.res.res1.status = WERR_ACCESS_DENIED;			} else {				r->out.res.res1.status = WERR_OK;			}			return WERR_OK;		}	}		return WERR_UNKNOWN_LEVEL;}/*   drsuapi_DsRemoveDSServer*/static WERROR dcesrv_drsuapi_DsRemoveDSServer(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,				       struct drsuapi_DsRemoveDSServer *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   DRSUAPI_REMOVE_DS_DOMAIN */static WERROR dcesrv_DRSUAPI_REMOVE_DS_DOMAIN(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct DRSUAPI_REMOVE_DS_DOMAIN *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/* Obtain the site name from a server DN */const char *result_site_name(struct ldb_dn *site_dn){	/* Format is cn=<NETBIOS name>,cn=Servers,cn=<site>,cn=sites.... */	const struct ldb_val *val = ldb_dn_get_component_val(site_dn, 2);	const char *name = ldb_dn_get_component_name(site_dn, 2);	if (!name || (ldb_attr_cmp(name, "cn") != 0)) {		/* Ensure this matches the format.  This gives us a		 * bit more confidence that a 'cn' value will be a		 * ascii string */		return NULL;	}	if (val) {		return (char *)val->data;	}	return NULL;}/*   drsuapi_DsGetDomainControllerInfo */static WERROR dcesrv_drsuapi_DsGetDomainControllerInfo_1(struct drsuapi_bind_state *b_state, 						TALLOC_CTX *mem_ctx,						struct drsuapi_DsGetDomainControllerInfo *r){	struct ldb_dn *sites_dn;	struct ldb_result *res;	const char *attrs_account_1[] = { "cn", "dnsHostName", NULL };	const char *attrs_account_2[] = { "cn", "dnsHostName", "objectGUID", NULL };	const char *attrs_none[] = { NULL };	const char *attrs_site[] = { "objectGUID", NULL };	const char *attrs_ntds[] = { "options", "objectGUID", NULL };	const char *attrs_1[] = { "serverReference", "cn", "dnsHostName", NULL };	const char *attrs_2[] = { "serverReference", "cn", "dnsHostName", "objectGUID", NULL };	const char **attrs;	struct drsuapi_DsGetDCInfoCtr1 *ctr1;	struct drsuapi_DsGetDCInfoCtr2 *ctr2;	int ret, i;	r->out.level_out = r->in.req.req1.level;	sites_dn = samdb_sites_dn(b_state->sam_ctx, mem_ctx);	if (!sites_dn) {		return WERR_DS_OBJ_NOT_FOUND;	}	switch (r->out.level_out) {	case -1:		/* this level is not like the others */		return WERR_UNKNOWN_LEVEL;	case 1:		attrs = attrs_1;		break;	case 2:		attrs = attrs_2;		break;	default:		return WERR_UNKNOWN_LEVEL;	}	ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res, sites_dn, LDB_SCOPE_SUBTREE, attrs, 				 "objectClass=server");		if (ret) {		DEBUG(1, ("searching for servers in sites DN %s failed: %s\n", 			  ldb_dn_get_linearized(sites_dn), ldb_errstring(b_state->sam_ctx)));		return WERR_GENERAL_FAILURE;	}	switch (r->out.level_out) {	case 1:		ctr1 = &r->out.ctr.ctr1;		ctr1->count = res->count;		ctr1->array = talloc_zero_array(mem_ctx, 						struct drsuapi_DsGetDCInfo1, 						res->count);		for (i=0; i < res->count; i++) {			struct ldb_dn *domain_dn;			struct ldb_result *res_domain;			struct ldb_result *res_account;			struct ldb_dn *ntds_dn = ldb_dn_copy(mem_ctx, res->msgs[i]->dn);						struct ldb_dn *ref_dn				= ldb_msg_find_attr_as_dn(b_state->sam_ctx, 							  mem_ctx, res->msgs[i], 							  "serverReference");			if (!ntds_dn || !ldb_dn_add_child_fmt(ntds_dn, "CN=NTDS Settings")) {				return WERR_NOMEM;			}			ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_account, ref_dn, 						 LDB_SCOPE_BASE, attrs_account_1, "objectClass=computer");			if (ret == LDB_SUCCESS && res_account->count == 1) {				const char *errstr;				ctr1->array[i].dns_name					= ldb_msg_find_attr_as_string(res_account->msgs[0], "dNSHostName", NULL);				ctr1->array[i].netbios_name					= ldb_msg_find_attr_as_string(res_account->msgs[0], "cn", NULL);				ctr1->array[i].computer_dn					= ldb_dn_get_linearized(res_account->msgs[0]->dn);				/* Determine if this is the PDC */				ret = samdb_search_for_parent_domain(b_state->sam_ctx, 								     mem_ctx, res_account->msgs[0]->dn,								     &domain_dn, &errstr);								if (ret == LDB_SUCCESS) {					ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_domain, domain_dn, 								 LDB_SCOPE_BASE, attrs_none, "fSMORoleOwner=%s",								 ldb_dn_get_linearized(ntds_dn));					if (ret) {						return WERR_GENERAL_FAILURE;					}					if (res_domain->count == 1) {						ctr1->array[i].is_pdc = true;					}				}			}			if ((ret != LDB_SUCCESS) && (ret != LDB_ERR_NO_SUCH_OBJECT)) {				DEBUG(5, ("warning: searching for computer DN %s failed: %s\n", 					  ldb_dn_get_linearized(ref_dn), ldb_errstring(b_state->sam_ctx)));			}			/* Look at server DN and extract site component */			ctr1->array[i].site_name = result_site_name(res->msgs[i]->dn);			ctr1->array[i].server_dn = ldb_dn_get_linearized(res->msgs[i]->dn);			ctr1->array[i].is_enabled = true;		}		break;	case 2:		ctr2 = &r->out.ctr.ctr2;		ctr2->count = res->count;		ctr2->array = talloc_zero_array(mem_ctx, 						 struct drsuapi_DsGetDCInfo2, 						 res->count);		for (i=0; i < res->count; i++) {			struct ldb_dn *domain_dn;			struct ldb_result *res_domain;			struct ldb_result *res_account;			struct ldb_dn *ntds_dn = ldb_dn_copy(mem_ctx, res->msgs[i]->dn);			struct ldb_result *res_ntds;			struct ldb_dn *site_dn = ldb_dn_copy(mem_ctx, res->msgs[i]->dn);			struct ldb_result *res_site;			struct ldb_dn *ref_dn				= ldb_msg_find_attr_as_dn(b_state->sam_ctx, 							  mem_ctx, res->msgs[i], 							  "serverReference");			if (!ntds_dn || !ldb_dn_add_child_fmt(ntds_dn, "CN=NTDS Settings")) {				return WERR_NOMEM;			}			/* Format is cn=<NETBIOS name>,cn=Servers,cn=<site>,cn=sites.... */			if (!site_dn || !ldb_dn_remove_child_components(site_dn, 2)) {				return WERR_NOMEM;			}			ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_ntds, ntds_dn, 						 LDB_SCOPE_BASE, attrs_ntds, "objectClass=nTDSDSA");			if (ret == LDB_SUCCESS && res_ntds->count == 1) {				ctr2->array[i].is_gc					= (ldb_msg_find_attr_as_int(res_ntds->msgs[0], "options", 0) == 1);				ctr2->array[i].ntds_guid 					= samdb_result_guid(res_ntds->msgs[0], "objectGUID");				ctr2->array[i].ntds_dn = ldb_dn_get_linearized(res_ntds->msgs[0]->dn);			}			if ((ret != LDB_SUCCESS) && (ret != LDB_ERR_NO_SUCH_OBJECT)) {				DEBUG(5, ("warning: searching for NTDS DN %s failed: %s\n", 					  ldb_dn_get_linearized(ntds_dn), ldb_errstring(b_state->sam_ctx)));			}			ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_site, site_dn, 						 LDB_SCOPE_BASE, attrs_site, "objectClass=site");			if (ret == LDB_SUCCESS && res_site->count == 1) {				ctr2->array[i].site_guid 					= samdb_result_guid(res_site->msgs[0], "objectGUID");				ctr2->array[i].site_dn = ldb_dn_get_linearized(res_site->msgs[0]->dn);			}			if ((ret != LDB_SUCCESS) && (ret != LDB_ERR_NO_SUCH_OBJECT)) {				DEBUG(5, ("warning: searching for site DN %s failed: %s\n", 					  ldb_dn_get_linearized(site_dn), ldb_errstring(b_state->sam_ctx)));			}			ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_account, ref_dn, 						 LDB_SCOPE_BASE, attrs_account_2, "objectClass=computer");			if (ret == LDB_SUCCESS && res_account->count == 1) {				const char *errstr;				ctr2->array[i].dns_name					= ldb_msg_find_attr_as_string(res_account->msgs[0], "dNSHostName", NULL);				ctr2->array[i].netbios_name					= ldb_msg_find_attr_as_string(res_account->msgs[0], "cn", NULL);				ctr2->array[i].computer_dn = ldb_dn_get_linearized(res_account->msgs[0]->dn);				ctr2->array[i].computer_guid 					= samdb_result_guid(res_account->msgs[0], "objectGUID");				/* Determine if this is the PDC */				ret = samdb_search_for_parent_domain(b_state->sam_ctx, 								     mem_ctx, res_account->msgs[0]->dn,								     &domain_dn, &errstr);								if (ret == LDB_SUCCESS) {					ret = ldb_search_exp_fmt(b_state->sam_ctx, mem_ctx, &res_domain, domain_dn, 								 LDB_SCOPE_BASE, attrs_none, "fSMORoleOwner=%s",								 ldb_dn_get_linearized(ntds_dn));					if (ret == LDB_SUCCESS && res_domain->count == 1) {						ctr2->array[i].is_pdc = true;					}					if ((ret != LDB_SUCCESS) && (ret != LDB_ERR_NO_SUCH_OBJECT)) {						DEBUG(5, ("warning: searching for domain DN %s failed: %s\n", 							  ldb_dn_get_linearized(domain_dn), ldb_errstring(b_state->sam_ctx)));					}				}			}			if ((ret != LDB_SUCCESS) && (ret != LDB_ERR_NO_SUCH_OBJECT)) {				DEBUG(5, ("warning: searching for computer account DN %s failed: %s\n", 					  ldb_dn_get_linearized(ref_dn), ldb_errstring(b_state->sam_ctx)));			}			/* Look at server DN and extract site component */			ctr2->array[i].site_name = result_site_name(res->msgs[i]->dn);			ctr2->array[i].server_dn = ldb_dn_get_linearized(res->msgs[i]->dn);			ctr2->array[i].server_guid 				= samdb_result_guid(res->msgs[i], "objectGUID");			ctr2->array[i].is_enabled = true;		}		break;	}	return WERR_OK;}/*   drsuapi_DsGetDomainControllerInfo */static WERROR dcesrv_drsuapi_DsGetDomainControllerInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,						struct drsuapi_DsGetDomainControllerInfo *r){	struct dcesrv_handle *h;	struct drsuapi_bind_state *b_state;		DCESRV_PULL_HANDLE_WERR(h, r->in.bind_handle, DRSUAPI_BIND_HANDLE);	b_state = h->data;	switch (r->in.level) {	case 1:		return dcesrv_drsuapi_DsGetDomainControllerInfo_1(b_state, mem_ctx, r);	}	return WERR_UNKNOWN_LEVEL;}/*   drsuapi_DsAddEntry*/static WERROR dcesrv_drsuapi_DsAddEntry(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct drsuapi_DsAddEntry *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   DRSUAPI_EXECUTE_KCC */static WERROR dcesrv_DRSUAPI_EXECUTE_KCC(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct DRSUAPI_EXECUTE_KCC *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   drsuapi_DsReplicaGetInfo */static WERROR dcesrv_drsuapi_DsReplicaGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct drsuapi_DsReplicaGetInfo *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   DRSUAPI_ADD_SID_HISTORY */static WERROR dcesrv_DRSUAPI_ADD_SID_HISTORY(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct DRSUAPI_ADD_SID_HISTORY *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   drsuapi_DsGetMemberships2 */static WERROR dcesrv_drsuapi_DsGetMemberships2(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct drsuapi_DsGetMemberships2 *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   DRSUAPI_REPLICA_VERIFY_OBJECTS */static WERROR dcesrv_DRSUAPI_REPLICA_VERIFY_OBJECTS(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct DRSUAPI_REPLICA_VERIFY_OBJECTS *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   DRSUAPI_GET_OBJECT_EXISTENCE */static WERROR dcesrv_DRSUAPI_GET_OBJECT_EXISTENCE(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct DRSUAPI_GET_OBJECT_EXISTENCE *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/*   drsuapi_QuerySitesByCost */static WERROR dcesrv_drsuapi_QuerySitesByCost(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,		       struct drsuapi_QuerySitesByCost *r){	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);}/* include the generated boilerplate */#include "librpc/gen_ndr/ndr_drsuapi_s.c"

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?