winbindd: Add retry also for ADS method calls
[samba.git] / source3 / winbindd / winbindd_ndr.c
1 /*
2  *  Unix SMB/CIFS implementation.
3  *  winbindd debug helper
4  *  Copyright (C) Guenther Deschner 2008
5  *
6  *  This program is free software; you can redistribute it and/or modify
7  *  it under the terms of the GNU General Public License as published by
8  *  the Free Software Foundation; either version 3 of the License, or
9  *  (at your option) any later version.
10  *
11  *  This program is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *  GNU General Public License for more details.
15  *
16  *  You should have received a copy of the GNU General Public License
17  *  along with this program; if not, see <http://www.gnu.org/licenses/>.
18  */
19
20 #include "includes.h"
21 #include "winbindd.h"
22 #include "../librpc/gen_ndr/ndr_netlogon.h"
23 #include "../librpc/gen_ndr/ndr_security.h"
24 #include "../librpc/gen_ndr/ndr_lsa.h"
25 #include "../librpc/ndr/libndr.h"
26
27 #undef DBGC_CLASS
28 #define DBGC_CLASS DBGC_WINBIND
29
30 /****************************************************************
31 ****************************************************************/
32
33 void ndr_print_winbindd_child(struct ndr_print *ndr,
34                               const char *name,
35                               const struct winbindd_child *r)
36 {
37         ndr_print_struct(ndr, name, "winbindd_child");
38         ndr->depth++;
39         ndr_print_ptr(ndr, "next", r->next);
40         ndr_print_ptr(ndr, "prev", r->prev);
41         ndr_print_uint32(ndr, "pid", (uint32_t)r->pid);
42 #if 0
43         ndr_print_winbindd_domain(ndr, "domain", r->domain);
44 #else
45         ndr_print_ptr(ndr, "domain", r->domain);
46 #endif
47         ndr_print_string(ndr, "logfilename", r->logfilename);
48         /* struct fd_event event; */
49         ndr_print_ptr(ndr, "lockout_policy_event", r->lockout_policy_event);
50         ndr_print_ptr(ndr, "table", r->table);
51         ndr->depth--;
52 }
53
54 /****************************************************************
55 ****************************************************************/
56
57 void ndr_print_winbindd_cm_conn(struct ndr_print *ndr,
58                                 const char *name,
59                                 const struct winbindd_cm_conn *r)
60 {
61         ndr_print_struct(ndr, name, "winbindd_cm_conn");
62         ndr->depth++;
63         ndr_print_ptr(ndr, "cli", r->cli);
64         ndr_print_ptr(ndr, "samr_pipe", r->samr_pipe);
65         ndr_print_policy_handle(ndr, "sam_connect_handle", &r->sam_connect_handle);
66         ndr_print_policy_handle(ndr, "sam_domain_handle", &r->sam_domain_handle);
67         ndr_print_ptr(ndr, "lsa_pipe", r->lsa_pipe);
68         ndr_print_policy_handle(ndr, "lsa_policy", &r->lsa_policy);
69         ndr_print_ptr(ndr, "netlogon_pipe", r->netlogon_pipe);
70         ndr->depth--;
71 }
72
73 /****************************************************************
74 ****************************************************************/
75
76 #ifdef HAVE_ADS
77 extern struct winbindd_methods ads_methods;
78 extern struct winbindd_methods reconnect_ads_methods;
79 #endif
80 extern struct winbindd_methods msrpc_methods;
81 extern struct winbindd_methods builtin_passdb_methods;
82 extern struct winbindd_methods sam_passdb_methods;
83 extern struct winbindd_methods reconnect_methods;
84 extern struct winbindd_methods cache_methods;
85
86 void ndr_print_winbindd_methods(struct ndr_print *ndr,
87                                 const char *name,
88                                 const struct winbindd_methods *r)
89 {
90         ndr_print_struct(ndr, name, "winbindd_methods");
91         ndr->depth++;
92
93         if (r == NULL) {
94                 ndr_print_string(ndr, name, "(NULL)");
95                 ndr->depth--;
96                 return;
97         }
98
99         if (r == &msrpc_methods) {
100                 ndr_print_string(ndr, name, "msrpc_methods");
101 #ifdef HAVE_ADS
102         } else if (r == &ads_methods) {
103                 ndr_print_string(ndr, name, "ads_methods");
104         } else if (r == &reconnect_ads_methods) {
105                 ndr_print_string(ndr, name, "reconnect_ads_methods");
106 #endif
107         } else if (r == &builtin_passdb_methods) {
108                 ndr_print_string(ndr, name, "builtin_passdb_methods");
109         } else if (r == &sam_passdb_methods) {
110                 ndr_print_string(ndr, name, "sam_passdb_methods");
111         } else if (r == &reconnect_methods) {
112                 ndr_print_string(ndr, name, "reconnect_methods");
113         } else if (r == &cache_methods) {
114                 ndr_print_string(ndr, name, "cache_methods");
115         } else {
116                 ndr_print_string(ndr, name, "UNKNOWN");
117         }
118         ndr->depth--;
119 }
120
121 /****************************************************************
122 ****************************************************************/
123
124 void ndr_print_winbindd_domain(struct ndr_print *ndr,
125                                const char *name,
126                                const struct winbindd_domain *r)
127 {
128         int i;
129         if (!r) {
130                 return;
131         }
132
133         ndr_print_struct(ndr, name, "winbindd_domain");
134         ndr->depth++;
135         ndr_print_string(ndr, "name", r->name);
136         ndr_print_string(ndr, "alt_name", r->alt_name);
137         ndr_print_string(ndr, "forest_name", r->forest_name);
138         ndr_print_dom_sid(ndr, "sid", &r->sid);
139         ndr_print_netr_TrustFlags(ndr, "domain_flags", r->domain_flags);
140         ndr_print_lsa_TrustType(ndr, "domain_type", r->domain_type);
141         ndr_print_lsa_TrustAttributes(ndr, "domain_trust_attribs", r->domain_trust_attribs);
142         ndr_print_bool(ndr, "initialized", r->initialized);
143         ndr_print_bool(ndr, "native_mode", r->native_mode);
144         ndr_print_bool(ndr, "active_directory", r->active_directory);
145         ndr_print_bool(ndr, "primary", r->primary);
146         ndr_print_bool(ndr, "internal", r->internal);
147         ndr_print_bool(ndr, "online", r->online);
148         ndr_print_time_t(ndr, "startup_time", r->startup_time);
149         ndr_print_bool(ndr, "startup", r->startup);
150         ndr_print_winbindd_methods(ndr, "methods", r->methods);
151         ndr_print_winbindd_methods(ndr, "backend", r->backend);
152         ndr_print_ptr(ndr, "private_data", r->private_data);
153         ndr_print_string(ndr, "dcname", r->dcname);
154         ndr_print_sockaddr_storage(ndr, "dcaddr", &r->dcaddr);
155         ndr_print_time_t(ndr, "last_seq_check", r->last_seq_check);
156         ndr_print_uint32(ndr, "sequence_number", r->sequence_number);
157         ndr_print_NTSTATUS(ndr, "last_status", r->last_status);
158         ndr_print_winbindd_cm_conn(ndr, "conn", &r->conn);
159         for (i=0; i<lp_winbind_max_domain_connections(); i++) {
160                 ndr_print_winbindd_child(ndr, "children", &r->children[i]);
161         }
162         ndr_print_uint32(ndr, "check_online_timeout", r->check_online_timeout);
163         ndr_print_ptr(ndr, "check_online_event", r->check_online_event);
164         ndr->depth--;
165 }