2 Unix SMB/CIFS implementation.
4 Winbind rpc backend functions
6 Copyright (C) Tim Potter 2000-2001,2003
7 Copyright (C) Andrew Tridgell 2001
8 Copyright (C) Volker Lendecke 2005
9 Copyright (C) Guenther Deschner 2008 (pidl conversion)
11 This program is free software; you can redistribute it and/or modify
12 it under the terms of the GNU General Public License as published by
13 the Free Software Foundation; either version 3 of the License, or
14 (at your option) any later version.
16 This program is distributed in the hope that it will be useful,
17 but WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 GNU General Public License for more details.
21 You should have received a copy of the GNU General Public License
22 along with this program. If not, see <http://www.gnu.org/licenses/>.
27 #include "winbindd_rpc.h"
29 #include "../librpc/gen_ndr/cli_samr.h"
30 #include "rpc_client/cli_samr.h"
31 #include "../librpc/gen_ndr/cli_lsa.h"
32 #include "rpc_client/cli_lsarpc.h"
33 #include "../libcli/security/security.h"
36 #define DBGC_CLASS DBGC_WINBIND
39 /* Query display info for a domain. This returns enough information plus a
40 bit extra to give an overview of domain users for the User Manager
42 static NTSTATUS msrpc_query_user_list(struct winbindd_domain *domain,
45 struct wbint_userinfo **pinfo)
47 struct rpc_pipe_client *samr_pipe = NULL;
48 struct policy_handle dom_pol;
49 struct wbint_userinfo *info = NULL;
50 uint32_t num_info = 0;
54 DEBUG(3, ("msrpc_query_user_list\n"));
60 tmp_ctx = talloc_stackframe();
61 if (tmp_ctx == NULL) {
62 return NT_STATUS_NO_MEMORY;
65 if ( !winbindd_can_contact_domain( domain ) ) {
66 DEBUG(10,("query_user_list: No incoming trust for domain %s\n",
68 status = NT_STATUS_OK;
72 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
73 if (!NT_STATUS_IS_OK(status)) {
77 status = rpc_query_user_list(tmp_ctx,
83 if (!NT_STATUS_IS_OK(status)) {
88 *pnum_info = num_info;
92 *pinfo = talloc_move(mem_ctx, &info);
100 /* list all domain groups */
101 static NTSTATUS msrpc_enum_dom_groups(struct winbindd_domain *domain,
104 struct acct_info **pinfo)
106 struct rpc_pipe_client *samr_pipe;
107 struct policy_handle dom_pol;
108 struct acct_info *info = NULL;
109 uint32_t num_info = 0;
113 DEBUG(3,("msrpc_enum_dom_groups\n"));
119 tmp_ctx = talloc_stackframe();
120 if (tmp_ctx == NULL) {
121 return NT_STATUS_NO_MEMORY;
124 if ( !winbindd_can_contact_domain( domain ) ) {
125 DEBUG(10,("enum_domain_groups: No incoming trust for domain %s\n",
127 status = NT_STATUS_OK;
131 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
132 if (!NT_STATUS_IS_OK(status)) {
136 status = rpc_enum_dom_groups(tmp_ctx,
141 if (!NT_STATUS_IS_OK(status)) {
146 *pnum_info = num_info;
150 *pinfo = talloc_move(mem_ctx, &info);
154 TALLOC_FREE(tmp_ctx);
158 /* List all domain groups */
160 static NTSTATUS msrpc_enum_local_groups(struct winbindd_domain *domain,
163 struct acct_info **pinfo)
165 struct rpc_pipe_client *samr_pipe;
166 struct policy_handle dom_pol;
167 struct acct_info *info = NULL;
168 uint32_t num_info = 0;
172 DEBUG(3,("msrpc_enum_local_groups\n"));
178 tmp_ctx = talloc_stackframe();
179 if (tmp_ctx == NULL) {
180 return NT_STATUS_NO_MEMORY;
183 if ( !winbindd_can_contact_domain( domain ) ) {
184 DEBUG(10,("enum_local_groups: No incoming trust for domain %s\n",
186 status = NT_STATUS_OK;
190 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
191 if (!NT_STATUS_IS_OK(status)) {
195 status = rpc_enum_local_groups(mem_ctx,
200 if (!NT_STATUS_IS_OK(status)) {
205 *pnum_info = num_info;
209 *pinfo = talloc_move(mem_ctx, &info);
213 TALLOC_FREE(tmp_ctx);
217 /* convert a single name to a sid in a domain */
218 static NTSTATUS msrpc_name_to_sid(struct winbindd_domain *domain,
220 const char *domain_name,
224 enum lsa_SidType *type)
227 struct dom_sid *sids = NULL;
228 enum lsa_SidType *types = NULL;
229 char *full_name = NULL;
230 NTSTATUS name_map_status = NT_STATUS_UNSUCCESSFUL;
231 char *mapped_name = NULL;
233 if (name == NULL || *name=='\0') {
234 full_name = talloc_asprintf(mem_ctx, "%s", domain_name);
235 } else if (domain_name == NULL || *domain_name == '\0') {
236 full_name = talloc_asprintf(mem_ctx, "%s", name);
238 full_name = talloc_asprintf(mem_ctx, "%s\\%s", domain_name, name);
241 DEBUG(0, ("talloc_asprintf failed!\n"));
242 return NT_STATUS_NO_MEMORY;
245 DEBUG(3, ("msrpc_name_to_sid: name=%s\n", full_name));
247 name_map_status = normalize_name_unmap(mem_ctx, full_name,
250 /* Reset the full_name pointer if we mapped anytthing */
252 if (NT_STATUS_IS_OK(name_map_status) ||
253 NT_STATUS_EQUAL(name_map_status, NT_STATUS_FILE_RENAMED))
255 full_name = mapped_name;
258 DEBUG(3,("name_to_sid [rpc] %s for domain %s\n",
259 full_name?full_name:"", domain_name ));
261 result = winbindd_lookup_names(mem_ctx, domain, 1,
262 (const char **)&full_name, NULL,
264 if (!NT_STATUS_IS_OK(result))
267 /* Return rid and type if lookup successful */
269 sid_copy(sid, &sids[0]);
276 convert a domain SID to a user or group name
278 static NTSTATUS msrpc_sid_to_name(struct winbindd_domain *domain,
280 const struct dom_sid *sid,
283 enum lsa_SidType *type)
287 enum lsa_SidType *types = NULL;
289 NTSTATUS name_map_status = NT_STATUS_UNSUCCESSFUL;
290 char *mapped_name = NULL;
292 DEBUG(3, ("msrpc_sid_to_name: %s for domain %s\n", sid_string_dbg(sid),
295 result = winbindd_lookup_sids(mem_ctx,
302 if (!NT_STATUS_IS_OK(result)) {
303 DEBUG(2,("msrpc_sid_to_name: failed to lookup sids: %s\n",
309 *type = (enum lsa_SidType)types[0];
310 *domain_name = domains[0];
313 DEBUG(5,("Mapped sid to [%s]\\[%s]\n", domains[0], *name));
315 name_map_status = normalize_name_map(mem_ctx, domain, *name,
317 if (NT_STATUS_IS_OK(name_map_status) ||
318 NT_STATUS_EQUAL(name_map_status, NT_STATUS_FILE_RENAMED))
321 DEBUG(5,("returning mapped name -- %s\n", *name));
327 static NTSTATUS msrpc_rids_to_names(struct winbindd_domain *domain,
329 const struct dom_sid *sid,
334 enum lsa_SidType **types)
338 struct dom_sid *sids;
342 DEBUG(3, ("msrpc_rids_to_names: domain %s\n", domain->name ));
345 sids = TALLOC_ARRAY(mem_ctx, struct dom_sid, num_rids);
347 return NT_STATUS_NO_MEMORY;
353 for (i=0; i<num_rids; i++) {
354 if (!sid_compose(&sids[i], sid, rids[i])) {
355 return NT_STATUS_INTERNAL_ERROR;
359 result = winbindd_lookup_sids(mem_ctx,
367 if (!NT_STATUS_IS_OK(result) &&
368 !NT_STATUS_EQUAL(result, STATUS_SOME_UNMAPPED)) {
373 for (i=0; i<num_rids; i++) {
374 NTSTATUS name_map_status = NT_STATUS_UNSUCCESSFUL;
375 char *mapped_name = NULL;
377 if ((*types)[i] != SID_NAME_UNKNOWN) {
378 name_map_status = normalize_name_map(mem_ctx,
382 if (NT_STATUS_IS_OK(name_map_status) ||
383 NT_STATUS_EQUAL(name_map_status, NT_STATUS_FILE_RENAMED))
385 ret_names[i] = mapped_name;
388 *domain_name = domains[i];
395 /* Lookup user information from a rid or username. */
396 static NTSTATUS msrpc_query_user(struct winbindd_domain *domain,
398 const struct dom_sid *user_sid,
399 struct wbint_userinfo *user_info)
401 struct rpc_pipe_client *samr_pipe;
402 struct policy_handle dom_pol;
403 struct netr_SamInfo3 *user;
407 DEBUG(3,("msrpc_query_user sid=%s\n", sid_string_dbg(user_sid)));
409 tmp_ctx = talloc_stackframe();
410 if (tmp_ctx == NULL) {
411 return NT_STATUS_NO_MEMORY;
415 user_info->homedir = NULL;
416 user_info->shell = NULL;
417 user_info->primary_gid = (gid_t)-1;
420 /* try netsamlogon cache first */
421 user = netsamlogon_cache_get(tmp_ctx, user_sid);
423 DEBUG(5,("msrpc_query_user: Cache lookup succeeded for %s\n",
424 sid_string_dbg(user_sid)));
426 sid_compose(&user_info->user_sid, &domain->sid, user->base.rid);
427 sid_compose(&user_info->group_sid, &domain->sid,
428 user->base.primary_gid);
430 user_info->acct_name = talloc_strdup(user_info,
431 user->base.account_name.string);
432 user_info->full_name = talloc_strdup(user_info,
433 user->base.full_name.string);
435 status = NT_STATUS_OK;
439 if ( !winbindd_can_contact_domain( domain ) ) {
440 DEBUG(10,("query_user: No incoming trust for domain %s\n",
442 /* Tell the cache manager not to remember this one */
443 status = NT_STATUS_SYNCHRONIZATION_REQUIRED;
447 /* no cache; hit the wire */
448 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
449 if (!NT_STATUS_IS_OK(status)) {
453 status = rpc_query_user(tmp_ctx,
461 TALLOC_FREE(tmp_ctx);
465 /* Lookup groups a user is a member of. I wish Unix had a call like this! */
466 static NTSTATUS msrpc_lookup_usergroups(struct winbindd_domain *domain,
468 const struct dom_sid *user_sid,
469 uint32_t *pnum_groups,
470 struct dom_sid **puser_grpsids)
472 struct rpc_pipe_client *samr_pipe;
473 struct policy_handle dom_pol;
474 struct dom_sid *user_grpsids = NULL;
475 uint32_t num_groups = 0;
479 DEBUG(3,("msrpc_lookup_usergroups sid=%s\n", sid_string_dbg(user_sid)));
483 tmp_ctx = talloc_stackframe();
484 if (tmp_ctx == NULL) {
485 return NT_STATUS_NO_MEMORY;
488 /* Check if we have a cached user_info_3 */
489 status = lookup_usergroups_cached(domain,
494 if (NT_STATUS_IS_OK(status)) {
498 if ( !winbindd_can_contact_domain( domain ) ) {
499 DEBUG(10,("lookup_usergroups: No incoming trust for domain %s\n",
502 /* Tell the cache manager not to remember this one */
503 status = NT_STATUS_SYNCHRONIZATION_REQUIRED;
507 /* no cache; hit the wire */
508 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
509 if (!NT_STATUS_IS_OK(status)) {
513 status = rpc_lookup_usergroups(tmp_ctx,
520 if (!NT_STATUS_IS_OK(status)) {
526 *pnum_groups = num_groups;
530 *puser_grpsids = talloc_move(mem_ctx, &user_grpsids);
534 TALLOC_FREE(tmp_ctx);
539 #define MAX_SAM_ENTRIES_W2K 0x400 /* 1024 */
541 static NTSTATUS msrpc_lookup_useraliases(struct winbindd_domain *domain,
543 uint32 num_sids, const struct dom_sid *sids,
544 uint32 *pnum_aliases,
545 uint32 **palias_rids)
547 struct rpc_pipe_client *samr_pipe;
548 struct policy_handle dom_pol;
549 uint32_t num_aliases = 0;
550 uint32_t *alias_rids = NULL;
554 DEBUG(3,("msrpc_lookup_useraliases\n"));
560 tmp_ctx = talloc_stackframe();
561 if (tmp_ctx == NULL) {
562 return NT_STATUS_NO_MEMORY;
565 if (!winbindd_can_contact_domain(domain)) {
566 DEBUG(10,("msrpc_lookup_useraliases: No incoming trust for domain %s\n",
568 /* Tell the cache manager not to remember this one */
569 status = NT_STATUS_SYNCHRONIZATION_REQUIRED;
573 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
574 if (!NT_STATUS_IS_OK(status)) {
578 status = rpc_lookup_useraliases(tmp_ctx,
585 if (!NT_STATUS_IS_OK(status)) {
590 *pnum_aliases = num_aliases;
594 *palias_rids = talloc_move(mem_ctx, &alias_rids);
598 TALLOC_FREE(tmp_ctx);
603 /* Lookup group membership given a rid. */
604 static NTSTATUS msrpc_lookup_groupmem(struct winbindd_domain *domain,
606 const struct dom_sid *group_sid,
607 enum lsa_SidType type,
609 struct dom_sid **sid_mem,
611 uint32_t **name_types)
613 NTSTATUS result = NT_STATUS_UNSUCCESSFUL;
614 uint32 i, total_names = 0;
615 struct policy_handle dom_pol, group_pol;
616 uint32 des_access = SEC_FLAG_MAXIMUM_ALLOWED;
617 uint32 *rid_mem = NULL;
620 struct rpc_pipe_client *cli;
621 unsigned int orig_timeout;
622 struct samr_RidAttrArray *rids = NULL;
624 DEBUG(3,("msrpc_lookup_groupmem: %s sid=%s\n", domain->name,
625 sid_string_dbg(group_sid)));
627 if ( !winbindd_can_contact_domain( domain ) ) {
628 DEBUG(10,("lookup_groupmem: No incoming trust for domain %s\n",
633 if (!sid_peek_check_rid(&domain->sid, group_sid, &group_rid))
634 return NT_STATUS_UNSUCCESSFUL;
638 result = cm_connect_sam(domain, mem_ctx, &cli, &dom_pol);
639 if (!NT_STATUS_IS_OK(result))
642 result = rpccli_samr_OpenGroup(cli, mem_ctx,
648 if (!NT_STATUS_IS_OK(result))
651 /* Step #1: Get a list of user rids that are the members of the
654 /* This call can take a long time - allow the server to time out.
655 35 seconds should do it. */
657 orig_timeout = rpccli_set_timeout(cli, 35000);
659 result = rpccli_samr_QueryGroupMember(cli, mem_ctx,
663 /* And restore our original timeout. */
664 rpccli_set_timeout(cli, orig_timeout);
666 rpccli_samr_Close(cli, mem_ctx, &group_pol);
668 if (!NT_STATUS_IS_OK(result))
671 if (!rids || !rids->count) {
678 *num_names = rids->count;
679 rid_mem = rids->rids;
681 /* Step #2: Convert list of rids into list of usernames. Do this
682 in bunches of ~1000 to avoid crashing NT4. It looks like there
683 is a buffer overflow or something like that lurking around
686 #define MAX_LOOKUP_RIDS 900
688 *names = TALLOC_ZERO_ARRAY(mem_ctx, char *, *num_names);
689 *name_types = TALLOC_ZERO_ARRAY(mem_ctx, uint32, *num_names);
690 *sid_mem = TALLOC_ZERO_ARRAY(mem_ctx, struct dom_sid, *num_names);
692 for (j=0;j<(*num_names);j++)
693 sid_compose(&(*sid_mem)[j], &domain->sid, rid_mem[j]);
695 if (*num_names>0 && (!*names || !*name_types))
696 return NT_STATUS_NO_MEMORY;
698 for (i = 0; i < *num_names; i += MAX_LOOKUP_RIDS) {
699 int num_lookup_rids = MIN(*num_names - i, MAX_LOOKUP_RIDS);
700 struct lsa_Strings tmp_names;
701 struct samr_Ids tmp_types;
703 /* Lookup a chunk of rids */
705 result = rpccli_samr_LookupRids(cli, mem_ctx,
712 /* see if we have a real error (and yes the
713 STATUS_SOME_UNMAPPED is the one returned from 2k) */
715 if (!NT_STATUS_IS_OK(result) &&
716 !NT_STATUS_EQUAL(result, STATUS_SOME_UNMAPPED))
719 /* Copy result into array. The talloc system will take
720 care of freeing the temporary arrays later on. */
722 if (tmp_names.count != tmp_types.count) {
723 return NT_STATUS_UNSUCCESSFUL;
726 for (r=0; r<tmp_names.count; r++) {
727 if (tmp_types.ids[r] == SID_NAME_UNKNOWN) {
730 (*names)[total_names] = fill_domain_username_talloc(
731 mem_ctx, domain->name,
732 tmp_names.names[r].string, true);
733 (*name_types)[total_names] = tmp_types.ids[r];
738 *num_names = total_names;
747 static int get_ldap_seq(const char *server, int port, uint32 *seq)
751 const char *attrs[] = {"highestCommittedUSN", NULL};
752 LDAPMessage *res = NULL;
753 char **values = NULL;
756 *seq = DOM_SEQUENCE_NONE;
759 * Parameterised (5) second timeout on open. This is needed as the
760 * search timeout doesn't seem to apply to doing an open as well. JRA.
763 ldp = ldap_open_with_timeout(server, port, lp_ldap_timeout());
767 /* Timeout if no response within 20 seconds. */
771 if (ldap_search_st(ldp, "", LDAP_SCOPE_BASE, "(objectclass=*)",
772 CONST_DISCARD(char **, attrs), 0, &to, &res))
775 if (ldap_count_entries(ldp, res) != 1)
778 values = ldap_get_values(ldp, res, "highestCommittedUSN");
779 if (!values || !values[0])
782 *seq = atoi(values[0]);
788 ldap_value_free(values);
796 /**********************************************************************
797 Get the sequence number for a Windows AD native mode domain using
799 **********************************************************************/
801 static int get_ldap_sequence_number(struct winbindd_domain *domain, uint32 *seq)
804 char addr[INET6_ADDRSTRLEN];
806 print_sockaddr(addr, sizeof(addr), &domain->dcaddr);
807 if ((ret = get_ldap_seq(addr, LDAP_PORT, seq)) == 0) {
808 DEBUG(3, ("get_ldap_sequence_number: Retrieved sequence "
809 "number for Domain (%s) from DC (%s)\n",
810 domain->name, addr));
815 #endif /* HAVE_LDAP */
817 /* find the sequence number for a domain */
818 static NTSTATUS msrpc_sequence_number(struct winbindd_domain *domain,
821 struct rpc_pipe_client *samr_pipe;
822 struct policy_handle dom_pol;
827 DEBUG(3, ("msrpc_sequence_number: fetch sequence_number for %s\n", domain->name));
830 *pseq = DOM_SEQUENCE_NONE;
833 tmp_ctx = talloc_stackframe();
834 if (tmp_ctx == NULL) {
835 return NT_STATUS_NO_MEMORY;
838 if ( !winbindd_can_contact_domain( domain ) ) {
839 DEBUG(10,("sequence_number: No incoming trust for domain %s\n",
844 status = NT_STATUS_OK;
849 if (domain->active_directory) {
852 DEBUG(8,("using get_ldap_seq() to retrieve the "
853 "sequence number\n"));
855 rc = get_ldap_sequence_number(domain, &seq);
857 DEBUG(10,("domain_sequence_number: LDAP for "
865 status = NT_STATUS_OK;
869 DEBUG(10,("domain_sequence_number: failed to get LDAP "
870 "sequence number for domain %s\n",
873 #endif /* HAVE_LDAP */
875 status = cm_connect_sam(domain, tmp_ctx, &samr_pipe, &dom_pol);
876 if (!NT_STATUS_IS_OK(status)) {
880 status = rpc_sequence_number(tmp_ctx,
885 if (!NT_STATUS_IS_OK(status)) {
894 TALLOC_FREE(tmp_ctx);
898 /* get a list of trusted domains */
899 static NTSTATUS msrpc_trusted_domains(struct winbindd_domain *domain,
901 struct netr_DomainTrustList *ptrust_list)
903 struct rpc_pipe_client *lsa_pipe;
904 struct policy_handle lsa_policy;
905 struct netr_DomainTrust *trusts = NULL;
906 uint32_t num_trusts = 0;
910 DEBUG(3,("msrpc_trusted_domains\n"));
913 ZERO_STRUCTP(ptrust_list);
916 tmp_ctx = talloc_stackframe();
917 if (tmp_ctx == NULL) {
918 return NT_STATUS_NO_MEMORY;
921 status = cm_connect_lsa(domain, tmp_ctx, &lsa_pipe, &lsa_policy);
922 if (!NT_STATUS_IS_OK(status))
925 status = rpc_trusted_domains(tmp_ctx,
930 if (!NT_STATUS_IS_OK(status)) {
935 ptrust_list->count = num_trusts;
936 ptrust_list->array = talloc_move(mem_ctx, &trusts);
940 TALLOC_FREE(tmp_ctx);
944 /* find the lockout policy for a domain */
945 static NTSTATUS msrpc_lockout_policy(struct winbindd_domain *domain,
947 struct samr_DomInfo12 *lockout_policy)
950 struct rpc_pipe_client *cli;
951 struct policy_handle dom_pol;
952 union samr_DomainInfo *info = NULL;
954 DEBUG(3, ("msrpc_lockout_policy: fetch lockout policy for %s\n", domain->name));
956 if ( !winbindd_can_contact_domain( domain ) ) {
957 DEBUG(10,("msrpc_lockout_policy: No incoming trust for domain %s\n",
959 return NT_STATUS_NOT_SUPPORTED;
962 result = cm_connect_sam(domain, mem_ctx, &cli, &dom_pol);
963 if (!NT_STATUS_IS_OK(result)) {
967 result = rpccli_samr_QueryDomainInfo(cli, mem_ctx,
971 if (!NT_STATUS_IS_OK(result)) {
975 *lockout_policy = info->info12;
977 DEBUG(10,("msrpc_lockout_policy: lockout_threshold %d\n",
978 info->info12.lockout_threshold));
985 /* find the password policy for a domain */
986 static NTSTATUS msrpc_password_policy(struct winbindd_domain *domain,
988 struct samr_DomInfo1 *password_policy)
991 struct rpc_pipe_client *cli;
992 struct policy_handle dom_pol;
993 union samr_DomainInfo *info = NULL;
995 DEBUG(3, ("msrpc_password_policy: fetch password policy for %s\n",
998 if ( !winbindd_can_contact_domain( domain ) ) {
999 DEBUG(10,("msrpc_password_policy: No incoming trust for domain %s\n",
1001 return NT_STATUS_NOT_SUPPORTED;
1004 result = cm_connect_sam(domain, mem_ctx, &cli, &dom_pol);
1005 if (!NT_STATUS_IS_OK(result)) {
1009 result = rpccli_samr_QueryDomainInfo(cli, mem_ctx,
1013 if (!NT_STATUS_IS_OK(result)) {
1017 *password_policy = info->info1;
1019 DEBUG(10,("msrpc_password_policy: min_length_password %d\n",
1020 info->info1.min_password_length));
1027 typedef NTSTATUS (*lookup_sids_fn_t)(struct rpc_pipe_client *cli,
1028 TALLOC_CTX *mem_ctx,
1029 struct policy_handle *pol,
1031 const struct dom_sid *sids,
1034 enum lsa_SidType **ptypes);
1036 NTSTATUS winbindd_lookup_sids(TALLOC_CTX *mem_ctx,
1037 struct winbindd_domain *domain,
1039 const struct dom_sid *sids,
1042 enum lsa_SidType **types)
1045 struct rpc_pipe_client *cli = NULL;
1046 struct policy_handle lsa_policy;
1047 unsigned int orig_timeout;
1048 lookup_sids_fn_t lookup_sids_fn = rpccli_lsa_lookup_sids;
1050 if (domain->can_do_ncacn_ip_tcp) {
1051 status = cm_connect_lsa_tcp(domain, mem_ctx, &cli);
1052 if (NT_STATUS_IS_OK(status)) {
1053 lookup_sids_fn = rpccli_lsa_lookup_sids3;
1056 domain->can_do_ncacn_ip_tcp = false;
1058 status = cm_connect_lsa(domain, mem_ctx, &cli, &lsa_policy);
1060 if (!NT_STATUS_IS_OK(status)) {
1066 * This call can take a long time
1067 * allow the server to time out.
1068 * 35 seconds should do it.
1070 orig_timeout = rpccli_set_timeout(cli, 35000);
1072 status = lookup_sids_fn(cli,
1081 /* And restore our original timeout. */
1082 rpccli_set_timeout(cli, orig_timeout);
1087 typedef NTSTATUS (*lookup_names_fn_t)(struct rpc_pipe_client *cli,
1088 TALLOC_CTX *mem_ctx,
1089 struct policy_handle *pol,
1092 const char ***dom_names,
1094 struct dom_sid **sids,
1095 enum lsa_SidType **types);
1097 NTSTATUS winbindd_lookup_names(TALLOC_CTX *mem_ctx,
1098 struct winbindd_domain *domain,
1101 const char ***domains,
1102 struct dom_sid **sids,
1103 enum lsa_SidType **types)
1106 struct rpc_pipe_client *cli = NULL;
1107 struct policy_handle lsa_policy;
1108 unsigned int orig_timeout = 0;
1109 lookup_names_fn_t lookup_names_fn = rpccli_lsa_lookup_names;
1111 if (domain->can_do_ncacn_ip_tcp) {
1112 status = cm_connect_lsa_tcp(domain, mem_ctx, &cli);
1113 if (NT_STATUS_IS_OK(status)) {
1114 lookup_names_fn = rpccli_lsa_lookup_names4;
1117 domain->can_do_ncacn_ip_tcp = false;
1119 status = cm_connect_lsa(domain, mem_ctx, &cli, &lsa_policy);
1121 if (!NT_STATUS_IS_OK(status)) {
1128 * This call can take a long time
1129 * allow the server to time out.
1130 * 35 seconds should do it.
1132 orig_timeout = rpccli_set_timeout(cli, 35000);
1134 status = lookup_names_fn(cli,
1138 (const char **) names,
1144 /* And restore our original timeout. */
1145 rpccli_set_timeout(cli, orig_timeout);
1147 if (!NT_STATUS_IS_OK(status)) {
1154 /* the rpc backend methods are exposed via this structure */
1155 struct winbindd_methods msrpc_methods = {
1157 msrpc_query_user_list,
1158 msrpc_enum_dom_groups,
1159 msrpc_enum_local_groups,
1162 msrpc_rids_to_names,
1164 msrpc_lookup_usergroups,
1165 msrpc_lookup_useraliases,
1166 msrpc_lookup_groupmem,
1167 msrpc_sequence_number,
1168 msrpc_lockout_policy,
1169 msrpc_password_policy,
1170 msrpc_trusted_domains,