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 18 : _PUBLIC_ void ndr_print_nbt_string(struct ndr_print *ndr, const char *name, const char *s)
38 : {
39 18 : ndr_print_string(ndr, name, s);
40 18 : }
41 :
42 : /*
43 : pull one component of a nbt_string
44 : */
45 69179 : 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 : uint8_t len;
51 69179 : unsigned int loops = 0;
52 134016 : while (loops < 5) {
53 77654 : if (*offset >= ndr->data_size) {
54 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
55 : "BAD NBT NAME component");
56 : }
57 77654 : len = ndr->data[*offset];
58 77654 : if (len == 0) {
59 28654 : *offset += 1;
60 28654 : *max_offset = MAX(*max_offset, *offset);
61 28654 : *component = NULL;
62 28654 : return NDR_ERR_SUCCESS;
63 : }
64 49000 : if ((len & 0xC0) == 0xC0) {
65 : /* its a label pointer */
66 8475 : if (1 + *offset >= ndr->data_size) {
67 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
68 : "BAD NBT NAME component");
69 : }
70 8475 : *max_offset = MAX(*max_offset, *offset + 2);
71 8475 : *offset = ((len&0x3F)<<8) | ndr->data[1 + *offset];
72 8475 : *max_offset = MAX(*max_offset, *offset);
73 8475 : loops++;
74 8475 : continue;
75 : }
76 40525 : 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 40525 : if (*offset + len + 1 > ndr->data_size) {
82 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
83 : "BAD NBT NAME component");
84 : }
85 81050 : *component = (uint8_t*)talloc_strndup(
86 40525 : ndr->current_mem_ctx,
87 40525 : (const char *)&ndr->data[1 + *offset], len);
88 40525 : NDR_ERR_HAVE_NO_MEMORY(*component);
89 40525 : *offset += len + 1;
90 40525 : *max_offset = MAX(*max_offset, *offset);
91 40525 : 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 28654 : _PUBLIC_ enum ndr_err_code ndr_pull_nbt_string(struct ndr_pull *ndr, int ndr_flags, const char **s)
102 : {
103 28654 : uint32_t offset = ndr->offset;
104 28654 : uint32_t max_offset = offset;
105 : unsigned num_components;
106 : char *name;
107 :
108 28654 : if (!(ndr_flags & NDR_SCALARS)) {
109 0 : return NDR_ERR_SUCCESS;
110 : }
111 :
112 28654 : name = NULL;
113 :
114 : /* break up name into a list of components */
115 125541 : for (num_components=0;num_components<MAX_COMPONENTS;num_components++) {
116 69179 : uint8_t *component = NULL;
117 69179 : NDR_CHECK(ndr_pull_component(ndr, &component, &offset, &max_offset));
118 69179 : if (component == NULL) break;
119 40525 : if (name) {
120 12813 : name = talloc_asprintf_append_buffer(name, ".%s", component);
121 12813 : NDR_ERR_HAVE_NO_MEMORY(name);
122 : } else {
123 27712 : name = (char *)component;
124 : }
125 : }
126 28654 : if (num_components == MAX_COMPONENTS) {
127 0 : return ndr_pull_error(ndr, NDR_ERR_STRING,
128 : "BAD NBT NAME too many components");
129 : }
130 28654 : if (num_components == 0) {
131 942 : name = talloc_strdup(ndr->current_mem_ctx, "");
132 942 : NDR_ERR_HAVE_NO_MEMORY(name);
133 : }
134 :
135 28654 : (*s) = name;
136 28654 : ndr->offset = max_offset;
137 :
138 28654 : return NDR_ERR_SUCCESS;
139 : }
140 :
141 : /**
142 : push a nbt string to the wire
143 : */
144 23179 : _PUBLIC_ enum ndr_err_code ndr_push_nbt_string(struct ndr_push *ndr, int ndr_flags, const char *s)
145 : {
146 23179 : 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 16 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_REQUEST(struct ndr_push *ndr, int ndr_flags, const struct NETLOGON_SAM_LOGON_REQUEST *r)
156 : {
157 16 : if (ndr_flags & NDR_SCALARS) {
158 8 : NDR_CHECK(ndr_push_align(ndr, 4));
159 8 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->request_count));
160 : {
161 8 : uint32_t _flags_save_string = ndr->flags;
162 8 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
163 8 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->computer_name));
164 8 : ndr->flags = _flags_save_string;
165 : }
166 : {
167 8 : uint32_t _flags_save_string = ndr->flags;
168 8 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
169 8 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->user_name));
170 8 : ndr->flags = _flags_save_string;
171 : }
172 : {
173 8 : uint32_t _flags_save_string = ndr->flags;
174 8 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
175 8 : NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->mailslot_name));
176 8 : ndr->flags = _flags_save_string;
177 : }
178 8 : NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->acct_control));
179 8 : NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, ndr_size_dom_sid0(&r->sid, ndr->flags)));
180 8 : if (ndr_size_dom_sid0(&r->sid, ndr->flags)) {
181 : struct ndr_push *_ndr_sid;
182 4 : uint32_t _flags_save_DATA_BLOB = ndr->flags;
183 4 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
184 4 : NDR_CHECK(ndr_push_DATA_BLOB(ndr, NDR_SCALARS, r->_pad));
185 4 : ndr->flags = _flags_save_DATA_BLOB;
186 4 : NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
187 4 : NDR_CHECK(ndr_push_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
188 4 : NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sid, 0, ndr_size_dom_sid0(&r->sid, ndr->flags)));
189 : }
190 8 : NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
191 8 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
192 8 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
193 : }
194 16 : if (ndr_flags & NDR_BUFFERS) {
195 : }
196 16 : 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 18 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_REQUEST(struct ndr_pull *ndr, int ndr_flags, struct NETLOGON_SAM_LOGON_REQUEST *r)
201 : {
202 18 : if (ndr_flags & NDR_SCALARS) {
203 9 : NDR_CHECK(ndr_pull_align(ndr, 4));
204 9 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->request_count));
205 : {
206 9 : uint32_t _flags_save_string = ndr->flags;
207 9 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
208 9 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->computer_name));
209 9 : ndr->flags = _flags_save_string;
210 : }
211 : {
212 9 : uint32_t _flags_save_string = ndr->flags;
213 9 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
214 9 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->user_name));
215 9 : ndr->flags = _flags_save_string;
216 : }
217 : {
218 9 : uint32_t _flags_save_string = ndr->flags;
219 9 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM);
220 9 : NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->mailslot_name));
221 9 : ndr->flags = _flags_save_string;
222 : }
223 9 : NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->acct_control));
224 9 : NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->sid_size));
225 9 : if (r->sid_size) {
226 5 : uint32_t _flags_save_DATA_BLOB = ndr->flags;
227 : struct ndr_pull *_ndr_sid;
228 5 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_ALIGN4);
229 5 : NDR_CHECK(ndr_pull_DATA_BLOB(ndr, NDR_SCALARS, &r->_pad));
230 5 : ndr->flags = _flags_save_DATA_BLOB;
231 5 : NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sid, 0, r->sid_size));
232 5 : NDR_CHECK(ndr_pull_dom_sid0(_ndr_sid, NDR_SCALARS|NDR_BUFFERS, &r->sid));
233 5 : NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sid, 0, r->sid_size));
234 : } else {
235 4 : ZERO_STRUCT(r->sid);
236 : }
237 9 : NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
238 9 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
239 9 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
240 : }
241 18 : if (ndr_flags & NDR_BUFFERS) {
242 : }
243 18 : return NDR_ERR_SUCCESS;
244 : }
245 :
246 : /* Manually modified to only push some parts of the structure if certain flags are set */
247 1365 : enum ndr_err_code ndr_push_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_push *ndr, int ndr_flags, const struct NETLOGON_SAM_LOGON_RESPONSE_EX *r)
248 : {
249 : {
250 1365 : uint32_t _flags_save_STRUCT = ndr->flags;
251 1365 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
252 1365 : if (ndr_flags & NDR_SCALARS) {
253 1365 : NDR_CHECK(ndr_push_align(ndr, 4));
254 1365 : NDR_CHECK(ndr_push_netlogon_command(ndr, NDR_SCALARS, r->command));
255 1365 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->sbz));
256 1365 : NDR_CHECK(ndr_push_nbt_server_type(ndr, NDR_SCALARS, r->server_type));
257 1365 : NDR_CHECK(ndr_push_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
258 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->forest));
259 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->dns_domain));
260 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_dns_name));
261 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->domain_name));
262 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->pdc_name));
263 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->user_name));
264 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->server_site));
265 1365 : NDR_CHECK(ndr_push_nbt_string(ndr, NDR_SCALARS, r->client_site));
266 1365 : if (r->nt_version & NETLOGON_NT_VERSION_5EX_WITH_IP) {
267 259 : NDR_CHECK(ndr_push_uint8(ndr, NDR_SCALARS, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
268 : {
269 : struct ndr_push *_ndr_sockaddr;
270 259 : NDR_CHECK(ndr_push_subcontext_start(ndr, &_ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
271 259 : NDR_CHECK(ndr_push_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
272 259 : NDR_CHECK(ndr_push_subcontext_end(ndr, _ndr_sockaddr, 0, ndr_size_nbt_sockaddr(&r->sockaddr, ndr->flags)));
273 : }
274 : }
275 1365 : 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 1365 : NDR_CHECK(ndr_push_netlogon_nt_version_flags(ndr, NDR_SCALARS, r->nt_version));
279 1365 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lmnt_token));
280 1365 : NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->lm20_token));
281 : }
282 1365 : if (ndr_flags & NDR_BUFFERS) {
283 1365 : NDR_CHECK(ndr_push_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
284 : }
285 1365 : ndr->flags = _flags_save_STRUCT;
286 : }
287 1365 : return NDR_ERR_SUCCESS;
288 : }
289 :
290 : /* Manually modified to only pull some parts of the structure if certain flags provided */
291 1189 : enum ndr_err_code ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(struct ndr_pull *ndr, int ndr_flags, struct NETLOGON_SAM_LOGON_RESPONSE_EX *r,
292 : uint32_t nt_version_flags)
293 : {
294 : {
295 1189 : uint32_t _flags_save_STRUCT = ndr->flags;
296 1189 : ZERO_STRUCTP(r);
297 1189 : ndr_set_flags(&ndr->flags, LIBNDR_FLAG_NOALIGN);
298 1189 : if (ndr_flags & NDR_SCALARS) {
299 1189 : NDR_CHECK(ndr_pull_align(ndr, 4));
300 1189 : NDR_CHECK(ndr_pull_netlogon_command(ndr, NDR_SCALARS, &r->command));
301 1189 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->sbz));
302 1189 : NDR_CHECK(ndr_pull_nbt_server_type(ndr, NDR_SCALARS, &r->server_type));
303 1189 : NDR_CHECK(ndr_pull_GUID(ndr, NDR_SCALARS, &r->domain_uuid));
304 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->forest));
305 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->dns_domain));
306 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_dns_name));
307 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->domain_name));
308 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->pdc_name));
309 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->user_name));
310 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->server_site));
311 1189 : NDR_CHECK(ndr_pull_nbt_string(ndr, NDR_SCALARS, &r->client_site));
312 1189 : if (nt_version_flags & NETLOGON_NT_VERSION_5EX_WITH_IP) {
313 259 : NDR_CHECK(ndr_pull_uint8(ndr, NDR_SCALARS, &r->sockaddr_size));
314 : {
315 : struct ndr_pull *_ndr_sockaddr;
316 259 : NDR_CHECK(ndr_pull_subcontext_start(ndr, &_ndr_sockaddr, 0, r->sockaddr_size));
317 259 : NDR_CHECK(ndr_pull_nbt_sockaddr(_ndr_sockaddr, NDR_SCALARS|NDR_BUFFERS, &r->sockaddr));
318 259 : NDR_CHECK(ndr_pull_subcontext_end(ndr, _ndr_sockaddr, 0, r->sockaddr_size));
319 : }
320 : }
321 1189 : 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 1189 : NDR_CHECK(ndr_pull_netlogon_nt_version_flags(ndr, NDR_SCALARS, &r->nt_version));
325 1189 : if (r->nt_version != nt_version_flags) {
326 0 : return NDR_ERR_VALIDATE;
327 : }
328 1189 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lmnt_token));
329 1189 : NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->lm20_token));
330 : }
331 1189 : if (ndr_flags & NDR_BUFFERS) {
332 1189 : NDR_CHECK(ndr_pull_GUID(ndr, NDR_BUFFERS, &r->domain_uuid));
333 : }
334 1189 : ndr->flags = _flags_save_STRUCT;
335 : }
336 1189 : return NDR_ERR_SUCCESS;
337 : }
338 :
339 0 : _PUBLIC_ enum ndr_err_code ndr_push_netlogon_samlogon_response(struct ndr_push *ndr, int ndr_flags, const struct netlogon_samlogon_response *r)
340 : {
341 0 : 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 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
345 0 : 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 0 : _PUBLIC_ enum ndr_err_code ndr_pull_netlogon_samlogon_response(struct ndr_pull *ndr, int ndr_flags, struct netlogon_samlogon_response *r)
358 : {
359 0 : if (ndr->data_size < 8) {
360 0 : return NDR_ERR_BUFSIZE;
361 : }
362 :
363 : /* lmnttoken */
364 0 : if (SVAL(ndr->data, ndr->data_size - 4) != 0xffff) {
365 0 : return NDR_ERR_TOKEN;
366 : }
367 : /* lm20token */
368 0 : if (SVAL(ndr->data, ndr->data_size - 2) != 0xffff) {
369 0 : return NDR_ERR_TOKEN;
370 : }
371 :
372 0 : r->ntver = IVAL(ndr->data, ndr->data_size - 8);
373 :
374 0 : 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 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
378 0 : NDR_CHECK(ndr_pull_NETLOGON_SAM_LOGON_RESPONSE_EX_with_flags(
379 : ndr, ndr_flags, &r->data.nt5_ex, r->ntver));
380 0 : if (ndr->offset < ndr->data_size) {
381 0 : return ndr_pull_error(ndr, NDR_ERR_UNREAD_BYTES,
382 : "not all bytes consumed ofs[%u] size[%u]",
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 0 : return NDR_ERR_SUCCESS;
393 : }
394 :
395 0 : _PUBLIC_ void ndr_print_netlogon_samlogon_response(struct ndr_print *ndr, const char *name, struct netlogon_samlogon_response *r)
396 : {
397 0 : ndr_print_struct(ndr, name, "netlogon_samlogon_response");
398 0 : if (r == NULL) { ndr_print_null(ndr); return; }
399 0 : if (r->ntver == NETLOGON_NT_VERSION_1) {
400 0 : ndr_print_NETLOGON_SAM_LOGON_RESPONSE_NT40(ndr, "data.nt4", &r->data.nt4);
401 0 : } else if (r->ntver & NETLOGON_NT_VERSION_5EX) {
402 0 : 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 : }
|