ea8225256bc39d68202eabaeebe4522db99e94f5
[samba.git] / source3 / winbindd / winbindd_proto.h
1 /*
2  * Unix SMB/CIFS implementation.
3  * collected prototypes header
4  *
5  * frozen from "make proto" in May 2008
6  *
7  * Copyright (C) Michael Adam 2008
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, see <http://www.gnu.org/licenses/>.
21  */
22
23 #ifndef _WINBINDD_PROTO_H_
24 #define _WINBINDD_PROTO_H_
25
26 /* The following definitions come from winbindd/winbindd.c  */
27 struct imessaging_context *winbind_imessaging_context(void);
28 void request_error(struct winbindd_cli_state *state);
29 void request_ok(struct winbindd_cli_state *state);
30 bool winbindd_setup_sig_term_handler(bool parent);
31 bool winbindd_setup_stdin_handler(bool parent, bool foreground);
32 bool winbindd_setup_sig_hup_handler(const char *lfile);
33 bool winbindd_use_idmap_cache(void);
34 bool winbindd_use_cache(void);
35 char *get_winbind_priv_pipe_dir(void);
36
37 /* The following definitions come from winbindd/winbindd_ads.c  */
38
39 /* The following definitions come from winbindd/winbindd_rpc.c  */
40
41 NTSTATUS winbindd_lookup_sids(TALLOC_CTX *mem_ctx,
42                               struct winbindd_domain *domain,
43                               uint32_t num_sids,
44                               const struct dom_sid *sids,
45                               char ***domains,
46                               char ***names,
47                               enum lsa_SidType **types);
48 NTSTATUS rpc_lookup_sids(TALLOC_CTX *mem_ctx,
49                          struct winbindd_domain *domain,
50                          struct lsa_SidArray *sids,
51                          struct lsa_RefDomainList **pdomains,
52                          struct lsa_TransNameArray **pnames);
53
54 /* The following definitions come from winbindd/winbindd_cache.c  */
55
56 NTSTATUS wb_cache_query_user_list(struct winbindd_domain *domain,
57                                   TALLOC_CTX *mem_ctx,
58                                   uint32_t **prids);
59 NTSTATUS wb_cache_enum_dom_groups(struct winbindd_domain *domain,
60                                   TALLOC_CTX *mem_ctx,
61                                   uint32_t *num_entries,
62                                   struct wb_acct_info **info);
63 NTSTATUS wb_cache_enum_local_groups(struct winbindd_domain *domain,
64                                     TALLOC_CTX *mem_ctx,
65                                     uint32_t *num_entries,
66                                     struct wb_acct_info **info);
67 NTSTATUS wb_cache_name_to_sid(struct winbindd_domain *domain,
68                               TALLOC_CTX *mem_ctx,
69                               const char *domain_name,
70                               const char *name,
71                               uint32_t flags,
72                               struct dom_sid *sid,
73                               enum lsa_SidType *type);
74 NTSTATUS wb_cache_sid_to_name(struct winbindd_domain *domain,
75                               TALLOC_CTX *mem_ctx,
76                               const struct dom_sid *sid,
77                               char **domain_name,
78                               char **name,
79                               enum lsa_SidType *type);
80 NTSTATUS wb_cache_rids_to_names(struct winbindd_domain *domain,
81                                 TALLOC_CTX *mem_ctx,
82                                 const struct dom_sid *domain_sid,
83                                 uint32_t *rids,
84                                 size_t num_rids,
85                                 char **domain_name,
86                                 char ***names,
87                                 enum lsa_SidType **types);
88 NTSTATUS wb_cache_lookup_usergroups(struct winbindd_domain *domain,
89                                     TALLOC_CTX *mem_ctx,
90                                     const struct dom_sid *user_sid,
91                                     uint32_t *pnum_sids,
92                                     struct dom_sid **psids);
93 NTSTATUS wb_cache_lookup_useraliases(struct winbindd_domain *domain,
94                                      TALLOC_CTX *mem_ctx,
95                                      uint32_t num_sids,
96                                      const struct dom_sid *sids,
97                                      uint32_t *num_aliases,
98                                      uint32_t **alias_rids);
99 NTSTATUS wb_cache_lookup_groupmem(struct winbindd_domain *domain,
100                                   TALLOC_CTX *mem_ctx,
101                                   const struct dom_sid *group_sid,
102                                   enum lsa_SidType type,
103                                   uint32_t *num_names,
104                                   struct dom_sid **sid_mem,
105                                   char ***names,
106                                   uint32_t **name_types);
107 NTSTATUS wb_cache_sequence_number(struct winbindd_domain *domain,
108                                   uint32_t *seq);
109 NTSTATUS wb_cache_lockout_policy(struct winbindd_domain *domain,
110                                  TALLOC_CTX *mem_ctx,
111                                  struct samr_DomInfo12 *policy);
112 NTSTATUS wb_cache_password_policy(struct winbindd_domain *domain,
113                                   TALLOC_CTX *mem_ctx,
114                                   struct samr_DomInfo1 *policy);
115 NTSTATUS wb_cache_trusted_domains(struct winbindd_domain *domain,
116                                   TALLOC_CTX *mem_ctx,
117                                   struct netr_DomainTrustList *trusts);
118
119 NTSTATUS wcache_cached_creds_exist(struct winbindd_domain *domain, const struct dom_sid *sid);
120 NTSTATUS wcache_get_creds(struct winbindd_domain *domain, 
121                           TALLOC_CTX *mem_ctx, 
122                           const struct dom_sid *sid,
123                           const uint8_t **cached_nt_pass,
124                           const uint8_t **cached_salt);
125 NTSTATUS wcache_save_creds(struct winbindd_domain *domain, 
126                            const struct dom_sid *sid,
127                            const uint8_t nt_pass[NT_HASH_LEN]);
128 void wcache_invalidate_samlogon(struct winbindd_domain *domain, 
129                                 const struct dom_sid *user_sid);
130 bool wcache_invalidate_cache(void);
131 bool wcache_invalidate_cache_noinit(void);
132 bool initialize_winbindd_cache(void);
133 void close_winbindd_cache(void);
134 bool lookup_cached_sid(TALLOC_CTX *mem_ctx, const struct dom_sid *sid,
135                        char **domain_name, char **name,
136                        enum lsa_SidType *type);
137 bool lookup_cached_name(const char *namespace,
138                         const char *domain_name,
139                         const char *name,
140                         struct dom_sid *sid,
141                         enum lsa_SidType *type);
142 void cache_name2sid_trusted(struct winbindd_domain *domain,
143                         const char *domain_name,
144                         const char *name,
145                         enum lsa_SidType type,
146                         const struct dom_sid *sid);
147 void cache_name2sid(struct winbindd_domain *domain, 
148                     const char *domain_name, const char *name,
149                     enum lsa_SidType type, const struct dom_sid *sid);
150 NTSTATUS wcache_query_user_fullname(struct winbindd_domain *domain,
151                                     TALLOC_CTX *mem_ctx,
152                                     const struct dom_sid *user_sid,
153                                     const char **full_name);
154
155 NTSTATUS wcache_count_cached_creds(struct winbindd_domain *domain, int *count);
156 NTSTATUS wcache_remove_oldest_cached_creds(struct winbindd_domain *domain, const struct dom_sid *sid) ;
157 bool set_global_winbindd_state_offline(void);
158 void set_global_winbindd_state_online(void);
159 bool get_global_winbindd_state_offline(void);
160 int winbindd_validate_cache(void);
161 int winbindd_validate_cache_nobackup(void);
162 bool winbindd_cache_validate_and_initialize(void);
163 bool wcache_tdc_fetch_list( struct winbindd_tdc_domain **domains, size_t *num_domains );
164 bool wcache_tdc_add_domain( struct winbindd_domain *domain );
165 struct winbindd_tdc_domain * wcache_tdc_fetch_domain( TALLOC_CTX *ctx, const char *name );
166 void wcache_tdc_clear( void );
167 bool wcache_store_seqnum(const char *domain_name, uint32_t seqnum,
168                          time_t last_seq_check);
169 bool wcache_fetch_ndr(TALLOC_CTX *mem_ctx, struct winbindd_domain *domain,
170                       uint32_t opnum, const DATA_BLOB *req, DATA_BLOB *resp);
171 void wcache_store_ndr(struct winbindd_domain *domain, uint32_t opnum,
172                       const DATA_BLOB *req, const DATA_BLOB *resp);
173
174 /* The following definitions come from winbindd/winbindd_ccache_access.c  */
175
176 void winbindd_ccache_ntlm_auth(struct winbindd_cli_state *state);
177 enum winbindd_result winbindd_dual_ccache_ntlm_auth(struct winbindd_domain *domain,
178                                                 struct winbindd_cli_state *state);
179 void winbindd_ccache_save(struct winbindd_cli_state *state);
180
181 /* The following definitions come from winbindd/winbindd_cm.c  */
182 void winbind_msg_domain_offline(struct messaging_context *msg_ctx,
183                                 void *private_data,
184                                 uint32_t msg_type,
185                                 struct server_id server_id,
186                                 DATA_BLOB *data);
187 void winbind_msg_domain_online(struct messaging_context *msg_ctx,
188                                 void *private_data,
189                                 uint32_t msg_type,
190                                 struct server_id server_id,
191                                 DATA_BLOB *data);
192
193 void set_domain_offline(struct winbindd_domain *domain);
194 void set_domain_online_request(struct winbindd_domain *domain);
195
196 struct ndr_interface_table;
197 NTSTATUS wb_open_internal_pipe(TALLOC_CTX *mem_ctx,
198                                const struct ndr_interface_table *table,
199                                struct rpc_pipe_client **ret_pipe);
200 void invalidate_cm_connection(struct winbindd_domain *domain);
201 void close_conns_after_fork(void);
202 NTSTATUS init_dc_connection(struct winbindd_domain *domain, bool need_rw_dc);
203 NTSTATUS cm_connect_sam(struct winbindd_domain *domain, TALLOC_CTX *mem_ctx,
204                         bool need_rw_dc,
205                         struct rpc_pipe_client **cli, struct policy_handle *sam_handle);
206 NTSTATUS cm_connect_lsa(struct winbindd_domain *domain, TALLOC_CTX *mem_ctx,
207                         struct rpc_pipe_client **cli, struct policy_handle *lsa_policy);
208 NTSTATUS cm_connect_lsat(struct winbindd_domain *domain,
209                          TALLOC_CTX *mem_ctx,
210                          struct rpc_pipe_client **cli,
211                          struct policy_handle *lsa_policy);
212 NTSTATUS cm_connect_netlogon(struct winbindd_domain *domain,
213                              struct rpc_pipe_client **cli);
214 NTSTATUS cm_connect_netlogon_secure(struct winbindd_domain *domain,
215                                     struct rpc_pipe_client **cli,
216                                     struct netlogon_creds_cli_context **ppdc);
217 bool fetch_current_dc_from_gencache(TALLOC_CTX *mem_ctx,
218                                     const char *domain_name,
219                                     char **p_dc_name, char **p_dc_ip);
220
221 /* The following definitions come from winbindd/winbindd_cred_cache.c  */
222
223 bool ccache_entry_exists(const char *username);
224 bool ccache_entry_identical(const char *username,
225                             uid_t uid,
226                             const char *ccname);
227 void ccache_remove_all_after_fork(void);
228 void ccache_regain_all_now(void);
229 NTSTATUS add_ccache_to_list(const char *princ_name,
230                             const char *ccname,
231                             const char *service,
232                             const char *username,
233                             const char *password,
234                             const char *realm,
235                             uid_t uid,
236                             time_t create_time,
237                             time_t ticket_end,
238                             time_t renew_until,
239                             bool postponed_request);
240 NTSTATUS remove_ccache(const char *username);
241 struct WINBINDD_MEMORY_CREDS *find_memory_creds_by_name(const char *username);
242 NTSTATUS winbindd_add_memory_creds(const char *username,
243                                    uid_t uid,
244                                    const char *pass);
245 NTSTATUS winbindd_delete_memory_creds(const char *username);
246 NTSTATUS winbindd_replace_memory_creds(const char *username,
247                                        const char *pass);
248
249 /* The following definitions come from winbindd/winbindd_creds.c  */
250
251 NTSTATUS winbindd_get_creds(struct winbindd_domain *domain,
252                             TALLOC_CTX *mem_ctx,
253                             const struct dom_sid *sid,
254                             struct netr_SamInfo3 **info3,
255                             const uint8_t *cached_nt_pass[NT_HASH_LEN],
256                             const uint8_t *cred_salt[NT_HASH_LEN]);
257 NTSTATUS winbindd_store_creds(struct winbindd_domain *domain,
258                               const char *user, 
259                               const char *pass, 
260                               struct netr_SamInfo3 *info3);
261 NTSTATUS winbindd_update_creds_by_info3(struct winbindd_domain *domain,
262                                         const char *user,
263                                         const char *pass,
264                                         struct netr_SamInfo3 *info3);
265 NTSTATUS winbindd_update_creds_by_name(struct winbindd_domain *domain,
266                                        const char *user,
267                                        const char *pass);
268
269 /* The following definitions come from winbindd/winbindd_domain.c  */
270
271 void setup_domain_child(struct winbindd_domain *domain);
272
273 /* The following definitions come from winbindd/winbindd_dual.c  */
274
275 struct dcerpc_binding_handle *dom_child_handle(struct winbindd_domain *domain);
276
277 struct tevent_req *wb_child_request_send(TALLOC_CTX *mem_ctx,
278                                          struct tevent_context *ev,
279                                          struct winbindd_child *child,
280                                          struct winbindd_request *request);
281 int wb_child_request_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
282                           struct winbindd_response **presponse, int *err);
283 struct tevent_req *wb_domain_request_send(TALLOC_CTX *mem_ctx,
284                                           struct tevent_context *ev,
285                                           struct winbindd_domain *domain,
286                                           struct winbindd_request *request);
287 int wb_domain_request_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
288                            struct winbindd_response **presponse, int *err);
289
290 void setup_child(struct winbindd_domain *domain, struct winbindd_child *child,
291                  const struct winbindd_child_dispatch_table *table,
292                  const char *logprefix,
293                  const char *logname);
294 void winbind_child_died(pid_t pid);
295 void winbindd_flush_negative_conn_cache(struct winbindd_domain *domain);
296 void winbind_msg_debug(struct messaging_context *msg_ctx,
297                          void *private_data,
298                          uint32_t msg_type,
299                          struct server_id server_id,
300                          DATA_BLOB *data);
301 void winbind_disconnect_dc_parent(struct messaging_context *msg_ctx,
302                                   void *private_data,
303                                   uint32_t msg_type,
304                                   struct server_id server_id,
305                                   DATA_BLOB *data);
306 void winbind_msg_offline(struct messaging_context *msg_ctx,
307                          void *private_data,
308                          uint32_t msg_type,
309                          struct server_id server_id,
310                          DATA_BLOB *data);
311 void winbind_msg_online(struct messaging_context *msg_ctx,
312                         void *private_data,
313                         uint32_t msg_type,
314                         struct server_id server_id,
315                         DATA_BLOB *data);
316 void winbind_msg_onlinestatus(struct messaging_context *msg_ctx,
317                               void *private_data,
318                               uint32_t msg_type,
319                               struct server_id server_id,
320                               DATA_BLOB *data);
321 void winbind_msg_dump_event_list(struct messaging_context *msg_ctx,
322                                  void *private_data,
323                                  uint32_t msg_type,
324                                  struct server_id server_id,
325                                  DATA_BLOB *data);
326 void winbind_msg_dump_domain_list(struct messaging_context *msg_ctx,
327                                   void *private_data,
328                                   uint32_t msg_type,
329                                   struct server_id server_id,
330                                   DATA_BLOB *data);
331 void winbind_msg_ip_dropped(struct messaging_context *msg_ctx,
332                             void *private_data,
333                             uint32_t msg_type,
334                             struct server_id server_id,
335                             DATA_BLOB *data);
336 void winbind_msg_disconnect_dc(struct messaging_context *msg_ctx,
337                                void *private_data,
338                                uint32_t msg_type,
339                                struct server_id server_id,
340                                DATA_BLOB *data);
341 void winbind_msg_ip_dropped_parent(struct messaging_context *msg_ctx,
342                                    void *private_data,
343                                    uint32_t msg_type,
344                                    struct server_id server_id,
345                                    DATA_BLOB *data);
346 NTSTATUS winbindd_reinit_after_fork(const struct winbindd_child *myself,
347                                     const char *logfilename);
348 struct winbindd_domain *wb_child_domain(void);
349
350 /* The following definitions come from winbindd/winbindd_group.c  */
351 bool fill_grent(TALLOC_CTX *mem_ctx, struct winbindd_gr *gr,
352                 const char *dom_name, const char *gr_name, gid_t unix_gid);
353
354 struct db_context;
355 NTSTATUS winbindd_print_groupmembers(struct db_context *members,
356                                      TALLOC_CTX *mem_ctx,
357                                      int *num_members, char **result);
358
359
360 /* The following definitions come from winbindd/winbindd_idmap.c  */
361
362 void init_idmap_child(void);
363 struct winbindd_child *idmap_child(void);
364 struct dcerpc_binding_handle *idmap_child_handle(void);
365 struct idmap_domain *idmap_find_domain_with_sid(const char *domname,
366                                                 const struct dom_sid *sid);
367 const char *idmap_config_const_string(const char *domname, const char *option,
368                                       const char *def);
369 bool idmap_config_bool(const char *domname, const char *option, bool def);
370 int idmap_config_int(const char *domname, const char *option, int def);
371 bool domain_has_idmap_config(const char *domname);
372 bool lp_scan_idmap_domains(bool (*fn)(const char *domname,
373                                       void *private_data),
374                            void *private_data);
375
376 /* The following definitions come from winbindd/winbindd_locator.c  */
377
378 void init_locator_child(void);
379 struct winbindd_child *locator_child(void);
380 struct dcerpc_binding_handle *locator_child_handle(void);
381
382 /* The following definitions come from winbindd/winbindd_misc.c  */
383
384 void winbindd_list_trusted_domains(struct winbindd_cli_state *state);
385 enum winbindd_result winbindd_dual_list_trusted_domains(struct winbindd_domain *domain,
386                                                         struct winbindd_cli_state *state);
387 void winbindd_show_sequence(struct winbindd_cli_state *state);
388 void winbindd_domain_info(struct winbindd_cli_state *state);
389 bool winbindd_dc_info(struct winbindd_cli_state *state);
390 bool winbindd_ping(struct winbindd_cli_state *state);
391 bool winbindd_info(struct winbindd_cli_state *state);
392 bool winbindd_interface_version(struct winbindd_cli_state *state);
393 bool winbindd_domain_name(struct winbindd_cli_state *state);
394 bool winbindd_netbios_name(struct winbindd_cli_state *state);
395 void winbindd_priv_pipe_dir(struct winbindd_cli_state *state);
396
397 /* The following definitions come from winbindd/winbindd_ndr.c  */
398 struct ndr_print;
399 void ndr_print_winbindd_child(struct ndr_print *ndr,
400                               const char *name,
401                               const struct winbindd_child *r);
402 void ndr_print_winbindd_cm_conn(struct ndr_print *ndr,
403                                 const char *name,
404                                 const struct winbindd_cm_conn *r);
405 void ndr_print_winbindd_methods(struct ndr_print *ndr,
406                                 const char *name,
407                                 const struct winbindd_methods *r);
408 void ndr_print_winbindd_domain(struct ndr_print *ndr,
409                                const char *name,
410                                const struct winbindd_domain *r);
411
412 /* The following definitions come from winbindd/winbindd_pam.c  */
413
414 bool check_request_flags(uint32_t flags);
415 NTSTATUS append_auth_data(TALLOC_CTX *mem_ctx,
416                           struct winbindd_response *resp,
417                           uint32_t request_flags,
418                           uint16_t validation_level,
419                           union netr_Validation *validation,
420                           const char *name_domain,
421                           const char *name_user);
422 uid_t get_uid_from_request(struct winbindd_request *request);
423 struct winbindd_domain *find_auth_domain(uint8_t flags,
424                                          const char *domain_name);
425 enum winbindd_result winbindd_dual_pam_auth(struct winbindd_domain *domain,
426                                             struct winbindd_cli_state *state) ;
427 enum winbindd_result winbindd_dual_pam_auth_crap(struct winbindd_domain *domain,
428                                                  struct winbindd_cli_state *state) ;
429 enum winbindd_result winbindd_dual_pam_chauthtok(struct winbindd_domain *contact_domain,
430                                                  struct winbindd_cli_state *state);
431 enum winbindd_result winbindd_dual_pam_logoff(struct winbindd_domain *domain,
432                                               struct winbindd_cli_state *state) ;
433 enum winbindd_result winbindd_dual_pam_chng_pswd_auth_crap(struct winbindd_domain *domainSt, struct winbindd_cli_state *state);
434 NTSTATUS winbindd_pam_auth_pac_verify(struct winbindd_cli_state *state,
435                                       bool *p_is_trusted,
436                                       uint16_t *p_validation_level,
437                                       union netr_Validation **p_validation);
438
439 NTSTATUS winbind_dual_SamLogon(struct winbindd_domain *domain,
440                                TALLOC_CTX *mem_ctx,
441                                bool interactive,
442                                uint32_t logon_parameters,
443                                const char *name_user,
444                                const char *name_domain,
445                                const char *workstation,
446                                const uint8_t chal[8],
447                                DATA_BLOB lm_response,
448                                DATA_BLOB nt_response,
449                                uint8_t *authoritative,
450                                bool skip_sam,
451                                uint32_t *flags,
452                                uint16_t *_validation_level,
453                                union netr_Validation **_validation);
454
455 /* The following definitions come from winbindd/winbindd_util.c  */
456
457 struct winbindd_domain *domain_list(void);
458 struct winbindd_domain *wb_next_domain(struct winbindd_domain *domain);
459 bool set_routing_domain(struct winbindd_domain *domain,
460                         struct winbindd_domain *routing_domain);
461 bool add_trusted_domain_from_auth(uint16_t validation_level,
462                                   struct info3_text *info3,
463                                   struct info6_text *info6);
464 bool domain_is_forest_root(const struct winbindd_domain *domain);
465 void rescan_trusted_domains(struct tevent_context *ev, struct tevent_timer *te,
466                             struct timeval now, void *private_data);
467 enum winbindd_result winbindd_dual_init_connection(struct winbindd_domain *domain,
468                                                    struct winbindd_cli_state *state);
469 bool init_domain_list(void);
470 struct winbindd_domain *find_domain_from_name_noinit(const char *domain_name);
471 struct winbindd_domain *find_trust_from_name_noinit(const char *domain_name);
472 struct winbindd_domain *find_domain_from_name(const char *domain_name);
473 struct winbindd_domain *find_domain_from_sid_noinit(const struct dom_sid *sid);
474 struct winbindd_domain *find_trust_from_sid_noinit(const struct dom_sid *sid);
475 struct winbindd_domain *find_domain_from_sid(const struct dom_sid *sid);
476 struct winbindd_domain *find_our_domain(void);
477 struct winbindd_domain *find_default_route_domain(void);
478 struct winbindd_domain *find_lookup_domain_from_sid(const struct dom_sid *sid);
479 struct winbindd_domain *find_lookup_domain_from_name(const char *domain_name);
480 bool parse_domain_user(const char *domuser,
481                        fstring namespace,
482                        fstring domain,
483                        fstring user);
484 bool canonicalize_username(fstring username_inout,
485                            fstring namespace,
486                            fstring domain,
487                            fstring user);
488 void fill_domain_username(fstring name, const char *domain, const char *user, bool can_assume);
489 char *fill_domain_username_talloc(TALLOC_CTX *ctx,
490                                   const char *domain,
491                                   const char *user,
492                                   bool can_assume);
493 struct winbindd_cli_state *winbindd_client_list(void);
494 struct winbindd_cli_state *winbindd_client_list_tail(void);
495 struct winbindd_cli_state *
496 winbindd_client_list_prev(struct winbindd_cli_state *cli);
497 void winbindd_add_client(struct winbindd_cli_state *cli);
498 void winbindd_remove_client(struct winbindd_cli_state *cli);
499 void winbindd_promote_client(struct winbindd_cli_state *cli);
500 int winbindd_num_clients(void);
501 NTSTATUS lookup_usergroups_cached(TALLOC_CTX *mem_ctx,
502                                   const struct dom_sid *user_sid,
503                                   uint32_t *p_num_groups, struct dom_sid **user_sids);
504
505 NTSTATUS normalize_name_map(TALLOC_CTX *mem_ctx,
506                              const char *domain_name,
507                              const char *name,
508                              char **normalized);
509 NTSTATUS normalize_name_unmap(TALLOC_CTX *mem_ctx,
510                               char *name,
511                               char **normalized);
512
513 NTSTATUS resolve_username_to_alias(TALLOC_CTX *mem_ctx,
514                                    struct winbindd_domain *domain,
515                                    const char *name, char **alias);
516 NTSTATUS resolve_alias_to_username(TALLOC_CTX *mem_ctx,
517                                    struct winbindd_domain *domain,
518                                    const char *alias, char **name);
519
520 bool winbindd_can_contact_domain(struct winbindd_domain *domain);
521 void winbindd_set_locator_kdc_envs(const struct winbindd_domain *domain);
522 void winbindd_unset_locator_kdc_env(const struct winbindd_domain *domain);
523 void winbindd_set_locator_kdc_envs(const struct winbindd_domain *domain);
524 void winbindd_unset_locator_kdc_env(const struct winbindd_domain *domain);
525 void set_auth_errors(struct winbindd_response *resp, NTSTATUS result);
526 bool is_domain_offline(const struct winbindd_domain *domain);
527 bool is_domain_online(const struct winbindd_domain *domain);
528 bool parse_sidlist(TALLOC_CTX *mem_ctx, const char *sidstr,
529                    struct dom_sid **sids, uint32_t *num_sids);
530 bool parse_xidlist(TALLOC_CTX *mem_ctx, const char *xidstr,
531                    struct unixid **pxids, uint32_t *pnum_xids);
532
533 /* The following definitions come from winbindd/winbindd_wins.c  */
534
535 void winbindd_wins_byname(struct winbindd_cli_state *state);
536
537 enum winbindd_result winbindd_dual_ping(struct winbindd_domain *domain,
538                                         struct winbindd_cli_state *state);
539
540 struct dcerpc_binding_handle *wbint_binding_handle(TALLOC_CTX *mem_ctx,
541                                                 struct winbindd_domain *domain,
542                                                 struct winbindd_child *child);
543 enum winbindd_result winbindd_dual_ndrcmd(struct winbindd_domain *domain,
544                                           struct winbindd_cli_state *state);
545
546 struct tevent_req *wb_lookupsid_send(TALLOC_CTX *mem_ctx,
547                                      struct tevent_context *ev,
548                                      const struct dom_sid *sid);
549 NTSTATUS wb_lookupsid_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
550                            enum lsa_SidType *type, const char **domain,
551                            const char **name);
552
553 struct tevent_req *winbindd_lookupsid_send(TALLOC_CTX *mem_ctx,
554                                            struct tevent_context *ev,
555                                            struct winbindd_cli_state *cli,
556                                            struct winbindd_request *request);
557 NTSTATUS winbindd_lookupsid_recv(struct tevent_req *req,
558                                  struct winbindd_response *response);
559
560 struct tevent_req *winbindd_lookupsids_send(TALLOC_CTX *mem_ctx,
561                                             struct tevent_context *ev,
562                                             struct winbindd_cli_state *cli,
563                                             struct winbindd_request *request);
564 NTSTATUS winbindd_lookupsids_recv(struct tevent_req *req,
565                                   struct winbindd_response *response);
566
567 struct tevent_req *wb_lookupname_send(TALLOC_CTX *mem_ctx,
568                                       struct tevent_context *ev,
569                                       const char *namespace,
570                                       const char *dom_name,
571                                       const char *name,
572                                       uint32_t flags);
573 NTSTATUS wb_lookupname_recv(struct tevent_req *req, struct dom_sid *sid,
574                             enum lsa_SidType *type);
575
576 struct tevent_req *winbindd_lookupname_send(TALLOC_CTX *mem_ctx,
577                                             struct tevent_context *ev,
578                                             struct winbindd_cli_state *cli,
579                                             struct winbindd_request *request);
580 NTSTATUS winbindd_lookupname_recv(struct tevent_req *req,
581                                   struct winbindd_response *response);
582
583 struct tevent_req *winbindd_allocate_uid_send(TALLOC_CTX *mem_ctx,
584                                               struct tevent_context *ev,
585                                               struct winbindd_cli_state *cli,
586                                               struct winbindd_request *request);
587 NTSTATUS winbindd_allocate_uid_recv(struct tevent_req *req,
588                                     struct winbindd_response *response);
589
590 struct tevent_req *winbindd_allocate_gid_send(TALLOC_CTX *mem_ctx,
591                                               struct tevent_context *ev,
592                                               struct winbindd_cli_state *cli,
593                                               struct winbindd_request *request);
594 NTSTATUS winbindd_allocate_gid_recv(struct tevent_req *req,
595                                     struct winbindd_response *response);
596
597 struct tevent_req *wb_queryuser_send(TALLOC_CTX *mem_ctx,
598                                      struct tevent_context *ev,
599                                      const struct dom_sid *user_sid);
600 NTSTATUS wb_queryuser_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
601                            struct wbint_userinfo **pinfo);
602
603 struct tevent_req *wb_getpwsid_send(TALLOC_CTX *mem_ctx,
604                                     struct tevent_context *ev,
605                                     const struct dom_sid *user_sid,
606                                     struct winbindd_pw *pw);
607 NTSTATUS wb_getpwsid_recv(struct tevent_req *req);
608
609 struct tevent_req *winbindd_getpwsid_send(TALLOC_CTX *mem_ctx,
610                                           struct tevent_context *ev,
611                                           struct winbindd_cli_state *cli,
612                                           struct winbindd_request *request);
613 NTSTATUS winbindd_getpwsid_recv(struct tevent_req *req,
614                                 struct winbindd_response *response);
615
616 struct tevent_req *winbindd_getpwnam_send(TALLOC_CTX *mem_ctx,
617                                           struct tevent_context *ev,
618                                           struct winbindd_cli_state *cli,
619                                           struct winbindd_request *request);
620 NTSTATUS winbindd_getpwnam_recv(struct tevent_req *req,
621                                 struct winbindd_response *response);
622
623 struct tevent_req *winbindd_getpwuid_send(TALLOC_CTX *mem_ctx,
624                                           struct tevent_context *ev,
625                                           struct winbindd_cli_state *cli,
626                                           struct winbindd_request *request);
627 NTSTATUS winbindd_getpwuid_recv(struct tevent_req *req,
628                                 struct winbindd_response *response);
629 struct tevent_req *wb_lookupuseraliases_send(TALLOC_CTX *mem_ctx,
630                                              struct tevent_context *ev,
631                                              struct winbindd_domain *domain,
632                                              int num_sids,
633                                              const struct dom_sid *sids);
634 NTSTATUS wb_lookupuseraliases_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
635                                    uint32_t *num_aliases, uint32_t **aliases);
636 struct tevent_req *winbindd_getsidaliases_send(TALLOC_CTX *mem_ctx,
637                                                struct tevent_context *ev,
638                                                struct winbindd_cli_state *cli,
639                                                struct winbindd_request *request);
640 NTSTATUS winbindd_getsidaliases_recv(struct tevent_req *req,
641                                      struct winbindd_response *response);
642 struct tevent_req *wb_lookupusergroups_send(TALLOC_CTX *mem_ctx,
643                                             struct tevent_context *ev,
644                                             const struct dom_sid *sid);
645 NTSTATUS wb_lookupusergroups_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
646                                   int *num_sids, struct dom_sid **sids);
647
648 struct tevent_req *winbindd_getuserdomgroups_send(TALLOC_CTX *mem_ctx,
649                                                   struct tevent_context *ev,
650                                                   struct winbindd_cli_state *cli,
651                                                   struct winbindd_request *request);
652 NTSTATUS winbindd_getuserdomgroups_recv(struct tevent_req *req,
653                                         struct winbindd_response *response);
654 struct tevent_req *wb_gettoken_send(TALLOC_CTX *mem_ctx,
655                                     struct tevent_context *ev,
656                                     const struct dom_sid *sid,
657                                     bool expand_local_aliases);
658 NTSTATUS wb_gettoken_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
659                           int *num_sids, struct dom_sid **sids);
660 struct tevent_req *winbindd_getgroups_send(TALLOC_CTX *mem_ctx,
661                                            struct tevent_context *ev,
662                                            struct winbindd_cli_state *cli,
663                                            struct winbindd_request *request);
664 NTSTATUS winbindd_getgroups_recv(struct tevent_req *req,
665                                  struct winbindd_response *response);
666
667 struct tevent_req *wb_seqnum_send(TALLOC_CTX *mem_ctx,
668                                   struct tevent_context *ev,
669                                   struct winbindd_domain *domain);
670 NTSTATUS wb_seqnum_recv(struct tevent_req *req, uint32_t *seqnum);
671
672 struct tevent_req *wb_seqnums_send(TALLOC_CTX *mem_ctx,
673                                    struct tevent_context *ev);
674 NTSTATUS wb_seqnums_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
675                          int *num_domains, struct winbindd_domain ***domains,
676                          NTSTATUS **stati, uint32_t **seqnums);
677
678 struct tevent_req *winbindd_show_sequence_send(TALLOC_CTX *mem_ctx,
679                                                struct tevent_context *ev,
680                                                struct winbindd_cli_state *cli,
681                                                struct winbindd_request *request);
682 NTSTATUS winbindd_show_sequence_recv(struct tevent_req *req,
683                                      struct winbindd_response *response);
684
685 struct tevent_req *wb_group_members_send(TALLOC_CTX *mem_ctx,
686                                          struct tevent_context *ev,
687                                          const struct dom_sid *sid,
688                                          enum lsa_SidType type,
689                                          int max_depth);
690 NTSTATUS wb_group_members_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
691                                struct db_context **members);
692 NTSTATUS add_member_to_db(struct db_context *db, struct dom_sid *sid,
693                           const char *name);
694
695 struct tevent_req *wb_getgrsid_send(TALLOC_CTX *mem_ctx,
696                                     struct tevent_context *ev,
697                                     const struct dom_sid *group_sid,
698                                     int max_nesting);
699 NTSTATUS wb_getgrsid_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
700                           const char **domname, const char **name, gid_t *gid,
701                           struct db_context **members);
702
703 struct tevent_req *winbindd_getgrgid_send(TALLOC_CTX *mem_ctx,
704                                           struct tevent_context *ev,
705                                           struct winbindd_cli_state *cli,
706                                           struct winbindd_request *request);
707 NTSTATUS winbindd_getgrgid_recv(struct tevent_req *req,
708                                 struct winbindd_response *response);
709
710 struct tevent_req *winbindd_getgrnam_send(TALLOC_CTX *mem_ctx,
711                                           struct tevent_context *ev,
712                                           struct winbindd_cli_state *cli,
713                                           struct winbindd_request *request);
714 NTSTATUS winbindd_getgrnam_recv(struct tevent_req *req,
715                                 struct winbindd_response *response);
716
717 struct tevent_req *winbindd_getusersids_send(TALLOC_CTX *mem_ctx,
718                                              struct tevent_context *ev,
719                                              struct winbindd_cli_state *cli,
720                                              struct winbindd_request *request);
721 NTSTATUS winbindd_getusersids_recv(struct tevent_req *req,
722                                    struct winbindd_response *response);
723
724 struct tevent_req *winbindd_lookuprids_send(TALLOC_CTX *mem_ctx,
725                                             struct tevent_context *ev,
726                                             struct winbindd_cli_state *cli,
727                                             struct winbindd_request *request);
728 NTSTATUS winbindd_lookuprids_recv(struct tevent_req *req,
729                                   struct winbindd_response *response);
730
731 struct tevent_req *wb_query_user_list_send(TALLOC_CTX *mem_ctx,
732                                            struct tevent_context *ev,
733                                            struct winbindd_domain *domain);
734 NTSTATUS wb_query_user_list_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
735                                  char **users);
736
737 struct tevent_req *wb_query_group_list_send(TALLOC_CTX *mem_ctx,
738                                             struct tevent_context *ev,
739                                             struct winbindd_domain *domain);
740 NTSTATUS wb_query_group_list_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
741                                   int *num_users,
742                                   struct wbint_Principal **groups);
743
744 struct tevent_req *wb_next_pwent_send(TALLOC_CTX *mem_ctx,
745                                       struct tevent_context *ev,
746                                       struct getpwent_state *gstate,
747                                       struct winbindd_pw *pw);
748 NTSTATUS wb_next_pwent_recv(struct tevent_req *req);
749
750 struct tevent_req *winbindd_setpwent_send(TALLOC_CTX *mem_ctx,
751                                           struct tevent_context *ev,
752                                           struct winbindd_cli_state *cli,
753                                           struct winbindd_request *request);
754 NTSTATUS winbindd_setpwent_recv(struct tevent_req *req,
755                                 struct winbindd_response *presp);
756
757 struct tevent_req *winbindd_getpwent_send(TALLOC_CTX *mem_ctx,
758                                           struct tevent_context *ev,
759                                           struct winbindd_cli_state *cli,
760                                           struct winbindd_request *request);
761 NTSTATUS winbindd_getpwent_recv(struct tevent_req *req,
762                                 struct winbindd_response *response);
763
764 struct tevent_req *winbindd_endpwent_send(TALLOC_CTX *mem_ctx,
765                                           struct tevent_context *ev,
766                                           struct winbindd_cli_state *cli,
767                                           struct winbindd_request *request);
768 NTSTATUS winbindd_endpwent_recv(struct tevent_req *req,
769                                 struct winbindd_response *response);
770
771 struct tevent_req *winbindd_dsgetdcname_send(TALLOC_CTX *mem_ctx,
772                                              struct tevent_context *ev,
773                                              struct winbindd_cli_state *cli,
774                                              struct winbindd_request *request);
775 NTSTATUS winbindd_dsgetdcname_recv(struct tevent_req *req,
776                                    struct winbindd_response *response);
777
778 struct tevent_req *wb_dsgetdcname_send(TALLOC_CTX *mem_ctx,
779                                        struct tevent_context *ev,
780                                        const char *domain_name,
781                                        const struct GUID *domain_guid,
782                                        const char *site_name,
783                                        uint32_t flags);
784 NTSTATUS wb_dsgetdcname_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
785                              struct netr_DsRGetDCNameInfo **pdcinfo);
786 NTSTATUS wb_dsgetdcname_gencache_set(const char *domname,
787                                      struct netr_DsRGetDCNameInfo *dcinfo);
788 NTSTATUS wb_dsgetdcname_gencache_get(TALLOC_CTX *mem_ctx,
789                                      const char *domname,
790                                      struct netr_DsRGetDCNameInfo **dcinfo);
791
792 struct tevent_req *winbindd_getdcname_send(TALLOC_CTX *mem_ctx,
793                                            struct tevent_context *ev,
794                                            struct winbindd_cli_state *cli,
795                                            struct winbindd_request *request);
796 NTSTATUS winbindd_getdcname_recv(struct tevent_req *req,
797                                  struct winbindd_response *response);
798
799 struct tevent_req *wb_next_grent_send(TALLOC_CTX *mem_ctx,
800                                       struct tevent_context *ev,
801                                       int max_nesting,
802                                       struct getgrent_state *gstate,
803                                       struct winbindd_gr *gr);
804 NTSTATUS wb_next_grent_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
805                             struct db_context **members);
806
807 struct tevent_req *winbindd_setgrent_send(TALLOC_CTX *mem_ctx,
808                                           struct tevent_context *ev,
809                                           struct winbindd_cli_state *cli,
810                                           struct winbindd_request *request);
811 NTSTATUS winbindd_setgrent_recv(struct tevent_req *req,
812                                 struct winbindd_response *response);
813 struct tevent_req *winbindd_getgrent_send(TALLOC_CTX *mem_ctx,
814                                           struct tevent_context *ev,
815                                           struct winbindd_cli_state *cli,
816                                           struct winbindd_request *request);
817 NTSTATUS winbindd_getgrent_recv(struct tevent_req *req,
818                                 struct winbindd_response *response);
819 struct tevent_req *winbindd_endgrent_send(TALLOC_CTX *mem_ctx,
820                                           struct tevent_context *ev,
821                                           struct winbindd_cli_state *cli,
822                                           struct winbindd_request *request);
823 NTSTATUS winbindd_endgrent_recv(struct tevent_req *req,
824                                 struct winbindd_response *response);
825
826 struct tevent_req *winbindd_list_users_send(TALLOC_CTX *mem_ctx,
827                                             struct tevent_context *ev,
828                                             struct winbindd_cli_state *cli,
829                                             struct winbindd_request *request);
830 NTSTATUS winbindd_list_users_recv(struct tevent_req *req,
831                                   struct winbindd_response *response);
832
833 struct tevent_req *winbindd_list_groups_send(TALLOC_CTX *mem_ctx,
834                                              struct tevent_context *ev,
835                                              struct winbindd_cli_state *cli,
836                                              struct winbindd_request *request);
837 NTSTATUS winbindd_list_groups_recv(struct tevent_req *req,
838                                    struct winbindd_response *response);
839
840 struct tevent_req *winbindd_check_machine_acct_send(TALLOC_CTX *mem_ctx,
841                                                     struct tevent_context *ev,
842                                                     struct winbindd_cli_state *cli,
843                                                     struct winbindd_request *request);
844 NTSTATUS winbindd_check_machine_acct_recv(struct tevent_req *req,
845                                           struct winbindd_response *presp);
846
847 struct tevent_req *winbindd_ping_dc_send(TALLOC_CTX *mem_ctx,
848                                          struct tevent_context *ev,
849                                          struct winbindd_cli_state *cli,
850                                          struct winbindd_request *request);
851 NTSTATUS winbindd_ping_dc_recv(struct tevent_req *req,
852                                struct winbindd_response *presp);
853
854 struct tevent_req *winbindd_change_machine_acct_send(TALLOC_CTX *mem_ctx,
855                                                      struct tevent_context *ev,
856                                                      struct winbindd_cli_state *cli,
857                                                      struct winbindd_request *request);
858 NTSTATUS winbindd_change_machine_acct_recv(struct tevent_req *req,
859                                            struct winbindd_response *presp);
860
861 struct tevent_req *winbindd_pam_auth_send(TALLOC_CTX *mem_ctx,
862                                           struct tevent_context *ev,
863                                           struct winbindd_cli_state *cli,
864                                           struct winbindd_request *request);
865 NTSTATUS winbindd_pam_auth_recv(struct tevent_req *req,
866                                 struct winbindd_response *response);
867
868 struct tevent_req *winbindd_pam_auth_crap_send(
869         TALLOC_CTX *mem_ctx,
870         struct tevent_context *ev,
871         struct winbindd_cli_state *cli,
872         struct winbindd_request *request);
873 NTSTATUS winbindd_pam_auth_crap_recv(struct tevent_req *req,
874                                      struct winbindd_response *response);
875
876 struct tevent_req *winbindd_pam_chauthtok_send(
877         TALLOC_CTX *mem_ctx,
878         struct tevent_context *ev,
879         struct winbindd_cli_state *cli,
880         struct winbindd_request *request);
881 NTSTATUS winbindd_pam_chauthtok_recv(struct tevent_req *req,
882                                      struct winbindd_response *response);
883
884 struct tevent_req *winbindd_pam_logoff_send(TALLOC_CTX *mem_ctx,
885                                             struct tevent_context *ev,
886                                             struct winbindd_cli_state *cli,
887                                             struct winbindd_request *request);
888 NTSTATUS winbindd_pam_logoff_recv(struct tevent_req *req,
889                                   struct winbindd_response *response);
890
891 struct tevent_req *winbindd_pam_chng_pswd_auth_crap_send(
892         TALLOC_CTX *mem_ctx,
893         struct tevent_context *ev,
894         struct winbindd_cli_state *cli,
895         struct winbindd_request *request);
896 NTSTATUS winbindd_pam_chng_pswd_auth_crap_recv(
897         struct tevent_req *req,
898         struct winbindd_response *response);
899
900 struct tevent_req *wb_lookupsids_send(TALLOC_CTX *mem_ctx,
901                                       struct tevent_context *ev,
902                                       struct dom_sid *sids,
903                                       uint32_t num_sids);
904 NTSTATUS wb_lookupsids_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
905                             struct lsa_RefDomainList **domains,
906                             struct lsa_TransNameArray **names);
907
908 struct tevent_req *wb_sids2xids_send(TALLOC_CTX *mem_ctx,
909                                      struct tevent_context *ev,
910                                      const struct dom_sid *sids,
911                                      const uint32_t num_sids);
912 NTSTATUS wb_sids2xids_recv(struct tevent_req *req,
913                            struct unixid xids[], uint32_t num_xids);
914 struct tevent_req *winbindd_sids_to_xids_send(TALLOC_CTX *mem_ctx,
915                                               struct tevent_context *ev,
916                                               struct winbindd_cli_state *cli,
917                                               struct winbindd_request *request);
918 NTSTATUS winbindd_sids_to_xids_recv(struct tevent_req *req,
919                                     struct winbindd_response *response);
920 struct tevent_req *wb_xids2sids_send(TALLOC_CTX *mem_ctx,
921                                      struct tevent_context *ev,
922                                      struct unixid *xids,
923                                      uint32_t num_xids);
924 NTSTATUS wb_xids2sids_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
925                            struct dom_sid **sids);
926 struct tevent_req *winbindd_xids_to_sids_send(TALLOC_CTX *mem_ctx,
927                                               struct tevent_context *ev,
928                                               struct winbindd_cli_state *cli,
929                                               struct winbindd_request *request);
930 NTSTATUS winbindd_xids_to_sids_recv(struct tevent_req *req,
931                                     struct winbindd_response *response);
932 struct tevent_req *winbindd_wins_byip_send(TALLOC_CTX *mem_ctx,
933                                            struct tevent_context *ev,
934                                            struct winbindd_cli_state *cli,
935                                            struct winbindd_request *request);
936 NTSTATUS winbindd_wins_byip_recv(struct tevent_req *req,
937                                  struct winbindd_response *presp);
938 struct tevent_req *winbindd_wins_byname_send(TALLOC_CTX *mem_ctx,
939                                              struct tevent_context *ev,
940                                              struct winbindd_cli_state *cli,
941                                              struct winbindd_request *request);
942 NTSTATUS winbindd_wins_byname_recv(struct tevent_req *req,
943                                    struct winbindd_response *presp);
944
945
946 /* The following definitions come from winbindd/winbindd_samr.c  */
947
948 NTSTATUS open_internal_samr_conn(TALLOC_CTX *mem_ctx,
949                                  struct winbindd_domain *domain,
950                                  struct rpc_pipe_client **samr_pipe,
951                                  struct policy_handle *samr_domain_hnd);
952 NTSTATUS open_internal_lsa_conn(TALLOC_CTX *mem_ctx,
953                                 struct rpc_pipe_client **lsa_pipe,
954                                 struct policy_handle *lsa_hnd);
955
956 /* The following definitions come from winbindd/winbindd_irpc.c  */
957 NTSTATUS wb_irpc_register(void);
958
959 /* The following definitions come from winbindd/winbindd_reconnect.c  */
960 bool reconnect_need_retry(NTSTATUS status, struct winbindd_domain *domain);
961
962 /* The following definitions come from winbindd/winbindd_gpupdate.c  */
963 void gpupdate_init(void);
964
965 /* The following comes from winbindd/winbindd_dual_srv.c */
966 bool reset_cm_connection_on_error(struct winbindd_domain *domain,
967                                   struct dcerpc_binding_handle *b,
968                                   NTSTATUS status);
969
970 #endif /*  _WINBINDD_PROTO_H_  */