winbindd: pass down validation to append_auth_data()
[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 *domain_name,
138                         const char *name,
139                         struct dom_sid *sid,
140                         enum lsa_SidType *type);
141 void cache_name2sid_trusted(struct winbindd_domain *domain,
142                         const char *domain_name,
143                         const char *name,
144                         enum lsa_SidType type,
145                         const struct dom_sid *sid);
146 void cache_name2sid(struct winbindd_domain *domain, 
147                     const char *domain_name, const char *name,
148                     enum lsa_SidType type, const struct dom_sid *sid);
149 NTSTATUS wcache_query_user_fullname(struct winbindd_domain *domain,
150                                     TALLOC_CTX *mem_ctx,
151                                     const struct dom_sid *user_sid,
152                                     const char **full_name);
153
154 NTSTATUS wcache_count_cached_creds(struct winbindd_domain *domain, int *count);
155 NTSTATUS wcache_remove_oldest_cached_creds(struct winbindd_domain *domain, const struct dom_sid *sid) ;
156 bool set_global_winbindd_state_offline(void);
157 void set_global_winbindd_state_online(void);
158 bool get_global_winbindd_state_offline(void);
159 int winbindd_validate_cache(void);
160 int winbindd_validate_cache_nobackup(void);
161 bool winbindd_cache_validate_and_initialize(void);
162 bool wcache_tdc_fetch_list( struct winbindd_tdc_domain **domains, size_t *num_domains );
163 bool wcache_tdc_add_domain( struct winbindd_domain *domain );
164 struct winbindd_tdc_domain * wcache_tdc_fetch_domain( TALLOC_CTX *ctx, const char *name );
165 void wcache_tdc_clear( void );
166 bool wcache_store_seqnum(const char *domain_name, uint32_t seqnum,
167                          time_t last_seq_check);
168 bool wcache_fetch_ndr(TALLOC_CTX *mem_ctx, struct winbindd_domain *domain,
169                       uint32_t opnum, const DATA_BLOB *req, DATA_BLOB *resp);
170 void wcache_store_ndr(struct winbindd_domain *domain, uint32_t opnum,
171                       const DATA_BLOB *req, const DATA_BLOB *resp);
172
173 /* The following definitions come from winbindd/winbindd_ccache_access.c  */
174
175 void winbindd_ccache_ntlm_auth(struct winbindd_cli_state *state);
176 enum winbindd_result winbindd_dual_ccache_ntlm_auth(struct winbindd_domain *domain,
177                                                 struct winbindd_cli_state *state);
178 void winbindd_ccache_save(struct winbindd_cli_state *state);
179
180 /* The following definitions come from winbindd/winbindd_cm.c  */
181 void winbind_msg_domain_offline(struct messaging_context *msg_ctx,
182                                 void *private_data,
183                                 uint32_t msg_type,
184                                 struct server_id server_id,
185                                 DATA_BLOB *data);
186 void winbind_msg_domain_online(struct messaging_context *msg_ctx,
187                                 void *private_data,
188                                 uint32_t msg_type,
189                                 struct server_id server_id,
190                                 DATA_BLOB *data);
191
192 void set_domain_offline(struct winbindd_domain *domain);
193 void set_domain_online_request(struct winbindd_domain *domain);
194
195 struct ndr_interface_table;
196 NTSTATUS wb_open_internal_pipe(TALLOC_CTX *mem_ctx,
197                                const struct ndr_interface_table *table,
198                                struct rpc_pipe_client **ret_pipe);
199 void invalidate_cm_connection(struct winbindd_domain *domain);
200 void close_conns_after_fork(void);
201 NTSTATUS init_dc_connection(struct winbindd_domain *domain, bool need_rw_dc);
202 NTSTATUS cm_connect_sam(struct winbindd_domain *domain, TALLOC_CTX *mem_ctx,
203                         bool need_rw_dc,
204                         struct rpc_pipe_client **cli, struct policy_handle *sam_handle);
205 NTSTATUS cm_connect_lsa(struct winbindd_domain *domain, TALLOC_CTX *mem_ctx,
206                         struct rpc_pipe_client **cli, struct policy_handle *lsa_policy);
207 NTSTATUS cm_connect_lsat(struct winbindd_domain *domain,
208                          TALLOC_CTX *mem_ctx,
209                          struct rpc_pipe_client **cli,
210                          struct policy_handle *lsa_policy);
211 NTSTATUS cm_connect_netlogon(struct winbindd_domain *domain,
212                              struct rpc_pipe_client **cli);
213 bool fetch_current_dc_from_gencache(TALLOC_CTX *mem_ctx,
214                                     const char *domain_name,
215                                     char **p_dc_name, char **p_dc_ip);
216
217 /* The following definitions come from winbindd/winbindd_cred_cache.c  */
218
219 bool ccache_entry_exists(const char *username);
220 bool ccache_entry_identical(const char *username,
221                             uid_t uid,
222                             const char *ccname);
223 void ccache_remove_all_after_fork(void);
224 void ccache_regain_all_now(void);
225 NTSTATUS add_ccache_to_list(const char *princ_name,
226                             const char *ccname,
227                             const char *service,
228                             const char *username,
229                             const char *password,
230                             const char *realm,
231                             uid_t uid,
232                             time_t create_time,
233                             time_t ticket_end,
234                             time_t renew_until,
235                             bool postponed_request);
236 NTSTATUS remove_ccache(const char *username);
237 struct WINBINDD_MEMORY_CREDS *find_memory_creds_by_name(const char *username);
238 NTSTATUS winbindd_add_memory_creds(const char *username,
239                                    uid_t uid,
240                                    const char *pass);
241 NTSTATUS winbindd_delete_memory_creds(const char *username);
242 NTSTATUS winbindd_replace_memory_creds(const char *username,
243                                        const char *pass);
244
245 /* The following definitions come from winbindd/winbindd_creds.c  */
246
247 NTSTATUS winbindd_get_creds(struct winbindd_domain *domain,
248                             TALLOC_CTX *mem_ctx,
249                             const struct dom_sid *sid,
250                             struct netr_SamInfo3 **info3,
251                             const uint8_t *cached_nt_pass[NT_HASH_LEN],
252                             const uint8_t *cred_salt[NT_HASH_LEN]);
253 NTSTATUS winbindd_store_creds(struct winbindd_domain *domain,
254                               const char *user, 
255                               const char *pass, 
256                               struct netr_SamInfo3 *info3);
257 NTSTATUS winbindd_update_creds_by_info3(struct winbindd_domain *domain,
258                                         const char *user,
259                                         const char *pass,
260                                         struct netr_SamInfo3 *info3);
261 NTSTATUS winbindd_update_creds_by_name(struct winbindd_domain *domain,
262                                        const char *user,
263                                        const char *pass);
264
265 /* The following definitions come from winbindd/winbindd_domain.c  */
266
267 void setup_domain_child(struct winbindd_domain *domain);
268
269 /* The following definitions come from winbindd/winbindd_dual.c  */
270
271 struct dcerpc_binding_handle *dom_child_handle(struct winbindd_domain *domain);
272 struct winbindd_child *choose_domain_child(struct winbindd_domain *domain);
273
274 struct tevent_req *wb_child_request_send(TALLOC_CTX *mem_ctx,
275                                          struct tevent_context *ev,
276                                          struct winbindd_child *child,
277                                          struct winbindd_request *request);
278 int wb_child_request_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
279                           struct winbindd_response **presponse, int *err);
280 struct tevent_req *wb_domain_request_send(TALLOC_CTX *mem_ctx,
281                                           struct tevent_context *ev,
282                                           struct winbindd_domain *domain,
283                                           struct winbindd_request *request);
284 int wb_domain_request_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
285                            struct winbindd_response **presponse, int *err);
286
287 void setup_child(struct winbindd_domain *domain, struct winbindd_child *child,
288                  const struct winbindd_child_dispatch_table *table,
289                  const char *logprefix,
290                  const char *logname);
291 void winbind_child_died(pid_t pid);
292 void winbindd_flush_negative_conn_cache(struct winbindd_domain *domain);
293 void winbind_msg_debug(struct messaging_context *msg_ctx,
294                          void *private_data,
295                          uint32_t msg_type,
296                          struct server_id server_id,
297                          DATA_BLOB *data);
298 void winbind_msg_offline(struct messaging_context *msg_ctx,
299                          void *private_data,
300                          uint32_t msg_type,
301                          struct server_id server_id,
302                          DATA_BLOB *data);
303 void winbind_msg_online(struct messaging_context *msg_ctx,
304                         void *private_data,
305                         uint32_t msg_type,
306                         struct server_id server_id,
307                         DATA_BLOB *data);
308 void winbind_msg_onlinestatus(struct messaging_context *msg_ctx,
309                               void *private_data,
310                               uint32_t msg_type,
311                               struct server_id server_id,
312                               DATA_BLOB *data);
313 void winbind_msg_dump_event_list(struct messaging_context *msg_ctx,
314                                  void *private_data,
315                                  uint32_t msg_type,
316                                  struct server_id server_id,
317                                  DATA_BLOB *data);
318 void winbind_msg_dump_domain_list(struct messaging_context *msg_ctx,
319                                   void *private_data,
320                                   uint32_t msg_type,
321                                   struct server_id server_id,
322                                   DATA_BLOB *data);
323 void winbind_msg_ip_dropped(struct messaging_context *msg_ctx,
324                             void *private_data,
325                             uint32_t msg_type,
326                             struct server_id server_id,
327                             DATA_BLOB *data);
328 void winbind_msg_ip_dropped_parent(struct messaging_context *msg_ctx,
329                                    void *private_data,
330                                    uint32_t msg_type,
331                                    struct server_id server_id,
332                                    DATA_BLOB *data);
333 NTSTATUS winbindd_reinit_after_fork(const struct winbindd_child *myself,
334                                     const char *logfilename);
335 struct winbindd_domain *wb_child_domain(void);
336
337 /* The following definitions come from winbindd/winbindd_group.c  */
338 bool fill_grent(TALLOC_CTX *mem_ctx, struct winbindd_gr *gr,
339                 const char *dom_name, const char *gr_name, gid_t unix_gid);
340
341 struct db_context;
342 NTSTATUS winbindd_print_groupmembers(struct db_context *members,
343                                      TALLOC_CTX *mem_ctx,
344                                      int *num_members, char **result);
345
346
347 /* The following definitions come from winbindd/winbindd_idmap.c  */
348
349 void init_idmap_child(void);
350 struct winbindd_child *idmap_child(void);
351 struct idmap_domain *idmap_find_domain_with_sid(const char *domname,
352                                                 const struct dom_sid *sid);
353 const char *idmap_config_const_string(const char *domname, const char *option,
354                                       const char *def);
355 bool idmap_config_bool(const char *domname, const char *option, bool def);
356 int idmap_config_int(const char *domname, const char *option, int def);
357 bool domain_has_idmap_config(const char *domname);
358 bool lp_scan_idmap_domains(bool (*fn)(const char *domname,
359                                       void *private_data),
360                            void *private_data);
361
362 /* The following definitions come from winbindd/winbindd_locator.c  */
363
364 void init_locator_child(void);
365 struct winbindd_child *locator_child(void);
366
367 /* The following definitions come from winbindd/winbindd_misc.c  */
368
369 void winbindd_list_trusted_domains(struct winbindd_cli_state *state);
370 enum winbindd_result winbindd_dual_list_trusted_domains(struct winbindd_domain *domain,
371                                                         struct winbindd_cli_state *state);
372 void winbindd_show_sequence(struct winbindd_cli_state *state);
373 void winbindd_domain_info(struct winbindd_cli_state *state);
374 void winbindd_dc_info(struct winbindd_cli_state *state);
375 void winbindd_ping(struct winbindd_cli_state *state);
376 void winbindd_info(struct winbindd_cli_state *state);
377 void winbindd_interface_version(struct winbindd_cli_state *state);
378 void winbindd_domain_name(struct winbindd_cli_state *state);
379 void winbindd_netbios_name(struct winbindd_cli_state *state);
380 void winbindd_priv_pipe_dir(struct winbindd_cli_state *state);
381
382 /* The following definitions come from winbindd/winbindd_ndr.c  */
383 struct ndr_print;
384 void ndr_print_winbindd_child(struct ndr_print *ndr,
385                               const char *name,
386                               const struct winbindd_child *r);
387 void ndr_print_winbindd_cm_conn(struct ndr_print *ndr,
388                                 const char *name,
389                                 const struct winbindd_cm_conn *r);
390 void ndr_print_winbindd_methods(struct ndr_print *ndr,
391                                 const char *name,
392                                 const struct winbindd_methods *r);
393 void ndr_print_winbindd_domain(struct ndr_print *ndr,
394                                const char *name,
395                                const struct winbindd_domain *r);
396
397 /* The following definitions come from winbindd/winbindd_pam.c  */
398
399 bool check_request_flags(uint32_t flags);
400 NTSTATUS append_auth_data(TALLOC_CTX *mem_ctx,
401                           struct winbindd_response *resp,
402                           uint32_t request_flags,
403                           uint16_t validation_level,
404                           union netr_Validation *validation,
405                           const char *name_domain,
406                           const char *name_user);
407 uid_t get_uid_from_request(struct winbindd_request *request);
408 struct winbindd_domain *find_auth_domain(uint8_t flags,
409                                          const char *domain_name);
410 enum winbindd_result winbindd_dual_pam_auth(struct winbindd_domain *domain,
411                                             struct winbindd_cli_state *state) ;
412 enum winbindd_result winbindd_dual_pam_auth_crap(struct winbindd_domain *domain,
413                                                  struct winbindd_cli_state *state) ;
414 enum winbindd_result winbindd_dual_pam_chauthtok(struct winbindd_domain *contact_domain,
415                                                  struct winbindd_cli_state *state);
416 enum winbindd_result winbindd_dual_pam_logoff(struct winbindd_domain *domain,
417                                               struct winbindd_cli_state *state) ;
418 enum winbindd_result winbindd_dual_pam_chng_pswd_auth_crap(struct winbindd_domain *domainSt, struct winbindd_cli_state *state);
419 NTSTATUS winbindd_pam_auth_pac_send(struct winbindd_cli_state *state,
420                                     struct netr_SamInfo3 **info3);
421
422 NTSTATUS winbind_dual_SamLogon(struct winbindd_domain *domain,
423                                TALLOC_CTX *mem_ctx,
424                                uint32_t logon_parameters,
425                                const char *name_user,
426                                const char *name_domain,
427                                const char *workstation,
428                                const uint8_t chal[8],
429                                DATA_BLOB lm_response,
430                                DATA_BLOB nt_response,
431                                uint8_t *authoritative,
432                                bool skip_sam,
433                                uint32_t *flags,
434                                uint16_t *_validation_level,
435                                union netr_Validation **_validation);
436
437 /* The following definitions come from winbindd/winbindd_util.c  */
438
439 struct winbindd_domain *domain_list(void);
440 struct winbindd_domain *wb_next_domain(struct winbindd_domain *domain);
441 bool domain_is_forest_root(const struct winbindd_domain *domain);
442 void rescan_trusted_domains(struct tevent_context *ev, struct tevent_timer *te,
443                             struct timeval now, void *private_data);
444 enum winbindd_result winbindd_dual_init_connection(struct winbindd_domain *domain,
445                                                    struct winbindd_cli_state *state);
446 bool init_domain_list(void);
447 struct winbindd_domain *find_domain_from_name_noinit(const char *domain_name);
448 struct winbindd_domain *find_domain_from_name(const char *domain_name);
449 struct winbindd_domain *find_domain_from_sid_noinit(const struct dom_sid *sid);
450 struct winbindd_domain *find_domain_from_sid(const struct dom_sid *sid);
451 struct winbindd_domain *find_our_domain(void);
452 struct winbindd_domain *find_lookup_domain_from_sid(const struct dom_sid *sid);
453 struct winbindd_domain *find_lookup_domain_from_name(const char *domain_name);
454 bool parse_domain_user(const char *domuser, fstring domain, fstring user);
455 bool parse_domain_user_talloc(TALLOC_CTX *mem_ctx, const char *domuser,
456                               char **domain, char **user);
457 bool canonicalize_username(fstring username_inout, fstring domain, fstring user);
458 void fill_domain_username(fstring name, const char *domain, const char *user, bool can_assume);
459 char *fill_domain_username_talloc(TALLOC_CTX *ctx,
460                                   const char *domain,
461                                   const char *user,
462                                   bool can_assume);
463 struct winbindd_cli_state *winbindd_client_list(void);
464 struct winbindd_cli_state *winbindd_client_list_tail(void);
465 struct winbindd_cli_state *
466 winbindd_client_list_prev(struct winbindd_cli_state *cli);
467 void winbindd_add_client(struct winbindd_cli_state *cli);
468 void winbindd_remove_client(struct winbindd_cli_state *cli);
469 void winbindd_promote_client(struct winbindd_cli_state *cli);
470 int winbindd_num_clients(void);
471 NTSTATUS lookup_usergroups_cached(TALLOC_CTX *mem_ctx,
472                                   const struct dom_sid *user_sid,
473                                   uint32_t *p_num_groups, struct dom_sid **user_sids);
474
475 NTSTATUS normalize_name_map(TALLOC_CTX *mem_ctx,
476                              const char *domain_name,
477                              const char *name,
478                              char **normalized);
479 NTSTATUS normalize_name_unmap(TALLOC_CTX *mem_ctx,
480                               char *name,
481                               char **normalized);
482
483 NTSTATUS resolve_username_to_alias(TALLOC_CTX *mem_ctx,
484                                    struct winbindd_domain *domain,
485                                    const char *name, char **alias);
486 NTSTATUS resolve_alias_to_username(TALLOC_CTX *mem_ctx,
487                                    struct winbindd_domain *domain,
488                                    const char *alias, char **name);
489
490 bool winbindd_can_contact_domain(struct winbindd_domain *domain);
491 bool winbindd_internal_child(struct winbindd_child *child);
492 void winbindd_set_locator_kdc_envs(const struct winbindd_domain *domain);
493 void winbindd_unset_locator_kdc_env(const struct winbindd_domain *domain);
494 void winbindd_set_locator_kdc_envs(const struct winbindd_domain *domain);
495 void winbindd_unset_locator_kdc_env(const struct winbindd_domain *domain);
496 void set_auth_errors(struct winbindd_response *resp, NTSTATUS result);
497 bool is_domain_offline(const struct winbindd_domain *domain);
498 bool is_domain_online(const struct winbindd_domain *domain);
499 bool parse_sidlist(TALLOC_CTX *mem_ctx, const char *sidstr,
500                    struct dom_sid **sids, uint32_t *num_sids);
501 bool parse_xidlist(TALLOC_CTX *mem_ctx, const char *xidstr,
502                    struct unixid **pxids, uint32_t *pnum_xids);
503
504 /* The following definitions come from winbindd/winbindd_wins.c  */
505
506 void winbindd_wins_byname(struct winbindd_cli_state *state);
507
508 struct tevent_req *wb_ping_send(TALLOC_CTX *mem_ctx, struct tevent_context *ev,
509                                 struct winbindd_cli_state *cli,
510                                 struct winbindd_request *request);
511 NTSTATUS wb_ping_recv(struct tevent_req *req,
512                       struct winbindd_response *resp);
513
514 enum winbindd_result winbindd_dual_ping(struct winbindd_domain *domain,
515                                         struct winbindd_cli_state *state);
516
517 struct dcerpc_binding_handle *wbint_binding_handle(TALLOC_CTX *mem_ctx,
518                                                 struct winbindd_domain *domain,
519                                                 struct winbindd_child *child);
520 enum winbindd_result winbindd_dual_ndrcmd(struct winbindd_domain *domain,
521                                           struct winbindd_cli_state *state);
522
523 struct tevent_req *wb_lookupsid_send(TALLOC_CTX *mem_ctx,
524                                      struct tevent_context *ev,
525                                      const struct dom_sid *sid);
526 NTSTATUS wb_lookupsid_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
527                            enum lsa_SidType *type, const char **domain,
528                            const char **name);
529
530 struct tevent_req *winbindd_lookupsid_send(TALLOC_CTX *mem_ctx,
531                                            struct tevent_context *ev,
532                                            struct winbindd_cli_state *cli,
533                                            struct winbindd_request *request);
534 NTSTATUS winbindd_lookupsid_recv(struct tevent_req *req,
535                                  struct winbindd_response *response);
536
537 struct tevent_req *winbindd_lookupsids_send(TALLOC_CTX *mem_ctx,
538                                             struct tevent_context *ev,
539                                             struct winbindd_cli_state *cli,
540                                             struct winbindd_request *request);
541 NTSTATUS winbindd_lookupsids_recv(struct tevent_req *req,
542                                   struct winbindd_response *response);
543
544 struct tevent_req *wb_lookupname_send(TALLOC_CTX *mem_ctx,
545                                       struct tevent_context *ev,
546                                       const char *dom_name, const char *name,
547                                       uint32_t flags);
548 NTSTATUS wb_lookupname_recv(struct tevent_req *req, struct dom_sid *sid,
549                             enum lsa_SidType *type);
550
551 struct tevent_req *winbindd_lookupname_send(TALLOC_CTX *mem_ctx,
552                                             struct tevent_context *ev,
553                                             struct winbindd_cli_state *cli,
554                                             struct winbindd_request *request);
555 NTSTATUS winbindd_lookupname_recv(struct tevent_req *req,
556                                   struct winbindd_response *response);
557
558 struct tevent_req *winbindd_allocate_uid_send(TALLOC_CTX *mem_ctx,
559                                               struct tevent_context *ev,
560                                               struct winbindd_cli_state *cli,
561                                               struct winbindd_request *request);
562 NTSTATUS winbindd_allocate_uid_recv(struct tevent_req *req,
563                                     struct winbindd_response *response);
564
565 struct tevent_req *winbindd_allocate_gid_send(TALLOC_CTX *mem_ctx,
566                                               struct tevent_context *ev,
567                                               struct winbindd_cli_state *cli,
568                                               struct winbindd_request *request);
569 NTSTATUS winbindd_allocate_gid_recv(struct tevent_req *req,
570                                     struct winbindd_response *response);
571
572 struct tevent_req *wb_queryuser_send(TALLOC_CTX *mem_ctx,
573                                      struct tevent_context *ev,
574                                      const struct dom_sid *user_sid);
575 NTSTATUS wb_queryuser_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
576                            struct wbint_userinfo **pinfo);
577
578 struct tevent_req *wb_getpwsid_send(TALLOC_CTX *mem_ctx,
579                                     struct tevent_context *ev,
580                                     const struct dom_sid *user_sid,
581                                     struct winbindd_pw *pw);
582 NTSTATUS wb_getpwsid_recv(struct tevent_req *req);
583
584 struct tevent_req *winbindd_getpwsid_send(TALLOC_CTX *mem_ctx,
585                                           struct tevent_context *ev,
586                                           struct winbindd_cli_state *cli,
587                                           struct winbindd_request *request);
588 NTSTATUS winbindd_getpwsid_recv(struct tevent_req *req,
589                                 struct winbindd_response *response);
590
591 struct tevent_req *winbindd_getpwnam_send(TALLOC_CTX *mem_ctx,
592                                           struct tevent_context *ev,
593                                           struct winbindd_cli_state *cli,
594                                           struct winbindd_request *request);
595 NTSTATUS winbindd_getpwnam_recv(struct tevent_req *req,
596                                 struct winbindd_response *response);
597
598 struct tevent_req *winbindd_getpwuid_send(TALLOC_CTX *mem_ctx,
599                                           struct tevent_context *ev,
600                                           struct winbindd_cli_state *cli,
601                                           struct winbindd_request *request);
602 NTSTATUS winbindd_getpwuid_recv(struct tevent_req *req,
603                                 struct winbindd_response *response);
604 struct tevent_req *wb_lookupuseraliases_send(TALLOC_CTX *mem_ctx,
605                                              struct tevent_context *ev,
606                                              struct winbindd_domain *domain,
607                                              int num_sids,
608                                              const struct dom_sid *sids);
609 NTSTATUS wb_lookupuseraliases_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
610                                    uint32_t *num_aliases, uint32_t **aliases);
611 struct tevent_req *winbindd_getsidaliases_send(TALLOC_CTX *mem_ctx,
612                                                struct tevent_context *ev,
613                                                struct winbindd_cli_state *cli,
614                                                struct winbindd_request *request);
615 NTSTATUS winbindd_getsidaliases_recv(struct tevent_req *req,
616                                      struct winbindd_response *response);
617 struct tevent_req *wb_lookupusergroups_send(TALLOC_CTX *mem_ctx,
618                                             struct tevent_context *ev,
619                                             const struct dom_sid *sid);
620 NTSTATUS wb_lookupusergroups_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
621                                   int *num_sids, struct dom_sid **sids);
622
623 struct tevent_req *winbindd_getuserdomgroups_send(TALLOC_CTX *mem_ctx,
624                                                   struct tevent_context *ev,
625                                                   struct winbindd_cli_state *cli,
626                                                   struct winbindd_request *request);
627 NTSTATUS winbindd_getuserdomgroups_recv(struct tevent_req *req,
628                                         struct winbindd_response *response);
629 struct tevent_req *wb_gettoken_send(TALLOC_CTX *mem_ctx,
630                                     struct tevent_context *ev,
631                                     const struct dom_sid *sid,
632                                     bool expand_local_aliases);
633 NTSTATUS wb_gettoken_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
634                           int *num_sids, struct dom_sid **sids);
635 struct tevent_req *winbindd_getgroups_send(TALLOC_CTX *mem_ctx,
636                                            struct tevent_context *ev,
637                                            struct winbindd_cli_state *cli,
638                                            struct winbindd_request *request);
639 NTSTATUS winbindd_getgroups_recv(struct tevent_req *req,
640                                  struct winbindd_response *response);
641
642 struct tevent_req *wb_seqnum_send(TALLOC_CTX *mem_ctx,
643                                   struct tevent_context *ev,
644                                   struct winbindd_domain *domain);
645 NTSTATUS wb_seqnum_recv(struct tevent_req *req, uint32_t *seqnum);
646
647 struct tevent_req *wb_seqnums_send(TALLOC_CTX *mem_ctx,
648                                    struct tevent_context *ev);
649 NTSTATUS wb_seqnums_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
650                          int *num_domains, struct winbindd_domain ***domains,
651                          NTSTATUS **stati, uint32_t **seqnums);
652
653 struct tevent_req *winbindd_show_sequence_send(TALLOC_CTX *mem_ctx,
654                                                struct tevent_context *ev,
655                                                struct winbindd_cli_state *cli,
656                                                struct winbindd_request *request);
657 NTSTATUS winbindd_show_sequence_recv(struct tevent_req *req,
658                                      struct winbindd_response *response);
659
660 struct tevent_req *wb_group_members_send(TALLOC_CTX *mem_ctx,
661                                          struct tevent_context *ev,
662                                          const struct dom_sid *sid,
663                                          enum lsa_SidType type,
664                                          int max_depth);
665 NTSTATUS wb_group_members_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
666                                struct db_context **members);
667 NTSTATUS add_member_to_db(struct db_context *db, struct dom_sid *sid,
668                           const char *name);
669
670 struct tevent_req *wb_getgrsid_send(TALLOC_CTX *mem_ctx,
671                                     struct tevent_context *ev,
672                                     const struct dom_sid *group_sid,
673                                     int max_nesting);
674 NTSTATUS wb_getgrsid_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
675                           const char **domname, const char **name, gid_t *gid,
676                           struct db_context **members);
677
678 struct tevent_req *winbindd_getgrgid_send(TALLOC_CTX *mem_ctx,
679                                           struct tevent_context *ev,
680                                           struct winbindd_cli_state *cli,
681                                           struct winbindd_request *request);
682 NTSTATUS winbindd_getgrgid_recv(struct tevent_req *req,
683                                 struct winbindd_response *response);
684
685 struct tevent_req *winbindd_getgrnam_send(TALLOC_CTX *mem_ctx,
686                                           struct tevent_context *ev,
687                                           struct winbindd_cli_state *cli,
688                                           struct winbindd_request *request);
689 NTSTATUS winbindd_getgrnam_recv(struct tevent_req *req,
690                                 struct winbindd_response *response);
691
692 struct tevent_req *winbindd_getusersids_send(TALLOC_CTX *mem_ctx,
693                                              struct tevent_context *ev,
694                                              struct winbindd_cli_state *cli,
695                                              struct winbindd_request *request);
696 NTSTATUS winbindd_getusersids_recv(struct tevent_req *req,
697                                    struct winbindd_response *response);
698
699 struct tevent_req *winbindd_lookuprids_send(TALLOC_CTX *mem_ctx,
700                                             struct tevent_context *ev,
701                                             struct winbindd_cli_state *cli,
702                                             struct winbindd_request *request);
703 NTSTATUS winbindd_lookuprids_recv(struct tevent_req *req,
704                                   struct winbindd_response *response);
705
706 struct tevent_req *wb_query_user_list_send(TALLOC_CTX *mem_ctx,
707                                            struct tevent_context *ev,
708                                            struct winbindd_domain *domain);
709 NTSTATUS wb_query_user_list_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
710                                  char **users);
711
712 struct tevent_req *wb_query_group_list_send(TALLOC_CTX *mem_ctx,
713                                             struct tevent_context *ev,
714                                             struct winbindd_domain *domain);
715 NTSTATUS wb_query_group_list_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
716                                   int *num_users,
717                                   struct wbint_Principal **groups);
718
719 struct tevent_req *wb_next_pwent_send(TALLOC_CTX *mem_ctx,
720                                       struct tevent_context *ev,
721                                       struct getpwent_state *gstate,
722                                       struct winbindd_pw *pw);
723 NTSTATUS wb_next_pwent_recv(struct tevent_req *req);
724
725 struct tevent_req *winbindd_setpwent_send(TALLOC_CTX *mem_ctx,
726                                           struct tevent_context *ev,
727                                           struct winbindd_cli_state *cli,
728                                           struct winbindd_request *request);
729 NTSTATUS winbindd_setpwent_recv(struct tevent_req *req,
730                                 struct winbindd_response *presp);
731
732 struct tevent_req *winbindd_getpwent_send(TALLOC_CTX *mem_ctx,
733                                           struct tevent_context *ev,
734                                           struct winbindd_cli_state *cli,
735                                           struct winbindd_request *request);
736 NTSTATUS winbindd_getpwent_recv(struct tevent_req *req,
737                                 struct winbindd_response *response);
738
739 struct tevent_req *winbindd_endpwent_send(TALLOC_CTX *mem_ctx,
740                                           struct tevent_context *ev,
741                                           struct winbindd_cli_state *cli,
742                                           struct winbindd_request *request);
743 NTSTATUS winbindd_endpwent_recv(struct tevent_req *req,
744                                 struct winbindd_response *response);
745
746 struct tevent_req *winbindd_dsgetdcname_send(TALLOC_CTX *mem_ctx,
747                                              struct tevent_context *ev,
748                                              struct winbindd_cli_state *cli,
749                                              struct winbindd_request *request);
750 NTSTATUS winbindd_dsgetdcname_recv(struct tevent_req *req,
751                                    struct winbindd_response *response);
752
753 struct tevent_req *wb_dsgetdcname_send(TALLOC_CTX *mem_ctx,
754                                        struct tevent_context *ev,
755                                        const char *domain_name,
756                                        const struct GUID *domain_guid,
757                                        const char *site_name,
758                                        uint32_t flags);
759 NTSTATUS wb_dsgetdcname_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
760                              struct netr_DsRGetDCNameInfo **pdcinfo);
761 NTSTATUS wb_dsgetdcname_gencache_set(const char *domname,
762                                      struct netr_DsRGetDCNameInfo *dcinfo);
763 NTSTATUS wb_dsgetdcname_gencache_get(TALLOC_CTX *mem_ctx,
764                                      const char *domname,
765                                      struct netr_DsRGetDCNameInfo **dcinfo);
766
767 struct tevent_req *winbindd_getdcname_send(TALLOC_CTX *mem_ctx,
768                                            struct tevent_context *ev,
769                                            struct winbindd_cli_state *cli,
770                                            struct winbindd_request *request);
771 NTSTATUS winbindd_getdcname_recv(struct tevent_req *req,
772                                  struct winbindd_response *response);
773
774 struct tevent_req *wb_next_grent_send(TALLOC_CTX *mem_ctx,
775                                       struct tevent_context *ev,
776                                       int max_nesting,
777                                       struct getgrent_state *gstate,
778                                       struct winbindd_gr *gr);
779 NTSTATUS wb_next_grent_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
780                             struct db_context **members);
781
782 struct tevent_req *winbindd_setgrent_send(TALLOC_CTX *mem_ctx,
783                                           struct tevent_context *ev,
784                                           struct winbindd_cli_state *cli,
785                                           struct winbindd_request *request);
786 NTSTATUS winbindd_setgrent_recv(struct tevent_req *req,
787                                 struct winbindd_response *response);
788 struct tevent_req *winbindd_getgrent_send(TALLOC_CTX *mem_ctx,
789                                           struct tevent_context *ev,
790                                           struct winbindd_cli_state *cli,
791                                           struct winbindd_request *request);
792 NTSTATUS winbindd_getgrent_recv(struct tevent_req *req,
793                                 struct winbindd_response *response);
794 struct tevent_req *winbindd_endgrent_send(TALLOC_CTX *mem_ctx,
795                                           struct tevent_context *ev,
796                                           struct winbindd_cli_state *cli,
797                                           struct winbindd_request *request);
798 NTSTATUS winbindd_endgrent_recv(struct tevent_req *req,
799                                 struct winbindd_response *response);
800
801 struct tevent_req *winbindd_list_users_send(TALLOC_CTX *mem_ctx,
802                                             struct tevent_context *ev,
803                                             struct winbindd_cli_state *cli,
804                                             struct winbindd_request *request);
805 NTSTATUS winbindd_list_users_recv(struct tevent_req *req,
806                                   struct winbindd_response *response);
807
808 struct tevent_req *winbindd_list_groups_send(TALLOC_CTX *mem_ctx,
809                                              struct tevent_context *ev,
810                                              struct winbindd_cli_state *cli,
811                                              struct winbindd_request *request);
812 NTSTATUS winbindd_list_groups_recv(struct tevent_req *req,
813                                    struct winbindd_response *response);
814
815 struct tevent_req *winbindd_check_machine_acct_send(TALLOC_CTX *mem_ctx,
816                                                     struct tevent_context *ev,
817                                                     struct winbindd_cli_state *cli,
818                                                     struct winbindd_request *request);
819 NTSTATUS winbindd_check_machine_acct_recv(struct tevent_req *req,
820                                           struct winbindd_response *presp);
821
822 struct tevent_req *winbindd_ping_dc_send(TALLOC_CTX *mem_ctx,
823                                          struct tevent_context *ev,
824                                          struct winbindd_cli_state *cli,
825                                          struct winbindd_request *request);
826 NTSTATUS winbindd_ping_dc_recv(struct tevent_req *req,
827                                struct winbindd_response *presp);
828
829 struct tevent_req *winbindd_change_machine_acct_send(TALLOC_CTX *mem_ctx,
830                                                      struct tevent_context *ev,
831                                                      struct winbindd_cli_state *cli,
832                                                      struct winbindd_request *request);
833 NTSTATUS winbindd_change_machine_acct_recv(struct tevent_req *req,
834                                            struct winbindd_response *presp);
835
836 struct tevent_req *winbindd_pam_auth_send(TALLOC_CTX *mem_ctx,
837                                           struct tevent_context *ev,
838                                           struct winbindd_cli_state *cli,
839                                           struct winbindd_request *request);
840 NTSTATUS winbindd_pam_auth_recv(struct tevent_req *req,
841                                 struct winbindd_response *response);
842
843 struct tevent_req *winbindd_pam_auth_crap_send(
844         TALLOC_CTX *mem_ctx,
845         struct tevent_context *ev,
846         struct winbindd_cli_state *cli,
847         struct winbindd_request *request);
848 NTSTATUS winbindd_pam_auth_crap_recv(struct tevent_req *req,
849                                      struct winbindd_response *response);
850
851 struct tevent_req *winbindd_pam_chauthtok_send(
852         TALLOC_CTX *mem_ctx,
853         struct tevent_context *ev,
854         struct winbindd_cli_state *cli,
855         struct winbindd_request *request);
856 NTSTATUS winbindd_pam_chauthtok_recv(struct tevent_req *req,
857                                      struct winbindd_response *response);
858
859 struct tevent_req *winbindd_pam_logoff_send(TALLOC_CTX *mem_ctx,
860                                             struct tevent_context *ev,
861                                             struct winbindd_cli_state *cli,
862                                             struct winbindd_request *request);
863 NTSTATUS winbindd_pam_logoff_recv(struct tevent_req *req,
864                                   struct winbindd_response *response);
865
866 struct tevent_req *winbindd_pam_chng_pswd_auth_crap_send(
867         TALLOC_CTX *mem_ctx,
868         struct tevent_context *ev,
869         struct winbindd_cli_state *cli,
870         struct winbindd_request *request);
871 NTSTATUS winbindd_pam_chng_pswd_auth_crap_recv(
872         struct tevent_req *req,
873         struct winbindd_response *response);
874
875 struct tevent_req *wb_lookupsids_send(TALLOC_CTX *mem_ctx,
876                                       struct tevent_context *ev,
877                                       struct dom_sid *sids,
878                                       uint32_t num_sids);
879 NTSTATUS wb_lookupsids_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
880                             struct lsa_RefDomainList **domains,
881                             struct lsa_TransNameArray **names);
882
883 struct tevent_req *wb_sids2xids_send(TALLOC_CTX *mem_ctx,
884                                      struct tevent_context *ev,
885                                      const struct dom_sid *sids,
886                                      const uint32_t num_sids);
887 NTSTATUS wb_sids2xids_recv(struct tevent_req *req,
888                            struct unixid xids[], uint32_t num_xids);
889 struct tevent_req *winbindd_sids_to_xids_send(TALLOC_CTX *mem_ctx,
890                                               struct tevent_context *ev,
891                                               struct winbindd_cli_state *cli,
892                                               struct winbindd_request *request);
893 NTSTATUS winbindd_sids_to_xids_recv(struct tevent_req *req,
894                                     struct winbindd_response *response);
895 struct tevent_req *wb_xids2sids_send(TALLOC_CTX *mem_ctx,
896                                      struct tevent_context *ev,
897                                      struct unixid *xids,
898                                      uint32_t num_xids);
899 NTSTATUS wb_xids2sids_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
900                            struct dom_sid **sids);
901 struct tevent_req *winbindd_xids_to_sids_send(TALLOC_CTX *mem_ctx,
902                                               struct tevent_context *ev,
903                                               struct winbindd_cli_state *cli,
904                                               struct winbindd_request *request);
905 NTSTATUS winbindd_xids_to_sids_recv(struct tevent_req *req,
906                                     struct winbindd_response *response);
907 struct tevent_req *winbindd_wins_byip_send(TALLOC_CTX *mem_ctx,
908                                            struct tevent_context *ev,
909                                            struct winbindd_cli_state *cli,
910                                            struct winbindd_request *request);
911 NTSTATUS winbindd_wins_byip_recv(struct tevent_req *req,
912                                  struct winbindd_response *presp);
913 struct tevent_req *winbindd_wins_byname_send(TALLOC_CTX *mem_ctx,
914                                              struct tevent_context *ev,
915                                              struct winbindd_cli_state *cli,
916                                              struct winbindd_request *request);
917 NTSTATUS winbindd_wins_byname_recv(struct tevent_req *req,
918                                    struct winbindd_response *presp);
919
920
921 /* The following definitions come from winbindd/winbindd_samr.c  */
922
923 NTSTATUS open_internal_samr_conn(TALLOC_CTX *mem_ctx,
924                                  struct winbindd_domain *domain,
925                                  struct rpc_pipe_client **samr_pipe,
926                                  struct policy_handle *samr_domain_hnd);
927 NTSTATUS open_internal_lsa_conn(TALLOC_CTX *mem_ctx,
928                                 struct rpc_pipe_client **lsa_pipe,
929                                 struct policy_handle *lsa_hnd);
930
931 /* The following definitions come from winbindd/winbindd_irpc.c  */
932 NTSTATUS wb_irpc_register(void);
933
934 /* The following definitions come from winbindd/winbindd_reconnect.c  */
935 bool reconnect_need_retry(NTSTATUS status, struct winbindd_domain *domain);
936
937 #endif /*  _WINBINDD_PROTO_H_  */