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 + -
显示快捷键?