Line data Source code
1 : /*
2 : Unix SMB/CIFS implementation.
3 :
4 : CLDAP server structures
5 :
6 : Copyright (C) Andrew Tridgell 2005
7 : Copyright (C) Andrew Bartlett <abartlet@samba.org> 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 : /* parser auto-generated by pidl, then hand-modified by abartlet */
24 :
25 : #include "includes.h"
26 : #include "../libcli/nbt/libnbt.h"
27 : #include "../libcli/netlogon/netlogon.h"
28 : #include "ndr_dns_utils.h"
29 :
30 :
31 : /* don't allow an unlimited number of name components */
32 : #define MAX_COMPONENTS 128
33 :
34 : /**
35 : print a nbt string
36 : */
37 81 : _PUBLIC_ void ndr_print_nbt_string(struct ndr_print *ndr, const char *name, const char *s)
38 : {
39 81 : ndr_print_string(ndr, name, s);
40 81 : }
41 :
42 : /*
43 : pull one component of a nbt_string
44 : */
45 110314 : static enum ndr_err_code ndr_pull_component(struct ndr_pull *ndr,
46 : uint8_t **component,
47 : uint32_t *offset,
48 : uint32_t *max_offset)
49 : {
50 1692 : uint8_t len;
51 110314 : unsigned int loops = 0;
52 123777 : while (loops < 5) {
53 123777 : if (*offset >= ndr->data_size) {
54 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
55 : "BAD NBT NAME component");
56 : }
57 123777 : len = ndr->data[*offset];
58 123777 : if (len == 0) {
59 42511 : *offset += 1;
60 42511 : *max_offset = MAX(*max_offset, *offset);
61 42511 : *component = NULL;
62 42511 : return NDR_ERR_SUCCESS;
63 : }
64 81266 : if ((len & 0xC0) == 0xC0) {
65 : /* its a label pointer */
66 13463 : if (1 + *offset >= ndr->data_size) {
67 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
68 : "BAD NBT NAME component");
69 : }
70 13463 : *max_offset = MAX(*max_offset, *offset + 2);
71 13463 : *offset = ((len&0x3F)<<8) | ndr->data[1 + *offset];
72 13463 : *max_offset = MAX(*max_offset, *offset);
73 13463 : loops++;
74 13463 : continue;
75 : }
76 67803 : if ((len & 0xC0) != 0) {
77 : /* its a reserved length field */
78 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
79 : "BAD NBT NAME component");
80 : }
81 67803 : if (*offset + len + 1 > ndr->data_size) {
82 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
83 : "BAD NBT NAME component");
84 : }
85 135606 : *component = (uint8_t*)talloc_strndup(
86 67803 : ndr->current_mem_ctx,
87 67803 : (const char *)&ndr->data[1 + *offset], len);
88 67803 : NDR_ERR_HAVE_NO_MEMORY(*component);
89 67803 : *offset += len + 1;
90 67803 : *max_offset = MAX(*max_offset, *offset);
91 67803 : return NDR_ERR_SUCCESS;
92 : }
93 :
94 : /* too many pointers */
95 0 : return ndr_pull_error(ndr, NDR_ERR_STRING, "BAD NBT NAME component");
96 : }
97 :
98 : /**
99 : pull a nbt_string from the wire
100 : */
101 42511 : _PUBLIC_ enum ndr_err_code ndr_pull_nbt_string(struct ndr_pull *ndr, ndr_flags_type ndr_flags, const char **s)
102 : {
103 42511 : uint32_t offset = ndr->offset;
104 42511 : uint32_t max_offset = offset;
105 535 : unsigned num_components;
106 535 : char *name;
107 :
108 42511 : if (!(ndr_flags & NDR_SCALARS)) {
109 0 : return NDR_ERR_SUCCESS;
110 : }
111 :
112 41976 : name = NULL;
113 :
114 : /* break up name into a list of components */
115 110314 : for (num_components=0;num_components<MAX_COMPONENTS;num_components++) {
116 110314 : uint8_t *component = NULL;
117 110314 : NDR_CHECK(ndr_pull_component(ndr, &component, &offset, &max_offset));
118 110314 : if (component == NULL) break;
119 67803 : if (name) {
120 27420 : name = talloc_asprintf_append_buffer(name, ".%s", component);
121 27420 : NDR_ERR_HAVE_NO_MEMORY(name);
122 : } else {
123 39888 : name = (char *)component;
124 : }
125 : }
126 42511 : if (num_components == MAX_COMPONENTS) {
127 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
128 : "BAD NBT NAME too many components");
129 : }
130 42511 : if (num_components == 0) {
131 2128 : name = talloc_strdup(ndr->current_mem_ctx, "");
132 2128 : NDR_ERR_HAVE_NO_MEMORY(name);
133 : }
134 :
135 42511 : (*s) = name;
136 42511 : ndr->offset = max_offset;
137 :
138 42511 : return NDR_ERR_SUCCESS;
139 : }
140 :
141 : /**
142 : push a nbt string to the wire
143 : */
144 37982 : _PUBLIC_ enum ndr_err_code ndr_push_nbt_string(struct ndr_push *ndr, ndr_flags_type ndr_flags, const char *s)
145 : {
146 37982 : return ndr_push_dns_string_list(ndr,
147 : &ndr->dns_string_list,
148 : ndr_flags,
149 : s,
150 : true);
151 : }
152 :
153 :
154 : /* Manually modified to handle the dom_sid being optional based on if it is present or all zero */
155 68 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_REQUEST(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct NETLOGON_SAM_LOGON_REQUEST *r)
156 : {
157 68 : if (ndr_flags & NDR_SCALARS) {
158 34 : NDR_CHECK(ndr_push_align(ndr, 4));
159 34 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->request_count));
160 : {
161 34 : libndr_flags _flags_save_string = ndr->flags;
162 34 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
163 34 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->computer_name));
164 34 : ndr->flags = _flags_save_string;
165 : }
166 : {
167 34 : libndr_flags _flags_save_string = ndr->flags;
168 34 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
169 34 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->user_name));
170 34 : ndr->flags = _flags_save_string;
171 : }
172 : {
173 34 : libndr_flags _flags_save_string = ndr->flags;
174 34 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
175 34 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->mailslot_name));
176 34 : ndr->flags = _flags_save_string;
177 : }
178 34 : NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->acct_control));
179 34 : NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_size_dom_sid0(&r->sid, ndr->flags)));
180 34 : if (ndr_size_dom_sid0(&r->sid, ndr->flags)) {
181 2 : struct ndr_push *_ndr_sid;
182 16 : libndr_flags _flags_save_DATA_BLOB = ndr->flags;
183 16 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
184 16 : NDR_CHECK(ndr_push_DATA_BLOB(ndr, NDR_SCALARS, r->_pad));
185 16 : ndr->flags = _flags_save_DATA_BLOB;
186 16 : NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
187 16 : NDR_CHECK(ndr_push_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
188 16 : NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
189 : }
190 34 : NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
191 34 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
192 34 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
193 : }
194 68 : if (ndr_flags & NDR_BUFFERS) {
195 4 : }
196 68 : return NDR_ERR_SUCCESS;
197 : }
198 :
199 : /* Manually modified to handle the dom_sid being optional based on if it is present (size is non-zero) or not */
200 120 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_REQUEST(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct NETLOGON_SAM_LOGON_REQUEST *r)
201 : {
202 120 : if (ndr_flags & NDR_SCALARS) {
203 60 : NDR_CHECK(ndr_pull_align(ndr, 4));
204 60 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->request_count));
205 : {
206 60 : libndr_flags _flags_save_string = ndr->flags;
207 60 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
208 60 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->computer_name));
209 60 : ndr->flags = _flags_save_string;
210 : }
211 : {
212 60 : libndr_flags _flags_save_string = ndr->flags;
213 60 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
214 60 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->user_name));
215 60 : ndr->flags = _flags_save_string;
216 : }
217 : {
218 60 : libndr_flags _flags_save_string = ndr->flags;
219 60 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
220 60 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->mailslot_name));
221 60 : ndr->flags = _flags_save_string;
222 : }
223 60 : NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->acct_control));
224 60 : NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->sid_size));
225 60 : if (r->sid_size) {
226 27 : libndr_flags _flags_save_DATA_BLOB = ndr->flags;
227 2 : struct ndr_pull *_ndr_sid;
228 27 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
229 27 : NDR_CHECK(ndr_pull_DATA_BLOB(ndr, NDR_SCALARS, &r->_pad));
230 27 : ndr->flags = _flags_save_DATA_BLOB;
231 27 : NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sid, 0, r->sid_size));
232 27 : NDR_CHECK(ndr_pull_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
233 27 : NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sid, 0, r->sid_size));
234 : } else {
235 33 : ZERO_STRUCT(r->sid);
236 : }
237 60 : NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
238 60 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
239 60 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
240 : }
241 120 : if (ndr_flags & NDR_BUFFERS) {
242 4 : }
243 120 : return NDR_ERR_SUCCESS;
244 : }
245 :
246 : /* Manually modified to only push some parts of the structure if certain flags are set */
247 2773 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct NETLOGON_SAM_LOGON_RESPONSE_EX *r)
248 : {
249 : {
250 2773 : libndr_flags _flags_save_STRUCT = ndr->flags;
251 2773 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
252 2773 : if (ndr_flags & NDR_SCALARS) {
253 2773 : NDR_CHECK(ndr_push_align(ndr, 4));
254 2773 : NDR_CHECK(ndr_push_netlogon_command(ndr, NDR_SCALARS, r->command));
255 2773 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->sbz));
256 2773 : NDR_CHECK(ndr_push_nbt_server_type(ndr, NDR_SCALARS, r->server_type));
257 2773 : NDR_CHECK(ndr_push_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
258 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->forest));
259 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->dns_domain));
260 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_dns_name));
261 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->domain_name));
262 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_name));
263 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->user_name));
264 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->server_site));
265 2773 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->client_site));
266 2773 : if (r->nt_version & NETLOGON_NT_VERSION_5EX_WITH_IP) {
267 272 : NDR_CHECK(ndr_push_uint8(ndr, NDR_SCALARS, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
268 : {
269 0 : struct ndr_push *_ndr_sockaddr;
270 272 : NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
271 272 : NDR_CHECK(ndr_push_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
272 272 : NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
273 : }
274 : }
275 2773 : if (r->nt_version & NETLOGON_NT_VERSION_WITH_CLOSEST_SITE) {
276 0 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->next_closest_site));
277 : }
278 2773 : NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
279 2773 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
280 2773 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
281 : }
282 2773 : if (ndr_flags & NDR_BUFFERS) {
283 2773 : NDR_CHECK(ndr_push_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
284 : }
285 2773 : ndr->flags = _flags_save_STRUCT;
286 : }
287 2773 : return NDR_ERR_SUCCESS;
288 : }
289 :
290 : /* Manually modified to only pull some parts of the structure if certain flags provided */
291 2517 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct NETLOGON_SAM_LOGON_RESPONSE_EX *r,
292 : uint32_t nt_version_flags)
293 : {
294 : {
295 2517 : libndr_flags _flags_save_STRUCT = ndr->flags;
296 2517 : ZERO_STRUCTP(r);
297 2517 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
298 2517 : if (ndr_flags & NDR_SCALARS) {
299 2517 : NDR_CHECK(ndr_pull_align(ndr, 4));
300 2517 : NDR_CHECK(ndr_pull_netlogon_command(ndr, NDR_SCALARS, &r->command));
301 2517 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->sbz));
302 2517 : NDR_CHECK(ndr_pull_nbt_server_type(ndr, NDR_SCALARS, &r->server_type));
303 2517 : NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
304 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->forest));
305 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->dns_domain));
306 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_dns_name));
307 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->domain_name));
308 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_name));
309 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->user_name));
310 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->server_site));
311 2517 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->client_site));
312 2517 : if (nt_version_flags & NETLOGON_NT_VERSION_5EX_WITH_IP) {
313 261 : NDR_CHECK(ndr_pull_uint8(ndr, NDR_SCALARS, &r->sockaddr_size));
314 : {
315 0 : struct ndr_pull *_ndr_sockaddr;
316 261 : NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sockaddr, 0, r->sockaddr_size));
317 261 : NDR_CHECK(ndr_pull_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
318 261 : NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sockaddr, 0, r->sockaddr_size));
319 : }
320 : }
321 2517 : if (nt_version_flags & NETLOGON_NT_VERSION_WITH_CLOSEST_SITE) {
322 0 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->next_closest_site));
323 : }
324 2517 : NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
325 2517 : if (r->nt_version != nt_version_flags) {
326 0 : return NDR_ERR_VALIDATE;
327 : }
328 2517 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
329 2517 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
330 : }
331 2517 : if (ndr_flags & NDR_BUFFERS) {
332 2517 : NDR_CHECK(ndr_pull_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
333 : }
334 2517 : ndr->flags = _flags_save_STRUCT;
335 : }
336 2517 : return NDR_ERR_SUCCESS;
337 : }
338 :
339 4 : _PUBLIC_ enum ndr_err_code ndr_push_netlogon_samlogon_response(struct ndr_push *ndr, ndr_flags_type ndr_flags, const struct netlogon_samlogon_response *r)
340 : {
341 4 : if (r->ntver == NETLOGON_NT_VERSION_1) {
342 0 : NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE_NT40(
343 : ndr, ndr_flags, &r->data.nt4));
344 4 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
345 4 : NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
346 : ndr, ndr_flags, &r->data.nt5_ex));
347 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5) {
348 0 : NDR_CHECK(ndr_push_NETLOGON_SAM_LOGON_RESPONSE(
349 : ndr, ndr_flags, &r->data.nt5));
350 : } else {
351 0 : return NDR_ERR_BAD_SWITCH;
352 : }
353 :
354 0 : return NDR_ERR_SUCCESS;
355 : }
356 :
357 156 : _PUBLIC_ enum ndr_err_code ndr_pull_netlogon_samlogon_response(struct ndr_pull *ndr, ndr_flags_type ndr_flags, struct netlogon_samlogon_response *r)
358 : {
359 156 : if (ndr->data_size < 8) {
360 0 : return NDR_ERR_BUFSIZE;
361 : }
362 :
363 : /* lmnttoken */
364 156 : if (SVAL(ndr->data, ndr->data_size - 4) != 0xffff) {
365 0 : return NDR_ERR_TOKEN;
366 : }
367 : /* lm20token */
368 156 : if (SVAL(ndr->data, ndr->data_size - 2) != 0xffff) {
369 0 : return NDR_ERR_TOKEN;
370 : }
371 :
372 156 : r->ntver = IVAL(ndr->data, ndr->data_size - 8);
373 :
374 156 : if (r->ntver == NETLOGON_NT_VERSION_1) {
375 0 : NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_NT40(
376 : ndr, ndr_flags, &r->data.nt4));
377 156 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
378 156 : NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
379 : ndr, ndr_flags, &r->data.nt5_ex, r->ntver));
380 156 : if (ndr->offset < ndr->data_size) {
381 0 : return ndr_pull_error(ndr, NDR_ERR_UNREAD_BYTES,
382 : "not all bytes consumed ofs[%"PRIu32"] size[%"PRIu32"]",
383 : ndr->offset, ndr->data_size);
384 : }
385 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5) {
386 0 : NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE(
387 : ndr, ndr_flags, &r->data.nt5));
388 : } else {
389 0 : return NDR_ERR_BAD_SWITCH;
390 : }
391 :
392 150 : return NDR_ERR_SUCCESS;
393 : }
394 :
395 6 : _PUBLIC_ void ndr_print_netlogon_samlogon_response(struct ndr_print *ndr, const char *name, const struct netlogon_samlogon_response *r)
396 : {
397 6 : ndr_print_struct(ndr, name, "netlogon_samlogon_response");
398 6 : if (r == NULL) { ndr_print_null(ndr); return; }
399 6 : if (r->ntver == NETLOGON_NT_VERSION_1) {
400 0 : ndr_print_NETLOGON_SAM_LOGON_RESPONSE_NT40(ndr, "data.nt4", &r->data.nt4);
401 6 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
402 6 : ndr_print_NETLOGON_SAM_LOGON_RESPONSE_EX(ndr, "data.nt5_ex", &r->data.nt5_ex);
403 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5) {
404 0 : ndr_print_NETLOGON_SAM_LOGON_RESPONSE(ndr, "data.nt5", &r->data.nt5);
405 : }
406 : }
|