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/ndr_samr_c.h"
30 #include "rpc_client/cli_pipe.h"
31 #include "rpc_client/cli_samr.h"
32 #include "rpc_client/cli_lsarpc.h"
33 #include "../libcli/security/security.h"
34 #include "libsmb/samlogon_cache.h"
37 #define DBGC_CLASS DBGC_WINBIND
39 static NTSTATUS
winbindd_lookup_names(TALLOC_CTX
*mem_ctx
,
40 struct winbindd_domain
*domain
,
43 const char ***domains
,
44 struct dom_sid
**sids
,
45 enum lsa_SidType
**types
);
47 /* Query display info for a domain. This returns enough information plus a
48 bit extra to give an overview of domain users for the User Manager
50 static NTSTATUS
msrpc_query_user_list(struct winbindd_domain
*domain
,
54 struct rpc_pipe_client
*samr_pipe
= NULL
;
55 struct policy_handle dom_pol
;
60 DEBUG(3, ("msrpc_query_user_list\n"));
62 tmp_ctx
= talloc_stackframe();
63 if (tmp_ctx
== NULL
) {
64 return NT_STATUS_NO_MEMORY
;
67 if ( !winbindd_can_contact_domain( domain
) ) {
68 DEBUG(10,("query_user_list: No incoming trust for domain %s\n",
70 status
= NT_STATUS_OK
;
74 status
= cm_connect_sam(domain
, tmp_ctx
, false, &samr_pipe
, &dom_pol
);
75 if (!NT_STATUS_IS_OK(status
)) {
79 status
= rpc_query_user_list(tmp_ctx
,
84 if (!NT_STATUS_IS_OK(status
)) {
89 *prids
= talloc_move(mem_ctx
, &rids
);
98 /* list all domain groups */
99 static NTSTATUS
msrpc_enum_dom_groups(struct winbindd_domain
*domain
,
102 struct wb_acct_info
**pinfo
)
104 struct rpc_pipe_client
*samr_pipe
;
105 struct policy_handle dom_pol
;
106 struct wb_acct_info
*info
= NULL
;
107 uint32_t num_info
= 0;
111 DEBUG(3,("msrpc_enum_dom_groups\n"));
117 tmp_ctx
= talloc_stackframe();
118 if (tmp_ctx
== NULL
) {
119 return NT_STATUS_NO_MEMORY
;
122 if ( !winbindd_can_contact_domain( domain
) ) {
123 DEBUG(10,("enum_domain_groups: No incoming trust for domain %s\n",
125 status
= NT_STATUS_OK
;
129 status
= cm_connect_sam(domain
, tmp_ctx
, false, &samr_pipe
, &dom_pol
);
130 if (!NT_STATUS_IS_OK(status
)) {
134 status
= rpc_enum_dom_groups(tmp_ctx
,
139 if (!NT_STATUS_IS_OK(status
)) {
144 *pnum_info
= num_info
;
148 *pinfo
= talloc_move(mem_ctx
, &info
);
152 TALLOC_FREE(tmp_ctx
);
156 /* List all domain groups */
158 static NTSTATUS
msrpc_enum_local_groups(struct winbindd_domain
*domain
,
161 struct wb_acct_info
**pinfo
)
163 struct rpc_pipe_client
*samr_pipe
;
164 struct policy_handle dom_pol
;
165 struct wb_acct_info
*info
= NULL
;
166 uint32_t num_info
= 0;
170 DEBUG(3,("msrpc_enum_local_groups\n"));
176 tmp_ctx
= talloc_stackframe();
177 if (tmp_ctx
== NULL
) {
178 return NT_STATUS_NO_MEMORY
;
181 if ( !winbindd_can_contact_domain( domain
) ) {
182 DEBUG(10,("enum_local_groups: No incoming trust for domain %s\n",
184 status
= NT_STATUS_OK
;
188 status
= cm_connect_sam(domain
, tmp_ctx
, false, &samr_pipe
, &dom_pol
);
189 if (!NT_STATUS_IS_OK(status
)) {
193 status
= rpc_enum_local_groups(mem_ctx
,
198 if (!NT_STATUS_IS_OK(status
)) {
203 *pnum_info
= num_info
;
207 *pinfo
= talloc_move(mem_ctx
, &info
);
211 TALLOC_FREE(tmp_ctx
);
215 /* convert a single name to a sid in a domain */
216 static NTSTATUS
msrpc_name_to_sid(struct winbindd_domain
*domain
,
218 const char *domain_name
,
222 enum lsa_SidType
*type
)
225 struct dom_sid
*sids
= NULL
;
226 enum lsa_SidType
*types
= NULL
;
227 char *full_name
= NULL
;
228 const char *names
[1];
229 NTSTATUS name_map_status
= NT_STATUS_UNSUCCESSFUL
;
230 char *mapped_name
= NULL
;
232 if (name
== NULL
|| *name
=='\0') {
233 full_name
= talloc_asprintf(mem_ctx
, "%s", domain_name
);
234 } else if (domain_name
== NULL
|| *domain_name
== '\0') {
235 full_name
= talloc_asprintf(mem_ctx
, "%s", name
);
237 full_name
= talloc_asprintf(mem_ctx
, "%s\\%s", domain_name
, name
);
240 DEBUG(0, ("talloc_asprintf failed!\n"));
241 return NT_STATUS_NO_MEMORY
;
244 DEBUG(3, ("msrpc_name_to_sid: name=%s\n", full_name
));
246 name_map_status
= normalize_name_unmap(mem_ctx
, full_name
,
249 /* Reset the full_name pointer if we mapped anything */
251 if (NT_STATUS_IS_OK(name_map_status
) ||
252 NT_STATUS_EQUAL(name_map_status
, NT_STATUS_FILE_RENAMED
))
254 full_name
= mapped_name
;
257 DEBUG(3,("name_to_sid [rpc] %s for domain %s\n",
258 full_name
?full_name
:"", domain_name
));
260 names
[0] = full_name
;
262 result
= winbindd_lookup_names(mem_ctx
, domain
, 1,
265 if (!NT_STATUS_IS_OK(result
))
268 /* Return rid and type if lookup successful */
270 sid_copy(sid
, &sids
[0]);
277 convert a domain SID to a user or group name
279 static NTSTATUS
msrpc_sid_to_name(struct winbindd_domain
*domain
,
281 const struct dom_sid
*sid
,
284 enum lsa_SidType
*type
)
288 enum lsa_SidType
*types
= NULL
;
290 NTSTATUS name_map_status
= NT_STATUS_UNSUCCESSFUL
;
291 char *mapped_name
= NULL
;
293 DEBUG(3, ("msrpc_sid_to_name: %s for domain %s\n", sid_string_dbg(sid
),
296 result
= winbindd_lookup_sids(mem_ctx
,
303 if (!NT_STATUS_IS_OK(result
)) {
304 DEBUG(2,("msrpc_sid_to_name: failed to lookup sids: %s\n",
310 *type
= (enum lsa_SidType
)types
[0];
311 *domain_name
= domains
[0];
314 DEBUG(5,("Mapped sid to [%s]\\[%s]\n", domains
[0], *name
));
316 name_map_status
= normalize_name_map(mem_ctx
, domain
, *name
,
318 if (NT_STATUS_IS_OK(name_map_status
) ||
319 NT_STATUS_EQUAL(name_map_status
, NT_STATUS_FILE_RENAMED
))
322 DEBUG(5,("returning mapped name -- %s\n", *name
));
328 static NTSTATUS
msrpc_rids_to_names(struct winbindd_domain
*domain
,
330 const struct dom_sid
*sid
,
335 enum lsa_SidType
**types
)
339 struct dom_sid
*sids
;
343 DEBUG(3, ("msrpc_rids_to_names: domain %s\n", domain
->name
));
346 sids
= talloc_array(mem_ctx
, struct dom_sid
, num_rids
);
348 return NT_STATUS_NO_MEMORY
;
354 for (i
=0; i
<num_rids
; i
++) {
355 if (!sid_compose(&sids
[i
], sid
, rids
[i
])) {
356 return NT_STATUS_INTERNAL_ERROR
;
360 result
= winbindd_lookup_sids(mem_ctx
,
368 if (!NT_STATUS_IS_OK(result
) &&
369 !NT_STATUS_EQUAL(result
, STATUS_SOME_UNMAPPED
)) {
374 for (i
=0; i
<num_rids
; i
++) {
375 NTSTATUS name_map_status
= NT_STATUS_UNSUCCESSFUL
;
376 char *mapped_name
= NULL
;
378 if ((*types
)[i
] != SID_NAME_UNKNOWN
) {
379 name_map_status
= normalize_name_map(mem_ctx
,
383 if (NT_STATUS_IS_OK(name_map_status
) ||
384 NT_STATUS_EQUAL(name_map_status
, NT_STATUS_FILE_RENAMED
))
386 ret_names
[i
] = mapped_name
;
389 *domain_name
= domains
[i
];
396 #define MAX_SAM_ENTRIES_W2K 0x400 /* 1024 */
398 static NTSTATUS
msrpc_lookup_useraliases(struct winbindd_domain
*domain
,
400 uint32_t num_sids
, const struct dom_sid
*sids
,
401 uint32_t *pnum_aliases
,
402 uint32_t **palias_rids
)
404 struct rpc_pipe_client
*samr_pipe
;
405 struct policy_handle dom_pol
;
406 uint32_t num_aliases
= 0;
407 uint32_t *alias_rids
= NULL
;
411 DEBUG(3,("msrpc_lookup_useraliases\n"));
417 tmp_ctx
= talloc_stackframe();
418 if (tmp_ctx
== NULL
) {
419 return NT_STATUS_NO_MEMORY
;
422 if (!winbindd_can_contact_domain(domain
)) {
423 DEBUG(10,("msrpc_lookup_useraliases: No incoming trust for domain %s\n",
425 /* Tell the cache manager not to remember this one */
426 status
= NT_STATUS_SYNCHRONIZATION_REQUIRED
;
430 status
= cm_connect_sam(domain
, tmp_ctx
, false, &samr_pipe
, &dom_pol
);
431 if (!NT_STATUS_IS_OK(status
)) {
435 status
= rpc_lookup_useraliases(tmp_ctx
,
442 if (!NT_STATUS_IS_OK(status
)) {
447 *pnum_aliases
= num_aliases
;
451 *palias_rids
= talloc_move(mem_ctx
, &alias_rids
);
455 TALLOC_FREE(tmp_ctx
);
460 /* Lookup group membership given a rid. */
461 static NTSTATUS
msrpc_lookup_groupmem(struct winbindd_domain
*domain
,
463 const struct dom_sid
*group_sid
,
464 enum lsa_SidType type
,
466 struct dom_sid
**sid_mem
,
468 uint32_t **name_types
)
470 NTSTATUS status
, result
;
471 uint32_t i
, total_names
= 0;
472 struct policy_handle dom_pol
, group_pol
;
473 uint32_t des_access
= SEC_FLAG_MAXIMUM_ALLOWED
;
474 uint32_t *rid_mem
= NULL
;
477 struct rpc_pipe_client
*cli
;
478 unsigned int orig_timeout
;
479 struct samr_RidAttrArray
*rids
= NULL
;
480 struct dcerpc_binding_handle
*b
;
482 DEBUG(3,("msrpc_lookup_groupmem: %s sid=%s\n", domain
->name
,
483 sid_string_dbg(group_sid
)));
485 if ( !winbindd_can_contact_domain( domain
) ) {
486 DEBUG(10,("lookup_groupmem: No incoming trust for domain %s\n",
491 if (!sid_peek_check_rid(&domain
->sid
, group_sid
, &group_rid
))
492 return NT_STATUS_UNSUCCESSFUL
;
496 result
= cm_connect_sam(domain
, mem_ctx
, false, &cli
, &dom_pol
);
497 if (!NT_STATUS_IS_OK(result
))
500 b
= cli
->binding_handle
;
502 status
= dcerpc_samr_OpenGroup(b
, mem_ctx
,
508 if (!NT_STATUS_IS_OK(status
)) {
511 if (!NT_STATUS_IS_OK(result
)) {
515 /* Step #1: Get a list of user rids that are the members of the
518 /* This call can take a long time - allow the server to time out.
519 35 seconds should do it. */
521 orig_timeout
= rpccli_set_timeout(cli
, 35000);
523 status
= dcerpc_samr_QueryGroupMember(b
, mem_ctx
,
528 /* And restore our original timeout. */
529 rpccli_set_timeout(cli
, orig_timeout
);
533 dcerpc_samr_Close(b
, mem_ctx
, &group_pol
, &_result
);
536 if (!NT_STATUS_IS_OK(status
)) {
540 if (!NT_STATUS_IS_OK(result
)) {
544 if (!rids
|| !rids
->count
) {
551 *num_names
= rids
->count
;
552 rid_mem
= rids
->rids
;
554 /* Step #2: Convert list of rids into list of usernames. Do this
555 in bunches of ~1000 to avoid crashing NT4. It looks like there
556 is a buffer overflow or something like that lurking around
559 #define MAX_LOOKUP_RIDS 900
561 *names
= talloc_zero_array(mem_ctx
, char *, *num_names
);
562 *name_types
= talloc_zero_array(mem_ctx
, uint32_t, *num_names
);
563 *sid_mem
= talloc_zero_array(mem_ctx
, struct dom_sid
, *num_names
);
565 for (j
=0;j
<(*num_names
);j
++)
566 sid_compose(&(*sid_mem
)[j
], &domain
->sid
, rid_mem
[j
]);
568 if (*num_names
>0 && (!*names
|| !*name_types
))
569 return NT_STATUS_NO_MEMORY
;
571 for (i
= 0; i
< *num_names
; i
+= MAX_LOOKUP_RIDS
) {
572 int num_lookup_rids
= MIN(*num_names
- i
, MAX_LOOKUP_RIDS
);
573 struct lsa_Strings tmp_names
;
574 struct samr_Ids tmp_types
;
576 /* Lookup a chunk of rids */
578 status
= dcerpc_samr_LookupRids(b
, mem_ctx
,
585 if (!NT_STATUS_IS_OK(status
)) {
589 /* see if we have a real error (and yes the
590 STATUS_SOME_UNMAPPED is the one returned from 2k) */
592 if (!NT_STATUS_IS_OK(result
) &&
593 !NT_STATUS_EQUAL(result
, STATUS_SOME_UNMAPPED
))
596 /* Copy result into array. The talloc system will take
597 care of freeing the temporary arrays later on. */
599 if (tmp_names
.count
!= num_lookup_rids
) {
600 return NT_STATUS_INVALID_NETWORK_RESPONSE
;
602 if (tmp_types
.count
!= num_lookup_rids
) {
603 return NT_STATUS_INVALID_NETWORK_RESPONSE
;
606 for (r
=0; r
<tmp_names
.count
; r
++) {
607 if (tmp_types
.ids
[r
] == SID_NAME_UNKNOWN
) {
610 if (total_names
>= *num_names
) {
613 (*names
)[total_names
] = fill_domain_username_talloc(
614 mem_ctx
, domain
->name
,
615 tmp_names
.names
[r
].string
, true);
616 (*name_types
)[total_names
] = tmp_types
.ids
[r
];
621 *num_names
= total_names
;
630 static int get_ldap_seq(const char *server
, struct sockaddr_storage
*ss
, int port
, uint32_t *seq
)
634 const char *attrs
[] = {"highestCommittedUSN", NULL
};
635 LDAPMessage
*res
= NULL
;
636 char **values
= NULL
;
639 *seq
= DOM_SEQUENCE_NONE
;
642 * Parameterised (5) second timeout on open. This is needed as the
643 * search timeout doesn't seem to apply to doing an open as well. JRA.
646 ldp
= ldap_open_with_timeout(server
, ss
, port
, lp_ldap_timeout());
650 /* Timeout if no response within 20 seconds. */
654 if (ldap_search_st(ldp
, "", LDAP_SCOPE_BASE
, "(objectclass=*)",
655 discard_const_p(char *, attrs
), 0, &to
, &res
))
658 if (ldap_count_entries(ldp
, res
) != 1)
661 values
= ldap_get_values(ldp
, res
, "highestCommittedUSN");
662 if (!values
|| !values
[0])
665 *seq
= atoi(values
[0]);
671 ldap_value_free(values
);
679 /**********************************************************************
680 Get the sequence number for a Windows AD native mode domain using
682 **********************************************************************/
684 static int get_ldap_sequence_number(struct winbindd_domain
*domain
, uint32_t *seq
)
687 char addr
[INET6_ADDRSTRLEN
];
689 print_sockaddr(addr
, sizeof(addr
), &domain
->dcaddr
);
690 if ((ret
= get_ldap_seq(addr
, &domain
->dcaddr
, LDAP_PORT
, seq
)) == 0) {
691 DEBUG(3, ("get_ldap_sequence_number: Retrieved sequence "
692 "number for Domain (%s) from DC (%s)\n",
693 domain
->name
, addr
));
698 #endif /* HAVE_LDAP */
700 /* find the sequence number for a domain */
701 static NTSTATUS
msrpc_sequence_number(struct winbindd_domain
*domain
,
704 struct rpc_pipe_client
*samr_pipe
;
705 struct policy_handle dom_pol
;
706 uint32_t seq
= DOM_SEQUENCE_NONE
;
710 DEBUG(3, ("msrpc_sequence_number: fetch sequence_number for %s\n", domain
->name
));
713 *pseq
= DOM_SEQUENCE_NONE
;
716 tmp_ctx
= talloc_stackframe();
717 if (tmp_ctx
== NULL
) {
718 return NT_STATUS_NO_MEMORY
;
721 if ( !winbindd_can_contact_domain( domain
) ) {
722 DEBUG(10,("sequence_number: No incoming trust for domain %s\n",
727 status
= NT_STATUS_OK
;
732 if (domain
->active_directory
) {
735 DEBUG(8,("using get_ldap_seq() to retrieve the "
736 "sequence number\n"));
738 rc
= get_ldap_sequence_number(domain
, &seq
);
740 DEBUG(10,("domain_sequence_number: LDAP for "
748 status
= NT_STATUS_OK
;
752 DEBUG(10,("domain_sequence_number: failed to get LDAP "
753 "sequence number for domain %s\n",
756 #endif /* HAVE_LDAP */
758 status
= cm_connect_sam(domain
, tmp_ctx
, false, &samr_pipe
, &dom_pol
);
759 if (!NT_STATUS_IS_OK(status
)) {
763 status
= rpc_sequence_number(tmp_ctx
,
768 if (!NT_STATUS_IS_OK(status
)) {
777 TALLOC_FREE(tmp_ctx
);
781 /* get a list of trusted domains */
782 static NTSTATUS
msrpc_trusted_domains(struct winbindd_domain
*domain
,
784 struct netr_DomainTrustList
*ptrust_list
)
786 struct rpc_pipe_client
*lsa_pipe
;
787 struct policy_handle lsa_policy
;
788 struct netr_DomainTrust
*trusts
= NULL
;
789 uint32_t num_trusts
= 0;
793 DEBUG(3,("msrpc_trusted_domains\n"));
796 ZERO_STRUCTP(ptrust_list
);
799 tmp_ctx
= talloc_stackframe();
800 if (tmp_ctx
== NULL
) {
801 return NT_STATUS_NO_MEMORY
;
804 status
= cm_connect_lsa(domain
, tmp_ctx
, &lsa_pipe
, &lsa_policy
);
805 if (!NT_STATUS_IS_OK(status
)) {
809 status
= rpc_trusted_domains(tmp_ctx
,
814 if (!NT_STATUS_IS_OK(status
)) {
819 ptrust_list
->count
= num_trusts
;
820 ptrust_list
->array
= talloc_move(mem_ctx
, &trusts
);
824 TALLOC_FREE(tmp_ctx
);
828 /* find the lockout policy for a domain */
829 static NTSTATUS
msrpc_lockout_policy(struct winbindd_domain
*domain
,
831 struct samr_DomInfo12
*lockout_policy
)
833 NTSTATUS status
, result
;
834 struct rpc_pipe_client
*cli
;
835 struct policy_handle dom_pol
;
836 union samr_DomainInfo
*info
= NULL
;
837 struct dcerpc_binding_handle
*b
;
839 DEBUG(3, ("msrpc_lockout_policy: fetch lockout policy for %s\n", domain
->name
));
841 if ( !winbindd_can_contact_domain( domain
) ) {
842 DEBUG(10,("msrpc_lockout_policy: No incoming trust for domain %s\n",
844 return NT_STATUS_NOT_SUPPORTED
;
847 status
= cm_connect_sam(domain
, mem_ctx
, false, &cli
, &dom_pol
);
848 if (!NT_STATUS_IS_OK(status
)) {
852 b
= cli
->binding_handle
;
854 status
= dcerpc_samr_QueryDomainInfo(b
, mem_ctx
,
856 DomainLockoutInformation
,
859 if (!NT_STATUS_IS_OK(status
)) {
862 if (!NT_STATUS_IS_OK(result
)) {
867 *lockout_policy
= info
->info12
;
869 DEBUG(10,("msrpc_lockout_policy: lockout_threshold %d\n",
870 info
->info12
.lockout_threshold
));
877 /* find the password policy for a domain */
878 static NTSTATUS
msrpc_password_policy(struct winbindd_domain
*domain
,
880 struct samr_DomInfo1
*password_policy
)
882 NTSTATUS status
, result
;
883 struct rpc_pipe_client
*cli
;
884 struct policy_handle dom_pol
;
885 union samr_DomainInfo
*info
= NULL
;
886 struct dcerpc_binding_handle
*b
;
888 DEBUG(3, ("msrpc_password_policy: fetch password policy for %s\n",
891 if ( !winbindd_can_contact_domain( domain
) ) {
892 DEBUG(10,("msrpc_password_policy: No incoming trust for domain %s\n",
894 return NT_STATUS_NOT_SUPPORTED
;
897 status
= cm_connect_sam(domain
, mem_ctx
, false, &cli
, &dom_pol
);
898 if (!NT_STATUS_IS_OK(status
)) {
902 b
= cli
->binding_handle
;
904 status
= dcerpc_samr_QueryDomainInfo(b
, mem_ctx
,
906 DomainPasswordInformation
,
909 if (!NT_STATUS_IS_OK(status
)) {
912 if (!NT_STATUS_IS_OK(result
)) {
916 *password_policy
= info
->info1
;
918 DEBUG(10,("msrpc_password_policy: min_length_password %d\n",
919 info
->info1
.min_password_length
));
926 NTSTATUS
winbindd_lookup_sids(TALLOC_CTX
*mem_ctx
,
927 struct winbindd_domain
*domain
,
929 const struct dom_sid
*sids
,
932 enum lsa_SidType
**types
)
936 struct rpc_pipe_client
*cli
= NULL
;
937 struct dcerpc_binding_handle
*b
= NULL
;
938 struct policy_handle lsa_policy
;
939 unsigned int orig_timeout
;
940 bool use_lookupsids3
= false;
941 bool retried
= false;
944 status
= cm_connect_lsat(domain
, mem_ctx
, &cli
, &lsa_policy
);
945 if (!NT_STATUS_IS_OK(status
)) {
949 b
= cli
->binding_handle
;
951 if (cli
->transport
->transport
== NCACN_IP_TCP
) {
952 use_lookupsids3
= true;
956 * This call can take a long time
957 * allow the server to time out.
958 * 35 seconds should do it.
960 orig_timeout
= dcerpc_binding_handle_set_timeout(b
, 35000);
962 status
= dcerpc_lsa_lookup_sids_generic(b
,
973 /* And restore our original timeout. */
974 dcerpc_binding_handle_set_timeout(b
, orig_timeout
);
976 if (NT_STATUS_EQUAL(status
, NT_STATUS_ACCESS_DENIED
) ||
977 NT_STATUS_EQUAL(status
, NT_STATUS_RPC_SEC_PKG_ERROR
) ||
978 NT_STATUS_EQUAL(status
, NT_STATUS_NETWORK_ACCESS_DENIED
)) {
980 * This can happen if the schannel key is not
981 * valid anymore, we need to invalidate the
982 * all connections to the dc and reestablish
983 * a netlogon connection first.
985 invalidate_cm_connection(domain
);
986 domain
->can_do_ncacn_ip_tcp
= domain
->active_directory
;
991 status
= NT_STATUS_ACCESS_DENIED
;
994 if (!NT_STATUS_IS_OK(status
)) {
998 if (!NT_STATUS_IS_OK(result
)) {
1002 return NT_STATUS_OK
;
1005 static NTSTATUS
winbindd_lookup_names(TALLOC_CTX
*mem_ctx
,
1006 struct winbindd_domain
*domain
,
1009 const char ***domains
,
1010 struct dom_sid
**sids
,
1011 enum lsa_SidType
**types
)
1015 struct rpc_pipe_client
*cli
= NULL
;
1016 struct dcerpc_binding_handle
*b
= NULL
;
1017 struct policy_handle lsa_policy
;
1018 unsigned int orig_timeout
= 0;
1019 bool use_lookupnames4
= false;
1020 bool retried
= false;
1023 status
= cm_connect_lsat(domain
, mem_ctx
, &cli
, &lsa_policy
);
1024 if (!NT_STATUS_IS_OK(status
)) {
1028 b
= cli
->binding_handle
;
1030 if (cli
->transport
->transport
== NCACN_IP_TCP
) {
1031 use_lookupnames4
= true;
1035 * This call can take a long time
1036 * allow the server to time out.
1037 * 35 seconds should do it.
1039 orig_timeout
= dcerpc_binding_handle_set_timeout(b
, 35000);
1041 status
= dcerpc_lsa_lookup_names_generic(b
,
1045 (const char **) names
,
1053 /* And restore our original timeout. */
1054 dcerpc_binding_handle_set_timeout(b
, orig_timeout
);
1056 if (NT_STATUS_EQUAL(status
, NT_STATUS_ACCESS_DENIED
) ||
1057 NT_STATUS_EQUAL(status
, NT_STATUS_RPC_SEC_PKG_ERROR
) ||
1058 NT_STATUS_EQUAL(status
, NT_STATUS_NETWORK_ACCESS_DENIED
)) {
1060 * This can happen if the schannel key is not
1061 * valid anymore, we need to invalidate the
1062 * all connections to the dc and reestablish
1063 * a netlogon connection first.
1065 invalidate_cm_connection(domain
);
1070 status
= NT_STATUS_ACCESS_DENIED
;
1073 if (!NT_STATUS_IS_OK(status
)) {
1077 if (!NT_STATUS_IS_OK(result
)) {
1081 return NT_STATUS_OK
;
1084 /* the rpc backend methods are exposed via this structure */
1085 struct winbindd_methods msrpc_methods
= {
1087 msrpc_query_user_list
,
1088 msrpc_enum_dom_groups
,
1089 msrpc_enum_local_groups
,
1092 msrpc_rids_to_names
,
1093 msrpc_lookup_useraliases
,
1094 msrpc_lookup_groupmem
,
1095 msrpc_sequence_number
,
1096 msrpc_lockout_policy
,
1097 msrpc_password_policy
,
1098 msrpc_trusted_domains
,