s4:torture: FinderInfo conversion test with AppleDouble without xattr data
[Samba.git] / source3 / winbindd / winbindd_rpc.h
blob162f1ef3329feb21e3c6a1bd11e838f9c353641e
1 /*
2 * Unix SMB/CIFS implementation.
4 * Winbind rpc backend functions
6 * Copyright (c) 2000-2003 Tim Potter
7 * Copyright (c) 2001 Andrew Tridgell
8 * Copyright (c) 2005 Volker Lendecke
9 * Copyright (c) 2008 Guenther Deschner (pidl conversion)
10 * Copyright (c) 2010 Andreas Schneider <asn@samba.org>
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; either version 3 of the License, or
15 * (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
22 * You should have received a copy of the GNU General Public License
23 * along with this program. If not, see <http://www.gnu.org/licenses/>.
26 #ifndef _WINBINDD_RPC_H_
27 #define _WINBINDD_RPC_H_
29 /* Query display info for a domain */
30 NTSTATUS rpc_query_user_list(TALLOC_CTX *mem_ctx,
31 struct rpc_pipe_client *samr_pipe,
32 struct policy_handle *samr_policy,
33 const struct dom_sid *domain_sid,
34 uint32_t **prids);
36 NTSTATUS rpc_enum_dom_groups(TALLOC_CTX *mem_ctx,
37 struct rpc_pipe_client *samr_pipe,
38 struct policy_handle *sam_policy,
39 uint32_t *pnum_info,
40 struct wb_acct_info **pinfo);
42 /* List all domain groups */
43 NTSTATUS rpc_enum_local_groups(TALLOC_CTX *mem_ctx,
44 struct rpc_pipe_client *samr_pipe,
45 struct policy_handle *samr_policy,
46 uint32_t *pnum_info,
47 struct wb_acct_info **pinfo);
49 /* Convert a single name to a sid in a domain */
50 NTSTATUS rpc_name_to_sid(TALLOC_CTX *mem_ctx,
51 struct rpc_pipe_client *lsa_pipe,
52 struct policy_handle *lsa_policy,
53 const char *domain_name,
54 const char *name,
55 uint32_t flags,
56 struct dom_sid *psid,
57 enum lsa_SidType *ptype);
59 /* Convert a domain SID to a user or group name */
60 NTSTATUS rpc_sid_to_name(TALLOC_CTX *mem_ctx,
61 struct rpc_pipe_client *lsa_pipe,
62 struct policy_handle *lsa_policy,
63 struct winbindd_domain *domain,
64 const struct dom_sid *sid,
65 char **pdomain_name,
66 char **pname,
67 enum lsa_SidType *ptype);
69 /* Convert a bunch of rids to user or group names */
70 NTSTATUS rpc_rids_to_names(TALLOC_CTX *mem_ctx,
71 struct rpc_pipe_client *lsa_pipe,
72 struct policy_handle *lsa_policy,
73 struct winbindd_domain *domain,
74 const struct dom_sid *sid,
75 uint32_t *rids,
76 size_t num_rids,
77 char **pdomain_name,
78 char ***pnames,
79 enum lsa_SidType **ptypes);
81 /* Lookup groups a user is a member of. */
82 NTSTATUS rpc_lookup_usergroups(TALLOC_CTX *mem_ctx,
83 struct rpc_pipe_client *samr_pipe,
84 struct policy_handle *samr_policy,
85 const struct dom_sid *domain_sid,
86 const struct dom_sid *user_sid,
87 uint32_t *pnum_groups,
88 struct dom_sid **puser_grpsids);
90 NTSTATUS rpc_lookup_useraliases(TALLOC_CTX *mem_ctx,
91 struct rpc_pipe_client *samr_pipe,
92 struct policy_handle *samr_policy,
93 uint32_t num_sids,
94 const struct dom_sid *sids,
95 uint32_t *pnum_aliases,
96 uint32_t **palias_rids);
98 /* Lookup group membership given a rid. */
99 NTSTATUS rpc_lookup_groupmem(TALLOC_CTX *mem_ctx,
100 struct rpc_pipe_client *samr_pipe,
101 struct policy_handle *samr_policy,
102 const char *domain_name,
103 const struct dom_sid *domain_sid,
104 const struct dom_sid *group_sid,
105 enum lsa_SidType type,
106 uint32_t *pnum_names,
107 struct dom_sid **psid_mem,
108 char ***pnames,
109 uint32_t **pname_types);
111 /* Find the sequence number for a domain */
112 NTSTATUS rpc_sequence_number(TALLOC_CTX *mem_ctx,
113 struct rpc_pipe_client *samr_pipe,
114 struct policy_handle *samr_policy,
115 const char *domain_name,
116 uint32_t *pseq);
118 /* Get a list of trusted domains */
119 NTSTATUS rpc_trusted_domains(TALLOC_CTX *mem_ctx,
120 struct rpc_pipe_client *lsa_pipe,
121 struct policy_handle *lsa_policy,
122 uint32_t *pnum_trusts,
123 struct netr_DomainTrust **ptrusts);
125 #endif /* _WINBINDD_RPC_H_ */