r23271: merge service control pidl change for CloseServiceHandle() from SAMBA_3_0_26
[Samba.git] / source3 / rpc_parse / parse_samr.c
blobe7726fbb26cb93455a7feddc1485c72b7f78c987
1 /*
2 * Unix SMB/CIFS implementation.
3 * RPC Pipe client / server routines
4 * Copyright (C) Andrew Tridgell 1992-2000,
5 * Copyright (C) Luke Kenneth Casson Leighton 1996-2000,
6 * Copyright (C) Paul Ashton 1997-2000,
7 * Copyright (C) Elrond 2000,
8 * Copyright (C) Jeremy Allison 2001,
9 * Copyright (C) Jean François Micouleau 1998-2001,
10 * Copyright (C) Jim McDonough <jmcd@us.ibm.com> 2002.
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; either version 2 of the License, or
15 * (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, write to the Free Software
24 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
27 #include "includes.h"
29 #undef DBGC_CLASS
30 #define DBGC_CLASS DBGC_RPC_PARSE
32 /*******************************************************************
33 inits a SAMR_Q_CLOSE_HND structure.
34 ********************************************************************/
36 void init_samr_q_close_hnd(SAMR_Q_CLOSE_HND * q_c, POLICY_HND *hnd)
38 DEBUG(5, ("init_samr_q_close_hnd\n"));
40 q_c->pol = *hnd;
43 /*******************************************************************
44 reads or writes a structure.
45 ********************************************************************/
47 BOOL samr_io_q_close_hnd(const char *desc, SAMR_Q_CLOSE_HND * q_u,
48 prs_struct *ps, int depth)
50 if (q_u == NULL)
51 return False;
53 prs_debug(ps, depth, desc, "samr_io_q_close_hnd");
54 depth++;
56 if(!prs_align(ps))
57 return False;
59 return smb_io_pol_hnd("pol", &q_u->pol, ps, depth);
62 /*******************************************************************
63 reads or writes a structure.
64 ********************************************************************/
66 BOOL samr_io_r_close_hnd(const char *desc, SAMR_R_CLOSE_HND * r_u,
67 prs_struct *ps, int depth)
69 if (r_u == NULL)
70 return False;
72 prs_debug(ps, depth, desc, "samr_io_r_close_hnd");
73 depth++;
75 if(!prs_align(ps))
76 return False;
78 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
79 return False;
81 if(!prs_ntstatus("status", ps, depth, &r_u->status))
82 return False;
84 return True;
87 /*******************************************************************
88 inits a SAMR_Q_LOOKUP_DOMAIN structure.
89 ********************************************************************/
91 void init_samr_q_lookup_domain(SAMR_Q_LOOKUP_DOMAIN * q_u,
92 POLICY_HND *pol, char *dom_name)
94 DEBUG(5, ("init_samr_q_lookup_domain\n"));
96 q_u->connect_pol = *pol;
98 init_unistr2(&q_u->uni_domain, dom_name, UNI_FLAGS_NONE);
99 init_uni_hdr(&q_u->hdr_domain, &q_u->uni_domain);
102 /*******************************************************************
103 reads or writes a structure.
104 ********************************************************************/
105 BOOL samr_io_q_lookup_domain(const char *desc, SAMR_Q_LOOKUP_DOMAIN * q_u,
106 prs_struct *ps, int depth)
108 if (q_u == NULL)
109 return False;
111 prs_debug(ps, depth, desc, "samr_io_q_lookup_domain");
112 depth++;
114 if(!prs_align(ps))
115 return False;
117 if(!smb_io_pol_hnd("connect_pol", &q_u->connect_pol, ps, depth))
118 return False;
120 if(!smb_io_unihdr("hdr_domain", &q_u->hdr_domain, ps, depth))
121 return False;
123 if(!smb_io_unistr2("uni_domain", &q_u->uni_domain, q_u->hdr_domain.buffer, ps, depth))
124 return False;
126 return True;
129 /*******************************************************************
130 inits a SAMR_R_LOOKUP_DOMAIN structure.
131 ********************************************************************/
133 void init_samr_r_lookup_domain(SAMR_R_LOOKUP_DOMAIN * r_u,
134 DOM_SID *dom_sid, NTSTATUS status)
136 DEBUG(5, ("init_samr_r_lookup_domain\n"));
138 r_u->status = status;
139 r_u->ptr_sid = 0;
140 if (NT_STATUS_IS_OK(status)) {
141 r_u->ptr_sid = 1;
142 init_dom_sid2(&r_u->dom_sid, dom_sid);
146 /*******************************************************************
147 reads or writes a structure.
148 ********************************************************************/
150 BOOL samr_io_r_lookup_domain(const char *desc, SAMR_R_LOOKUP_DOMAIN * r_u,
151 prs_struct *ps, int depth)
153 if (r_u == NULL)
154 return False;
156 prs_debug(ps, depth, desc, "samr_io_r_lookup_domain");
157 depth++;
159 if(!prs_align(ps))
160 return False;
162 if(!prs_uint32("ptr", ps, depth, &r_u->ptr_sid))
163 return False;
165 if (r_u->ptr_sid != 0) {
166 if(!smb_io_dom_sid2("sid", &r_u->dom_sid, ps, depth))
167 return False;
168 if(!prs_align(ps))
169 return False;
172 if(!prs_ntstatus("status", ps, depth, &r_u->status))
173 return False;
175 return True;
178 /*******************************************************************
179 reads or writes a structure.
180 ********************************************************************/
182 void init_samr_q_remove_sid_foreign_domain(SAMR_Q_REMOVE_SID_FOREIGN_DOMAIN * q_u, POLICY_HND *dom_pol, DOM_SID *sid)
184 DEBUG(5, ("samr_init_samr_q_remove_sid_foreign_domain\n"));
186 q_u->dom_pol = *dom_pol;
187 init_dom_sid2(&q_u->sid, sid);
190 /*******************************************************************
191 reads or writes a structure.
192 ********************************************************************/
194 BOOL samr_io_q_remove_sid_foreign_domain(const char *desc, SAMR_Q_REMOVE_SID_FOREIGN_DOMAIN * q_u,
195 prs_struct *ps, int depth)
197 if (q_u == NULL)
198 return False;
200 prs_debug(ps, depth, desc, "samr_io_q_remove_sid_foreign_domain");
201 depth++;
203 if(!prs_align(ps))
204 return False;
206 if(!smb_io_pol_hnd("domain_pol", &q_u->dom_pol, ps, depth))
207 return False;
209 if(!smb_io_dom_sid2("sid", &q_u->sid, ps, depth))
210 return False;
212 if(!prs_align(ps))
213 return False;
215 return True;
218 /*******************************************************************
219 reads or writes a structure.
220 ********************************************************************/
222 BOOL samr_io_r_remove_sid_foreign_domain(const char *desc, SAMR_R_REMOVE_SID_FOREIGN_DOMAIN * r_u,
223 prs_struct *ps, int depth)
225 if (r_u == NULL)
226 return False;
228 prs_debug(ps, depth, desc, "samr_io_r_remove_sid_foreign_domain");
229 depth++;
231 if(!prs_align(ps))
232 return False;
234 if(!prs_ntstatus("status", ps, depth, &r_u->status))
235 return False;
237 return True;
240 /*******************************************************************
241 reads or writes a structure.
242 ********************************************************************/
244 void init_samr_q_open_domain(SAMR_Q_OPEN_DOMAIN * q_u,
245 POLICY_HND *pol, uint32 flags,
246 const DOM_SID *sid)
248 DEBUG(5, ("samr_init_samr_q_open_domain\n"));
250 q_u->pol = *pol;
251 q_u->flags = flags;
252 init_dom_sid2(&q_u->dom_sid, sid);
255 /*******************************************************************
256 reads or writes a structure.
257 ********************************************************************/
259 BOOL samr_io_q_open_domain(const char *desc, SAMR_Q_OPEN_DOMAIN * q_u,
260 prs_struct *ps, int depth)
262 if (q_u == NULL)
263 return False;
265 prs_debug(ps, depth, desc, "samr_io_q_open_domain");
266 depth++;
268 if(!prs_align(ps))
269 return False;
271 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
272 return False;
274 if(!prs_uint32("flags", ps, depth, &q_u->flags))
275 return False;
277 if(!smb_io_dom_sid2("sid", &q_u->dom_sid, ps, depth))
278 return False;
280 return True;
283 /*******************************************************************
284 reads or writes a structure.
285 ********************************************************************/
287 BOOL samr_io_r_open_domain(const char *desc, SAMR_R_OPEN_DOMAIN * r_u,
288 prs_struct *ps, int depth)
290 if (r_u == NULL)
291 return False;
293 prs_debug(ps, depth, desc, "samr_io_r_open_domain");
294 depth++;
296 if(!prs_align(ps))
297 return False;
299 if(!smb_io_pol_hnd("domain_pol", &r_u->domain_pol, ps, depth))
300 return False;
302 if(!prs_ntstatus("status", ps, depth, &r_u->status))
303 return False;
305 return True;
308 /*******************************************************************
309 reads or writes a structure.
310 ********************************************************************/
312 void init_samr_q_get_usrdom_pwinfo(SAMR_Q_GET_USRDOM_PWINFO * q_u,
313 POLICY_HND *user_pol)
315 DEBUG(5, ("samr_init_samr_q_get_usrdom_pwinfo\n"));
317 q_u->user_pol = *user_pol;
320 /*******************************************************************
321 reads or writes a structure.
322 ********************************************************************/
324 BOOL samr_io_q_get_usrdom_pwinfo(const char *desc, SAMR_Q_GET_USRDOM_PWINFO * q_u,
325 prs_struct *ps, int depth)
327 if (q_u == NULL)
328 return False;
330 prs_debug(ps, depth, desc, "samr_io_q_get_usrdom_pwinfo");
331 depth++;
333 if(!prs_align(ps))
334 return False;
336 return smb_io_pol_hnd("user_pol", &q_u->user_pol, ps, depth);
339 /*******************************************************************
340 Init.
341 ********************************************************************/
343 void init_samr_r_get_usrdom_pwinfo(SAMR_R_GET_USRDOM_PWINFO *r_u, NTSTATUS status)
345 DEBUG(5, ("init_samr_r_get_usrdom_pwinfo\n"));
347 r_u->min_pwd_length = 0x0000;
350 * used to be
351 * r_u->unknown_1 = 0x0015;
352 * but for trusts.
354 r_u->unknown_1 = 0x01D1;
355 r_u->unknown_1 = 0x0015;
357 r_u->password_properties = 0x00000000;
359 r_u->status = status;
362 /*******************************************************************
363 reads or writes a structure.
364 ********************************************************************/
366 BOOL samr_io_r_get_usrdom_pwinfo(const char *desc, SAMR_R_GET_USRDOM_PWINFO * r_u,
367 prs_struct *ps, int depth)
369 if (r_u == NULL)
370 return False;
372 prs_debug(ps, depth, desc, "samr_io_r_get_usrdom_pwinfo");
373 depth++;
375 if(!prs_align(ps))
376 return False;
378 if(!prs_uint16("min_pwd_length", ps, depth, &r_u->min_pwd_length))
379 return False;
380 if(!prs_uint16("unknown_1", ps, depth, &r_u->unknown_1))
381 return False;
382 if(!prs_uint32("password_properties", ps, depth, &r_u->password_properties))
383 return False;
385 if(!prs_ntstatus("status ", ps, depth, &r_u->status))
386 return False;
388 return True;
392 /*******************************************************************
393 reads or writes a structure.
394 ********************************************************************/
396 BOOL samr_io_q_set_sec_obj(const char *desc, SAMR_Q_SET_SEC_OBJ * q_u,
397 prs_struct *ps, int depth)
399 if (q_u == NULL)
400 return False;
402 prs_debug(ps, depth, desc, "samr_io_q_set_sec_obj");
403 depth++;
405 if(!prs_align(ps))
406 return False;
408 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
409 return False;
411 if(!prs_uint32("sec_info", ps, depth, &q_u->sec_info))
412 return False;
414 if(!sec_io_desc_buf("sec_desc", &q_u->buf, ps, depth))
415 return False;
417 return True;
421 /*******************************************************************
422 reads or writes a structure.
423 ********************************************************************/
425 void init_samr_q_query_sec_obj(SAMR_Q_QUERY_SEC_OBJ * q_u,
426 POLICY_HND *user_pol, uint32 sec_info)
428 DEBUG(5, ("samr_init_samr_q_query_sec_obj\n"));
430 q_u->user_pol = *user_pol;
431 q_u->sec_info = sec_info;
435 /*******************************************************************
436 reads or writes a structure.
437 ********************************************************************/
439 BOOL samr_io_q_query_sec_obj(const char *desc, SAMR_Q_QUERY_SEC_OBJ * q_u,
440 prs_struct *ps, int depth)
442 if (q_u == NULL)
443 return False;
445 prs_debug(ps, depth, desc, "samr_io_q_query_sec_obj");
446 depth++;
448 if(!prs_align(ps))
449 return False;
451 if(!smb_io_pol_hnd("user_pol", &q_u->user_pol, ps, depth))
452 return False;
454 if(!prs_uint32("sec_info", ps, depth, &q_u->sec_info))
455 return False;
457 return True;
460 /*******************************************************************
461 reads or writes a structure.
462 ********************************************************************/
464 void init_samr_q_query_domain_info(SAMR_Q_QUERY_DOMAIN_INFO * q_u,
465 POLICY_HND *domain_pol, uint16 switch_value)
467 DEBUG(5, ("samr_init_samr_q_query_domain_info\n"));
469 q_u->domain_pol = *domain_pol;
470 q_u->switch_value = switch_value;
473 /*******************************************************************
474 reads or writes a structure.
475 ********************************************************************/
477 BOOL samr_io_q_query_domain_info(const char *desc, SAMR_Q_QUERY_DOMAIN_INFO * q_u,
478 prs_struct *ps, int depth)
480 if (q_u == NULL)
481 return False;
483 prs_debug(ps, depth, desc, "samr_io_q_query_domain_info");
484 depth++;
486 if(!prs_align(ps))
487 return False;
489 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
490 return False;
492 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value))
493 return False;
495 return True;
498 /*******************************************************************
499 inits a structure.
500 ********************************************************************/
502 void init_unk_info1(SAM_UNK_INFO_1 *u_1, uint16 min_pass_len, uint16 pass_hist,
503 uint32 password_properties, NTTIME nt_expire, NTTIME nt_min_age)
505 u_1->min_length_password = min_pass_len;
506 u_1->password_history = pass_hist;
508 if (lp_check_password_script() && *lp_check_password_script()) {
509 password_properties |= DOMAIN_PASSWORD_COMPLEX;
511 u_1->password_properties = password_properties;
513 /* password never expire */
514 u_1->expire = nt_expire;
516 /* can change the password now */
517 u_1->min_passwordage = nt_min_age;
521 /*******************************************************************
522 reads or writes a structure.
523 ********************************************************************/
525 static BOOL sam_io_unk_info1(const char *desc, SAM_UNK_INFO_1 * u_1,
526 prs_struct *ps, int depth)
528 if (u_1 == NULL)
529 return False;
531 prs_debug(ps, depth, desc, "sam_io_unk_info1");
532 depth++;
534 if(!prs_uint16("min_length_password", ps, depth, &u_1->min_length_password))
535 return False;
536 if(!prs_uint16("password_history", ps, depth, &u_1->password_history))
537 return False;
538 if(!prs_uint32("password_properties", ps, depth, &u_1->password_properties))
539 return False;
540 if(!smb_io_time("expire", &u_1->expire, ps, depth))
541 return False;
542 if(!smb_io_time("min_passwordage", &u_1->min_passwordage, ps, depth))
543 return False;
545 return True;
548 /*******************************************************************
549 inits a structure.
550 ********************************************************************/
552 void init_unk_info2(SAM_UNK_INFO_2 * u_2,
553 const char *comment, const char *domain, const char *server,
554 uint32 seq_num, uint32 num_users, uint32 num_groups, uint32 num_alias, NTTIME nt_logout, uint32 server_role)
556 u_2->logout = nt_logout;
558 u_2->seq_num = seq_num;
561 u_2->unknown_4 = 0x00000001;
562 u_2->server_role = server_role;
563 u_2->unknown_6 = 0x00000001;
564 u_2->num_domain_usrs = num_users;
565 u_2->num_domain_grps = num_groups;
566 u_2->num_local_grps = num_alias;
568 init_unistr2(&u_2->uni_comment, comment, UNI_FLAGS_NONE);
569 init_uni_hdr(&u_2->hdr_comment, &u_2->uni_comment);
570 init_unistr2(&u_2->uni_domain, domain, UNI_FLAGS_NONE);
571 init_uni_hdr(&u_2->hdr_domain, &u_2->uni_domain);
572 init_unistr2(&u_2->uni_server, server, UNI_FLAGS_NONE);
573 init_uni_hdr(&u_2->hdr_server, &u_2->uni_server);
576 /*******************************************************************
577 reads or writes a structure.
578 ********************************************************************/
580 static BOOL sam_io_unk_info2(const char *desc, SAM_UNK_INFO_2 * u_2,
581 prs_struct *ps, int depth)
583 if (u_2 == NULL)
584 return False;
586 prs_debug(ps, depth, desc, "sam_io_unk_info2");
587 depth++;
589 if(!smb_io_time("logout", &u_2->logout, ps, depth))
590 return False;
591 if(!smb_io_unihdr("hdr_comment", &u_2->hdr_comment, ps, depth))
592 return False;
593 if(!smb_io_unihdr("hdr_domain", &u_2->hdr_domain, ps, depth))
594 return False;
595 if(!smb_io_unihdr("hdr_server", &u_2->hdr_server, ps, depth))
596 return False;
598 /* put all the data in here, at the moment, including what the above
599 pointer is referring to
602 if(!prs_uint64("seq_num ", ps, depth, &u_2->seq_num))
603 return False;
605 if(!prs_uint32("unknown_4 ", ps, depth, &u_2->unknown_4)) /* 0x0000 0001 */
606 return False;
607 if(!prs_uint32("server_role ", ps, depth, &u_2->server_role))
608 return False;
609 if(!prs_uint32("unknown_6 ", ps, depth, &u_2->unknown_6)) /* 0x0000 0001 */
610 return False;
611 if(!prs_uint32("num_domain_usrs ", ps, depth, &u_2->num_domain_usrs))
612 return False;
613 if(!prs_uint32("num_domain_grps", ps, depth, &u_2->num_domain_grps))
614 return False;
615 if(!prs_uint32("num_local_grps", ps, depth, &u_2->num_local_grps))
616 return False;
618 if(!smb_io_unistr2("uni_comment", &u_2->uni_comment, u_2->hdr_comment.buffer, ps, depth))
619 return False;
620 if(!smb_io_unistr2("uni_domain", &u_2->uni_domain, u_2->hdr_domain.buffer, ps, depth))
621 return False;
622 if(!smb_io_unistr2("uni_server", &u_2->uni_server, u_2->hdr_server.buffer, ps, depth))
623 return False;
625 return True;
628 /*******************************************************************
629 inits a structure.
630 ********************************************************************/
632 void init_unk_info3(SAM_UNK_INFO_3 *u_3, NTTIME nt_logout)
634 u_3->logout = nt_logout;
637 /*******************************************************************
638 reads or writes a structure.
639 ********************************************************************/
641 static BOOL sam_io_unk_info3(const char *desc, SAM_UNK_INFO_3 * u_3,
642 prs_struct *ps, int depth)
644 if (u_3 == NULL)
645 return False;
647 prs_debug(ps, depth, desc, "sam_io_unk_info3");
648 depth++;
650 if(!smb_io_time("logout", &u_3->logout, ps, depth))
651 return False;
653 return True;
656 /*******************************************************************
657 inits a structure.
658 ********************************************************************/
660 void init_unk_info4(SAM_UNK_INFO_4 * u_4,const char *comment)
662 init_unistr2(&u_4->uni_comment, comment, UNI_FLAGS_NONE);
663 init_uni_hdr(&u_4->hdr_comment, &u_4->uni_comment);
666 /*******************************************************************
667 reads or writes a structure.
668 ********************************************************************/
670 static BOOL sam_io_unk_info4(const char *desc, SAM_UNK_INFO_4 * u_4,
671 prs_struct *ps, int depth)
673 if (u_4 == NULL)
674 return False;
676 prs_debug(ps, depth, desc, "sam_io_unk_info4");
677 depth++;
679 if(!smb_io_unihdr("hdr_comment", &u_4->hdr_comment, ps, depth))
680 return False;
682 if(!smb_io_unistr2("uni_comment", &u_4->uni_comment, u_4->hdr_comment.buffer, ps, depth))
683 return False;
685 return True;
688 /*******************************************************************
689 inits a structure.
690 ********************************************************************/
692 void init_unk_info5(SAM_UNK_INFO_5 * u_5,const char *domain)
694 init_unistr2(&u_5->uni_domain, domain, UNI_FLAGS_NONE);
695 init_uni_hdr(&u_5->hdr_domain, &u_5->uni_domain);
698 /*******************************************************************
699 reads or writes a structure.
700 ********************************************************************/
702 static BOOL sam_io_unk_info5(const char *desc, SAM_UNK_INFO_5 * u_5,
703 prs_struct *ps, int depth)
705 if (u_5 == NULL)
706 return False;
708 prs_debug(ps, depth, desc, "sam_io_unk_info5");
709 depth++;
711 if(!smb_io_unihdr("hdr_domain", &u_5->hdr_domain, ps, depth))
712 return False;
714 if(!smb_io_unistr2("uni_domain", &u_5->uni_domain, u_5->hdr_domain.buffer, ps, depth))
715 return False;
717 return True;
720 /*******************************************************************
721 inits a structure.
722 ********************************************************************/
724 void init_unk_info6(SAM_UNK_INFO_6 * u_6, const char *server)
726 init_unistr2(&u_6->uni_server, server, UNI_FLAGS_NONE);
727 init_uni_hdr(&u_6->hdr_server, &u_6->uni_server);
730 /*******************************************************************
731 reads or writes a structure.
732 ********************************************************************/
734 static BOOL sam_io_unk_info6(const char *desc, SAM_UNK_INFO_6 * u_6,
735 prs_struct *ps, int depth)
737 if (u_6 == NULL)
738 return False;
740 prs_debug(ps, depth, desc, "sam_io_unk_info6");
741 depth++;
743 if(!smb_io_unihdr("hdr_server", &u_6->hdr_server, ps, depth))
744 return False;
746 if(!smb_io_unistr2("uni_server", &u_6->uni_server, u_6->hdr_server.buffer, ps, depth))
747 return False;
749 return True;
752 /*******************************************************************
753 inits a structure.
754 ********************************************************************/
756 void init_unk_info7(SAM_UNK_INFO_7 * u_7, uint32 server_role)
758 u_7->server_role = server_role;
761 /*******************************************************************
762 reads or writes a structure.
763 ********************************************************************/
765 static BOOL sam_io_unk_info7(const char *desc, SAM_UNK_INFO_7 * u_7,
766 prs_struct *ps, int depth)
768 if (u_7 == NULL)
769 return False;
771 prs_debug(ps, depth, desc, "sam_io_unk_info7");
772 depth++;
774 if(!prs_uint16("server_role", ps, depth, &u_7->server_role))
775 return False;
777 return True;
780 /*******************************************************************
781 inits a structure.
782 ********************************************************************/
784 void init_unk_info8(SAM_UNK_INFO_8 * u_8, uint32 seq_num)
786 unix_to_nt_time(&u_8->domain_create_time, 0);
787 u_8->seq_num = seq_num;
790 /*******************************************************************
791 reads or writes a structure.
792 ********************************************************************/
794 static BOOL sam_io_unk_info8(const char *desc, SAM_UNK_INFO_8 * u_8,
795 prs_struct *ps, int depth)
797 if (u_8 == NULL)
798 return False;
800 prs_debug(ps, depth, desc, "sam_io_unk_info8");
801 depth++;
803 if (!prs_uint64("seq_num", ps, depth, &u_8->seq_num))
804 return False;
806 if(!smb_io_time("domain_create_time", &u_8->domain_create_time, ps, depth))
807 return False;
809 return True;
812 /*******************************************************************
813 inits a structure.
814 ********************************************************************/
816 void init_unk_info9(SAM_UNK_INFO_9 * u_9, uint32 unknown)
818 u_9->unknown = unknown;
821 /*******************************************************************
822 reads or writes a structure.
823 ********************************************************************/
825 static BOOL sam_io_unk_info9(const char *desc, SAM_UNK_INFO_9 * u_9,
826 prs_struct *ps, int depth)
828 if (u_9 == NULL)
829 return False;
831 prs_debug(ps, depth, desc, "sam_io_unk_info9");
832 depth++;
834 if (!prs_uint32("unknown", ps, depth, &u_9->unknown))
835 return False;
837 return True;
840 /*******************************************************************
841 inits a structure.
842 ********************************************************************/
844 void init_unk_info12(SAM_UNK_INFO_12 * u_12, NTTIME nt_lock_duration, NTTIME nt_reset_time, uint16 lockout)
846 u_12->duration = nt_lock_duration;
847 u_12->reset_count = nt_reset_time;
849 u_12->bad_attempt_lockout = lockout;
852 /*******************************************************************
853 reads or writes a structure.
854 ********************************************************************/
856 static BOOL sam_io_unk_info12(const char *desc, SAM_UNK_INFO_12 * u_12,
857 prs_struct *ps, int depth)
859 if (u_12 == NULL)
860 return False;
862 prs_debug(ps, depth, desc, "sam_io_unk_info12");
863 depth++;
865 if(!smb_io_time("duration", &u_12->duration, ps, depth))
866 return False;
867 if(!smb_io_time("reset_count", &u_12->reset_count, ps, depth))
868 return False;
869 if(!prs_uint16("bad_attempt_lockout", ps, depth, &u_12->bad_attempt_lockout))
870 return False;
872 return True;
875 /*******************************************************************
876 inits a structure.
877 ********************************************************************/
879 void init_unk_info13(SAM_UNK_INFO_13 * u_13, uint32 seq_num)
881 unix_to_nt_time(&u_13->domain_create_time, 0);
882 u_13->seq_num = seq_num;
883 u_13->unknown1 = 0;
884 u_13->unknown2 = 0;
887 /*******************************************************************
888 reads or writes a structure.
889 ********************************************************************/
891 static BOOL sam_io_unk_info13(const char *desc, SAM_UNK_INFO_13 * u_13,
892 prs_struct *ps, int depth)
894 if (u_13 == NULL)
895 return False;
897 prs_debug(ps, depth, desc, "sam_io_unk_info13");
898 depth++;
900 if (!prs_uint64("seq_num", ps, depth, &u_13->seq_num))
901 return False;
903 if(!smb_io_time("domain_create_time", &u_13->domain_create_time, ps, depth))
904 return False;
906 if (!prs_uint32("unknown1", ps, depth, &u_13->unknown1))
907 return False;
908 if (!prs_uint32("unknown2", ps, depth, &u_13->unknown2))
909 return False;
911 return True;
914 /*******************************************************************
915 inits a SAMR_R_QUERY_DOMAIN_INFO structure.
916 ********************************************************************/
918 void init_samr_r_query_domain_info(SAMR_R_QUERY_DOMAIN_INFO * r_u,
919 uint16 switch_value, SAM_UNK_CTR * ctr,
920 NTSTATUS status)
922 DEBUG(5, ("init_samr_r_query_domain_info\n"));
924 r_u->ptr_0 = 0;
925 r_u->switch_value = 0;
926 r_u->status = status; /* return status */
928 if (NT_STATUS_IS_OK(status)) {
929 r_u->switch_value = switch_value;
930 r_u->ptr_0 = 1;
931 r_u->ctr = ctr;
935 /*******************************************************************
936 reads or writes a structure.
937 ********************************************************************/
939 BOOL samr_io_r_query_domain_info(const char *desc, SAMR_R_QUERY_DOMAIN_INFO * r_u,
940 prs_struct *ps, int depth)
942 if (r_u == NULL)
943 return False;
945 prs_debug(ps, depth, desc, "samr_io_r_query_domain_info");
946 depth++;
948 if(!prs_align(ps))
949 return False;
951 if(!prs_uint32("ptr_0 ", ps, depth, &r_u->ptr_0))
952 return False;
954 if (r_u->ptr_0 != 0 && r_u->ctr != NULL) {
955 if(!prs_uint16("switch_value", ps, depth, &r_u->switch_value))
956 return False;
957 if(!prs_align(ps))
958 return False;
960 switch (r_u->switch_value) {
961 case 0x0d:
962 if(!sam_io_unk_info13("unk_inf13", &r_u->ctr->info.inf13, ps, depth))
963 return False;
964 break;
965 case 0x0c:
966 if(!sam_io_unk_info12("unk_inf12", &r_u->ctr->info.inf12, ps, depth))
967 return False;
968 break;
969 case 0x09:
970 if(!sam_io_unk_info9("unk_inf9",&r_u->ctr->info.inf9, ps,depth))
971 return False;
972 break;
973 case 0x08:
974 if(!sam_io_unk_info8("unk_inf8",&r_u->ctr->info.inf8, ps,depth))
975 return False;
976 break;
977 case 0x07:
978 if(!sam_io_unk_info7("unk_inf7",&r_u->ctr->info.inf7, ps,depth))
979 return False;
980 break;
981 case 0x06:
982 if(!sam_io_unk_info6("unk_inf6",&r_u->ctr->info.inf6, ps,depth))
983 return False;
984 break;
985 case 0x05:
986 if(!sam_io_unk_info5("unk_inf5",&r_u->ctr->info.inf5, ps,depth))
987 return False;
988 break;
989 case 0x04:
990 if(!sam_io_unk_info4("unk_inf4",&r_u->ctr->info.inf4, ps,depth))
991 return False;
992 break;
993 case 0x03:
994 if(!sam_io_unk_info3("unk_inf3",&r_u->ctr->info.inf3, ps,depth))
995 return False;
996 break;
997 case 0x02:
998 if(!sam_io_unk_info2("unk_inf2",&r_u->ctr->info.inf2, ps,depth))
999 return False;
1000 break;
1001 case 0x01:
1002 if(!sam_io_unk_info1("unk_inf1",&r_u->ctr->info.inf1, ps,depth))
1003 return False;
1004 break;
1005 default:
1006 DEBUG(0, ("samr_io_r_query_domain_info: unknown switch level 0x%x\n",
1007 r_u->switch_value));
1008 r_u->status = NT_STATUS_INVALID_INFO_CLASS;
1009 return False;
1013 if(!prs_align(ps))
1014 return False;
1016 if(!prs_ntstatus("status", ps, depth, &r_u->status))
1017 return False;
1019 return True;
1022 /*******************************************************************
1023 reads or writes a structure.
1024 ********************************************************************/
1026 void init_samr_q_set_sec_obj(SAMR_Q_SET_SEC_OBJ * q_u,
1027 POLICY_HND *pol, uint32 sec_info, SEC_DESC_BUF *buf)
1029 DEBUG(5, ("samr_init_samr_q_set_sec_obj\n"));
1031 q_u->pol = *pol;
1032 q_u->sec_info = sec_info;
1033 q_u->buf = buf;
1037 /*******************************************************************
1038 reads or writes a SAMR_R_SET_SEC_OBJ structure.
1039 ********************************************************************/
1041 BOOL samr_io_r_set_sec_obj(const char *desc, SAMR_R_SET_SEC_OBJ * r_u,
1042 prs_struct *ps, int depth)
1044 if (r_u == NULL)
1045 return False;
1047 prs_debug(ps, depth, desc, "samr_io_r_set_sec_obj");
1048 depth++;
1050 if(!prs_align(ps))
1051 return False;
1053 if(!prs_ntstatus("status", ps, depth, &r_u->status))
1054 return False;
1056 return True;
1059 /*******************************************************************
1060 reads or writes a SAMR_R_QUERY_SEC_OBJ structure.
1061 ********************************************************************/
1063 BOOL samr_io_r_query_sec_obj(const char *desc, SAMR_R_QUERY_SEC_OBJ * r_u,
1064 prs_struct *ps, int depth)
1066 if (r_u == NULL)
1067 return False;
1069 prs_debug(ps, depth, desc, "samr_io_r_query_sec_obj");
1070 depth++;
1072 if(!prs_align(ps))
1073 return False;
1075 if(!prs_uint32("ptr", ps, depth, &r_u->ptr))
1076 return False;
1077 if (r_u->ptr != 0) {
1078 if(!sec_io_desc_buf("sec", &r_u->buf, ps, depth))
1079 return False;
1082 if(!prs_ntstatus("status", ps, depth, &r_u->status))
1083 return False;
1085 return True;
1088 /*******************************************************************
1089 reads or writes a SAM_STR1 structure.
1090 ********************************************************************/
1092 static BOOL sam_io_sam_str1(const char *desc, SAM_STR1 * sam, uint32 acct_buf,
1093 uint32 name_buf, uint32 desc_buf,
1094 prs_struct *ps, int depth)
1096 if (sam == NULL)
1097 return False;
1099 prs_debug(ps, depth, desc, "sam_io_sam_str1");
1100 depth++;
1102 if(!prs_align(ps))
1103 return False;
1104 if (!smb_io_unistr2("name", &sam->uni_acct_name, acct_buf, ps, depth))
1105 return False;
1107 if (!smb_io_unistr2("desc", &sam->uni_acct_desc, desc_buf, ps, depth))
1108 return False;
1110 if (!smb_io_unistr2("full", &sam->uni_full_name, name_buf, ps, depth))
1111 return False;
1113 return True;
1116 /*******************************************************************
1117 inits a SAM_ENTRY1 structure.
1118 ********************************************************************/
1120 static void init_sam_entry1(SAM_ENTRY1 *sam, uint32 user_idx,
1121 UNISTR2 *sam_name, UNISTR2 *sam_full,
1122 UNISTR2 *sam_desc, uint32 rid_user,
1123 uint32 acb_info)
1125 DEBUG(5, ("init_sam_entry1\n"));
1127 ZERO_STRUCTP(sam);
1129 sam->user_idx = user_idx;
1130 sam->rid_user = rid_user;
1131 sam->acb_info = acb_info;
1133 init_uni_hdr(&sam->hdr_acct_name, sam_name);
1134 init_uni_hdr(&sam->hdr_user_name, sam_full);
1135 init_uni_hdr(&sam->hdr_user_desc, sam_desc);
1138 /*******************************************************************
1139 reads or writes a SAM_ENTRY1 structure.
1140 ********************************************************************/
1142 static BOOL sam_io_sam_entry1(const char *desc, SAM_ENTRY1 * sam,
1143 prs_struct *ps, int depth)
1145 if (sam == NULL)
1146 return False;
1148 prs_debug(ps, depth, desc, "sam_io_sam_entry1");
1149 depth++;
1151 if(!prs_align(ps))
1152 return False;
1154 if(!prs_uint32("user_idx ", ps, depth, &sam->user_idx))
1155 return False;
1157 if(!prs_uint32("rid_user ", ps, depth, &sam->rid_user))
1158 return False;
1159 if(!prs_uint32("acb_info ", ps, depth, &sam->acb_info))
1160 return False;
1162 if (!smb_io_unihdr("hdr_acct_name", &sam->hdr_acct_name, ps, depth))
1163 return False;
1164 if (!smb_io_unihdr("hdr_user_desc", &sam->hdr_user_desc, ps, depth))
1165 return False;
1166 if (!smb_io_unihdr("hdr_user_name", &sam->hdr_user_name, ps, depth))
1167 return False;
1169 return True;
1172 /*******************************************************************
1173 reads or writes a SAM_STR2 structure.
1174 ********************************************************************/
1176 static BOOL sam_io_sam_str2(const char *desc, SAM_STR2 * sam, uint32 acct_buf,
1177 uint32 desc_buf, prs_struct *ps, int depth)
1179 if (sam == NULL)
1180 return False;
1182 prs_debug(ps, depth, desc, "sam_io_sam_str2");
1183 depth++;
1185 if(!prs_align(ps))
1186 return False;
1188 if(!smb_io_unistr2("uni_srv_name", &sam->uni_srv_name, acct_buf, ps, depth)) /* account name unicode string */
1189 return False;
1190 if(!smb_io_unistr2("uni_srv_desc", &sam->uni_srv_desc, desc_buf, ps, depth)) /* account desc unicode string */
1191 return False;
1193 return True;
1196 /*******************************************************************
1197 inits a SAM_ENTRY2 structure.
1198 ********************************************************************/
1199 static void init_sam_entry2(SAM_ENTRY2 * sam, uint32 user_idx,
1200 UNISTR2 *sam_name, UNISTR2 *sam_desc,
1201 uint32 rid_user, uint32 acb_info)
1203 DEBUG(5, ("init_sam_entry2\n"));
1205 sam->user_idx = user_idx;
1206 sam->rid_user = rid_user;
1207 sam->acb_info = acb_info;
1209 init_uni_hdr(&sam->hdr_srv_name, sam_name);
1210 init_uni_hdr(&sam->hdr_srv_desc, sam_desc);
1213 /*******************************************************************
1214 reads or writes a SAM_ENTRY2 structure.
1215 ********************************************************************/
1217 static BOOL sam_io_sam_entry2(const char *desc, SAM_ENTRY2 * sam,
1218 prs_struct *ps, int depth)
1220 if (sam == NULL)
1221 return False;
1223 prs_debug(ps, depth, desc, "sam_io_sam_entry2");
1224 depth++;
1226 if(!prs_align(ps))
1227 return False;
1229 if(!prs_uint32("user_idx ", ps, depth, &sam->user_idx))
1230 return False;
1232 if(!prs_uint32("rid_user ", ps, depth, &sam->rid_user))
1233 return False;
1234 if(!prs_uint32("acb_info ", ps, depth, &sam->acb_info))
1235 return False;
1237 if(!smb_io_unihdr("unihdr", &sam->hdr_srv_name, ps, depth)) /* account name unicode string header */
1238 return False;
1239 if(!smb_io_unihdr("unihdr", &sam->hdr_srv_desc, ps, depth)) /* account name unicode string header */
1240 return False;
1242 return True;
1245 /*******************************************************************
1246 reads or writes a SAM_STR3 structure.
1247 ********************************************************************/
1249 static BOOL sam_io_sam_str3(const char *desc, SAM_STR3 * sam, uint32 acct_buf,
1250 uint32 desc_buf, prs_struct *ps, int depth)
1252 if (sam == NULL)
1253 return False;
1255 prs_debug(ps, depth, desc, "sam_io_sam_str3");
1256 depth++;
1258 if(!prs_align(ps))
1259 return False;
1261 if(!smb_io_unistr2("uni_grp_name", &sam->uni_grp_name, acct_buf, ps, depth)) /* account name unicode string */
1262 return False;
1263 if(!smb_io_unistr2("uni_grp_desc", &sam->uni_grp_desc, desc_buf, ps, depth)) /* account desc unicode string */
1264 return False;
1266 return True;
1269 /*******************************************************************
1270 inits a SAM_ENTRY3 structure.
1271 ********************************************************************/
1273 static void init_sam_entry3(SAM_ENTRY3 * sam, uint32 grp_idx,
1274 UNISTR2 *grp_name, UNISTR2 *grp_desc,
1275 uint32 rid_grp)
1277 DEBUG(5, ("init_sam_entry3\n"));
1279 sam->grp_idx = grp_idx;
1280 sam->rid_grp = rid_grp;
1281 sam->attr = 0x07; /* group rid attributes - gets ignored by nt 4.0 */
1283 init_uni_hdr(&sam->hdr_grp_name, grp_name);
1284 init_uni_hdr(&sam->hdr_grp_desc, grp_desc);
1287 /*******************************************************************
1288 reads or writes a SAM_ENTRY3 structure.
1289 ********************************************************************/
1291 static BOOL sam_io_sam_entry3(const char *desc, SAM_ENTRY3 * sam,
1292 prs_struct *ps, int depth)
1294 if (sam == NULL)
1295 return False;
1297 prs_debug(ps, depth, desc, "sam_io_sam_entry3");
1298 depth++;
1300 if(!prs_align(ps))
1301 return False;
1303 if(!prs_uint32("grp_idx", ps, depth, &sam->grp_idx))
1304 return False;
1306 if(!prs_uint32("rid_grp", ps, depth, &sam->rid_grp))
1307 return False;
1308 if(!prs_uint32("attr ", ps, depth, &sam->attr))
1309 return False;
1311 if(!smb_io_unihdr("unihdr", &sam->hdr_grp_name, ps, depth)) /* account name unicode string header */
1312 return False;
1313 if(!smb_io_unihdr("unihdr", &sam->hdr_grp_desc, ps, depth)) /* account name unicode string header */
1314 return False;
1316 return True;
1319 /*******************************************************************
1320 inits a SAM_ENTRY4 structure.
1321 ********************************************************************/
1323 static void init_sam_entry4(SAM_ENTRY4 * sam, uint32 user_idx,
1324 uint32 len_acct_name)
1326 DEBUG(5, ("init_sam_entry4\n"));
1328 sam->user_idx = user_idx;
1329 init_str_hdr(&sam->hdr_acct_name, len_acct_name+1, len_acct_name, len_acct_name != 0);
1332 /*******************************************************************
1333 reads or writes a SAM_ENTRY4 structure.
1334 ********************************************************************/
1336 static BOOL sam_io_sam_entry4(const char *desc, SAM_ENTRY4 * sam,
1337 prs_struct *ps, int depth)
1339 if (sam == NULL)
1340 return False;
1342 prs_debug(ps, depth, desc, "sam_io_sam_entry4");
1343 depth++;
1345 if(!prs_align(ps))
1346 return False;
1348 if(!prs_uint32("user_idx", ps, depth, &sam->user_idx))
1349 return False;
1350 if(!smb_io_strhdr("strhdr", &sam->hdr_acct_name, ps, depth))
1351 return False;
1353 return True;
1356 /*******************************************************************
1357 inits a SAM_ENTRY5 structure.
1358 ********************************************************************/
1360 static void init_sam_entry5(SAM_ENTRY5 * sam, uint32 grp_idx,
1361 uint32 len_grp_name)
1363 DEBUG(5, ("init_sam_entry5\n"));
1365 sam->grp_idx = grp_idx;
1366 init_str_hdr(&sam->hdr_grp_name, len_grp_name, len_grp_name,
1367 len_grp_name != 0);
1370 /*******************************************************************
1371 reads or writes a SAM_ENTRY5 structure.
1372 ********************************************************************/
1374 static BOOL sam_io_sam_entry5(const char *desc, SAM_ENTRY5 * sam,
1375 prs_struct *ps, int depth)
1377 if (sam == NULL)
1378 return False;
1380 prs_debug(ps, depth, desc, "sam_io_sam_entry5");
1381 depth++;
1383 if(!prs_align(ps))
1384 return False;
1386 if(!prs_uint32("grp_idx", ps, depth, &sam->grp_idx))
1387 return False;
1388 if(!smb_io_strhdr("strhdr", &sam->hdr_grp_name, ps, depth))
1389 return False;
1391 return True;
1394 /*******************************************************************
1395 inits a SAM_ENTRY structure.
1396 ********************************************************************/
1398 void init_sam_entry(SAM_ENTRY *sam, UNISTR2 *uni2, uint32 rid)
1400 DEBUG(10, ("init_sam_entry: %d\n", rid));
1402 sam->rid = rid;
1403 init_uni_hdr(&sam->hdr_name, uni2);
1406 /*******************************************************************
1407 reads or writes a SAM_ENTRY structure.
1408 ********************************************************************/
1410 static BOOL sam_io_sam_entry(const char *desc, SAM_ENTRY * sam,
1411 prs_struct *ps, int depth)
1413 if (sam == NULL)
1414 return False;
1416 prs_debug(ps, depth, desc, "sam_io_sam_entry");
1417 depth++;
1419 if(!prs_align(ps))
1420 return False;
1421 if(!prs_uint32("rid", ps, depth, &sam->rid))
1422 return False;
1423 if(!smb_io_unihdr("unihdr", &sam->hdr_name, ps, depth)) /* account name unicode string header */
1424 return False;
1426 return True;
1429 /*******************************************************************
1430 inits a SAMR_Q_ENUM_DOM_USERS structure.
1431 ********************************************************************/
1433 void init_samr_q_enum_dom_users(SAMR_Q_ENUM_DOM_USERS * q_e, POLICY_HND *pol,
1434 uint32 start_idx,
1435 uint32 acb_mask, uint32 size)
1437 DEBUG(5, ("init_samr_q_enum_dom_users\n"));
1439 q_e->pol = *pol;
1441 q_e->start_idx = start_idx; /* zero indicates lots */
1442 q_e->acb_mask = acb_mask;
1443 q_e->max_size = size;
1446 /*******************************************************************
1447 reads or writes a structure.
1448 ********************************************************************/
1450 BOOL samr_io_q_enum_dom_users(const char *desc, SAMR_Q_ENUM_DOM_USERS * q_e,
1451 prs_struct *ps, int depth)
1453 if (q_e == NULL)
1454 return False;
1456 prs_debug(ps, depth, desc, "samr_io_q_enum_dom_users");
1457 depth++;
1459 if(!prs_align(ps))
1460 return False;
1462 if(!smb_io_pol_hnd("domain_pol", &q_e->pol, ps, depth))
1463 return False;
1465 if(!prs_uint32("start_idx", ps, depth, &q_e->start_idx))
1466 return False;
1467 if(!prs_uint32("acb_mask ", ps, depth, &q_e->acb_mask))
1468 return False;
1470 if(!prs_uint32("max_size ", ps, depth, &q_e->max_size))
1471 return False;
1473 return True;
1477 /*******************************************************************
1478 inits a SAMR_R_ENUM_DOM_USERS structure.
1479 ********************************************************************/
1481 void init_samr_r_enum_dom_users(SAMR_R_ENUM_DOM_USERS * r_u,
1482 uint32 next_idx, uint32 num_sam_entries)
1484 DEBUG(5, ("init_samr_r_enum_dom_users\n"));
1486 r_u->next_idx = next_idx;
1488 if (num_sam_entries != 0) {
1489 r_u->ptr_entries1 = 1;
1490 r_u->ptr_entries2 = 1;
1491 r_u->num_entries2 = num_sam_entries;
1492 r_u->num_entries3 = num_sam_entries;
1494 r_u->num_entries4 = num_sam_entries;
1495 } else {
1496 r_u->ptr_entries1 = 0;
1497 r_u->num_entries2 = num_sam_entries;
1498 r_u->ptr_entries2 = 1;
1502 /*******************************************************************
1503 reads or writes a structure.
1504 ********************************************************************/
1506 BOOL samr_io_r_enum_dom_users(const char *desc, SAMR_R_ENUM_DOM_USERS * r_u,
1507 prs_struct *ps, int depth)
1509 uint32 i;
1511 if (r_u == NULL)
1512 return False;
1514 prs_debug(ps, depth, desc, "samr_io_r_enum_dom_users");
1515 depth++;
1517 if(!prs_align(ps))
1518 return False;
1520 if(!prs_uint32("next_idx ", ps, depth, &r_u->next_idx))
1521 return False;
1522 if(!prs_uint32("ptr_entries1", ps, depth, &r_u->ptr_entries1))
1523 return False;
1525 if (r_u->ptr_entries1 != 0) {
1526 if(!prs_uint32("num_entries2", ps, depth, &r_u->num_entries2))
1527 return False;
1528 if(!prs_uint32("ptr_entries2", ps, depth, &r_u->ptr_entries2))
1529 return False;
1530 if(!prs_uint32("num_entries3", ps, depth, &r_u->num_entries3))
1531 return False;
1533 if (UNMARSHALLING(ps) && (r_u->num_entries2 != 0)) {
1534 r_u->sam = PRS_ALLOC_MEM(ps,SAM_ENTRY, r_u->num_entries2);
1535 r_u->uni_acct_name = PRS_ALLOC_MEM(ps,UNISTR2, r_u->num_entries2);
1538 if ((r_u->sam == NULL || r_u->uni_acct_name == NULL) && r_u->num_entries2 != 0) {
1539 DEBUG(0,("NULL pointers in SAMR_R_ENUM_DOM_USERS\n"));
1540 r_u->num_entries4 = 0;
1541 r_u->status = NT_STATUS_MEMORY_NOT_ALLOCATED;
1542 return False;
1545 for (i = 0; i < r_u->num_entries2; i++) {
1546 if(!sam_io_sam_entry("", &r_u->sam[i], ps, depth))
1547 return False;
1550 for (i = 0; i < r_u->num_entries2; i++) {
1551 if(!smb_io_unistr2("", &r_u->uni_acct_name[i],r_u->sam[i].hdr_name.buffer, ps,depth))
1552 return False;
1557 if(!prs_align(ps))
1558 return False;
1560 if(!prs_uint32("num_entries4", ps, depth, &r_u->num_entries4))
1561 return False;
1562 if(!prs_ntstatus("status", ps, depth, &r_u->status))
1563 return False;
1565 return True;
1568 /*******************************************************************
1569 inits a SAMR_Q_QUERY_DISPINFO structure.
1570 ********************************************************************/
1572 void init_samr_q_query_dispinfo(SAMR_Q_QUERY_DISPINFO * q_e, POLICY_HND *pol,
1573 uint16 switch_level, uint32 start_idx,
1574 uint32 max_entries, uint32 max_size)
1576 DEBUG(5, ("init_samr_q_query_dispinfo\n"));
1578 q_e->domain_pol = *pol;
1580 q_e->switch_level = switch_level;
1582 q_e->start_idx = start_idx;
1583 q_e->max_entries = max_entries;
1584 q_e->max_size = max_size;
1587 /*******************************************************************
1588 reads or writes a structure.
1589 ********************************************************************/
1591 BOOL samr_io_q_query_dispinfo(const char *desc, SAMR_Q_QUERY_DISPINFO * q_e,
1592 prs_struct *ps, int depth)
1594 if (q_e == NULL)
1595 return False;
1597 prs_debug(ps, depth, desc, "samr_io_q_query_dispinfo");
1598 depth++;
1600 if(!prs_align(ps))
1601 return False;
1603 if(!smb_io_pol_hnd("domain_pol", &q_e->domain_pol, ps, depth))
1604 return False;
1606 if(!prs_uint16("switch_level", ps, depth, &q_e->switch_level))
1607 return False;
1608 if(!prs_align(ps))
1609 return False;
1611 if(!prs_uint32("start_idx ", ps, depth, &q_e->start_idx))
1612 return False;
1613 if(!prs_uint32("max_entries ", ps, depth, &q_e->max_entries))
1614 return False;
1615 if(!prs_uint32("max_size ", ps, depth, &q_e->max_size))
1616 return False;
1618 return True;
1621 /*******************************************************************
1622 inits a SAM_DISPINFO_1 structure.
1623 ********************************************************************/
1625 NTSTATUS init_sam_dispinfo_1(TALLOC_CTX *ctx, SAM_DISPINFO_1 **sam,
1626 uint32 num_entries, uint32 start_idx,
1627 struct samr_displayentry *entries)
1629 uint32 i;
1631 DEBUG(10, ("init_sam_dispinfo_1: num_entries: %d\n", num_entries));
1633 if (num_entries==0)
1634 return NT_STATUS_OK;
1636 *sam = TALLOC_ZERO_ARRAY(ctx, SAM_DISPINFO_1, num_entries);
1637 if (*sam == NULL)
1638 return NT_STATUS_NO_MEMORY;
1640 (*sam)->sam=TALLOC_ARRAY(ctx, SAM_ENTRY1, num_entries);
1641 if ((*sam)->sam == NULL)
1642 return NT_STATUS_NO_MEMORY;
1644 (*sam)->str=TALLOC_ARRAY(ctx, SAM_STR1, num_entries);
1645 if ((*sam)->str == NULL)
1646 return NT_STATUS_NO_MEMORY;
1648 for (i = 0; i < num_entries ; i++) {
1649 init_unistr2(&(*sam)->str[i].uni_acct_name,
1650 entries[i].account_name, UNI_FLAGS_NONE);
1651 init_unistr2(&(*sam)->str[i].uni_full_name,
1652 entries[i].fullname, UNI_FLAGS_NONE);
1653 init_unistr2(&(*sam)->str[i].uni_acct_desc,
1654 entries[i].description, UNI_FLAGS_NONE);
1656 init_sam_entry1(&(*sam)->sam[i], start_idx+i+1,
1657 &(*sam)->str[i].uni_acct_name,
1658 &(*sam)->str[i].uni_full_name,
1659 &(*sam)->str[i].uni_acct_desc,
1660 entries[i].rid, entries[i].acct_flags);
1663 return NT_STATUS_OK;
1666 /*******************************************************************
1667 reads or writes a structure.
1668 ********************************************************************/
1670 static BOOL sam_io_sam_dispinfo_1(const char *desc, SAM_DISPINFO_1 * sam,
1671 uint32 num_entries,
1672 prs_struct *ps, int depth)
1674 uint32 i;
1676 prs_debug(ps, depth, desc, "sam_io_sam_dispinfo_1");
1677 depth++;
1679 if(!prs_align(ps))
1680 return False;
1682 if (UNMARSHALLING(ps) && num_entries > 0) {
1684 if ((sam->sam = PRS_ALLOC_MEM(ps, SAM_ENTRY1, num_entries)) == NULL) {
1685 DEBUG(0, ("out of memory allocating SAM_ENTRY1\n"));
1686 return False;
1689 if ((sam->str = PRS_ALLOC_MEM(ps, SAM_STR1, num_entries)) == NULL) {
1690 DEBUG(0, ("out of memory allocating SAM_STR1\n"));
1691 return False;
1695 for (i = 0; i < num_entries; i++) {
1696 if(!sam_io_sam_entry1("", &sam->sam[i], ps, depth))
1697 return False;
1700 for (i = 0; i < num_entries; i++) {
1701 if(!sam_io_sam_str1("", &sam->str[i],
1702 sam->sam[i].hdr_acct_name.buffer,
1703 sam->sam[i].hdr_user_name.buffer,
1704 sam->sam[i].hdr_user_desc.buffer, ps, depth))
1705 return False;
1708 return True;
1711 /*******************************************************************
1712 inits a SAM_DISPINFO_2 structure.
1713 ********************************************************************/
1715 NTSTATUS init_sam_dispinfo_2(TALLOC_CTX *ctx, SAM_DISPINFO_2 **sam,
1716 uint32 num_entries, uint32 start_idx,
1717 struct samr_displayentry *entries)
1719 uint32 i;
1721 DEBUG(10, ("init_sam_dispinfo_2: num_entries: %d\n", num_entries));
1723 if (num_entries==0)
1724 return NT_STATUS_OK;
1726 *sam = TALLOC_ZERO_ARRAY(ctx, SAM_DISPINFO_2, num_entries);
1727 if (*sam == NULL)
1728 return NT_STATUS_NO_MEMORY;
1730 (*sam)->sam = TALLOC_ARRAY(ctx, SAM_ENTRY2, num_entries);
1731 if ((*sam)->sam == NULL)
1732 return NT_STATUS_NO_MEMORY;
1734 (*sam)->str=TALLOC_ARRAY(ctx, SAM_STR2, num_entries);
1735 if ((*sam)->str == NULL)
1736 return NT_STATUS_NO_MEMORY;
1738 for (i = 0; i < num_entries; i++) {
1739 init_unistr2(&(*sam)->str[i].uni_srv_name,
1740 entries[i].account_name, UNI_FLAGS_NONE);
1741 init_unistr2(&(*sam)->str[i].uni_srv_desc,
1742 entries[i].description, UNI_FLAGS_NONE);
1744 init_sam_entry2(&(*sam)->sam[i], start_idx + i + 1,
1745 &(*sam)->str[i].uni_srv_name,
1746 &(*sam)->str[i].uni_srv_desc,
1747 entries[i].rid, entries[i].acct_flags);
1750 return NT_STATUS_OK;
1753 /*******************************************************************
1754 reads or writes a structure.
1755 ********************************************************************/
1757 static BOOL sam_io_sam_dispinfo_2(const char *desc, SAM_DISPINFO_2 * sam,
1758 uint32 num_entries,
1759 prs_struct *ps, int depth)
1761 uint32 i;
1763 if (sam == NULL)
1764 return False;
1766 prs_debug(ps, depth, desc, "sam_io_sam_dispinfo_2");
1767 depth++;
1769 if(!prs_align(ps))
1770 return False;
1772 if (UNMARSHALLING(ps) && num_entries > 0) {
1774 if ((sam->sam = PRS_ALLOC_MEM(ps, SAM_ENTRY2, num_entries)) == NULL) {
1775 DEBUG(0, ("out of memory allocating SAM_ENTRY2\n"));
1776 return False;
1779 if ((sam->str = PRS_ALLOC_MEM(ps, SAM_STR2, num_entries)) == NULL) {
1780 DEBUG(0, ("out of memory allocating SAM_STR2\n"));
1781 return False;
1785 for (i = 0; i < num_entries; i++) {
1786 if(!sam_io_sam_entry2("", &sam->sam[i], ps, depth))
1787 return False;
1790 for (i = 0; i < num_entries; i++) {
1791 if(!sam_io_sam_str2("", &sam->str[i],
1792 sam->sam[i].hdr_srv_name.buffer,
1793 sam->sam[i].hdr_srv_desc.buffer, ps, depth))
1794 return False;
1797 return True;
1800 /*******************************************************************
1801 inits a SAM_DISPINFO_3 structure.
1802 ********************************************************************/
1804 NTSTATUS init_sam_dispinfo_3(TALLOC_CTX *ctx, SAM_DISPINFO_3 **sam,
1805 uint32 num_entries, uint32 start_idx,
1806 struct samr_displayentry *entries)
1808 uint32 i;
1810 DEBUG(5, ("init_sam_dispinfo_3: num_entries: %d\n", num_entries));
1812 if (num_entries==0)
1813 return NT_STATUS_OK;
1815 *sam = TALLOC_ZERO_ARRAY(ctx, SAM_DISPINFO_3, num_entries);
1816 if (*sam == NULL)
1817 return NT_STATUS_NO_MEMORY;
1819 if (!((*sam)->sam=TALLOC_ARRAY(ctx, SAM_ENTRY3, num_entries)))
1820 return NT_STATUS_NO_MEMORY;
1822 if (!((*sam)->str=TALLOC_ARRAY(ctx, SAM_STR3, num_entries)))
1823 return NT_STATUS_NO_MEMORY;
1825 for (i = 0; i < num_entries; i++) {
1826 DEBUG(11, ("init_sam_dispinfo_3: entry: %d\n",i));
1828 init_unistr2(&(*sam)->str[i].uni_grp_name,
1829 entries[i].account_name, UNI_FLAGS_NONE);
1830 init_unistr2(&(*sam)->str[i].uni_grp_desc,
1831 entries[i].description, UNI_FLAGS_NONE);
1833 init_sam_entry3(&(*sam)->sam[i], start_idx+i+1,
1834 &(*sam)->str[i].uni_grp_name,
1835 &(*sam)->str[i].uni_grp_desc,
1836 entries[i].rid);
1839 return NT_STATUS_OK;
1842 /*******************************************************************
1843 reads or writes a structure.
1844 ********************************************************************/
1846 static BOOL sam_io_sam_dispinfo_3(const char *desc, SAM_DISPINFO_3 * sam,
1847 uint32 num_entries,
1848 prs_struct *ps, int depth)
1850 uint32 i;
1852 if (sam == NULL)
1853 return False;
1855 prs_debug(ps, depth, desc, "sam_io_sam_dispinfo_3");
1856 depth++;
1858 if(!prs_align(ps))
1859 return False;
1861 if (UNMARSHALLING(ps) && num_entries > 0) {
1863 if ((sam->sam = PRS_ALLOC_MEM(ps, SAM_ENTRY3, num_entries)) == NULL) {
1864 DEBUG(0, ("out of memory allocating SAM_ENTRY3\n"));
1865 return False;
1868 if ((sam->str = PRS_ALLOC_MEM(ps, SAM_STR3, num_entries)) == NULL) {
1869 DEBUG(0, ("out of memory allocating SAM_STR3\n"));
1870 return False;
1874 for (i = 0; i < num_entries; i++) {
1875 if(!sam_io_sam_entry3("", &sam->sam[i], ps, depth))
1876 return False;
1879 for (i = 0; i < num_entries; i++) {
1880 if(!sam_io_sam_str3("", &sam->str[i],
1881 sam->sam[i].hdr_grp_name.buffer,
1882 sam->sam[i].hdr_grp_desc.buffer, ps, depth))
1883 return False;
1886 return True;
1889 /*******************************************************************
1890 inits a SAM_DISPINFO_4 structure.
1891 ********************************************************************/
1893 NTSTATUS init_sam_dispinfo_4(TALLOC_CTX *ctx, SAM_DISPINFO_4 **sam,
1894 uint32 num_entries, uint32 start_idx,
1895 struct samr_displayentry *entries)
1897 uint32 i;
1899 DEBUG(5, ("init_sam_dispinfo_4: num_entries: %d\n", num_entries));
1901 if (num_entries==0)
1902 return NT_STATUS_OK;
1904 *sam = TALLOC_ZERO_ARRAY(ctx, SAM_DISPINFO_4, num_entries);
1905 if (*sam == NULL)
1906 return NT_STATUS_NO_MEMORY;
1908 (*sam)->sam = TALLOC_ARRAY(ctx, SAM_ENTRY4, num_entries);
1909 if ((*sam)->sam == NULL)
1910 return NT_STATUS_NO_MEMORY;
1912 (*sam)->str=TALLOC_ARRAY(ctx, SAM_STR4, num_entries);
1913 if ((*sam)->str == NULL)
1914 return NT_STATUS_NO_MEMORY;
1916 for (i = 0; i < num_entries; i++) {
1917 size_t len_sam_name = strlen(entries[i].account_name);
1919 DEBUG(11, ("init_sam_dispinfo_2: entry: %d\n",i));
1921 init_sam_entry4(&(*sam)->sam[i], start_idx + i + 1,
1922 len_sam_name);
1924 init_string2(&(*sam)->str[i].acct_name,
1925 entries[i].account_name, len_sam_name+1,
1926 len_sam_name);
1929 return NT_STATUS_OK;
1932 /*******************************************************************
1933 reads or writes a structure.
1934 ********************************************************************/
1936 static BOOL sam_io_sam_dispinfo_4(const char *desc, SAM_DISPINFO_4 * sam,
1937 uint32 num_entries,
1938 prs_struct *ps, int depth)
1940 uint32 i;
1942 if (sam == NULL)
1943 return False;
1945 prs_debug(ps, depth, desc, "sam_io_sam_dispinfo_4");
1946 depth++;
1948 if(!prs_align(ps))
1949 return False;
1951 if (UNMARSHALLING(ps) && num_entries > 0) {
1953 if ((sam->sam = PRS_ALLOC_MEM(ps, SAM_ENTRY4, num_entries)) == NULL) {
1954 DEBUG(0, ("out of memory allocating SAM_ENTRY4\n"));
1955 return False;
1958 if ((sam->str = PRS_ALLOC_MEM(ps, SAM_STR4, num_entries)) == NULL) {
1959 DEBUG(0, ("out of memory allocating SAM_STR4\n"));
1960 return False;
1964 for (i = 0; i < num_entries; i++) {
1965 if(!sam_io_sam_entry4("", &sam->sam[i], ps, depth))
1966 return False;
1969 for (i = 0; i < num_entries; i++) {
1970 if(!smb_io_string2("acct_name", &sam->str[i].acct_name,
1971 sam->sam[i].hdr_acct_name.buffer, ps, depth))
1972 return False;
1975 return True;
1978 /*******************************************************************
1979 inits a SAM_DISPINFO_5 structure.
1980 ********************************************************************/
1982 NTSTATUS init_sam_dispinfo_5(TALLOC_CTX *ctx, SAM_DISPINFO_5 **sam,
1983 uint32 num_entries, uint32 start_idx,
1984 struct samr_displayentry *entries)
1986 uint32 len_sam_name;
1987 uint32 i;
1989 DEBUG(5, ("init_sam_dispinfo_5: num_entries: %d\n", num_entries));
1991 if (num_entries==0)
1992 return NT_STATUS_OK;
1994 *sam = TALLOC_ZERO_ARRAY(ctx, SAM_DISPINFO_5, num_entries);
1995 if (*sam == NULL)
1996 return NT_STATUS_NO_MEMORY;
1998 if (!((*sam)->sam=TALLOC_ARRAY(ctx, SAM_ENTRY5, num_entries)))
1999 return NT_STATUS_NO_MEMORY;
2001 if (!((*sam)->str=TALLOC_ARRAY(ctx, SAM_STR5, num_entries)))
2002 return NT_STATUS_NO_MEMORY;
2004 for (i = 0; i < num_entries; i++) {
2005 DEBUG(11, ("init_sam_dispinfo_5: entry: %d\n",i));
2007 len_sam_name = strlen(entries[i].account_name);
2009 init_sam_entry5(&(*sam)->sam[i], start_idx+i+1, len_sam_name);
2010 init_string2(&(*sam)->str[i].grp_name, entries[i].account_name,
2011 len_sam_name+1, len_sam_name);
2014 return NT_STATUS_OK;
2017 /*******************************************************************
2018 reads or writes a structure.
2019 ********************************************************************/
2021 static BOOL sam_io_sam_dispinfo_5(const char *desc, SAM_DISPINFO_5 * sam,
2022 uint32 num_entries,
2023 prs_struct *ps, int depth)
2025 uint32 i;
2027 if (sam == NULL)
2028 return False;
2030 prs_debug(ps, depth, desc, "sam_io_sam_dispinfo_5");
2031 depth++;
2033 if(!prs_align(ps))
2034 return False;
2036 if (UNMARSHALLING(ps) && num_entries > 0) {
2038 if ((sam->sam = PRS_ALLOC_MEM(ps, SAM_ENTRY5, num_entries)) == NULL) {
2039 DEBUG(0, ("out of memory allocating SAM_ENTRY5\n"));
2040 return False;
2043 if ((sam->str = PRS_ALLOC_MEM(ps, SAM_STR5, num_entries)) == NULL) {
2044 DEBUG(0, ("out of memory allocating SAM_STR5\n"));
2045 return False;
2049 for (i = 0; i < num_entries; i++) {
2050 if(!sam_io_sam_entry5("", &sam->sam[i], ps, depth))
2051 return False;
2054 for (i = 0; i < num_entries; i++) {
2055 if(!smb_io_string2("grp_name", &sam->str[i].grp_name,
2056 sam->sam[i].hdr_grp_name.buffer, ps, depth))
2057 return False;
2060 return True;
2063 /*******************************************************************
2064 inits a SAMR_R_QUERY_DISPINFO structure.
2065 ********************************************************************/
2067 void init_samr_r_query_dispinfo(SAMR_R_QUERY_DISPINFO * r_u,
2068 uint32 num_entries, uint32 total_size, uint32 data_size,
2069 uint16 switch_level, SAM_DISPINFO_CTR * ctr,
2070 NTSTATUS status)
2072 DEBUG(5, ("init_samr_r_query_dispinfo: level %d\n", switch_level));
2074 r_u->total_size = total_size;
2076 r_u->data_size = data_size;
2078 r_u->switch_level = switch_level;
2079 r_u->num_entries = num_entries;
2081 if (num_entries==0)
2082 r_u->ptr_entries = 0;
2083 else
2084 r_u->ptr_entries = 1;
2086 r_u->num_entries2 = num_entries;
2087 r_u->ctr = ctr;
2089 r_u->status = status;
2092 /*******************************************************************
2093 reads or writes a structure.
2094 ********************************************************************/
2096 BOOL samr_io_r_query_dispinfo(const char *desc, SAMR_R_QUERY_DISPINFO * r_u,
2097 prs_struct *ps, int depth)
2099 if (r_u == NULL)
2100 return False;
2102 prs_debug(ps, depth, desc, "samr_io_r_query_dispinfo");
2103 depth++;
2105 if(!prs_align(ps))
2106 return False;
2108 if(!prs_uint32("total_size ", ps, depth, &r_u->total_size))
2109 return False;
2110 if(!prs_uint32("data_size ", ps, depth, &r_u->data_size))
2111 return False;
2112 if(!prs_uint16("switch_level", ps, depth, &r_u->switch_level))
2113 return False;
2114 if(!prs_align(ps))
2115 return False;
2117 if(!prs_uint32("num_entries ", ps, depth, &r_u->num_entries))
2118 return False;
2119 if(!prs_uint32("ptr_entries ", ps, depth, &r_u->ptr_entries))
2120 return False;
2122 if (r_u->ptr_entries==0) {
2123 if(!prs_align(ps))
2124 return False;
2125 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2126 return False;
2128 return True;
2131 if(!prs_uint32("num_entries2", ps, depth, &r_u->num_entries2))
2132 return False;
2134 switch (r_u->switch_level) {
2135 case 0x1:
2136 if(!sam_io_sam_dispinfo_1("users", r_u->ctr->sam.info1,
2137 r_u->num_entries, ps, depth))
2138 return False;
2139 break;
2140 case 0x2:
2141 if(!sam_io_sam_dispinfo_2("servers", r_u->ctr->sam.info2,
2142 r_u->num_entries, ps, depth))
2143 return False;
2144 break;
2145 case 0x3:
2146 if(!sam_io_sam_dispinfo_3("groups", r_u->ctr->sam.info3,
2147 r_u->num_entries, ps, depth))
2148 return False;
2149 break;
2150 case 0x4:
2151 if(!sam_io_sam_dispinfo_4("user list",
2152 r_u->ctr->sam.info4,
2153 r_u->num_entries, ps, depth))
2154 return False;
2155 break;
2156 case 0x5:
2157 if(!sam_io_sam_dispinfo_5("group list",
2158 r_u->ctr->sam.info5,
2159 r_u->num_entries, ps, depth))
2160 return False;
2161 break;
2162 default:
2163 DEBUG(0,("samr_io_r_query_dispinfo: unknown switch value\n"));
2164 break;
2167 if(!prs_align(ps))
2168 return False;
2169 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2170 return False;
2172 return True;
2175 /*******************************************************************
2176 inits a SAMR_Q_GET_DISPENUM_INDEX structure.
2177 ********************************************************************/
2179 void init_samr_q_get_dispenum_index(SAMR_Q_GET_DISPENUM_INDEX * q_e, POLICY_HND *pol,
2180 uint16 switch_level, const char *name)
2182 DEBUG(5, ("init_samr_q_get_dispenum_index\n"));
2184 q_e->domain_pol = *pol;
2186 q_e->switch_level = switch_level;
2188 init_lsa_string(&q_e->name, name);
2191 /*******************************************************************
2192 reads or writes a structure.
2193 ********************************************************************/
2195 BOOL samr_io_q_get_dispenum_index(const char *desc, SAMR_Q_GET_DISPENUM_INDEX * q_e,
2196 prs_struct *ps, int depth)
2198 if (q_e == NULL)
2199 return False;
2201 prs_debug(ps, depth, desc, "samr_io_q_get_dispenum_index");
2202 depth++;
2204 if(!prs_align(ps))
2205 return False;
2207 if(!smb_io_pol_hnd("domain_pol", &q_e->domain_pol, ps, depth))
2208 return False;
2210 if(!prs_uint16("switch_level", ps, depth, &q_e->switch_level))
2211 return False;
2213 if (!smb_io_lsa_string("name", &q_e->name, ps, depth))
2214 return False;
2216 return True;
2219 /*******************************************************************
2220 reads or writes a structure.
2221 ********************************************************************/
2223 BOOL samr_io_r_get_dispenum_index(const char *desc, SAMR_R_GET_DISPENUM_INDEX * r_u,
2224 prs_struct *ps, int depth)
2226 if (r_u == NULL)
2227 return False;
2229 prs_debug(ps, depth, desc, "samr_io_r_get_dispenum_index");
2230 depth++;
2232 if(!prs_align(ps))
2233 return False;
2235 if(!prs_uint32("idx", ps, depth, &r_u->idx))
2236 return False;
2238 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2239 return False;
2241 return True;
2245 /*******************************************************************
2246 inits a SAMR_Q_OPEN_GROUP structure.
2247 ********************************************************************/
2249 void init_samr_q_open_group(SAMR_Q_OPEN_GROUP * q_c,
2250 POLICY_HND *hnd,
2251 uint32 access_mask, uint32 rid)
2253 DEBUG(5, ("init_samr_q_open_group\n"));
2255 q_c->domain_pol = *hnd;
2256 q_c->access_mask = access_mask;
2257 q_c->rid_group = rid;
2260 /*******************************************************************
2261 reads or writes a structure.
2262 ********************************************************************/
2264 BOOL samr_io_q_open_group(const char *desc, SAMR_Q_OPEN_GROUP * q_u,
2265 prs_struct *ps, int depth)
2267 if (q_u == NULL)
2268 return False;
2270 prs_debug(ps, depth, desc, "samr_io_q_open_group");
2271 depth++;
2273 if(!prs_align(ps))
2274 return False;
2276 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
2277 return False;
2279 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
2280 return False;
2281 if(!prs_uint32("rid_group", ps, depth, &q_u->rid_group))
2282 return False;
2284 return True;
2287 /*******************************************************************
2288 reads or writes a structure.
2289 ********************************************************************/
2291 BOOL samr_io_r_open_group(const char *desc, SAMR_R_OPEN_GROUP * r_u,
2292 prs_struct *ps, int depth)
2294 if (r_u == NULL)
2295 return False;
2297 prs_debug(ps, depth, desc, "samr_io_r_open_group");
2298 depth++;
2300 if(!prs_align(ps))
2301 return False;
2303 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
2304 return False;
2306 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2307 return False;
2309 return True;
2312 /*******************************************************************
2313 inits a GROUP_INFO1 structure.
2314 ********************************************************************/
2316 void init_samr_group_info1(GROUP_INFO1 * gr1,
2317 char *acct_name, char *acct_desc,
2318 uint32 num_members)
2320 DEBUG(5, ("init_samr_group_info1\n"));
2322 gr1->group_attr = (SE_GROUP_MANDATORY|SE_GROUP_ENABLED_BY_DEFAULT); /* why not | SE_GROUP_ENABLED ? */
2323 gr1->num_members = num_members;
2325 init_unistr2(&gr1->uni_acct_name, acct_name, UNI_FLAGS_NONE);
2326 init_uni_hdr(&gr1->hdr_acct_name, &gr1->uni_acct_name);
2327 init_unistr2(&gr1->uni_acct_desc, acct_desc, UNI_FLAGS_NONE);
2328 init_uni_hdr(&gr1->hdr_acct_desc, &gr1->uni_acct_desc);
2331 /*******************************************************************
2332 reads or writes a structure.
2333 ********************************************************************/
2335 BOOL samr_io_group_info1(const char *desc, GROUP_INFO1 * gr1,
2336 prs_struct *ps, int depth)
2338 uint16 dummy = 1;
2340 if (gr1 == NULL)
2341 return False;
2343 prs_debug(ps, depth, desc, "samr_io_group_info1");
2344 depth++;
2346 if(!prs_uint16("level", ps, depth, &dummy))
2347 return False;
2349 if(!prs_align(ps))
2350 return False;
2352 if(!smb_io_unihdr("hdr_acct_name", &gr1->hdr_acct_name, ps, depth))
2353 return False;
2355 if(!prs_uint32("group_attr", ps, depth, &gr1->group_attr))
2356 return False;
2357 if(!prs_uint32("num_members", ps, depth, &gr1->num_members))
2358 return False;
2360 if(!smb_io_unihdr("hdr_acct_desc", &gr1->hdr_acct_desc, ps, depth))
2361 return False;
2363 if(!smb_io_unistr2("uni_acct_name", &gr1->uni_acct_name,
2364 gr1->hdr_acct_name.buffer, ps, depth))
2365 return False;
2367 if(!smb_io_unistr2("uni_acct_desc", &gr1->uni_acct_desc,
2368 gr1->hdr_acct_desc.buffer, ps, depth))
2369 return False;
2371 return True;
2374 /*******************************************************************
2375 inits a GROUP_INFO2 structure.
2376 ********************************************************************/
2378 void init_samr_group_info2(GROUP_INFO2 * gr2, const char *acct_name)
2380 DEBUG(5, ("init_samr_group_info2\n"));
2382 gr2->level = 2;
2383 init_unistr2(&gr2->uni_acct_name, acct_name, UNI_FLAGS_NONE);
2384 init_uni_hdr(&gr2->hdr_acct_name, &gr2->uni_acct_name);
2387 /*******************************************************************
2388 reads or writes a structure.
2389 ********************************************************************/
2391 BOOL samr_io_group_info2(const char *desc, GROUP_INFO2 *gr2, prs_struct *ps, int depth)
2393 if (gr2 == NULL)
2394 return False;
2396 prs_debug(ps, depth, desc, "samr_io_group_info2");
2397 depth++;
2399 if(!prs_uint16("hdr_level", ps, depth, &gr2->level))
2400 return False;
2402 if(!smb_io_unihdr("hdr_acct_name", &gr2->hdr_acct_name, ps, depth))
2403 return False;
2404 if(!smb_io_unistr2("uni_acct_name", &gr2->uni_acct_name,
2405 gr2->hdr_acct_name.buffer, ps, depth))
2406 return False;
2408 return True;
2411 /*******************************************************************
2412 inits a GROUP_INFO3 structure.
2413 ********************************************************************/
2415 void init_samr_group_info3(GROUP_INFO3 *gr3)
2417 DEBUG(5, ("init_samr_group_info3\n"));
2419 gr3->group_attr = (SE_GROUP_MANDATORY|SE_GROUP_ENABLED_BY_DEFAULT); /* why not | SE_GROUP_ENABLED ? */
2422 /*******************************************************************
2423 reads or writes a structure.
2424 ********************************************************************/
2426 BOOL samr_io_group_info3(const char *desc, GROUP_INFO3 *gr3, prs_struct *ps, int depth)
2428 if (gr3 == NULL)
2429 return False;
2431 prs_debug(ps, depth, desc, "samr_io_group_info3");
2432 depth++;
2434 if(!prs_align(ps))
2435 return False;
2437 if(!prs_uint32("group_attr", ps, depth, &gr3->group_attr))
2438 return False;
2440 return True;
2443 /*******************************************************************
2444 inits a GROUP_INFO4 structure.
2445 ********************************************************************/
2447 void init_samr_group_info4(GROUP_INFO4 * gr4, const char *acct_desc)
2449 DEBUG(5, ("init_samr_group_info4\n"));
2451 gr4->level = 4;
2452 init_unistr2(&gr4->uni_acct_desc, acct_desc, UNI_FLAGS_NONE);
2453 init_uni_hdr(&gr4->hdr_acct_desc, &gr4->uni_acct_desc);
2456 /*******************************************************************
2457 reads or writes a structure.
2458 ********************************************************************/
2460 BOOL samr_io_group_info4(const char *desc, GROUP_INFO4 * gr4,
2461 prs_struct *ps, int depth)
2463 if (gr4 == NULL)
2464 return False;
2466 prs_debug(ps, depth, desc, "samr_io_group_info4");
2467 depth++;
2469 if(!prs_uint16("hdr_level", ps, depth, &gr4->level))
2470 return False;
2471 if(!smb_io_unihdr("hdr_acct_desc", &gr4->hdr_acct_desc, ps, depth))
2472 return False;
2473 if(!smb_io_unistr2("uni_acct_desc", &gr4->uni_acct_desc,
2474 gr4->hdr_acct_desc.buffer, ps, depth))
2475 return False;
2477 return True;
2480 /*******************************************************************
2481 inits a GROUP_INFO5 structure.
2482 ********************************************************************/
2484 void init_samr_group_info5(GROUP_INFO5 * gr5,
2485 char *acct_name, char *acct_desc,
2486 uint32 num_members)
2488 DEBUG(5, ("init_samr_group_info5\n"));
2490 gr5->group_attr = (SE_GROUP_MANDATORY|SE_GROUP_ENABLED_BY_DEFAULT); /* why not | SE_GROUP_ENABLED ? */
2491 gr5->num_members = num_members;
2493 init_unistr2(&gr5->uni_acct_name, acct_name, UNI_FLAGS_NONE);
2494 init_uni_hdr(&gr5->hdr_acct_name, &gr5->uni_acct_name);
2495 init_unistr2(&gr5->uni_acct_desc, acct_desc, UNI_FLAGS_NONE);
2496 init_uni_hdr(&gr5->hdr_acct_desc, &gr5->uni_acct_desc);
2499 /*******************************************************************
2500 reads or writes a structure.
2501 ********************************************************************/
2503 BOOL samr_io_group_info5(const char *desc, GROUP_INFO5 * gr5,
2504 prs_struct *ps, int depth)
2506 uint16 dummy = 1;
2508 if (gr5 == NULL)
2509 return False;
2511 prs_debug(ps, depth, desc, "samr_io_group_info5");
2512 depth++;
2514 if(!prs_uint16("level", ps, depth, &dummy))
2515 return False;
2517 if(!prs_align(ps))
2518 return False;
2520 if(!smb_io_unihdr("hdr_acct_name", &gr5->hdr_acct_name, ps, depth))
2521 return False;
2523 if(!prs_uint32("group_attr", ps, depth, &gr5->group_attr))
2524 return False;
2525 if(!prs_uint32("num_members", ps, depth, &gr5->num_members))
2526 return False;
2528 if(!smb_io_unihdr("hdr_acct_desc", &gr5->hdr_acct_desc, ps, depth))
2529 return False;
2531 if(!smb_io_unistr2("uni_acct_name", &gr5->uni_acct_name,
2532 gr5->hdr_acct_name.buffer, ps, depth))
2533 return False;
2535 if(!smb_io_unistr2("uni_acct_desc", &gr5->uni_acct_desc,
2536 gr5->hdr_acct_desc.buffer, ps, depth))
2537 return False;
2539 return True;
2543 /*******************************************************************
2544 reads or writes a structure.
2545 ********************************************************************/
2547 static BOOL samr_group_info_ctr(const char *desc, GROUP_INFO_CTR **ctr,
2548 prs_struct *ps, int depth)
2550 if (UNMARSHALLING(ps))
2551 *ctr = PRS_ALLOC_MEM(ps,GROUP_INFO_CTR,1);
2553 if (*ctr == NULL)
2554 return False;
2556 prs_debug(ps, depth, desc, "samr_group_info_ctr");
2557 depth++;
2559 if(!prs_uint16("switch_value1", ps, depth, &(*ctr)->switch_value1))
2560 return False;
2562 switch ((*ctr)->switch_value1) {
2563 case 1:
2564 if(!samr_io_group_info1("group_info1", &(*ctr)->group.info1, ps, depth))
2565 return False;
2566 break;
2567 case 2:
2568 if(!samr_io_group_info2("group_info2", &(*ctr)->group.info2, ps, depth))
2569 return False;
2570 break;
2571 case 3:
2572 if(!samr_io_group_info3("group_info3", &(*ctr)->group.info3, ps, depth))
2573 return False;
2574 break;
2575 case 4:
2576 if(!samr_io_group_info4("group_info4", &(*ctr)->group.info4, ps, depth))
2577 return False;
2578 break;
2579 case 5:
2580 if(!samr_io_group_info5("group_info5", &(*ctr)->group.info5, ps, depth))
2581 return False;
2582 break;
2583 default:
2584 DEBUG(0,("samr_group_info_ctr: unsupported switch level\n"));
2585 break;
2588 return True;
2591 /*******************************************************************
2592 inits a SAMR_Q_CREATE_DOM_GROUP structure.
2593 ********************************************************************/
2595 void init_samr_q_create_dom_group(SAMR_Q_CREATE_DOM_GROUP * q_e,
2596 POLICY_HND *pol, const char *acct_desc,
2597 uint32 access_mask)
2599 DEBUG(5, ("init_samr_q_create_dom_group\n"));
2601 q_e->pol = *pol;
2603 init_unistr2(&q_e->uni_acct_desc, acct_desc, UNI_FLAGS_NONE);
2604 init_uni_hdr(&q_e->hdr_acct_desc, &q_e->uni_acct_desc);
2606 q_e->access_mask = access_mask;
2609 /*******************************************************************
2610 reads or writes a structure.
2611 ********************************************************************/
2613 BOOL samr_io_q_create_dom_group(const char *desc, SAMR_Q_CREATE_DOM_GROUP * q_e,
2614 prs_struct *ps, int depth)
2616 if (q_e == NULL)
2617 return False;
2619 prs_debug(ps, depth, desc, "samr_io_q_create_dom_group");
2620 depth++;
2622 if(!prs_align(ps))
2623 return False;
2625 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
2626 return False;
2628 if(!smb_io_unihdr("hdr_acct_desc", &q_e->hdr_acct_desc, ps, depth))
2629 return False;
2630 if(!smb_io_unistr2("uni_acct_desc", &q_e->uni_acct_desc,
2631 q_e->hdr_acct_desc.buffer, ps, depth))
2632 return False;
2634 if(!prs_align(ps))
2635 return False;
2636 if(!prs_uint32("access", ps, depth, &q_e->access_mask))
2637 return False;
2639 return True;
2642 /*******************************************************************
2643 reads or writes a structure.
2644 ********************************************************************/
2646 BOOL samr_io_r_create_dom_group(const char *desc, SAMR_R_CREATE_DOM_GROUP * r_u,
2647 prs_struct *ps, int depth)
2649 if (r_u == NULL)
2650 return False;
2652 prs_debug(ps, depth, desc, "samr_io_r_create_dom_group");
2653 depth++;
2655 if(!prs_align(ps))
2656 return False;
2658 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
2659 return False;
2661 if(!prs_uint32("rid ", ps, depth, &r_u->rid))
2662 return False;
2663 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2664 return False;
2666 return True;
2669 /*******************************************************************
2670 inits a SAMR_Q_DELETE_DOM_GROUP structure.
2671 ********************************************************************/
2673 void init_samr_q_delete_dom_group(SAMR_Q_DELETE_DOM_GROUP * q_c,
2674 POLICY_HND *hnd)
2676 DEBUG(5, ("init_samr_q_delete_dom_group\n"));
2678 q_c->group_pol = *hnd;
2681 /*******************************************************************
2682 reads or writes a structure.
2683 ********************************************************************/
2685 BOOL samr_io_q_delete_dom_group(const char *desc, SAMR_Q_DELETE_DOM_GROUP * q_u,
2686 prs_struct *ps, int depth)
2688 if (q_u == NULL)
2689 return False;
2691 prs_debug(ps, depth, desc, "samr_io_q_delete_dom_group");
2692 depth++;
2694 if(!prs_align(ps))
2695 return False;
2697 if(!smb_io_pol_hnd("group_pol", &q_u->group_pol, ps, depth))
2698 return False;
2700 return True;
2703 /*******************************************************************
2704 reads or writes a structure.
2705 ********************************************************************/
2707 BOOL samr_io_r_delete_dom_group(const char *desc, SAMR_R_DELETE_DOM_GROUP * r_u,
2708 prs_struct *ps, int depth)
2710 if (r_u == NULL)
2711 return False;
2713 prs_debug(ps, depth, desc, "samr_io_r_delete_dom_group");
2714 depth++;
2716 if(!prs_align(ps))
2717 return False;
2719 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
2720 return False;
2722 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2723 return False;
2725 return True;
2728 /*******************************************************************
2729 inits a SAMR_Q_DEL_GROUPMEM structure.
2730 ********************************************************************/
2732 void init_samr_q_del_groupmem(SAMR_Q_DEL_GROUPMEM * q_e,
2733 POLICY_HND *pol, uint32 rid)
2735 DEBUG(5, ("init_samr_q_del_groupmem\n"));
2737 q_e->pol = *pol;
2738 q_e->rid = rid;
2741 /*******************************************************************
2742 reads or writes a structure.
2743 ********************************************************************/
2745 BOOL samr_io_q_del_groupmem(const char *desc, SAMR_Q_DEL_GROUPMEM * q_e,
2746 prs_struct *ps, int depth)
2748 if (q_e == NULL)
2749 return False;
2751 prs_debug(ps, depth, desc, "samr_io_q_del_groupmem");
2752 depth++;
2754 if(!prs_align(ps))
2755 return False;
2757 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
2758 return False;
2760 if(!prs_uint32("rid", ps, depth, &q_e->rid))
2761 return False;
2763 return True;
2766 /*******************************************************************
2767 inits a SAMR_R_DEL_GROUPMEM structure.
2768 ********************************************************************/
2770 void init_samr_r_del_groupmem(SAMR_R_DEL_GROUPMEM * r_u, POLICY_HND *pol,
2771 NTSTATUS status)
2773 DEBUG(5, ("init_samr_r_del_groupmem\n"));
2775 r_u->status = status;
2778 /*******************************************************************
2779 reads or writes a structure.
2780 ********************************************************************/
2782 BOOL samr_io_r_del_groupmem(const char *desc, SAMR_R_DEL_GROUPMEM * r_u,
2783 prs_struct *ps, int depth)
2785 if (r_u == NULL)
2786 return False;
2788 prs_debug(ps, depth, desc, "samr_io_r_del_groupmem");
2789 depth++;
2791 if(!prs_align(ps))
2792 return False;
2794 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2795 return False;
2797 return True;
2800 /*******************************************************************
2801 inits a SAMR_Q_ADD_GROUPMEM structure.
2802 ********************************************************************/
2804 void init_samr_q_add_groupmem(SAMR_Q_ADD_GROUPMEM * q_e,
2805 POLICY_HND *pol, uint32 rid)
2807 DEBUG(5, ("init_samr_q_add_groupmem\n"));
2809 q_e->pol = *pol;
2810 q_e->rid = rid;
2811 q_e->unknown = 0x0005;
2814 /*******************************************************************
2815 reads or writes a structure.
2816 ********************************************************************/
2818 BOOL samr_io_q_add_groupmem(const char *desc, SAMR_Q_ADD_GROUPMEM * q_e,
2819 prs_struct *ps, int depth)
2821 if (q_e == NULL)
2822 return False;
2824 prs_debug(ps, depth, desc, "samr_io_q_add_groupmem");
2825 depth++;
2827 if(!prs_align(ps))
2828 return False;
2830 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
2831 return False;
2833 if(!prs_uint32("rid ", ps, depth, &q_e->rid))
2834 return False;
2835 if(!prs_uint32("unknown", ps, depth, &q_e->unknown))
2836 return False;
2838 return True;
2841 /*******************************************************************
2842 inits a SAMR_R_ADD_GROUPMEM structure.
2843 ********************************************************************/
2845 void init_samr_r_add_groupmem(SAMR_R_ADD_GROUPMEM * r_u, POLICY_HND *pol,
2846 NTSTATUS status)
2848 DEBUG(5, ("init_samr_r_add_groupmem\n"));
2850 r_u->status = status;
2853 /*******************************************************************
2854 reads or writes a structure.
2855 ********************************************************************/
2857 BOOL samr_io_r_add_groupmem(const char *desc, SAMR_R_ADD_GROUPMEM * r_u,
2858 prs_struct *ps, int depth)
2860 if (r_u == NULL)
2861 return False;
2863 prs_debug(ps, depth, desc, "samr_io_r_add_groupmem");
2864 depth++;
2866 if(!prs_align(ps))
2867 return False;
2869 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2870 return False;
2872 return True;
2875 /*******************************************************************
2876 inits a SAMR_Q_SET_GROUPINFO structure.
2877 ********************************************************************/
2879 void init_samr_q_set_groupinfo(SAMR_Q_SET_GROUPINFO * q_e,
2880 POLICY_HND *pol, GROUP_INFO_CTR * ctr)
2882 DEBUG(5, ("init_samr_q_set_groupinfo\n"));
2884 q_e->pol = *pol;
2885 q_e->ctr = ctr;
2888 /*******************************************************************
2889 reads or writes a structure.
2890 ********************************************************************/
2892 BOOL samr_io_q_set_groupinfo(const char *desc, SAMR_Q_SET_GROUPINFO * q_e,
2893 prs_struct *ps, int depth)
2895 if (q_e == NULL)
2896 return False;
2898 prs_debug(ps, depth, desc, "samr_io_q_set_groupinfo");
2899 depth++;
2901 if(!prs_align(ps))
2902 return False;
2904 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
2905 return False;
2907 if(!samr_group_info_ctr("ctr", &q_e->ctr, ps, depth))
2908 return False;
2910 return True;
2913 /*******************************************************************
2914 inits a SAMR_R_SET_GROUPINFO structure.
2915 ********************************************************************/
2917 void init_samr_r_set_groupinfo(SAMR_R_SET_GROUPINFO * r_u, NTSTATUS status)
2919 DEBUG(5, ("init_samr_r_set_groupinfo\n"));
2921 r_u->status = status;
2924 /*******************************************************************
2925 reads or writes a structure.
2926 ********************************************************************/
2928 BOOL samr_io_r_set_groupinfo(const char *desc, SAMR_R_SET_GROUPINFO * r_u,
2929 prs_struct *ps, int depth)
2931 if (r_u == NULL)
2932 return False;
2934 prs_debug(ps, depth, desc, "samr_io_r_set_groupinfo");
2935 depth++;
2937 if(!prs_align(ps))
2938 return False;
2940 if(!prs_ntstatus("status", ps, depth, &r_u->status))
2941 return False;
2943 return True;
2946 /*******************************************************************
2947 inits a SAMR_Q_QUERY_GROUPINFO structure.
2948 ********************************************************************/
2950 void init_samr_q_query_groupinfo(SAMR_Q_QUERY_GROUPINFO * q_e,
2951 POLICY_HND *pol, uint16 switch_level)
2953 DEBUG(5, ("init_samr_q_query_groupinfo\n"));
2955 q_e->pol = *pol;
2957 q_e->switch_level = switch_level;
2960 /*******************************************************************
2961 reads or writes a structure.
2962 ********************************************************************/
2964 BOOL samr_io_q_query_groupinfo(const char *desc, SAMR_Q_QUERY_GROUPINFO * q_e,
2965 prs_struct *ps, int depth)
2967 if (q_e == NULL)
2968 return False;
2970 prs_debug(ps, depth, desc, "samr_io_q_query_groupinfo");
2971 depth++;
2973 if(!prs_align(ps))
2974 return False;
2976 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
2977 return False;
2979 if(!prs_uint16("switch_level", ps, depth, &q_e->switch_level))
2980 return False;
2982 return True;
2985 /*******************************************************************
2986 inits a SAMR_R_QUERY_GROUPINFO structure.
2987 ********************************************************************/
2989 void init_samr_r_query_groupinfo(SAMR_R_QUERY_GROUPINFO * r_u,
2990 GROUP_INFO_CTR * ctr, NTSTATUS status)
2992 DEBUG(5, ("init_samr_r_query_groupinfo\n"));
2994 r_u->ptr = (NT_STATUS_IS_OK(status) && ctr != NULL) ? 1 : 0;
2995 r_u->ctr = ctr;
2996 r_u->status = status;
2999 /*******************************************************************
3000 reads or writes a structure.
3001 ********************************************************************/
3003 BOOL samr_io_r_query_groupinfo(const char *desc, SAMR_R_QUERY_GROUPINFO * r_u,
3004 prs_struct *ps, int depth)
3006 if (r_u == NULL)
3007 return False;
3009 prs_debug(ps, depth, desc, "samr_io_r_query_groupinfo");
3010 depth++;
3012 if(!prs_align(ps))
3013 return False;
3015 if(!prs_uint32("ptr", ps, depth, &r_u->ptr))
3016 return False;
3018 if (r_u->ptr != 0) {
3019 if(!samr_group_info_ctr("ctr", &r_u->ctr, ps, depth))
3020 return False;
3023 if(!prs_align(ps))
3024 return False;
3025 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3026 return False;
3028 return True;
3031 /*******************************************************************
3032 inits a SAMR_Q_QUERY_GROUPMEM structure.
3033 ********************************************************************/
3035 void init_samr_q_query_groupmem(SAMR_Q_QUERY_GROUPMEM * q_c, POLICY_HND *hnd)
3037 DEBUG(5, ("init_samr_q_query_groupmem\n"));
3039 q_c->group_pol = *hnd;
3042 /*******************************************************************
3043 reads or writes a structure.
3044 ********************************************************************/
3046 BOOL samr_io_q_query_groupmem(const char *desc, SAMR_Q_QUERY_GROUPMEM * q_u,
3047 prs_struct *ps, int depth)
3049 if (q_u == NULL)
3050 return False;
3052 prs_debug(ps, depth, desc, "samr_io_q_query_groupmem");
3053 depth++;
3055 if(!prs_align(ps))
3056 return False;
3058 if(!smb_io_pol_hnd("group_pol", &q_u->group_pol, ps, depth))
3059 return False;
3061 return True;
3064 /*******************************************************************
3065 inits a SAMR_R_QUERY_GROUPMEM structure.
3066 ********************************************************************/
3068 void init_samr_r_query_groupmem(SAMR_R_QUERY_GROUPMEM * r_u,
3069 uint32 num_entries, uint32 *rid,
3070 uint32 *attr, NTSTATUS status)
3072 DEBUG(5, ("init_samr_r_query_groupmem\n"));
3074 if (NT_STATUS_IS_OK(status)) {
3075 r_u->ptr = 1;
3076 r_u->num_entries = num_entries;
3078 r_u->ptr_attrs = attr != NULL ? 1 : 0;
3079 r_u->ptr_rids = rid != NULL ? 1 : 0;
3081 r_u->num_rids = num_entries;
3082 r_u->rid = rid;
3084 r_u->num_attrs = num_entries;
3085 r_u->attr = attr;
3086 } else {
3087 r_u->ptr = 0;
3088 r_u->num_entries = 0;
3091 r_u->status = status;
3094 /*******************************************************************
3095 reads or writes a structure.
3096 ********************************************************************/
3098 BOOL samr_io_r_query_groupmem(const char *desc, SAMR_R_QUERY_GROUPMEM * r_u,
3099 prs_struct *ps, int depth)
3101 uint32 i;
3103 if (r_u == NULL)
3104 return False;
3106 if (UNMARSHALLING(ps))
3107 ZERO_STRUCTP(r_u);
3109 prs_debug(ps, depth, desc, "samr_io_r_query_groupmem");
3110 depth++;
3112 if(!prs_align(ps))
3113 return False;
3115 if(!prs_uint32("ptr", ps, depth, &r_u->ptr))
3116 return False;
3117 if(!prs_uint32("num_entries ", ps, depth, &r_u->num_entries))
3118 return False;
3120 if (r_u->ptr != 0) {
3121 if(!prs_uint32("ptr_rids ", ps, depth, &r_u->ptr_rids))
3122 return False;
3123 if(!prs_uint32("ptr_attrs", ps, depth, &r_u->ptr_attrs))
3124 return False;
3126 if (r_u->ptr_rids != 0) {
3127 if(!prs_uint32("num_rids", ps, depth, &r_u->num_rids))
3128 return False;
3129 if (UNMARSHALLING(ps) && r_u->num_rids != 0) {
3130 r_u->rid = PRS_ALLOC_MEM(ps,uint32,r_u->num_rids);
3131 if (r_u->rid == NULL)
3132 return False;
3135 for (i = 0; i < r_u->num_rids; i++) {
3136 if(!prs_uint32("", ps, depth, &r_u->rid[i]))
3137 return False;
3141 if (r_u->ptr_attrs != 0) {
3142 if(!prs_uint32("num_attrs", ps, depth, &r_u->num_attrs))
3143 return False;
3145 if (UNMARSHALLING(ps) && r_u->num_attrs != 0) {
3146 r_u->attr = PRS_ALLOC_MEM(ps,uint32,r_u->num_attrs);
3147 if (r_u->attr == NULL)
3148 return False;
3151 for (i = 0; i < r_u->num_attrs; i++) {
3152 if(!prs_uint32("", ps, depth, &r_u->attr[i]))
3153 return False;
3158 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3159 return False;
3161 return True;
3164 /*******************************************************************
3165 inits a SAMR_Q_QUERY_USERGROUPS structure.
3166 ********************************************************************/
3168 void init_samr_q_query_usergroups(SAMR_Q_QUERY_USERGROUPS * q_u,
3169 POLICY_HND *hnd)
3171 DEBUG(5, ("init_samr_q_query_usergroups\n"));
3173 q_u->pol = *hnd;
3176 /*******************************************************************
3177 reads or writes a structure.
3178 ********************************************************************/
3180 BOOL samr_io_q_query_usergroups(const char *desc, SAMR_Q_QUERY_USERGROUPS * q_u,
3181 prs_struct *ps, int depth)
3183 if (q_u == NULL)
3184 return False;
3186 prs_debug(ps, depth, desc, "samr_io_q_query_usergroups");
3187 depth++;
3189 if(!prs_align(ps))
3190 return False;
3192 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
3193 return False;
3195 return True;
3198 /*******************************************************************
3199 inits a SAMR_R_QUERY_USERGROUPS structure.
3200 ********************************************************************/
3202 void init_samr_r_query_usergroups(SAMR_R_QUERY_USERGROUPS * r_u,
3203 uint32 num_gids, DOM_GID * gid,
3204 NTSTATUS status)
3206 DEBUG(5, ("init_samr_r_query_usergroups\n"));
3208 if (NT_STATUS_IS_OK(status)) {
3209 r_u->ptr_0 = 1;
3210 r_u->num_entries = num_gids;
3211 r_u->ptr_1 = (num_gids != 0) ? 1 : 0;
3212 r_u->num_entries2 = num_gids;
3214 r_u->gid = gid;
3215 } else {
3216 r_u->ptr_0 = 0;
3217 r_u->num_entries = 0;
3218 r_u->ptr_1 = 0;
3219 r_u->gid = NULL;
3222 r_u->status = status;
3225 /*******************************************************************
3226 reads or writes a structure.
3227 ********************************************************************/
3229 BOOL samr_io_gids(const char *desc, uint32 *num_gids, DOM_GID ** gid,
3230 prs_struct *ps, int depth)
3232 uint32 i;
3233 if (gid == NULL)
3234 return False;
3236 prs_debug(ps, depth, desc, "samr_io_gids");
3237 depth++;
3239 if(!prs_align(ps))
3240 return False;
3242 if(!prs_uint32("num_gids", ps, depth, num_gids))
3243 return False;
3245 if ((*num_gids) != 0) {
3246 if (UNMARSHALLING(ps)) {
3247 (*gid) = PRS_ALLOC_MEM(ps,DOM_GID,*num_gids);
3250 if ((*gid) == NULL) {
3251 return False;
3254 for (i = 0; i < (*num_gids); i++) {
3255 if(!smb_io_gid("gids", &(*gid)[i], ps, depth))
3256 return False;
3260 return True;
3263 /*******************************************************************
3264 reads or writes a structure.
3265 ********************************************************************/
3267 BOOL samr_io_r_query_usergroups(const char *desc, SAMR_R_QUERY_USERGROUPS * r_u,
3268 prs_struct *ps, int depth)
3270 if (r_u == NULL)
3271 return False;
3273 prs_debug(ps, depth, desc, "samr_io_r_query_usergroups");
3274 depth++;
3276 if(!prs_align(ps))
3277 return False;
3279 if(!prs_uint32("ptr_0 ", ps, depth, &r_u->ptr_0))
3280 return False;
3282 if (r_u->ptr_0 != 0) {
3283 if(!prs_uint32("num_entries ", ps, depth, &r_u->num_entries))
3284 return False;
3285 if(!prs_uint32("ptr_1 ", ps, depth, &r_u->ptr_1))
3286 return False;
3288 if (r_u->num_entries != 0 && r_u->ptr_1 != 0) {
3289 if(!samr_io_gids("gids", &r_u->num_entries2, &r_u->gid, ps, depth))
3290 return False;
3294 if(!prs_align(ps))
3295 return False;
3296 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3297 return False;
3299 return True;
3302 /*******************************************************************
3303 inits a SAMR_Q_ENUM_DOMAINS structure.
3304 ********************************************************************/
3306 void init_samr_q_enum_domains(SAMR_Q_ENUM_DOMAINS * q_e,
3307 POLICY_HND *pol,
3308 uint32 start_idx, uint32 size)
3310 DEBUG(5, ("init_samr_q_enum_domains\n"));
3312 q_e->pol = *pol;
3314 q_e->start_idx = start_idx;
3315 q_e->max_size = size;
3318 /*******************************************************************
3319 reads or writes a structure.
3320 ********************************************************************/
3322 BOOL samr_io_q_enum_domains(const char *desc, SAMR_Q_ENUM_DOMAINS * q_e,
3323 prs_struct *ps, int depth)
3325 if (q_e == NULL)
3326 return False;
3328 prs_debug(ps, depth, desc, "samr_io_q_enum_domains");
3329 depth++;
3331 if(!prs_align(ps))
3332 return False;
3334 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
3335 return False;
3337 if(!prs_uint32("start_idx", ps, depth, &q_e->start_idx))
3338 return False;
3339 if(!prs_uint32("max_size ", ps, depth, &q_e->max_size))
3340 return False;
3342 return True;
3345 /*******************************************************************
3346 inits a SAMR_R_ENUM_DOMAINS structure.
3347 ********************************************************************/
3349 void init_samr_r_enum_domains(SAMR_R_ENUM_DOMAINS * r_u,
3350 uint32 next_idx, uint32 num_sam_entries)
3352 DEBUG(5, ("init_samr_r_enum_domains\n"));
3354 r_u->next_idx = next_idx;
3356 if (num_sam_entries != 0) {
3357 r_u->ptr_entries1 = 1;
3358 r_u->ptr_entries2 = 1;
3359 r_u->num_entries2 = num_sam_entries;
3360 r_u->num_entries3 = num_sam_entries;
3362 r_u->num_entries4 = num_sam_entries;
3363 } else {
3364 r_u->ptr_entries1 = 0;
3365 r_u->num_entries2 = num_sam_entries;
3366 r_u->ptr_entries2 = 1;
3370 /*******************************************************************
3371 reads or writes a structure.
3372 ********************************************************************/
3374 BOOL samr_io_r_enum_domains(const char *desc, SAMR_R_ENUM_DOMAINS * r_u,
3375 prs_struct *ps, int depth)
3377 uint32 i;
3379 if (r_u == NULL)
3380 return False;
3382 prs_debug(ps, depth, desc, "samr_io_r_enum_domains");
3383 depth++;
3385 if(!prs_align(ps))
3386 return False;
3388 if(!prs_uint32("next_idx ", ps, depth, &r_u->next_idx))
3389 return False;
3390 if(!prs_uint32("ptr_entries1", ps, depth, &r_u->ptr_entries1))
3391 return False;
3393 if (r_u->ptr_entries1 != 0) {
3394 if(!prs_uint32("num_entries2", ps, depth, &r_u->num_entries2))
3395 return False;
3396 if(!prs_uint32("ptr_entries2", ps, depth, &r_u->ptr_entries2))
3397 return False;
3398 if(!prs_uint32("num_entries3", ps, depth, &r_u->num_entries3))
3399 return False;
3401 if (UNMARSHALLING(ps) && r_u->num_entries2) {
3402 r_u->sam = PRS_ALLOC_MEM(ps,SAM_ENTRY,r_u->num_entries2);
3403 r_u->uni_dom_name = PRS_ALLOC_MEM(ps,UNISTR2,r_u->num_entries2);
3406 if ((r_u->sam == NULL || r_u->uni_dom_name == NULL) && r_u->num_entries2 != 0) {
3407 DEBUG(0, ("NULL pointers in SAMR_R_ENUM_DOMAINS\n"));
3408 r_u->num_entries4 = 0;
3409 r_u->status = NT_STATUS_MEMORY_NOT_ALLOCATED;
3410 return False;
3413 for (i = 0; i < r_u->num_entries2; i++) {
3414 fstring tmp;
3415 slprintf(tmp, sizeof(tmp) - 1, "dom[%d]", i);
3416 if(!sam_io_sam_entry(tmp, &r_u->sam[i], ps, depth))
3417 return False;
3420 for (i = 0; i < r_u->num_entries2; i++) {
3421 fstring tmp;
3422 slprintf(tmp, sizeof(tmp) - 1, "dom[%d]", i);
3423 if(!smb_io_unistr2(tmp, &r_u->uni_dom_name[i],
3424 r_u->sam[i].hdr_name.buffer, ps,
3425 depth))
3426 return False;
3431 if(!prs_align(ps))
3432 return False;
3433 if(!prs_uint32("num_entries4", ps, depth, &r_u->num_entries4))
3434 return False;
3435 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3436 return False;
3438 return True;
3441 /*******************************************************************
3442 inits a SAMR_Q_ENUM_DOM_GROUPS structure.
3443 ********************************************************************/
3445 void init_samr_q_enum_dom_groups(SAMR_Q_ENUM_DOM_GROUPS * q_e,
3446 POLICY_HND *pol,
3447 uint32 start_idx, uint32 size)
3449 DEBUG(5, ("init_samr_q_enum_dom_groups\n"));
3451 q_e->pol = *pol;
3453 q_e->start_idx = start_idx;
3454 q_e->max_size = size;
3457 /*******************************************************************
3458 reads or writes a structure.
3459 ********************************************************************/
3461 BOOL samr_io_q_enum_dom_groups(const char *desc, SAMR_Q_ENUM_DOM_GROUPS * q_e,
3462 prs_struct *ps, int depth)
3464 if (q_e == NULL)
3465 return False;
3467 prs_debug(ps, depth, desc, "samr_io_q_enum_dom_groups");
3468 depth++;
3470 if(!prs_align(ps))
3471 return False;
3473 if(!smb_io_pol_hnd("pol", &(q_e->pol), ps, depth))
3474 return False;
3476 if(!prs_uint32("start_idx", ps, depth, &q_e->start_idx))
3477 return False;
3478 if(!prs_uint32("max_size ", ps, depth, &q_e->max_size))
3479 return False;
3481 return True;
3484 /*******************************************************************
3485 inits a SAMR_R_ENUM_DOM_GROUPS structure.
3486 ********************************************************************/
3488 void init_samr_r_enum_dom_groups(SAMR_R_ENUM_DOM_GROUPS * r_u,
3489 uint32 next_idx, uint32 num_sam_entries)
3491 DEBUG(5, ("init_samr_r_enum_dom_groups\n"));
3493 r_u->next_idx = next_idx;
3495 if (num_sam_entries != 0) {
3496 r_u->ptr_entries1 = 1;
3497 r_u->ptr_entries2 = 1;
3498 r_u->num_entries2 = num_sam_entries;
3499 r_u->num_entries3 = num_sam_entries;
3501 r_u->num_entries4 = num_sam_entries;
3502 } else {
3503 r_u->ptr_entries1 = 0;
3504 r_u->num_entries2 = num_sam_entries;
3505 r_u->ptr_entries2 = 1;
3509 /*******************************************************************
3510 reads or writes a structure.
3511 ********************************************************************/
3513 BOOL samr_io_r_enum_dom_groups(const char *desc, SAMR_R_ENUM_DOM_GROUPS * r_u,
3514 prs_struct *ps, int depth)
3516 uint32 i;
3518 if (r_u == NULL)
3519 return False;
3521 prs_debug(ps, depth, desc, "samr_io_r_enum_dom_groups");
3522 depth++;
3524 if(!prs_align(ps))
3525 return False;
3527 if(!prs_uint32("next_idx ", ps, depth, &r_u->next_idx))
3528 return False;
3529 if(!prs_uint32("ptr_entries1", ps, depth, &r_u->ptr_entries1))
3530 return False;
3532 if (r_u->ptr_entries1 != 0) {
3533 if(!prs_uint32("num_entries2", ps, depth, &r_u->num_entries2))
3534 return False;
3535 if(!prs_uint32("ptr_entries2", ps, depth, &r_u->ptr_entries2))
3536 return False;
3537 if(!prs_uint32("num_entries3", ps, depth, &r_u->num_entries3))
3538 return False;
3540 if (UNMARSHALLING(ps) && r_u->num_entries2) {
3541 r_u->sam = PRS_ALLOC_MEM(ps,SAM_ENTRY,r_u->num_entries2);
3542 r_u->uni_grp_name = PRS_ALLOC_MEM(ps,UNISTR2,r_u->num_entries2);
3545 if ((r_u->sam == NULL || r_u->uni_grp_name == NULL) && r_u->num_entries2 != 0) {
3546 DEBUG(0,
3547 ("NULL pointers in SAMR_R_ENUM_DOM_GROUPS\n"));
3548 r_u->num_entries4 = 0;
3549 r_u->status = NT_STATUS_MEMORY_NOT_ALLOCATED;
3550 return False;
3553 for (i = 0; i < r_u->num_entries2; i++) {
3554 if(!sam_io_sam_entry("", &r_u->sam[i], ps, depth))
3555 return False;
3558 for (i = 0; i < r_u->num_entries2; i++) {
3559 if(!smb_io_unistr2("", &r_u->uni_grp_name[i],
3560 r_u->sam[i].hdr_name.buffer, ps, depth))
3561 return False;
3565 if(!prs_align(ps))
3566 return False;
3567 if(!prs_uint32("num_entries4", ps, depth, &r_u->num_entries4))
3568 return False;
3569 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3570 return False;
3572 return True;
3575 /*******************************************************************
3576 inits a SAMR_Q_ENUM_DOM_ALIASES structure.
3577 ********************************************************************/
3579 void init_samr_q_enum_dom_aliases(SAMR_Q_ENUM_DOM_ALIASES * q_e,
3580 POLICY_HND *pol, uint32 start_idx,
3581 uint32 size)
3583 DEBUG(5, ("init_samr_q_enum_dom_aliases\n"));
3585 q_e->pol = *pol;
3587 q_e->start_idx = start_idx;
3588 q_e->max_size = size;
3592 /*******************************************************************
3593 reads or writes a structure.
3594 ********************************************************************/
3596 BOOL samr_io_q_enum_dom_aliases(const char *desc, SAMR_Q_ENUM_DOM_ALIASES * q_e,
3597 prs_struct *ps, int depth)
3599 if (q_e == NULL)
3600 return False;
3602 prs_debug(ps, depth, desc, "samr_io_q_enum_dom_aliases");
3603 depth++;
3605 if(!prs_align(ps))
3606 return False;
3608 if(!smb_io_pol_hnd("pol", &q_e->pol, ps, depth))
3609 return False;
3611 if(!prs_uint32("start_idx", ps, depth, &q_e->start_idx))
3612 return False;
3613 if(!prs_uint32("max_size ", ps, depth, &q_e->max_size))
3614 return False;
3616 return True;
3619 /*******************************************************************
3620 inits a SAMR_R_ENUM_DOM_ALIASES structure.
3621 ********************************************************************/
3623 void init_samr_r_enum_dom_aliases(SAMR_R_ENUM_DOM_ALIASES *r_u, uint32 next_idx, uint32 num_sam_entries)
3625 DEBUG(5, ("init_samr_r_enum_dom_aliases\n"));
3627 r_u->next_idx = next_idx;
3629 if (num_sam_entries != 0) {
3630 r_u->ptr_entries1 = 1;
3631 r_u->ptr_entries2 = 1;
3632 r_u->num_entries2 = num_sam_entries;
3633 r_u->num_entries3 = num_sam_entries;
3635 r_u->num_entries4 = num_sam_entries;
3636 } else {
3637 r_u->ptr_entries1 = 0;
3638 r_u->num_entries2 = num_sam_entries;
3639 r_u->ptr_entries2 = 1;
3643 /*******************************************************************
3644 reads or writes a structure.
3645 ********************************************************************/
3647 BOOL samr_io_r_enum_dom_aliases(const char *desc, SAMR_R_ENUM_DOM_ALIASES * r_u,
3648 prs_struct *ps, int depth)
3650 uint32 i;
3652 if (r_u == NULL)
3653 return False;
3655 prs_debug(ps, depth, desc, "samr_io_r_enum_dom_aliases");
3656 depth++;
3658 if(!prs_align(ps))
3659 return False;
3661 if(!prs_uint32("next_idx ", ps, depth, &r_u->next_idx))
3662 return False;
3663 if(!prs_uint32("ptr_entries1", ps, depth, &r_u->ptr_entries1))
3664 return False;
3666 if (r_u->ptr_entries1 != 0) {
3667 if(!prs_uint32("num_entries2", ps, depth, &r_u->num_entries2))
3668 return False;
3669 if(!prs_uint32("ptr_entries2", ps, depth, &r_u->ptr_entries2))
3670 return False;
3671 if(!prs_uint32("num_entries3", ps, depth, &r_u->num_entries3))
3672 return False;
3674 if (UNMARSHALLING(ps) && (r_u->num_entries2 > 0)) {
3675 r_u->sam = PRS_ALLOC_MEM(ps,SAM_ENTRY,r_u->num_entries2);
3676 r_u->uni_grp_name = PRS_ALLOC_MEM(ps,UNISTR2,r_u->num_entries2);
3679 if (r_u->num_entries2 != 0 &&
3680 (r_u->sam == NULL || r_u->uni_grp_name == NULL)) {
3681 DEBUG(0,("NULL pointers in SAMR_R_ENUM_DOM_ALIASES\n"));
3682 r_u->num_entries4 = 0;
3683 r_u->status = NT_STATUS_MEMORY_NOT_ALLOCATED;
3684 return False;
3687 for (i = 0; i < r_u->num_entries2; i++) {
3688 if(!sam_io_sam_entry("", &r_u->sam[i], ps, depth))
3689 return False;
3692 for (i = 0; i < r_u->num_entries2; i++) {
3693 if(!smb_io_unistr2("", &r_u->uni_grp_name[i],
3694 r_u->sam[i].hdr_name.buffer, ps,
3695 depth))
3696 return False;
3700 if(!prs_align(ps))
3701 return False;
3702 if(!prs_uint32("num_entries4", ps, depth, &r_u->num_entries4))
3703 return False;
3704 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3705 return False;
3707 return True;
3710 /*******************************************************************
3711 inits a ALIAS_INFO1 structure.
3712 ********************************************************************/
3714 void init_samr_alias_info1(ALIAS_INFO1 * al1, char *acct_name, uint32 num_member, char *acct_desc)
3716 DEBUG(5, ("init_samr_alias_info1\n"));
3718 init_unistr4(&al1->name, acct_name, UNI_FLAGS_NONE);
3719 al1->num_member = num_member;
3720 init_unistr4(&al1->description, acct_desc, UNI_FLAGS_NONE);
3723 /*******************************************************************
3724 reads or writes a structure.
3725 ********************************************************************/
3727 BOOL samr_io_alias_info1(const char *desc, ALIAS_INFO1 * al1,
3728 prs_struct *ps, int depth)
3730 if (al1 == NULL)
3731 return False;
3733 prs_debug(ps, depth, desc, "samr_io_alias_info1");
3734 depth++;
3736 if(!prs_align(ps))
3737 return False;
3739 if ( !prs_unistr4_hdr("name", ps, depth, &al1->name) )
3740 return False;
3741 if ( !prs_uint32("num_member", ps, depth, &al1->num_member) )
3742 return False;
3743 if ( !prs_unistr4_hdr("description", ps, depth, &al1->description) )
3744 return False;
3746 if ( !prs_unistr4_str("name", ps, depth, &al1->name) )
3747 return False;
3748 if ( !prs_align(ps) )
3749 return False;
3750 if ( !prs_unistr4_str("description", ps, depth, &al1->description) )
3751 return False;
3752 if ( !prs_align(ps) )
3753 return False;
3755 return True;
3758 /*******************************************************************
3759 inits a ALIAS_INFO3 structure.
3760 ********************************************************************/
3762 void init_samr_alias_info3(ALIAS_INFO3 * al3, const char *acct_desc)
3764 DEBUG(5, ("init_samr_alias_info3\n"));
3766 init_unistr4(&al3->description, acct_desc, UNI_FLAGS_NONE);
3769 /*******************************************************************
3770 reads or writes a structure.
3771 ********************************************************************/
3773 BOOL samr_io_alias_info3(const char *desc, ALIAS_INFO3 *al3,
3774 prs_struct *ps, int depth)
3776 if (al3 == NULL)
3777 return False;
3779 prs_debug(ps, depth, desc, "samr_io_alias_info3");
3780 depth++;
3782 if(!prs_align(ps))
3783 return False;
3785 if (!prs_unistr4("description", ps, depth, &al3->description))
3786 return False;
3788 return True;
3791 /*******************************************************************
3792 reads or writes a structure.
3793 ********************************************************************/
3795 BOOL samr_io_alias_info2(const char *desc, ALIAS_INFO2 *al2,
3796 prs_struct *ps, int depth)
3798 if (al2 == NULL)
3799 return False;
3801 prs_debug(ps, depth, desc, "samr_io_alias_info2");
3802 depth++;
3804 if(!prs_align(ps))
3805 return False;
3807 if (!prs_unistr4("name", ps, depth, &al2->name))
3808 return False;
3810 return True;
3813 /*******************************************************************
3814 reads or writes a structure.
3815 ********************************************************************/
3817 BOOL samr_alias_info_ctr(const char *desc, prs_struct *ps, int depth, ALIAS_INFO_CTR * ctr)
3819 if ( !ctr )
3820 return False;
3822 prs_debug(ps, depth, desc, "samr_alias_info_ctr");
3823 depth++;
3825 if ( !prs_uint16("level", ps, depth, &ctr->level) )
3826 return False;
3828 if(!prs_align(ps))
3829 return False;
3830 switch (ctr->level) {
3831 case 1:
3832 if(!samr_io_alias_info1("alias_info1", &ctr->alias.info1, ps, depth))
3833 return False;
3834 break;
3835 case 2:
3836 if(!samr_io_alias_info2("alias_info2", &ctr->alias.info2, ps, depth))
3837 return False;
3838 break;
3839 case 3:
3840 if(!samr_io_alias_info3("alias_info3", &ctr->alias.info3, ps, depth))
3841 return False;
3842 break;
3843 default:
3844 DEBUG(0,("samr_alias_info_ctr: unsupported switch level\n"));
3845 break;
3848 return True;
3851 /*******************************************************************
3852 inits a SAMR_Q_QUERY_ALIASINFO structure.
3853 ********************************************************************/
3855 void init_samr_q_query_aliasinfo(SAMR_Q_QUERY_ALIASINFO * q_e,
3856 POLICY_HND *pol, uint32 switch_level)
3858 DEBUG(5, ("init_samr_q_query_aliasinfo\n"));
3860 q_e->pol = *pol;
3861 q_e->level = switch_level;
3864 /*******************************************************************
3865 reads or writes a structure.
3866 ********************************************************************/
3868 BOOL samr_io_q_query_aliasinfo(const char *desc, SAMR_Q_QUERY_ALIASINFO *in,
3869 prs_struct *ps, int depth)
3871 if ( !in )
3872 return False;
3874 prs_debug(ps, depth, desc, "samr_io_q_query_aliasinfo");
3875 depth++;
3877 if(!prs_align(ps))
3878 return False;
3880 if ( !smb_io_pol_hnd("pol", &(in->pol), ps, depth) )
3881 return False;
3883 if ( !prs_uint16("level", ps, depth, &in->level) )
3884 return False;
3886 return True;
3889 /*******************************************************************
3890 inits a SAMR_R_QUERY_ALIASINFO structure.
3891 ********************************************************************/
3893 void init_samr_r_query_aliasinfo(SAMR_R_QUERY_ALIASINFO *out,
3894 ALIAS_INFO_CTR * ctr, NTSTATUS status)
3896 DEBUG(5, ("init_samr_r_query_aliasinfo\n"));
3898 out->ctr = ctr;
3899 out->status = status;
3902 /*******************************************************************
3903 reads or writes a structure.
3904 ********************************************************************/
3906 BOOL samr_io_r_query_aliasinfo(const char *desc, SAMR_R_QUERY_ALIASINFO *out,
3907 prs_struct *ps, int depth)
3909 if ( !out )
3910 return False;
3912 prs_debug(ps, depth, desc, "samr_io_r_query_aliasinfo");
3913 depth++;
3915 if(!prs_align(ps))
3916 return False;
3918 if ( !prs_pointer("alias", ps, depth, (void*)&out->ctr, sizeof(ALIAS_INFO_CTR), (PRS_POINTER_CAST)samr_alias_info_ctr))
3919 return False;
3920 if(!prs_align(ps))
3921 return False;
3923 if(!prs_ntstatus("status", ps, depth, &out->status))
3924 return False;
3926 return True;
3929 /*******************************************************************
3930 inits a SAMR_Q_SET_ALIASINFO structure.
3931 ********************************************************************/
3933 void init_samr_q_set_aliasinfo(SAMR_Q_SET_ALIASINFO * q_u,
3934 POLICY_HND *hnd, ALIAS_INFO_CTR * ctr)
3936 DEBUG(5, ("init_samr_q_set_aliasinfo\n"));
3938 q_u->alias_pol = *hnd;
3939 q_u->ctr = *ctr;
3942 /*******************************************************************
3943 reads or writes a structure.
3944 ********************************************************************/
3946 BOOL samr_io_q_set_aliasinfo(const char *desc, SAMR_Q_SET_ALIASINFO * q_u,
3947 prs_struct *ps, int depth)
3949 if (q_u == NULL)
3950 return False;
3952 prs_debug(ps, depth, desc, "samr_io_q_set_aliasinfo");
3953 depth++;
3955 if(!prs_align(ps))
3956 return False;
3958 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
3959 return False;
3960 if(!samr_alias_info_ctr("ctr", ps, depth, &q_u->ctr))
3961 return False;
3963 return True;
3966 /*******************************************************************
3967 reads or writes a structure.
3968 ********************************************************************/
3970 BOOL samr_io_r_set_aliasinfo(const char *desc, SAMR_R_SET_ALIASINFO * r_u,
3971 prs_struct *ps, int depth)
3973 if (r_u == NULL)
3974 return False;
3976 prs_debug(ps, depth, desc, "samr_io_r_set_aliasinfo");
3977 depth++;
3979 if(!prs_align(ps))
3980 return False;
3981 if(!prs_ntstatus("status", ps, depth, &r_u->status))
3982 return False;
3984 return True;
3987 /*******************************************************************
3988 inits a SAMR_Q_QUERY_USERALIASES structure.
3989 ********************************************************************/
3991 void init_samr_q_query_useraliases(SAMR_Q_QUERY_USERALIASES * q_u,
3992 POLICY_HND *hnd,
3993 uint32 num_sids,
3994 uint32 *ptr_sid, DOM_SID2 * sid)
3996 DEBUG(5, ("init_samr_q_query_useraliases\n"));
3998 q_u->pol = *hnd;
4000 q_u->num_sids1 = num_sids;
4001 q_u->ptr = 1;
4002 q_u->num_sids2 = num_sids;
4004 q_u->ptr_sid = ptr_sid;
4005 q_u->sid = sid;
4008 /*******************************************************************
4009 reads or writes a SAMR_Q_QUERY_USERALIASES structure.
4010 ********************************************************************/
4012 BOOL samr_io_q_query_useraliases(const char *desc, SAMR_Q_QUERY_USERALIASES * q_u,
4013 prs_struct *ps, int depth)
4015 fstring tmp;
4016 uint32 i;
4018 if (q_u == NULL)
4019 return False;
4021 prs_debug(ps, depth, desc, "samr_io_q_query_useraliases");
4022 depth++;
4024 if(!prs_align(ps))
4025 return False;
4027 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
4028 return False;
4030 if(!prs_uint32("num_sids1", ps, depth, &q_u->num_sids1))
4031 return False;
4032 if(!prs_uint32("ptr ", ps, depth, &q_u->ptr))
4033 return False;
4035 if (q_u->ptr==0)
4036 return True;
4038 if(!prs_uint32("num_sids2", ps, depth, &q_u->num_sids2))
4039 return False;
4041 if (UNMARSHALLING(ps) && (q_u->num_sids2 != 0)) {
4042 q_u->ptr_sid = PRS_ALLOC_MEM(ps,uint32,q_u->num_sids2);
4043 if (q_u->ptr_sid == NULL)
4044 return False;
4046 q_u->sid = PRS_ALLOC_MEM(ps, DOM_SID2, q_u->num_sids2);
4047 if (q_u->sid == NULL)
4048 return False;
4051 for (i = 0; i < q_u->num_sids2; i++) {
4052 slprintf(tmp, sizeof(tmp) - 1, "ptr[%02d]", i);
4053 if(!prs_uint32(tmp, ps, depth, &q_u->ptr_sid[i]))
4054 return False;
4057 for (i = 0; i < q_u->num_sids2; i++) {
4058 if (q_u->ptr_sid[i] != 0) {
4059 slprintf(tmp, sizeof(tmp) - 1, "sid[%02d]", i);
4060 if(!smb_io_dom_sid2(tmp, &q_u->sid[i], ps, depth))
4061 return False;
4065 return True;
4068 /*******************************************************************
4069 inits a SAMR_R_QUERY_USERALIASES structure.
4070 ********************************************************************/
4072 void init_samr_r_query_useraliases(SAMR_R_QUERY_USERALIASES * r_u,
4073 uint32 num_rids, uint32 *rid,
4074 NTSTATUS status)
4076 DEBUG(5, ("init_samr_r_query_useraliases\n"));
4078 if (NT_STATUS_IS_OK(status)) {
4079 r_u->num_entries = num_rids;
4080 r_u->ptr = 1;
4081 r_u->num_entries2 = num_rids;
4083 r_u->rid = rid;
4084 } else {
4085 r_u->num_entries = 0;
4086 r_u->ptr = 0;
4087 r_u->num_entries2 = 0;
4090 r_u->status = status;
4093 /*******************************************************************
4094 reads or writes a structure.
4095 ********************************************************************/
4097 BOOL samr_io_rids(const char *desc, uint32 *num_rids, uint32 **rid,
4098 prs_struct *ps, int depth)
4100 fstring tmp;
4101 uint32 i;
4102 if (rid == NULL)
4103 return False;
4105 prs_debug(ps, depth, desc, "samr_io_rids");
4106 depth++;
4108 if(!prs_align(ps))
4109 return False;
4111 if(!prs_uint32("num_rids", ps, depth, num_rids))
4112 return False;
4114 if ((*num_rids) != 0) {
4115 if (UNMARSHALLING(ps)) {
4116 /* reading */
4117 (*rid) = PRS_ALLOC_MEM(ps,uint32, *num_rids);
4119 if ((*rid) == NULL)
4120 return False;
4122 for (i = 0; i < (*num_rids); i++) {
4123 slprintf(tmp, sizeof(tmp) - 1, "rid[%02d]", i);
4124 if(!prs_uint32(tmp, ps, depth, &((*rid)[i])))
4125 return False;
4129 return True;
4132 /*******************************************************************
4133 reads or writes a structure.
4134 ********************************************************************/
4136 BOOL samr_io_r_query_useraliases(const char *desc, SAMR_R_QUERY_USERALIASES * r_u,
4137 prs_struct *ps, int depth)
4139 if (r_u == NULL)
4140 return False;
4142 prs_debug(ps, depth, desc, "samr_io_r_query_useraliases");
4143 depth++;
4145 if(!prs_align(ps))
4146 return False;
4148 if(!prs_uint32("num_entries", ps, depth, &r_u->num_entries))
4149 return False;
4150 if(!prs_uint32("ptr ", ps, depth, &r_u->ptr))
4151 return False;
4153 if (r_u->ptr != 0) {
4154 if(!samr_io_rids("rids", &r_u->num_entries2, &r_u->rid, ps, depth))
4155 return False;
4158 if(!prs_align(ps))
4159 return False;
4160 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4161 return False;
4163 return True;
4166 /*******************************************************************
4167 inits a SAMR_Q_OPEN_ALIAS structure.
4168 ********************************************************************/
4170 void init_samr_q_open_alias(SAMR_Q_OPEN_ALIAS * q_u, POLICY_HND *pol,
4171 uint32 access_mask, uint32 rid)
4173 DEBUG(5, ("init_samr_q_open_alias\n"));
4175 q_u->dom_pol = *pol;
4176 q_u->access_mask = access_mask;
4177 q_u->rid_alias = rid;
4180 /*******************************************************************
4181 reads or writes a structure.
4182 ********************************************************************/
4184 BOOL samr_io_q_open_alias(const char *desc, SAMR_Q_OPEN_ALIAS * q_u,
4185 prs_struct *ps, int depth)
4187 if (q_u == NULL)
4188 return False;
4190 prs_debug(ps, depth, desc, "samr_io_q_open_alias");
4191 depth++;
4193 if(!prs_align(ps))
4194 return False;
4196 if(!smb_io_pol_hnd("domain_pol", &q_u->dom_pol, ps, depth))
4197 return False;
4199 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
4200 return False;
4201 if(!prs_uint32("rid_alias", ps, depth, &q_u->rid_alias))
4202 return False;
4204 return True;
4207 /*******************************************************************
4208 reads or writes a structure.
4209 ********************************************************************/
4211 BOOL samr_io_r_open_alias(const char *desc, SAMR_R_OPEN_ALIAS * r_u,
4212 prs_struct *ps, int depth)
4214 if (r_u == NULL)
4215 return False;
4217 prs_debug(ps, depth, desc, "samr_io_r_open_alias");
4218 depth++;
4220 if(!prs_align(ps))
4221 return False;
4223 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
4224 return False;
4226 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4227 return False;
4229 return True;
4232 /*******************************************************************
4233 inits a SAMR_Q_LOOKUP_RIDS structure.
4234 ********************************************************************/
4236 void init_samr_q_lookup_rids(TALLOC_CTX *ctx, SAMR_Q_LOOKUP_RIDS * q_u,
4237 POLICY_HND *pol, uint32 flags,
4238 uint32 num_rids, uint32 *rid)
4240 DEBUG(5, ("init_samr_q_lookup_rids\n"));
4242 q_u->pol = *pol;
4244 q_u->num_rids1 = num_rids;
4245 q_u->flags = flags;
4246 q_u->ptr = 0;
4247 q_u->num_rids2 = num_rids;
4248 if (num_rids) {
4249 q_u->rid = TALLOC_ZERO_ARRAY(ctx, uint32, num_rids );
4250 } else {
4251 q_u->rid = NULL;
4253 if (q_u->rid == NULL) {
4254 q_u->num_rids1 = 0;
4255 q_u->num_rids2 = 0;
4256 } else {
4257 memcpy(q_u->rid, rid, num_rids * sizeof(q_u->rid[0]));
4261 /*******************************************************************
4262 reads or writes a structure.
4263 ********************************************************************/
4265 BOOL samr_io_q_lookup_rids(const char *desc, SAMR_Q_LOOKUP_RIDS * q_u,
4266 prs_struct *ps, int depth)
4268 uint32 i;
4269 fstring tmp;
4271 if (q_u == NULL)
4272 return False;
4274 prs_debug(ps, depth, desc, "samr_io_q_lookup_rids");
4275 depth++;
4277 if (UNMARSHALLING(ps))
4278 ZERO_STRUCTP(q_u);
4280 if(!prs_align(ps))
4281 return False;
4283 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
4284 return False;
4286 if(!prs_uint32("num_rids1", ps, depth, &q_u->num_rids1))
4287 return False;
4288 if(!prs_uint32("flags ", ps, depth, &q_u->flags))
4289 return False;
4290 if(!prs_uint32("ptr ", ps, depth, &q_u->ptr))
4291 return False;
4292 if(!prs_uint32("num_rids2", ps, depth, &q_u->num_rids2))
4293 return False;
4295 if (UNMARSHALLING(ps) && (q_u->num_rids2 != 0)) {
4296 q_u->rid = PRS_ALLOC_MEM(ps, uint32, q_u->num_rids2);
4297 if (q_u->rid == NULL)
4298 return False;
4301 for (i = 0; i < q_u->num_rids2; i++) {
4302 slprintf(tmp, sizeof(tmp) - 1, "rid[%02d] ", i);
4303 if(!prs_uint32(tmp, ps, depth, &q_u->rid[i]))
4304 return False;
4307 return True;
4310 /*******************************************************************
4311 inits a SAMR_R_LOOKUP_RIDS structure.
4312 ********************************************************************/
4314 void init_samr_r_lookup_rids(SAMR_R_LOOKUP_RIDS * r_u,
4315 uint32 num_names, UNIHDR * hdr_name,
4316 UNISTR2 *uni_name, uint32 *type)
4318 DEBUG(5, ("init_samr_r_lookup_rids\n"));
4320 r_u->hdr_name = NULL;
4321 r_u->uni_name = NULL;
4322 r_u->type = NULL;
4324 if (num_names != 0) {
4325 r_u->num_names1 = num_names;
4326 r_u->ptr_names = 1;
4327 r_u->num_names2 = num_names;
4329 r_u->num_types1 = num_names;
4330 r_u->ptr_types = 1;
4331 r_u->num_types2 = num_names;
4333 r_u->hdr_name = hdr_name;
4334 r_u->uni_name = uni_name;
4335 r_u->type = type;
4336 } else {
4337 r_u->num_names1 = num_names;
4338 r_u->ptr_names = 0;
4339 r_u->num_names2 = num_names;
4341 r_u->num_types1 = num_names;
4342 r_u->ptr_types = 0;
4343 r_u->num_types2 = num_names;
4347 /*******************************************************************
4348 reads or writes a structure.
4349 ********************************************************************/
4351 BOOL samr_io_r_lookup_rids(const char *desc, SAMR_R_LOOKUP_RIDS * r_u,
4352 prs_struct *ps, int depth)
4354 uint32 i;
4355 fstring tmp;
4356 if (r_u == NULL)
4357 return False;
4359 prs_debug(ps, depth, desc, "samr_io_r_lookup_rids");
4360 depth++;
4362 if(!prs_align(ps))
4363 return False;
4365 if(!prs_uint32("num_names1", ps, depth, &r_u->num_names1))
4366 return False;
4367 if(!prs_uint32("ptr_names ", ps, depth, &r_u->ptr_names))
4368 return False;
4370 if (r_u->ptr_names != 0) {
4372 if(!prs_uint32("num_names2", ps, depth, &r_u->num_names2))
4373 return False;
4376 if (UNMARSHALLING(ps) && (r_u->num_names2 != 0)) {
4377 r_u->hdr_name = PRS_ALLOC_MEM(ps, UNIHDR, r_u->num_names2);
4378 if (r_u->hdr_name == NULL)
4379 return False;
4381 r_u->uni_name = PRS_ALLOC_MEM(ps, UNISTR2, r_u->num_names2);
4382 if (r_u->uni_name == NULL)
4383 return False;
4386 for (i = 0; i < r_u->num_names2; i++) {
4387 slprintf(tmp, sizeof(tmp) - 1, "hdr[%02d] ", i);
4388 if(!smb_io_unihdr("", &r_u->hdr_name[i], ps, depth))
4389 return False;
4391 for (i = 0; i < r_u->num_names2; i++) {
4392 slprintf(tmp, sizeof(tmp) - 1, "str[%02d] ", i);
4393 if(!smb_io_unistr2("", &r_u->uni_name[i], r_u->hdr_name[i].buffer, ps, depth))
4394 return False;
4399 if(!prs_align(ps))
4400 return False;
4401 if(!prs_uint32("num_types1", ps, depth, &r_u->num_types1))
4402 return False;
4403 if(!prs_uint32("ptr_types ", ps, depth, &r_u->ptr_types))
4404 return False;
4406 if (r_u->ptr_types != 0) {
4408 if(!prs_uint32("num_types2", ps, depth, &r_u->num_types2))
4409 return False;
4411 if (UNMARSHALLING(ps) && (r_u->num_types2 != 0)) {
4412 r_u->type = PRS_ALLOC_MEM(ps, uint32, r_u->num_types2);
4413 if (r_u->type == NULL)
4414 return False;
4417 for (i = 0; i < r_u->num_types2; i++) {
4418 slprintf(tmp, sizeof(tmp) - 1, "type[%02d] ", i);
4419 if(!prs_uint32(tmp, ps, depth, &r_u->type[i]))
4420 return False;
4424 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4425 return False;
4427 return True;
4430 /*******************************************************************
4431 inits a SAMR_Q_OPEN_ALIAS structure.
4432 ********************************************************************/
4434 void init_samr_q_delete_alias(SAMR_Q_DELETE_DOM_ALIAS * q_u, POLICY_HND *hnd)
4436 DEBUG(5, ("init_samr_q_delete_alias\n"));
4438 q_u->alias_pol = *hnd;
4441 /*******************************************************************
4442 reads or writes a structure.
4443 ********************************************************************/
4445 BOOL samr_io_q_delete_alias(const char *desc, SAMR_Q_DELETE_DOM_ALIAS * q_u,
4446 prs_struct *ps, int depth)
4448 if (q_u == NULL)
4449 return False;
4451 prs_debug(ps, depth, desc, "samr_io_q_delete_alias");
4452 depth++;
4454 if(!prs_align(ps))
4455 return False;
4457 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
4458 return False;
4460 return True;
4463 /*******************************************************************
4464 reads or writes a structure.
4465 ********************************************************************/
4467 BOOL samr_io_r_delete_alias(const char *desc, SAMR_R_DELETE_DOM_ALIAS * r_u,
4468 prs_struct *ps, int depth)
4470 if (r_u == NULL)
4471 return False;
4473 prs_debug(ps, depth, desc, "samr_io_r_delete_alias");
4474 depth++;
4476 if(!prs_align(ps))
4477 return False;
4479 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
4480 return False;
4481 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4482 return False;
4484 return True;
4487 /*******************************************************************
4488 inits a SAMR_Q_CREATE_DOM_ALIAS structure.
4489 ********************************************************************/
4491 void init_samr_q_create_dom_alias(SAMR_Q_CREATE_DOM_ALIAS * q_u,
4492 POLICY_HND *hnd, const char *acct_desc)
4494 DEBUG(5, ("init_samr_q_create_dom_alias\n"));
4496 q_u->dom_pol = *hnd;
4498 init_unistr2(&q_u->uni_acct_desc, acct_desc, UNI_FLAGS_NONE);
4499 init_uni_hdr(&q_u->hdr_acct_desc, &q_u->uni_acct_desc);
4501 q_u->access_mask = MAXIMUM_ALLOWED_ACCESS;
4504 /*******************************************************************
4505 reads or writes a structure.
4506 ********************************************************************/
4508 BOOL samr_io_q_create_dom_alias(const char *desc, SAMR_Q_CREATE_DOM_ALIAS * q_u,
4509 prs_struct *ps, int depth)
4511 if (q_u == NULL)
4512 return False;
4514 prs_debug(ps, depth, desc, "samr_io_q_create_dom_alias");
4515 depth++;
4517 if(!prs_align(ps))
4518 return False;
4520 if(!smb_io_pol_hnd("dom_pol", &q_u->dom_pol, ps, depth))
4521 return False;
4523 if(!smb_io_unihdr("hdr_acct_desc", &q_u->hdr_acct_desc, ps, depth))
4524 return False;
4525 if(!smb_io_unistr2("uni_acct_desc", &q_u->uni_acct_desc,
4526 q_u->hdr_acct_desc.buffer, ps, depth))
4527 return False;
4529 if(!prs_align(ps))
4530 return False;
4531 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
4532 return False;
4534 return True;
4537 /*******************************************************************
4538 reads or writes a structure.
4539 ********************************************************************/
4541 BOOL samr_io_r_create_dom_alias(const char *desc, SAMR_R_CREATE_DOM_ALIAS * r_u,
4542 prs_struct *ps, int depth)
4544 if (r_u == NULL)
4545 return False;
4547 prs_debug(ps, depth, desc, "samr_io_r_create_dom_alias");
4548 depth++;
4550 if(!prs_align(ps))
4551 return False;
4553 if(!smb_io_pol_hnd("alias_pol", &r_u->alias_pol, ps, depth))
4554 return False;
4556 if(!prs_uint32("rid", ps, depth, &r_u->rid))
4557 return False;
4559 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4560 return False;
4562 return True;
4565 /*******************************************************************
4566 inits a SAMR_Q_ADD_ALIASMEM structure.
4567 ********************************************************************/
4569 void init_samr_q_add_aliasmem(SAMR_Q_ADD_ALIASMEM * q_u, POLICY_HND *hnd,
4570 DOM_SID *sid)
4572 DEBUG(5, ("init_samr_q_add_aliasmem\n"));
4574 q_u->alias_pol = *hnd;
4575 init_dom_sid2(&q_u->sid, sid);
4578 /*******************************************************************
4579 reads or writes a structure.
4580 ********************************************************************/
4582 BOOL samr_io_q_add_aliasmem(const char *desc, SAMR_Q_ADD_ALIASMEM * q_u,
4583 prs_struct *ps, int depth)
4585 if (q_u == NULL)
4586 return False;
4588 prs_debug(ps, depth, desc, "samr_io_q_add_aliasmem");
4589 depth++;
4591 if(!prs_align(ps))
4592 return False;
4594 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
4595 return False;
4596 if(!smb_io_dom_sid2("sid ", &q_u->sid, ps, depth))
4597 return False;
4599 return True;
4602 /*******************************************************************
4603 reads or writes a structure.
4604 ********************************************************************/
4606 BOOL samr_io_r_add_aliasmem(const char *desc, SAMR_R_ADD_ALIASMEM * r_u,
4607 prs_struct *ps, int depth)
4609 if (r_u == NULL)
4610 return False;
4612 prs_debug(ps, depth, desc, "samr_io_r_add_aliasmem");
4613 depth++;
4615 if(!prs_align(ps))
4616 return False;
4618 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4619 return False;
4621 return True;
4624 /*******************************************************************
4625 inits a SAMR_Q_DEL_ALIASMEM structure.
4626 ********************************************************************/
4628 void init_samr_q_del_aliasmem(SAMR_Q_DEL_ALIASMEM * q_u, POLICY_HND *hnd,
4629 DOM_SID *sid)
4631 DEBUG(5, ("init_samr_q_del_aliasmem\n"));
4633 q_u->alias_pol = *hnd;
4634 init_dom_sid2(&q_u->sid, sid);
4637 /*******************************************************************
4638 reads or writes a structure.
4639 ********************************************************************/
4641 BOOL samr_io_q_del_aliasmem(const char *desc, SAMR_Q_DEL_ALIASMEM * q_u,
4642 prs_struct *ps, int depth)
4644 if (q_u == NULL)
4645 return False;
4647 prs_debug(ps, depth, desc, "samr_io_q_del_aliasmem");
4648 depth++;
4650 if(!prs_align(ps))
4651 return False;
4653 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
4654 return False;
4655 if(!smb_io_dom_sid2("sid ", &q_u->sid, ps, depth))
4656 return False;
4658 return True;
4661 /*******************************************************************
4662 reads or writes a structure.
4663 ********************************************************************/
4665 BOOL samr_io_r_del_aliasmem(const char *desc, SAMR_R_DEL_ALIASMEM * r_u,
4666 prs_struct *ps, int depth)
4668 if (r_u == NULL)
4669 return False;
4671 prs_debug(ps, depth, desc, "samr_io_r_del_aliasmem");
4672 depth++;
4674 if(!prs_align(ps))
4675 return False;
4677 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4678 return False;
4680 return True;
4683 /*******************************************************************
4684 inits a SAMR_Q_DELETE_DOM_ALIAS structure.
4685 ********************************************************************/
4687 void init_samr_q_delete_dom_alias(SAMR_Q_DELETE_DOM_ALIAS * q_c,
4688 POLICY_HND *hnd)
4690 DEBUG(5, ("init_samr_q_delete_dom_alias\n"));
4692 q_c->alias_pol = *hnd;
4695 /*******************************************************************
4696 reads or writes a structure.
4697 ********************************************************************/
4699 BOOL samr_io_q_delete_dom_alias(const char *desc, SAMR_Q_DELETE_DOM_ALIAS * q_u,
4700 prs_struct *ps, int depth)
4702 if (q_u == NULL)
4703 return False;
4705 prs_debug(ps, depth, desc, "samr_io_q_delete_dom_alias");
4706 depth++;
4708 if(!prs_align(ps))
4709 return False;
4711 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
4712 return False;
4714 return True;
4717 /*******************************************************************
4718 inits a SAMR_R_DELETE_DOM_ALIAS structure.
4719 ********************************************************************/
4721 void init_samr_r_delete_dom_alias(SAMR_R_DELETE_DOM_ALIAS * r_u,
4722 NTSTATUS status)
4724 DEBUG(5, ("init_samr_r_delete_dom_alias\n"));
4726 r_u->status = status;
4729 /*******************************************************************
4730 reads or writes a structure.
4731 ********************************************************************/
4733 BOOL samr_io_r_delete_dom_alias(const char *desc, SAMR_R_DELETE_DOM_ALIAS * r_u,
4734 prs_struct *ps, int depth)
4736 if (r_u == NULL)
4737 return False;
4739 prs_debug(ps, depth, desc, "samr_io_r_delete_dom_alias");
4740 depth++;
4742 if(!prs_align(ps))
4743 return False;
4745 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
4746 return False;
4748 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4749 return False;
4751 return True;
4754 /*******************************************************************
4755 inits a SAMR_Q_QUERY_ALIASMEM structure.
4756 ********************************************************************/
4758 void init_samr_q_query_aliasmem(SAMR_Q_QUERY_ALIASMEM * q_c,
4759 POLICY_HND *hnd)
4761 DEBUG(5, ("init_samr_q_query_aliasmem\n"));
4763 q_c->alias_pol = *hnd;
4766 /*******************************************************************
4767 reads or writes a structure.
4768 ********************************************************************/
4770 BOOL samr_io_q_query_aliasmem(const char *desc, SAMR_Q_QUERY_ALIASMEM * q_u,
4771 prs_struct *ps, int depth)
4773 if (q_u == NULL)
4774 return False;
4776 prs_debug(ps, depth, desc, "samr_io_q_query_aliasmem");
4777 depth++;
4779 if(!prs_align(ps))
4780 return False;
4782 if(!smb_io_pol_hnd("alias_pol", &q_u->alias_pol, ps, depth))
4783 return False;
4785 return True;
4788 /*******************************************************************
4789 inits a SAMR_R_QUERY_ALIASMEM structure.
4790 ********************************************************************/
4792 void init_samr_r_query_aliasmem(SAMR_R_QUERY_ALIASMEM * r_u,
4793 uint32 num_sids, DOM_SID2 * sid,
4794 NTSTATUS status)
4796 DEBUG(5, ("init_samr_r_query_aliasmem\n"));
4798 if (NT_STATUS_IS_OK(status)) {
4799 r_u->num_sids = num_sids;
4800 r_u->ptr = (num_sids != 0) ? 1 : 0;
4801 r_u->num_sids1 = num_sids;
4803 r_u->sid = sid;
4804 } else {
4805 r_u->ptr = 0;
4806 r_u->num_sids = 0;
4809 r_u->status = status;
4812 /*******************************************************************
4813 reads or writes a structure.
4814 ********************************************************************/
4816 BOOL samr_io_r_query_aliasmem(const char *desc, SAMR_R_QUERY_ALIASMEM * r_u,
4817 prs_struct *ps, int depth)
4819 uint32 i;
4821 if (r_u == NULL)
4822 return False;
4824 prs_debug(ps, depth, desc, "samr_io_r_query_aliasmem");
4825 depth++;
4827 if(!prs_align(ps))
4828 return False;
4830 if(!prs_uint32("num_sids ", ps, depth, &r_u->num_sids))
4831 return False;
4832 if(!prs_uint32("ptr", ps, depth, &r_u->ptr))
4833 return False;
4835 if (r_u->ptr != 0 && r_u->num_sids != 0) {
4836 uint32 *ptr_sid = NULL;
4838 if(!prs_uint32("num_sids1", ps, depth, &r_u->num_sids1))
4839 return False;
4841 /* We must always use talloc here even when marshalling. */
4842 if (r_u->num_sids1) {
4843 ptr_sid = TALLOC_ARRAY(ps->mem_ctx, uint32, r_u->num_sids1);
4844 if (!ptr_sid) {
4845 return False;
4847 } else {
4848 ptr_sid = NULL;
4851 for (i = 0; i < r_u->num_sids1; i++) {
4852 ptr_sid[i] = 1;
4853 if(!prs_uint32("ptr_sid", ps, depth, &ptr_sid[i]))
4854 return False;
4857 if (UNMARSHALLING(ps)) {
4858 if (r_u->num_sids1) {
4859 r_u->sid = TALLOC_ARRAY(ps->mem_ctx, DOM_SID2, r_u->num_sids1);
4860 if (!r_u->sid) {
4861 return False;
4863 } else {
4864 r_u->sid = NULL;
4868 for (i = 0; i < r_u->num_sids1; i++) {
4869 if (ptr_sid[i] != 0) {
4870 if(!smb_io_dom_sid2("sid", &r_u->sid[i], ps, depth))
4871 return False;
4876 if(!prs_align(ps))
4877 return False;
4878 if(!prs_ntstatus("status", ps, depth, &r_u->status))
4879 return False;
4881 return True;
4884 /*******************************************************************
4885 inits a SAMR_Q_LOOKUP_NAMES structure.
4886 ********************************************************************/
4888 NTSTATUS init_samr_q_lookup_names(TALLOC_CTX *ctx, SAMR_Q_LOOKUP_NAMES * q_u,
4889 POLICY_HND *pol, uint32 flags,
4890 uint32 num_names, const char **name)
4892 uint32 i;
4894 DEBUG(5, ("init_samr_q_lookup_names\n"));
4896 q_u->pol = *pol;
4898 q_u->num_names1 = num_names;
4899 q_u->flags = flags;
4900 q_u->ptr = 0;
4901 q_u->num_names2 = num_names;
4903 if (num_names) {
4904 if (!(q_u->hdr_name = TALLOC_ZERO_ARRAY(ctx, UNIHDR, num_names)))
4905 return NT_STATUS_NO_MEMORY;
4907 if (!(q_u->uni_name = TALLOC_ZERO_ARRAY(ctx, UNISTR2, num_names)))
4908 return NT_STATUS_NO_MEMORY;
4909 } else {
4910 q_u->hdr_name = NULL;
4911 q_u->uni_name = NULL;
4914 for (i = 0; i < num_names; i++) {
4915 init_unistr2(&q_u->uni_name[i], name[i], UNI_FLAGS_NONE); /* unicode string for machine account */
4916 init_uni_hdr(&q_u->hdr_name[i], &q_u->uni_name[i]); /* unicode header for user_name */
4919 return NT_STATUS_OK;
4922 /*******************************************************************
4923 reads or writes a structure.
4924 ********************************************************************/
4926 BOOL samr_io_q_lookup_names(const char *desc, SAMR_Q_LOOKUP_NAMES * q_u,
4927 prs_struct *ps, int depth)
4929 uint32 i;
4931 if (q_u == NULL)
4932 return False;
4934 prs_debug(ps, depth, desc, "samr_io_q_lookup_names");
4935 depth++;
4937 if (UNMARSHALLING(ps))
4938 ZERO_STRUCTP(q_u);
4940 if(!prs_align(ps))
4941 return False;
4943 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
4944 return False;
4946 if(!prs_uint32("num_names1", ps, depth, &q_u->num_names1))
4947 return False;
4948 if(!prs_uint32("flags ", ps, depth, &q_u->flags))
4949 return False;
4950 if(!prs_uint32("ptr ", ps, depth, &q_u->ptr))
4951 return False;
4952 if(!prs_uint32("num_names2", ps, depth, &q_u->num_names2))
4953 return False;
4955 if (UNMARSHALLING(ps) && (q_u->num_names2 != 0)) {
4956 q_u->hdr_name = PRS_ALLOC_MEM(ps, UNIHDR, q_u->num_names2);
4957 q_u->uni_name = PRS_ALLOC_MEM(ps, UNISTR2, q_u->num_names2);
4958 if (!q_u->hdr_name || !q_u->uni_name)
4959 return False;
4962 for (i = 0; i < q_u->num_names2; i++) {
4963 if(!smb_io_unihdr("", &q_u->hdr_name[i], ps, depth))
4964 return False;
4967 for (i = 0; i < q_u->num_names2; i++) {
4968 if(!smb_io_unistr2("", &q_u->uni_name[i], q_u->hdr_name[i].buffer, ps, depth))
4969 return False;
4972 return True;
4975 /*******************************************************************
4976 inits a SAMR_R_LOOKUP_NAMES structure.
4977 ********************************************************************/
4979 NTSTATUS init_samr_r_lookup_names(TALLOC_CTX *ctx, SAMR_R_LOOKUP_NAMES * r_u,
4980 uint32 num_rids,
4981 uint32 *rid, enum lsa_SidType *type,
4982 NTSTATUS status)
4984 DEBUG(5, ("init_samr_r_lookup_names\n"));
4986 if (NT_STATUS_IS_OK(status) && (num_rids != 0)) {
4987 uint32 i;
4989 r_u->num_types1 = num_rids;
4990 r_u->ptr_types = 1;
4991 r_u->num_types2 = num_rids;
4993 r_u->num_rids1 = num_rids;
4994 r_u->ptr_rids = 1;
4995 r_u->num_rids2 = num_rids;
4997 if (num_rids) {
4998 if (!(r_u->rids = TALLOC_ZERO_ARRAY(ctx, uint32, num_rids)))
4999 return NT_STATUS_NO_MEMORY;
5000 if (!(r_u->types = TALLOC_ZERO_ARRAY(ctx, uint32, num_rids)))
5001 return NT_STATUS_NO_MEMORY;
5002 } else {
5003 r_u->rids = NULL;
5004 r_u->types = NULL;
5007 if (!r_u->rids || !r_u->types)
5008 goto empty;
5010 for (i = 0; i < num_rids; i++) {
5011 r_u->rids[i] = rid[i];
5012 r_u->types[i] = type[i];
5014 } else {
5016 empty:
5017 r_u->num_types1 = 0;
5018 r_u->ptr_types = 0;
5019 r_u->num_types2 = 0;
5021 r_u->num_rids1 = 0;
5022 r_u->ptr_rids = 0;
5023 r_u->num_rids2 = 0;
5025 r_u->rids = NULL;
5026 r_u->types = NULL;
5029 r_u->status = status;
5031 return NT_STATUS_OK;
5034 /*******************************************************************
5035 reads or writes a structure.
5036 ********************************************************************/
5038 BOOL samr_io_r_lookup_names(const char *desc, SAMR_R_LOOKUP_NAMES * r_u,
5039 prs_struct *ps, int depth)
5041 uint32 i;
5042 fstring tmp;
5044 if (r_u == NULL)
5045 return False;
5047 prs_debug(ps, depth, desc, "samr_io_r_lookup_names");
5048 depth++;
5050 if (UNMARSHALLING(ps))
5051 ZERO_STRUCTP(r_u);
5053 if(!prs_align(ps))
5054 return False;
5056 if(!prs_uint32("num_rids1", ps, depth, &r_u->num_rids1))
5057 return False;
5058 if(!prs_uint32("ptr_rids ", ps, depth, &r_u->ptr_rids))
5059 return False;
5061 if (r_u->ptr_rids != 0) {
5062 if(!prs_uint32("num_rids2", ps, depth, &r_u->num_rids2))
5063 return False;
5065 if (r_u->num_rids2 != r_u->num_rids1) {
5066 /* RPC fault */
5067 return False;
5070 if (UNMARSHALLING(ps) && r_u->num_rids2) {
5071 r_u->rids = PRS_ALLOC_MEM(ps, uint32, r_u->num_rids2);
5073 if (!r_u->rids) {
5074 DEBUG(0, ("NULL rids in samr_io_r_lookup_names\n"));
5075 return False;
5079 for (i = 0; i < r_u->num_rids2; i++) {
5080 slprintf(tmp, sizeof(tmp) - 1, "rid[%02d] ", i);
5081 if(!prs_uint32(tmp, ps, depth, &r_u->rids[i]))
5082 return False;
5086 if(!prs_uint32("num_types1", ps, depth, &r_u->num_types1))
5087 return False;
5088 if(!prs_uint32("ptr_types ", ps, depth, &r_u->ptr_types))
5089 return False;
5091 if (r_u->ptr_types != 0) {
5092 if(!prs_uint32("num_types2", ps, depth, &r_u->num_types2))
5093 return False;
5095 if (r_u->num_types2 != r_u->num_types1) {
5096 /* RPC fault */
5097 return False;
5100 if (UNMARSHALLING(ps) && r_u->num_types2) {
5101 r_u->types = PRS_ALLOC_MEM(ps, uint32, r_u->num_types2);
5103 if (!r_u->types) {
5104 DEBUG(0, ("NULL types in samr_io_r_lookup_names\n"));
5105 return False;
5109 for (i = 0; i < r_u->num_types2; i++) {
5110 slprintf(tmp, sizeof(tmp) - 1, "type[%02d] ", i);
5111 if(!prs_uint32(tmp, ps, depth, &r_u->types[i]))
5112 return False;
5116 if(!prs_ntstatus("status", ps, depth, &r_u->status))
5117 return False;
5119 return True;
5122 /*******************************************************************
5123 inits a SAMR_Q_DELETE_DOM_USER structure.
5124 ********************************************************************/
5126 void init_samr_q_delete_dom_user(SAMR_Q_DELETE_DOM_USER * q_c,
5127 POLICY_HND *hnd)
5129 DEBUG(5, ("init_samr_q_delete_dom_user\n"));
5131 q_c->user_pol = *hnd;
5134 /*******************************************************************
5135 reads or writes a structure.
5136 ********************************************************************/
5138 BOOL samr_io_q_delete_dom_user(const char *desc, SAMR_Q_DELETE_DOM_USER * q_u,
5139 prs_struct *ps, int depth)
5141 if (q_u == NULL)
5142 return False;
5144 prs_debug(ps, depth, desc, "samr_io_q_delete_dom_user");
5145 depth++;
5147 if(!prs_align(ps))
5148 return False;
5150 if(!smb_io_pol_hnd("user_pol", &q_u->user_pol, ps, depth))
5151 return False;
5153 return True;
5156 /*******************************************************************
5157 reads or writes a structure.
5158 ********************************************************************/
5160 BOOL samr_io_r_delete_dom_user(const char *desc, SAMR_R_DELETE_DOM_USER * r_u,
5161 prs_struct *ps, int depth)
5163 if (r_u == NULL)
5164 return False;
5166 prs_debug(ps, depth, desc, "samr_io_r_delete_dom_user");
5167 depth++;
5169 if(!prs_align(ps))
5170 return False;
5172 if(!smb_io_pol_hnd("pol", &r_u->pol, ps, depth))
5173 return False;
5174 if(!prs_ntstatus("status", ps, depth, &r_u->status))
5175 return False;
5177 return True;
5180 /*******************************************************************
5181 reads or writes a structure.
5182 ********************************************************************/
5184 void init_samr_q_open_user(SAMR_Q_OPEN_USER * q_u,
5185 POLICY_HND *pol,
5186 uint32 access_mask, uint32 rid)
5188 DEBUG(5, ("samr_init_samr_q_open_user\n"));
5190 q_u->domain_pol = *pol;
5191 q_u->access_mask = access_mask;
5192 q_u->user_rid = rid;
5195 /*******************************************************************
5196 reads or writes a structure.
5197 ********************************************************************/
5199 BOOL samr_io_q_open_user(const char *desc, SAMR_Q_OPEN_USER * q_u,
5200 prs_struct *ps, int depth)
5202 if (q_u == NULL)
5203 return False;
5205 prs_debug(ps, depth, desc, "samr_io_q_open_user");
5206 depth++;
5208 if(!prs_align(ps))
5209 return False;
5211 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
5212 return False;
5214 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
5215 return False;
5216 if(!prs_uint32("user_rid ", ps, depth, &q_u->user_rid))
5217 return False;
5219 return True;
5222 /*******************************************************************
5223 reads or writes a structure.
5224 ********************************************************************/
5226 BOOL samr_io_r_open_user(const char *desc, SAMR_R_OPEN_USER * r_u,
5227 prs_struct *ps, int depth)
5229 if (r_u == NULL)
5230 return False;
5232 prs_debug(ps, depth, desc, "samr_io_r_open_user");
5233 depth++;
5235 if(!prs_align(ps))
5236 return False;
5238 if(!smb_io_pol_hnd("user_pol", &r_u->user_pol, ps, depth))
5239 return False;
5241 if(!prs_ntstatus("status", ps, depth, &r_u->status))
5242 return False;
5244 return True;
5248 /*******************************************************************
5249 reads or writes a structure.
5250 ********************************************************************/
5252 void init_samr_q_create_user(SAMR_Q_CREATE_USER * q_u,
5253 POLICY_HND *pol,
5254 const char *name,
5255 uint32 acb_info, uint32 access_mask)
5257 DEBUG(5, ("samr_init_samr_q_create_user\n"));
5259 q_u->domain_pol = *pol;
5261 init_unistr2(&q_u->uni_name, name, UNI_FLAGS_NONE);
5262 init_uni_hdr(&q_u->hdr_name, &q_u->uni_name);
5264 q_u->acb_info = acb_info;
5265 q_u->access_mask = access_mask;
5268 /*******************************************************************
5269 reads or writes a structure.
5270 ********************************************************************/
5272 BOOL samr_io_q_create_user(const char *desc, SAMR_Q_CREATE_USER * q_u,
5273 prs_struct *ps, int depth)
5275 if (q_u == NULL)
5276 return False;
5278 prs_debug(ps, depth, desc, "samr_io_q_create_user");
5279 depth++;
5281 if(!prs_align(ps))
5282 return False;
5284 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
5285 return False;
5287 if(!smb_io_unihdr("hdr_name", &q_u->hdr_name, ps, depth))
5288 return False;
5289 if(!smb_io_unistr2("uni_name", &q_u->uni_name, q_u->hdr_name.buffer, ps, depth))
5290 return False;
5292 if(!prs_align(ps))
5293 return False;
5294 if(!prs_uint32("acb_info ", ps, depth, &q_u->acb_info))
5295 return False;
5296 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
5297 return False;
5299 return True;
5302 /*******************************************************************
5303 reads or writes a structure.
5304 ********************************************************************/
5306 BOOL samr_io_r_create_user(const char *desc, SAMR_R_CREATE_USER * r_u,
5307 prs_struct *ps, int depth)
5309 if (r_u == NULL)
5310 return False;
5312 prs_debug(ps, depth, desc, "samr_io_r_create_user");
5313 depth++;
5315 if(!prs_align(ps))
5316 return False;
5318 if(!smb_io_pol_hnd("user_pol", &r_u->user_pol, ps, depth))
5319 return False;
5321 if(!prs_uint32("access_granted", ps, depth, &r_u->access_granted))
5322 return False;
5323 if(!prs_uint32("user_rid ", ps, depth, &r_u->user_rid))
5324 return False;
5325 if(!prs_ntstatus("status", ps, depth, &r_u->status))
5326 return False;
5328 return True;
5331 /*******************************************************************
5332 inits a SAMR_Q_QUERY_USERINFO structure.
5333 ********************************************************************/
5335 void init_samr_q_query_userinfo(SAMR_Q_QUERY_USERINFO * q_u,
5336 const POLICY_HND *hnd, uint16 switch_value)
5338 DEBUG(5, ("init_samr_q_query_userinfo\n"));
5340 q_u->pol = *hnd;
5341 q_u->switch_value = switch_value;
5344 /*******************************************************************
5345 reads or writes a structure.
5346 ********************************************************************/
5348 BOOL samr_io_q_query_userinfo(const char *desc, SAMR_Q_QUERY_USERINFO * q_u,
5349 prs_struct *ps, int depth)
5351 if (q_u == NULL)
5352 return False;
5354 prs_debug(ps, depth, desc, "samr_io_q_query_userinfo");
5355 depth++;
5357 if(!prs_align(ps))
5358 return False;
5360 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
5361 return False;
5363 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value)) /* 0x0015 or 0x0011 */
5364 return False;
5366 return True;
5369 /*******************************************************************
5370 reads or writes a LOGON_HRS structure.
5371 ********************************************************************/
5373 static BOOL sam_io_logon_hrs(const char *desc, LOGON_HRS * hrs,
5374 prs_struct *ps, int depth)
5376 if (hrs == NULL)
5377 return False;
5379 prs_debug(ps, depth, desc, "sam_io_logon_hrs");
5380 depth++;
5382 if(!prs_align(ps))
5383 return False;
5385 if(!prs_uint32("maxlen", ps, depth, &hrs->max_len))
5386 return False;
5388 if(!prs_uint32("offset", ps, depth, &hrs->offset))
5389 return False;
5391 if(!prs_uint32("len ", ps, depth, &hrs->len))
5392 return False;
5394 if (hrs->len > sizeof(hrs->hours)) {
5395 DEBUG(3, ("sam_io_logon_hrs: truncating length from %d\n", hrs->len));
5396 hrs->len = sizeof(hrs->hours);
5399 if(!prs_uint8s(False, "hours", ps, depth, hrs->hours, hrs->len))
5400 return False;
5402 return True;
5405 /*******************************************************************
5406 inits a SAM_USER_INFO_18 structure.
5407 ********************************************************************/
5409 void init_sam_user_info18(SAM_USER_INFO_18 * usr,
5410 const uint8 lm_pwd[16], const uint8 nt_pwd[16])
5412 DEBUG(5, ("init_sam_user_info18\n"));
5414 usr->lm_pwd_active =
5415 memcpy(usr->lm_pwd, lm_pwd, sizeof(usr->lm_pwd)) ? 1 : 0;
5416 usr->nt_pwd_active =
5417 memcpy(usr->nt_pwd, nt_pwd, sizeof(usr->nt_pwd)) ? 1 : 0;
5420 /*******************************************************************
5421 reads or writes a structure.
5422 ********************************************************************/
5424 static BOOL sam_io_user_info18(const char *desc, SAM_USER_INFO_18 * u,
5425 prs_struct *ps, int depth)
5427 if (u == NULL)
5428 return False;
5430 prs_debug(ps, depth, desc, "samr_io_r_user_info18");
5431 depth++;
5433 if(!prs_align(ps))
5434 return False;
5436 if(!prs_uint8s(False, "lm_pwd", ps, depth, u->lm_pwd, sizeof(u->lm_pwd)))
5437 return False;
5438 if(!prs_uint8s(False, "nt_pwd", ps, depth, u->nt_pwd, sizeof(u->nt_pwd)))
5439 return False;
5441 if(!prs_uint8("lm_pwd_active", ps, depth, &u->lm_pwd_active))
5442 return False;
5443 if(!prs_uint8("nt_pwd_active", ps, depth, &u->nt_pwd_active))
5444 return False;
5446 return True;
5449 /*******************************************************************
5450 inits a SAM_USER_INFO_7 structure.
5451 ********************************************************************/
5453 void init_sam_user_info7(SAM_USER_INFO_7 * usr, const char *name)
5455 DEBUG(5, ("init_sam_user_info7\n"));
5457 init_unistr2(&usr->uni_name, name, UNI_FLAGS_NONE); /* unicode string for name */
5458 init_uni_hdr(&usr->hdr_name, &usr->uni_name); /* unicode header for name */
5462 /*******************************************************************
5463 reads or writes a structure.
5464 ********************************************************************/
5466 static BOOL sam_io_user_info7(const char *desc, SAM_USER_INFO_7 * usr,
5467 prs_struct *ps, int depth)
5469 if (usr == NULL)
5470 return False;
5472 prs_debug(ps, depth, desc, "samr_io_r_user_info7");
5473 depth++;
5475 if(!prs_align(ps))
5476 return False;
5478 if(!smb_io_unihdr("unihdr", &usr->hdr_name, ps, depth))
5479 return False;
5481 if(!smb_io_unistr2("unistr2", &usr->uni_name, True, ps, depth))
5482 return False;
5484 return True;
5487 /*******************************************************************
5488 inits a SAM_USER_INFO_9 structure.
5489 ********************************************************************/
5491 void init_sam_user_info9(SAM_USER_INFO_9 * usr, uint32 rid_group)
5493 DEBUG(5, ("init_sam_user_info9\n"));
5495 usr->rid_group = rid_group;
5498 /*******************************************************************
5499 reads or writes a structure.
5500 ********************************************************************/
5502 static BOOL sam_io_user_info9(const char *desc, SAM_USER_INFO_9 * usr,
5503 prs_struct *ps, int depth)
5505 if (usr == NULL)
5506 return False;
5508 prs_debug(ps, depth, desc, "samr_io_r_user_info9");
5509 depth++;
5511 if(!prs_align(ps))
5512 return False;
5514 if(!prs_uint32("rid_group", ps, depth, &usr->rid_group))
5515 return False;
5517 return True;
5520 /*******************************************************************
5521 inits a SAM_USER_INFO_16 structure.
5522 ********************************************************************/
5524 void init_sam_user_info16(SAM_USER_INFO_16 * usr, uint32 acb_info)
5526 DEBUG(5, ("init_sam_user_info16\n"));
5528 usr->acb_info = acb_info;
5531 /*******************************************************************
5532 reads or writes a structure.
5533 ********************************************************************/
5535 static BOOL sam_io_user_info16(const char *desc, SAM_USER_INFO_16 * usr,
5536 prs_struct *ps, int depth)
5538 if (usr == NULL)
5539 return False;
5541 prs_debug(ps, depth, desc, "samr_io_r_user_info16");
5542 depth++;
5544 if(!prs_align(ps))
5545 return False;
5547 if(!prs_uint32("acb_info", ps, depth, &usr->acb_info))
5548 return False;
5550 return True;
5553 /*******************************************************************
5554 inits a SAM_USER_INFO_17 structure.
5555 ********************************************************************/
5557 void init_sam_user_info17(SAM_USER_INFO_17 * usr,
5558 NTTIME * expiry,
5559 char *mach_acct,
5560 uint32 rid_user, uint32 rid_group, uint16 acct_ctrl)
5562 DEBUG(5, ("init_sam_user_info17\n"));
5564 memcpy(&usr->expiry, expiry, sizeof(usr->expiry)); /* expiry time or something? */
5565 ZERO_STRUCT(usr->padding_1); /* 0 - padding 24 bytes */
5567 usr->padding_2 = 0; /* 0 - padding 4 bytes */
5569 usr->ptr_1 = 1; /* pointer */
5570 ZERO_STRUCT(usr->padding_3); /* 0 - padding 32 bytes */
5571 usr->padding_4 = 0; /* 0 - padding 4 bytes */
5573 usr->ptr_2 = 1; /* pointer */
5574 usr->padding_5 = 0; /* 0 - padding 4 bytes */
5576 usr->ptr_3 = 1; /* pointer */
5577 ZERO_STRUCT(usr->padding_6); /* 0 - padding 32 bytes */
5579 usr->rid_user = rid_user;
5580 usr->rid_group = rid_group;
5582 usr->acct_ctrl = acct_ctrl;
5583 usr->unknown_3 = 0x0000;
5585 usr->unknown_4 = 0x003f; /* 0x003f - 16 bit unknown */
5586 usr->unknown_5 = 0x003c; /* 0x003c - 16 bit unknown */
5588 ZERO_STRUCT(usr->padding_7); /* 0 - padding 16 bytes */
5589 usr->padding_8 = 0; /* 0 - padding 4 bytes */
5591 init_unistr2(&usr->uni_mach_acct, mach_acct, UNI_FLAGS_NONE); /* unicode string for machine account */
5592 init_uni_hdr(&usr->hdr_mach_acct, &usr->uni_mach_acct); /* unicode header for machine account */
5595 /*******************************************************************
5596 reads or writes a structure.
5597 ********************************************************************/
5599 static BOOL sam_io_user_info17(const char *desc, SAM_USER_INFO_17 * usr,
5600 prs_struct *ps, int depth)
5602 if (usr == NULL)
5603 return False;
5605 prs_debug(ps, depth, desc, "samr_io_r_unknown_17");
5606 depth++;
5608 if(!prs_align(ps))
5609 return False;
5611 if(!prs_uint8s(False, "padding_0", ps, depth, usr->padding_0, sizeof(usr->padding_0)))
5612 return False;
5614 if(!smb_io_time("time", &usr->expiry, ps, depth))
5615 return False;
5617 if(!prs_uint8s(False, "padding_1", ps, depth, usr->padding_1, sizeof(usr->padding_1)))
5618 return False;
5620 if(!smb_io_unihdr("unihdr", &usr->hdr_mach_acct, ps, depth))
5621 return False;
5623 if(!prs_uint32("padding_2", ps, depth, &usr->padding_2))
5624 return False;
5626 if(!prs_uint32("ptr_1 ", ps, depth, &usr->ptr_1))
5627 return False;
5628 if(!prs_uint8s(False, "padding_3", ps, depth, usr->padding_3, sizeof(usr->padding_3)))
5629 return False;
5631 if(!prs_uint32("padding_4", ps, depth, &usr->padding_4))
5632 return False;
5634 if(!prs_uint32("ptr_2 ", ps, depth, &usr->ptr_2))
5635 return False;
5636 if(!prs_uint32("padding_5", ps, depth, &usr->padding_5))
5637 return False;
5639 if(!prs_uint32("ptr_3 ", ps, depth, &usr->ptr_3))
5640 return False;
5641 if(!prs_uint8s(False, "padding_6", ps, depth, usr->padding_6,sizeof(usr->padding_6)))
5642 return False;
5644 if(!prs_uint32("rid_user ", ps, depth, &usr->rid_user))
5645 return False;
5646 if(!prs_uint32("rid_group", ps, depth, &usr->rid_group))
5647 return False;
5648 if(!prs_uint16("acct_ctrl", ps, depth, &usr->acct_ctrl))
5649 return False;
5650 if(!prs_uint16("unknown_3", ps, depth, &usr->unknown_3))
5651 return False;
5652 if(!prs_uint16("unknown_4", ps, depth, &usr->unknown_4))
5653 return False;
5654 if(!prs_uint16("unknown_5", ps, depth, &usr->unknown_5))
5655 return False;
5657 if(!prs_uint8s(False, "padding_7", ps, depth, usr->padding_7, sizeof(usr->padding_7)))
5658 return False;
5660 if(!prs_uint32("padding_8", ps, depth, &(usr->padding_8)))
5661 return False;
5663 if(!smb_io_unistr2("unistr2", &usr->uni_mach_acct, True, ps, depth))
5664 return False;
5666 if(!prs_align(ps))
5667 return False;
5669 if(!prs_uint8s(False, "padding_9", ps, depth, usr->padding_9, sizeof(usr->padding_9)))
5670 return False;
5672 return True;
5675 /*************************************************************************
5676 init_sam_user_infoa
5677 *************************************************************************/
5679 void init_sam_user_info24(SAM_USER_INFO_24 * usr, char newpass[516],
5680 uint8 pw_len)
5682 DEBUG(10, ("init_sam_user_info24:\n"));
5683 memcpy(usr->pass, newpass, sizeof(usr->pass));
5684 usr->pw_len = pw_len;
5687 /*******************************************************************
5688 reads or writes a structure.
5689 ********************************************************************/
5691 static BOOL sam_io_user_info24(const char *desc, SAM_USER_INFO_24 * usr,
5692 prs_struct *ps, int depth)
5694 if (usr == NULL)
5695 return False;
5697 prs_debug(ps, depth, desc, "sam_io_user_info24");
5698 depth++;
5700 if(!prs_align(ps))
5701 return False;
5703 if(!prs_uint8s(False, "password", ps, depth, usr->pass,
5704 sizeof(usr->pass)))
5705 return False;
5707 if (MARSHALLING(ps) && (usr->pw_len != 0)) {
5708 if (!prs_uint8("pw_len", ps, depth, &usr->pw_len))
5709 return False;
5710 } else if (UNMARSHALLING(ps)) {
5711 if (!prs_uint8("pw_len", ps, depth, &usr->pw_len))
5712 return False;
5715 return True;
5718 /*******************************************************************
5719 reads or writes a structure.
5720 ********************************************************************/
5722 static BOOL sam_io_user_info26(const char *desc, SAM_USER_INFO_26 * usr,
5723 prs_struct *ps, int depth)
5725 if (usr == NULL)
5726 return False;
5728 prs_debug(ps, depth, desc, "sam_io_user_info26");
5729 depth++;
5731 if(!prs_align(ps))
5732 return False;
5734 if(!prs_uint8s(False, "password", ps, depth, usr->pass,
5735 sizeof(usr->pass)))
5736 return False;
5738 if (!prs_uint8("pw_len", ps, depth, &usr->pw_len))
5739 return False;
5741 return True;
5745 /*************************************************************************
5746 init_sam_user_info23
5748 unknown_6 = 0x0000 04ec
5750 *************************************************************************/
5752 void init_sam_user_info23W(SAM_USER_INFO_23 * usr, NTTIME * logon_time, /* all zeros */
5753 NTTIME * logoff_time, /* all zeros */
5754 NTTIME * kickoff_time, /* all zeros */
5755 NTTIME * pass_last_set_time, /* all zeros */
5756 NTTIME * pass_can_change_time, /* all zeros */
5757 NTTIME * pass_must_change_time, /* all zeros */
5758 UNISTR2 *user_name,
5759 UNISTR2 *full_name,
5760 UNISTR2 *home_dir,
5761 UNISTR2 *dir_drive,
5762 UNISTR2 *log_scr,
5763 UNISTR2 *prof_path,
5764 UNISTR2 *desc,
5765 UNISTR2 *wkstas,
5766 UNISTR2 *unk_str,
5767 UNISTR2 *mung_dial,
5768 uint32 user_rid, /* 0x0000 0000 */
5769 uint32 group_rid,
5770 uint32 acb_info,
5771 uint32 fields_present,
5772 uint16 logon_divs,
5773 LOGON_HRS * hrs,
5774 uint16 bad_password_count,
5775 uint16 logon_count,
5776 char newpass[516])
5778 usr->logon_time = *logon_time; /* all zeros */
5779 usr->logoff_time = *logoff_time; /* all zeros */
5780 usr->kickoff_time = *kickoff_time; /* all zeros */
5781 usr->pass_last_set_time = *pass_last_set_time; /* all zeros */
5782 usr->pass_can_change_time = *pass_can_change_time; /* all zeros */
5783 usr->pass_must_change_time = *pass_must_change_time; /* all zeros */
5785 ZERO_STRUCT(usr->nt_pwd);
5786 ZERO_STRUCT(usr->lm_pwd);
5788 usr->user_rid = user_rid; /* 0x0000 0000 */
5789 usr->group_rid = group_rid;
5790 usr->acb_info = acb_info;
5791 usr->fields_present = fields_present; /* 09f8 27fa */
5793 usr->logon_divs = logon_divs; /* should be 168 (hours/week) */
5794 usr->ptr_logon_hrs = hrs ? 1 : 0;
5796 if (nt_time_is_zero(pass_must_change_time)) {
5797 usr->passmustchange=PASS_MUST_CHANGE_AT_NEXT_LOGON;
5798 } else {
5799 usr->passmustchange=0;
5802 ZERO_STRUCT(usr->padding1);
5803 ZERO_STRUCT(usr->padding2);
5805 usr->bad_password_count = bad_password_count;
5806 usr->logon_count = logon_count;
5808 memcpy(usr->pass, newpass, sizeof(usr->pass));
5810 copy_unistr2(&usr->uni_user_name, user_name);
5811 init_uni_hdr(&usr->hdr_user_name, &usr->uni_user_name);
5813 copy_unistr2(&usr->uni_full_name, full_name);
5814 init_uni_hdr(&usr->hdr_full_name, &usr->uni_full_name);
5816 copy_unistr2(&usr->uni_home_dir, home_dir);
5817 init_uni_hdr(&usr->hdr_home_dir, &usr->uni_home_dir);
5819 copy_unistr2(&usr->uni_dir_drive, dir_drive);
5820 init_uni_hdr(&usr->hdr_dir_drive, &usr->uni_dir_drive);
5822 copy_unistr2(&usr->uni_logon_script, log_scr);
5823 init_uni_hdr(&usr->hdr_logon_script, &usr->uni_logon_script);
5825 copy_unistr2(&usr->uni_profile_path, prof_path);
5826 init_uni_hdr(&usr->hdr_profile_path, &usr->uni_profile_path);
5828 copy_unistr2(&usr->uni_acct_desc, desc);
5829 init_uni_hdr(&usr->hdr_acct_desc, &usr->uni_acct_desc);
5831 copy_unistr2(&usr->uni_workstations, wkstas);
5832 init_uni_hdr(&usr->hdr_workstations, &usr->uni_workstations);
5834 copy_unistr2(&usr->uni_comment, unk_str);
5835 init_uni_hdr(&usr->hdr_comment, &usr->uni_comment);
5837 copy_unistr2(&usr->uni_munged_dial, mung_dial);
5838 init_uni_hdr(&usr->hdr_munged_dial, &usr->uni_munged_dial);
5840 if (hrs) {
5841 memcpy(&usr->logon_hrs, hrs, sizeof(usr->logon_hrs));
5842 } else {
5843 ZERO_STRUCT(usr->logon_hrs);
5847 /*************************************************************************
5848 init_sam_user_info23
5850 unknown_6 = 0x0000 04ec
5852 *************************************************************************/
5854 void init_sam_user_info23A(SAM_USER_INFO_23 * usr, NTTIME * logon_time, /* all zeros */
5855 NTTIME * logoff_time, /* all zeros */
5856 NTTIME * kickoff_time, /* all zeros */
5857 NTTIME * pass_last_set_time, /* all zeros */
5858 NTTIME * pass_can_change_time, /* all zeros */
5859 NTTIME * pass_must_change_time, /* all zeros */
5860 char *user_name, /* NULL */
5861 char *full_name,
5862 char *home_dir, char *dir_drive, char *log_scr,
5863 char *prof_path, const char *desc, char *wkstas,
5864 char *unk_str, char *mung_dial, uint32 user_rid, /* 0x0000 0000 */
5865 uint32 group_rid, uint32 acb_info,
5866 uint32 fields_present, uint16 logon_divs,
5867 LOGON_HRS * hrs, uint16 bad_password_count, uint16 logon_count,
5868 char newpass[516])
5870 DATA_BLOB blob = base64_decode_data_blob(mung_dial);
5872 usr->logon_time = *logon_time; /* all zeros */
5873 usr->logoff_time = *logoff_time; /* all zeros */
5874 usr->kickoff_time = *kickoff_time; /* all zeros */
5875 usr->pass_last_set_time = *pass_last_set_time; /* all zeros */
5876 usr->pass_can_change_time = *pass_can_change_time; /* all zeros */
5877 usr->pass_must_change_time = *pass_must_change_time; /* all zeros */
5879 ZERO_STRUCT(usr->nt_pwd);
5880 ZERO_STRUCT(usr->lm_pwd);
5882 usr->user_rid = user_rid; /* 0x0000 0000 */
5883 usr->group_rid = group_rid;
5884 usr->acb_info = acb_info;
5885 usr->fields_present = fields_present; /* 09f8 27fa */
5887 usr->logon_divs = logon_divs; /* should be 168 (hours/week) */
5888 usr->ptr_logon_hrs = hrs ? 1 : 0;
5890 if (nt_time_is_zero(pass_must_change_time)) {
5891 usr->passmustchange=PASS_MUST_CHANGE_AT_NEXT_LOGON;
5892 } else {
5893 usr->passmustchange=0;
5896 ZERO_STRUCT(usr->padding1);
5897 ZERO_STRUCT(usr->padding2);
5899 usr->bad_password_count = bad_password_count;
5900 usr->logon_count = logon_count;
5902 memcpy(usr->pass, newpass, sizeof(usr->pass));
5904 init_unistr2(&usr->uni_user_name, user_name, UNI_FLAGS_NONE);
5905 init_uni_hdr(&usr->hdr_user_name, &usr->uni_user_name);
5907 init_unistr2(&usr->uni_full_name, full_name, UNI_FLAGS_NONE);
5908 init_uni_hdr(&usr->hdr_full_name, &usr->uni_full_name);
5910 init_unistr2(&usr->uni_home_dir, home_dir, UNI_FLAGS_NONE);
5911 init_uni_hdr(&usr->hdr_home_dir, &usr->uni_home_dir);
5913 init_unistr2(&usr->uni_dir_drive, dir_drive, UNI_FLAGS_NONE);
5914 init_uni_hdr(&usr->hdr_dir_drive, &usr->uni_dir_drive);
5916 init_unistr2(&usr->uni_logon_script, log_scr, UNI_FLAGS_NONE);
5917 init_uni_hdr(&usr->hdr_logon_script, &usr->uni_logon_script);
5919 init_unistr2(&usr->uni_profile_path, prof_path, UNI_FLAGS_NONE);
5920 init_uni_hdr(&usr->hdr_profile_path, &usr->uni_profile_path);
5922 init_unistr2(&usr->uni_acct_desc, desc, UNI_FLAGS_NONE);
5923 init_uni_hdr(&usr->hdr_acct_desc, &usr->uni_acct_desc);
5925 init_unistr2(&usr->uni_workstations, wkstas, UNI_FLAGS_NONE);
5926 init_uni_hdr(&usr->hdr_workstations, &usr->uni_workstations);
5928 init_unistr2(&usr->uni_comment, unk_str, UNI_FLAGS_NONE);
5929 init_uni_hdr(&usr->hdr_comment, &usr->uni_comment);
5931 init_unistr2_from_datablob(&usr->uni_munged_dial, &blob);
5932 init_uni_hdr(&usr->hdr_munged_dial, &usr->uni_munged_dial);
5934 data_blob_free(&blob);
5936 if (hrs) {
5937 memcpy(&usr->logon_hrs, hrs, sizeof(usr->logon_hrs));
5938 } else {
5939 ZERO_STRUCT(usr->logon_hrs);
5943 /*******************************************************************
5944 reads or writes a structure.
5945 ********************************************************************/
5947 static BOOL sam_io_user_info23(const char *desc, SAM_USER_INFO_23 * usr,
5948 prs_struct *ps, int depth)
5950 if (usr == NULL)
5951 return False;
5953 prs_debug(ps, depth, desc, "sam_io_user_info23");
5954 depth++;
5956 if(!prs_align(ps))
5957 return False;
5959 if(!smb_io_time("logon_time ", &usr->logon_time, ps, depth))
5960 return False;
5961 if(!smb_io_time("logoff_time ", &usr->logoff_time, ps, depth))
5962 return False;
5963 if(!smb_io_time("kickoff_time ", &usr->kickoff_time, ps, depth))
5964 return False;
5965 if(!smb_io_time("pass_last_set_time ", &usr->pass_last_set_time, ps, depth))
5966 return False;
5967 if(!smb_io_time("pass_can_change_time ", &usr->pass_can_change_time, ps, depth))
5968 return False;
5969 if(!smb_io_time("pass_must_change_time", &usr->pass_must_change_time, ps, depth))
5970 return False;
5972 if(!smb_io_unihdr("hdr_user_name ", &usr->hdr_user_name, ps, depth)) /* username unicode string header */
5973 return False;
5974 if(!smb_io_unihdr("hdr_full_name ", &usr->hdr_full_name, ps, depth)) /* user's full name unicode string header */
5975 return False;
5976 if(!smb_io_unihdr("hdr_home_dir ", &usr->hdr_home_dir, ps, depth)) /* home directory unicode string header */
5977 return False;
5978 if(!smb_io_unihdr("hdr_dir_drive ", &usr->hdr_dir_drive, ps, depth)) /* home directory drive */
5979 return False;
5980 if(!smb_io_unihdr("hdr_logon_script", &usr->hdr_logon_script, ps, depth)) /* logon script unicode string header */
5981 return False;
5982 if(!smb_io_unihdr("hdr_profile_path", &usr->hdr_profile_path, ps, depth)) /* profile path unicode string header */
5983 return False;
5984 if(!smb_io_unihdr("hdr_acct_desc ", &usr->hdr_acct_desc, ps, depth)) /* account desc */
5985 return False;
5986 if(!smb_io_unihdr("hdr_workstations", &usr->hdr_workstations, ps, depth)) /* wkstas user can log on from */
5987 return False;
5988 if(!smb_io_unihdr("hdr_comment ", &usr->hdr_comment, ps, depth)) /* unknown string */
5989 return False;
5990 if(!smb_io_unihdr("hdr_munged_dial ", &usr->hdr_munged_dial, ps, depth)) /* wkstas user can log on from */
5991 return False;
5993 if(!prs_uint8s(False, "lm_pwd ", ps, depth, usr->lm_pwd, sizeof(usr->lm_pwd)))
5994 return False;
5995 if(!prs_uint8s(False, "nt_pwd ", ps, depth, usr->nt_pwd, sizeof(usr->nt_pwd)))
5996 return False;
5998 if(!prs_uint32("user_rid ", ps, depth, &usr->user_rid)) /* User ID */
5999 return False;
6000 if(!prs_uint32("group_rid ", ps, depth, &usr->group_rid)) /* Group ID */
6001 return False;
6002 if(!prs_uint32("acb_info ", ps, depth, &usr->acb_info))
6003 return False;
6005 if(!prs_uint32("fields_present ", ps, depth, &usr->fields_present))
6006 return False;
6007 if(!prs_uint16("logon_divs ", ps, depth, &usr->logon_divs)) /* logon divisions per week */
6008 return False;
6009 if(!prs_align(ps))
6010 return False;
6011 if(!prs_uint32("ptr_logon_hrs ", ps, depth, &usr->ptr_logon_hrs))
6012 return False;
6014 if(!prs_uint16("bad_password_count ", ps, depth, &usr->bad_password_count))
6015 return False;
6016 if(!prs_uint16("logon_count ", ps, depth, &usr->logon_count))
6017 return False;
6019 if(!prs_uint8s(False, "padding1 ", ps, depth, usr->padding1, sizeof(usr->padding1)))
6020 return False;
6021 if(!prs_uint8("passmustchange ", ps, depth, &usr->passmustchange))
6022 return False;
6023 if(!prs_uint8("padding2 ", ps, depth, &usr->padding2))
6024 return False;
6027 if(!prs_uint8s(False, "password ", ps, depth, usr->pass, sizeof(usr->pass)))
6028 return False;
6030 /* here begins pointed-to data */
6032 if(!smb_io_unistr2("uni_user_name ", &usr->uni_user_name, usr->hdr_user_name.buffer, ps, depth)) /* username unicode string */
6033 return False;
6035 if(!smb_io_unistr2("uni_full_name ", &usr->uni_full_name, usr->hdr_full_name.buffer, ps, depth)) /* user's full name unicode string */
6036 return False;
6038 if(!smb_io_unistr2("uni_home_dir ", &usr->uni_home_dir, usr->hdr_home_dir.buffer, ps, depth)) /* home directory unicode string */
6039 return False;
6041 if(!smb_io_unistr2("uni_dir_drive ", &usr->uni_dir_drive, usr->hdr_dir_drive.buffer, ps, depth)) /* home directory drive unicode string */
6042 return False;
6044 if(!smb_io_unistr2("uni_logon_script", &usr->uni_logon_script, usr->hdr_logon_script.buffer, ps, depth)) /* logon script unicode string */
6045 return False;
6047 if(!smb_io_unistr2("uni_profile_path", &usr->uni_profile_path, usr->hdr_profile_path.buffer, ps, depth)) /* profile path unicode string */
6048 return False;
6050 if(!smb_io_unistr2("uni_acct_desc ", &usr->uni_acct_desc, usr->hdr_acct_desc.buffer, ps, depth)) /* user desc unicode string */
6051 return False;
6053 if(!smb_io_unistr2("uni_workstations", &usr->uni_workstations, usr->hdr_workstations.buffer, ps, depth)) /* worksations user can log on from */
6054 return False;
6056 if(!smb_io_unistr2("uni_comment ", &usr->uni_comment, usr->hdr_comment.buffer, ps, depth)) /* unknown string */
6057 return False;
6059 if(!smb_io_unistr2("uni_munged_dial ", &usr->uni_munged_dial, usr->hdr_munged_dial.buffer, ps, depth))
6060 return False;
6062 /* ok, this is only guess-work (as usual) */
6063 if (usr->ptr_logon_hrs) {
6064 if(!sam_io_logon_hrs("logon_hrs", &usr->logon_hrs, ps, depth))
6065 return False;
6068 return True;
6071 /*******************************************************************
6072 reads or writes a structure.
6073 NB. This structure is *definately* incorrect. It's my best guess
6074 currently for W2K SP2. The password field is encrypted in a different
6075 way than normal... And there are definately other problems. JRA.
6076 ********************************************************************/
6078 static BOOL sam_io_user_info25(const char *desc, SAM_USER_INFO_25 * usr, prs_struct *ps, int depth)
6080 if (usr == NULL)
6081 return False;
6083 prs_debug(ps, depth, desc, "sam_io_user_info25");
6084 depth++;
6086 if(!prs_align(ps))
6087 return False;
6089 if(!smb_io_time("logon_time ", &usr->logon_time, ps, depth))
6090 return False;
6091 if(!smb_io_time("logoff_time ", &usr->logoff_time, ps, depth))
6092 return False;
6093 if(!smb_io_time("kickoff_time ", &usr->kickoff_time, ps, depth))
6094 return False;
6095 if(!smb_io_time("pass_last_set_time ", &usr->pass_last_set_time, ps, depth))
6096 return False;
6097 if(!smb_io_time("pass_can_change_time ", &usr->pass_can_change_time, ps, depth))
6098 return False;
6099 if(!smb_io_time("pass_must_change_time", &usr->pass_must_change_time, ps, depth))
6100 return False;
6102 if(!smb_io_unihdr("hdr_user_name ", &usr->hdr_user_name, ps, depth)) /* username unicode string header */
6103 return False;
6104 if(!smb_io_unihdr("hdr_full_name ", &usr->hdr_full_name, ps, depth)) /* user's full name unicode string header */
6105 return False;
6106 if(!smb_io_unihdr("hdr_home_dir ", &usr->hdr_home_dir, ps, depth)) /* home directory unicode string header */
6107 return False;
6108 if(!smb_io_unihdr("hdr_dir_drive ", &usr->hdr_dir_drive, ps, depth)) /* home directory drive */
6109 return False;
6110 if(!smb_io_unihdr("hdr_logon_script", &usr->hdr_logon_script, ps, depth)) /* logon script unicode string header */
6111 return False;
6112 if(!smb_io_unihdr("hdr_profile_path", &usr->hdr_profile_path, ps, depth)) /* profile path unicode string header */
6113 return False;
6114 if(!smb_io_unihdr("hdr_acct_desc ", &usr->hdr_acct_desc, ps, depth)) /* account desc */
6115 return False;
6116 if(!smb_io_unihdr("hdr_workstations", &usr->hdr_workstations, ps, depth)) /* wkstas user can log on from */
6117 return False;
6118 if(!smb_io_unihdr("hdr_comment ", &usr->hdr_comment, ps, depth)) /* unknown string */
6119 return False;
6120 if(!smb_io_unihdr("hdr_munged_dial ", &usr->hdr_munged_dial, ps, depth)) /* wkstas user can log on from */
6121 return False;
6123 if(!prs_uint8s(False, "lm_pwd ", ps, depth, usr->lm_pwd, sizeof(usr->lm_pwd)))
6124 return False;
6125 if(!prs_uint8s(False, "nt_pwd ", ps, depth, usr->nt_pwd, sizeof(usr->nt_pwd)))
6126 return False;
6128 if(!prs_uint32("user_rid ", ps, depth, &usr->user_rid)) /* User ID */
6129 return False;
6130 if(!prs_uint32("group_rid ", ps, depth, &usr->group_rid)) /* Group ID */
6131 return False;
6132 if(!prs_uint32("acb_info ", ps, depth, &usr->acb_info))
6133 return False;
6134 if(!prs_uint32("fields_present ", ps, depth, &usr->fields_present))
6135 return False;
6137 if(!prs_uint32s(False, "unknown_5 ", ps, depth, usr->unknown_5, 5))
6138 return False;
6140 if(!prs_uint8s(False, "password ", ps, depth, usr->pass, sizeof(usr->pass)))
6141 return False;
6143 /* here begins pointed-to data */
6145 if(!smb_io_unistr2("uni_user_name ", &usr->uni_user_name, usr->hdr_user_name.buffer, ps, depth)) /* username unicode string */
6146 return False;
6148 if(!smb_io_unistr2("uni_full_name ", &usr->uni_full_name, usr->hdr_full_name.buffer, ps, depth)) /* user's full name unicode string */
6149 return False;
6151 if(!smb_io_unistr2("uni_home_dir ", &usr->uni_home_dir, usr->hdr_home_dir.buffer, ps, depth)) /* home directory unicode string */
6152 return False;
6154 if(!smb_io_unistr2("uni_dir_drive ", &usr->uni_dir_drive, usr->hdr_dir_drive.buffer, ps, depth)) /* home directory drive unicode string */
6155 return False;
6157 if(!smb_io_unistr2("uni_logon_script", &usr->uni_logon_script, usr->hdr_logon_script.buffer, ps, depth)) /* logon script unicode string */
6158 return False;
6160 if(!smb_io_unistr2("uni_profile_path", &usr->uni_profile_path, usr->hdr_profile_path.buffer, ps, depth)) /* profile path unicode string */
6161 return False;
6163 if(!smb_io_unistr2("uni_acct_desc ", &usr->uni_acct_desc, usr->hdr_acct_desc.buffer, ps, depth)) /* user desc unicode string */
6164 return False;
6166 if(!smb_io_unistr2("uni_workstations", &usr->uni_workstations, usr->hdr_workstations.buffer, ps, depth)) /* worksations user can log on from */
6167 return False;
6169 if(!smb_io_unistr2("uni_comment ", &usr->uni_comment, usr->hdr_comment.buffer, ps, depth)) /* unknown string */
6170 return False;
6172 if(!smb_io_unistr2("uni_munged_dial ", &usr->uni_munged_dial, usr->hdr_munged_dial.buffer, ps, depth))
6173 return False;
6175 #if 0 /* JRA - unknown... */
6176 /* ok, this is only guess-work (as usual) */
6177 if (usr->ptr_logon_hrs) {
6178 if(!sam_io_logon_hrs("logon_hrs", &usr->logon_hrs, ps, depth))
6179 return False;
6181 #endif
6183 return True;
6187 /*************************************************************************
6188 init_sam_user_info21W
6190 unknown_6 = 0x0000 04ec
6192 *************************************************************************/
6194 void init_sam_user_info21W(SAM_USER_INFO_21 * usr,
6195 NTTIME * logon_time,
6196 NTTIME * logoff_time,
6197 NTTIME * kickoff_time,
6198 NTTIME * pass_last_set_time,
6199 NTTIME * pass_can_change_time,
6200 NTTIME * pass_must_change_time,
6201 UNISTR2 *user_name,
6202 UNISTR2 *full_name,
6203 UNISTR2 *home_dir,
6204 UNISTR2 *dir_drive,
6205 UNISTR2 *log_scr,
6206 UNISTR2 *prof_path,
6207 UNISTR2 *desc,
6208 UNISTR2 *wkstas,
6209 UNISTR2 *unk_str,
6210 UNISTR2 *mung_dial,
6211 uchar lm_pwd[16],
6212 uchar nt_pwd[16],
6213 uint32 user_rid,
6214 uint32 group_rid,
6215 uint32 acb_info,
6216 uint32 fields_present,
6217 uint16 logon_divs,
6218 LOGON_HRS * hrs,
6219 uint16 bad_password_count,
6220 uint16 logon_count)
6222 usr->logon_time = *logon_time;
6223 usr->logoff_time = *logoff_time;
6224 usr->kickoff_time = *kickoff_time;
6225 usr->pass_last_set_time = *pass_last_set_time;
6226 usr->pass_can_change_time = *pass_can_change_time;
6227 usr->pass_must_change_time = *pass_must_change_time;
6229 memcpy(usr->lm_pwd, lm_pwd, sizeof(usr->lm_pwd));
6230 memcpy(usr->nt_pwd, nt_pwd, sizeof(usr->nt_pwd));
6232 usr->user_rid = user_rid;
6233 usr->group_rid = group_rid;
6234 usr->acb_info = acb_info;
6235 usr->fields_present = fields_present; /* 0x00ff ffff */
6237 usr->logon_divs = logon_divs; /* should be 168 (hours/week) */
6238 usr->ptr_logon_hrs = hrs ? 1 : 0;
6239 usr->bad_password_count = bad_password_count;
6240 usr->logon_count = logon_count;
6242 if (nt_time_is_zero(pass_must_change_time)) {
6243 usr->passmustchange=PASS_MUST_CHANGE_AT_NEXT_LOGON;
6244 } else {
6245 usr->passmustchange=0;
6248 ZERO_STRUCT(usr->padding1);
6249 ZERO_STRUCT(usr->padding2);
6251 copy_unistr2(&usr->uni_user_name, user_name);
6252 init_uni_hdr(&usr->hdr_user_name, &usr->uni_user_name);
6254 copy_unistr2(&usr->uni_full_name, full_name);
6255 init_uni_hdr(&usr->hdr_full_name, &usr->uni_full_name);
6257 copy_unistr2(&usr->uni_home_dir, home_dir);
6258 init_uni_hdr(&usr->hdr_home_dir, &usr->uni_home_dir);
6260 copy_unistr2(&usr->uni_dir_drive, dir_drive);
6261 init_uni_hdr(&usr->hdr_dir_drive, &usr->uni_dir_drive);
6263 copy_unistr2(&usr->uni_logon_script, log_scr);
6264 init_uni_hdr(&usr->hdr_logon_script, &usr->uni_logon_script);
6266 copy_unistr2(&usr->uni_profile_path, prof_path);
6267 init_uni_hdr(&usr->hdr_profile_path, &usr->uni_profile_path);
6269 copy_unistr2(&usr->uni_acct_desc, desc);
6270 init_uni_hdr(&usr->hdr_acct_desc, &usr->uni_acct_desc);
6272 copy_unistr2(&usr->uni_workstations, wkstas);
6273 init_uni_hdr(&usr->hdr_workstations, &usr->uni_workstations);
6275 copy_unistr2(&usr->uni_comment, unk_str);
6276 init_uni_hdr(&usr->hdr_comment, &usr->uni_comment);
6278 copy_unistr2(&usr->uni_munged_dial, mung_dial);
6279 init_uni_hdr(&usr->hdr_munged_dial, &usr->uni_munged_dial);
6281 if (hrs) {
6282 memcpy(&usr->logon_hrs, hrs, sizeof(usr->logon_hrs));
6283 } else {
6284 ZERO_STRUCT(usr->logon_hrs);
6288 /*************************************************************************
6289 init_sam_user_info21
6291 unknown_6 = 0x0000 04ec
6293 *************************************************************************/
6295 NTSTATUS init_sam_user_info21A(SAM_USER_INFO_21 *usr, struct samu *pw, DOM_SID *domain_sid)
6297 NTTIME logon_time, logoff_time, kickoff_time,
6298 pass_last_set_time, pass_can_change_time,
6299 pass_must_change_time;
6301 time_t must_change_time;
6302 const char* user_name = pdb_get_username(pw);
6303 const char* full_name = pdb_get_fullname(pw);
6304 const char* home_dir = pdb_get_homedir(pw);
6305 const char* dir_drive = pdb_get_dir_drive(pw);
6306 const char* logon_script = pdb_get_logon_script(pw);
6307 const char* profile_path = pdb_get_profile_path(pw);
6308 const char* description = pdb_get_acct_desc(pw);
6309 const char* workstations = pdb_get_workstations(pw);
6310 const char* munged_dial = pdb_get_munged_dial(pw);
6311 DATA_BLOB munged_dial_blob;
6313 uint32 user_rid;
6314 const DOM_SID *user_sid;
6316 uint32 group_rid;
6317 const DOM_SID *group_sid;
6319 if (munged_dial) {
6320 munged_dial_blob = base64_decode_data_blob(munged_dial);
6321 } else {
6322 munged_dial_blob = data_blob_null;
6325 /* Create NTTIME structs */
6326 unix_to_nt_time (&logon_time, pdb_get_logon_time(pw));
6327 unix_to_nt_time (&logoff_time, pdb_get_logoff_time(pw));
6328 unix_to_nt_time (&kickoff_time, pdb_get_kickoff_time(pw));
6329 unix_to_nt_time (&pass_last_set_time, pdb_get_pass_last_set_time(pw));
6330 unix_to_nt_time (&pass_can_change_time,pdb_get_pass_can_change_time(pw));
6331 must_change_time = pdb_get_pass_must_change_time(pw);
6332 if (must_change_time == get_time_t_max())
6333 unix_to_nt_time_abs(&pass_must_change_time, must_change_time);
6334 else
6335 unix_to_nt_time(&pass_must_change_time, must_change_time);
6337 /* structure assignment */
6338 usr->logon_time = logon_time;
6339 usr->logoff_time = logoff_time;
6340 usr->kickoff_time = kickoff_time;
6341 usr->pass_last_set_time = pass_last_set_time;
6342 usr->pass_can_change_time = pass_can_change_time;
6343 usr->pass_must_change_time = pass_must_change_time;
6345 ZERO_STRUCT(usr->nt_pwd);
6346 ZERO_STRUCT(usr->lm_pwd);
6348 user_sid = pdb_get_user_sid(pw);
6350 if (!sid_peek_check_rid(domain_sid, user_sid, &user_rid)) {
6351 fstring user_sid_string;
6352 fstring domain_sid_string;
6353 DEBUG(0, ("init_sam_user_info_21A: User %s has SID %s, \nwhich conflicts with "
6354 "the domain sid %s. Failing operation.\n",
6355 user_name,
6356 sid_to_string(user_sid_string, user_sid),
6357 sid_to_string(domain_sid_string, domain_sid)));
6358 data_blob_free(&munged_dial_blob);
6359 return NT_STATUS_UNSUCCESSFUL;
6362 become_root();
6363 group_sid = pdb_get_group_sid(pw);
6364 unbecome_root();
6366 if (!sid_peek_check_rid(domain_sid, group_sid, &group_rid)) {
6367 fstring group_sid_string;
6368 fstring domain_sid_string;
6369 DEBUG(0, ("init_sam_user_info_21A: User %s has Primary Group SID %s, \n"
6370 "which conflicts with the domain sid %s. Failing operation.\n",
6371 user_name,
6372 sid_to_string(group_sid_string, group_sid),
6373 sid_to_string(domain_sid_string, domain_sid)));
6374 data_blob_free(&munged_dial_blob);
6375 return NT_STATUS_UNSUCCESSFUL;
6378 usr->user_rid = user_rid;
6379 usr->group_rid = group_rid;
6380 usr->acb_info = pdb_get_acct_ctrl(pw);
6383 Look at a user on a real NT4 PDC with usrmgr, press
6384 'ok'. Then you will see that fields_present is set to
6385 0x08f827fa. Look at the user immediately after that again,
6386 and you will see that 0x00fffff is returned. This solves
6387 the problem that you get access denied after having looked
6388 at the user.
6389 -- Volker
6391 usr->fields_present = pdb_build_fields_present(pw);
6393 usr->logon_divs = pdb_get_logon_divs(pw);
6394 usr->ptr_logon_hrs = pdb_get_hours(pw) ? 1 : 0;
6395 usr->bad_password_count = pdb_get_bad_password_count(pw);
6396 usr->logon_count = pdb_get_logon_count(pw);
6398 if (pdb_get_pass_must_change_time(pw) == 0) {
6399 usr->passmustchange=PASS_MUST_CHANGE_AT_NEXT_LOGON;
6400 } else {
6401 usr->passmustchange=0;
6404 ZERO_STRUCT(usr->padding1);
6405 ZERO_STRUCT(usr->padding2);
6407 init_unistr2(&usr->uni_user_name, user_name, UNI_STR_TERMINATE);
6408 init_uni_hdr(&usr->hdr_user_name, &usr->uni_user_name);
6410 init_unistr2(&usr->uni_full_name, full_name, UNI_STR_TERMINATE);
6411 init_uni_hdr(&usr->hdr_full_name, &usr->uni_full_name);
6413 init_unistr2(&usr->uni_home_dir, home_dir, UNI_STR_TERMINATE);
6414 init_uni_hdr(&usr->hdr_home_dir, &usr->uni_home_dir);
6416 init_unistr2(&usr->uni_dir_drive, dir_drive, UNI_STR_TERMINATE);
6417 init_uni_hdr(&usr->hdr_dir_drive, &usr->uni_dir_drive);
6419 init_unistr2(&usr->uni_logon_script, logon_script, UNI_STR_TERMINATE);
6420 init_uni_hdr(&usr->hdr_logon_script, &usr->uni_logon_script);
6422 init_unistr2(&usr->uni_profile_path, profile_path, UNI_STR_TERMINATE);
6423 init_uni_hdr(&usr->hdr_profile_path, &usr->uni_profile_path);
6425 init_unistr2(&usr->uni_acct_desc, description, UNI_STR_TERMINATE);
6426 init_uni_hdr(&usr->hdr_acct_desc, &usr->uni_acct_desc);
6428 init_unistr2(&usr->uni_workstations, workstations, UNI_STR_TERMINATE);
6429 init_uni_hdr(&usr->hdr_workstations, &usr->uni_workstations);
6431 init_unistr2(&usr->uni_comment, NULL, UNI_STR_TERMINATE);
6432 init_uni_hdr(&usr->hdr_comment, &usr->uni_comment);
6434 init_unistr2_from_datablob(&usr->uni_munged_dial, &munged_dial_blob);
6435 init_uni_hdr(&usr->hdr_munged_dial, &usr->uni_munged_dial);
6436 data_blob_free(&munged_dial_blob);
6438 if (pdb_get_hours(pw)) {
6439 usr->logon_hrs.max_len = 1260;
6440 usr->logon_hrs.offset = 0;
6441 usr->logon_hrs.len = pdb_get_hours_len(pw);
6442 memcpy(&usr->logon_hrs.hours, pdb_get_hours(pw), MAX_HOURS_LEN);
6443 } else {
6444 usr->logon_hrs.max_len = 1260;
6445 usr->logon_hrs.offset = 0;
6446 usr->logon_hrs.len = 0;
6447 memset(&usr->logon_hrs, 0xff, sizeof(usr->logon_hrs));
6450 return NT_STATUS_OK;
6453 /*******************************************************************
6454 reads or writes a structure.
6455 ********************************************************************/
6457 static BOOL sam_io_user_info21(const char *desc, SAM_USER_INFO_21 * usr,
6458 prs_struct *ps, int depth)
6460 if (usr == NULL)
6461 return False;
6463 prs_debug(ps, depth, desc, "sam_io_user_info21");
6464 depth++;
6466 if(!prs_align(ps))
6467 return False;
6469 if(!smb_io_time("logon_time ", &usr->logon_time, ps, depth))
6470 return False;
6471 if(!smb_io_time("logoff_time ", &usr->logoff_time, ps, depth))
6472 return False;
6473 if(!smb_io_time("pass_last_set_time ", &usr->pass_last_set_time, ps,depth))
6474 return False;
6475 if(!smb_io_time("kickoff_time ", &usr->kickoff_time, ps, depth))
6476 return False;
6477 if(!smb_io_time("pass_can_change_time ", &usr->pass_can_change_time, ps,depth))
6478 return False;
6479 if(!smb_io_time("pass_must_change_time", &usr->pass_must_change_time, ps, depth))
6480 return False;
6482 if(!smb_io_unihdr("hdr_user_name ", &usr->hdr_user_name, ps, depth)) /* username unicode string header */
6483 return False;
6484 if(!smb_io_unihdr("hdr_full_name ", &usr->hdr_full_name, ps, depth)) /* user's full name unicode string header */
6485 return False;
6486 if(!smb_io_unihdr("hdr_home_dir ", &usr->hdr_home_dir, ps, depth)) /* home directory unicode string header */
6487 return False;
6488 if(!smb_io_unihdr("hdr_dir_drive ", &usr->hdr_dir_drive, ps, depth)) /* home directory drive */
6489 return False;
6490 if(!smb_io_unihdr("hdr_logon_script", &usr->hdr_logon_script, ps, depth)) /* logon script unicode string header */
6491 return False;
6492 if(!smb_io_unihdr("hdr_profile_path", &usr->hdr_profile_path, ps, depth)) /* profile path unicode string header */
6493 return False;
6494 if(!smb_io_unihdr("hdr_acct_desc ", &usr->hdr_acct_desc, ps, depth)) /* account desc */
6495 return False;
6496 if(!smb_io_unihdr("hdr_workstations", &usr->hdr_workstations, ps, depth)) /* wkstas user can log on from */
6497 return False;
6498 if(!smb_io_unihdr("hdr_comment ", &usr->hdr_comment, ps, depth)) /* unknown string */
6499 return False;
6500 if(!smb_io_unihdr("hdr_munged_dial ", &usr->hdr_munged_dial, ps, depth)) /* wkstas user can log on from */
6501 return False;
6503 if(!prs_uint8s(False, "lm_pwd ", ps, depth, usr->lm_pwd, sizeof(usr->lm_pwd)))
6504 return False;
6505 if(!prs_uint8s(False, "nt_pwd ", ps, depth, usr->nt_pwd, sizeof(usr->nt_pwd)))
6506 return False;
6508 if(!prs_uint32("user_rid ", ps, depth, &usr->user_rid)) /* User ID */
6509 return False;
6510 if(!prs_uint32("group_rid ", ps, depth, &usr->group_rid)) /* Group ID */
6511 return False;
6512 if(!prs_uint32("acb_info ", ps, depth, &usr->acb_info))
6513 return False;
6515 if(!prs_uint32("fields_present ", ps, depth, &usr->fields_present))
6516 return False;
6517 if(!prs_uint16("logon_divs ", ps, depth, &usr->logon_divs)) /* logon divisions per week */
6518 return False;
6519 if(!prs_align(ps))
6520 return False;
6521 if(!prs_uint32("ptr_logon_hrs ", ps, depth, &usr->ptr_logon_hrs))
6522 return False;
6524 if(!prs_uint16("bad_password_count ", ps, depth, &usr->bad_password_count))
6525 return False;
6526 if(!prs_uint16("logon_count ", ps, depth, &usr->logon_count))
6527 return False;
6529 if(!prs_uint8s(False, "padding1 ", ps, depth, usr->padding1, sizeof(usr->padding1)))
6530 return False;
6531 if(!prs_uint8("passmustchange ", ps, depth, &usr->passmustchange))
6532 return False;
6533 if(!prs_uint8("padding2 ", ps, depth, &usr->padding2))
6534 return False;
6536 /* here begins pointed-to data */
6538 if(!smb_io_unistr2("uni_user_name ", &usr->uni_user_name,usr->hdr_user_name.buffer, ps, depth))
6539 return False;
6540 if(!smb_io_unistr2("uni_full_name ", &usr->uni_full_name, usr->hdr_full_name.buffer, ps, depth))
6541 return False;
6542 if(!smb_io_unistr2("uni_home_dir ", &usr->uni_home_dir, usr->hdr_home_dir.buffer, ps, depth))
6543 return False;
6544 if(!smb_io_unistr2("uni_dir_drive ", &usr->uni_dir_drive, usr->hdr_dir_drive.buffer, ps, depth))
6545 return False;
6546 if(!smb_io_unistr2("uni_logon_script", &usr->uni_logon_script, usr->hdr_logon_script.buffer, ps, depth))
6547 return False;
6548 if(!smb_io_unistr2("uni_profile_path", &usr->uni_profile_path, usr->hdr_profile_path.buffer, ps, depth))
6549 return False;
6550 if(!smb_io_unistr2("uni_acct_desc ", &usr->uni_acct_desc, usr->hdr_acct_desc.buffer, ps, depth))
6551 return False;
6552 if(!smb_io_unistr2("uni_workstations", &usr->uni_workstations, usr->hdr_workstations.buffer, ps, depth))
6553 return False;
6554 if(!smb_io_unistr2("uni_comment", &usr->uni_comment, usr->hdr_comment.buffer, ps, depth))
6555 return False;
6556 if(!smb_io_unistr2("uni_munged_dial ", &usr->uni_munged_dial,usr->hdr_munged_dial.buffer, ps, depth))
6557 return False;
6559 /* ok, this is only guess-work (as usual) */
6560 if (usr->ptr_logon_hrs) {
6561 if(!sam_io_logon_hrs("logon_hrs", &usr->logon_hrs, ps, depth))
6562 return False;
6565 return True;
6568 void init_sam_user_info20A(SAM_USER_INFO_20 *usr, struct samu *pw)
6570 const char *munged_dial = pdb_get_munged_dial(pw);
6571 DATA_BLOB blob;
6573 if (munged_dial) {
6574 blob = base64_decode_data_blob(munged_dial);
6575 } else {
6576 blob = data_blob_null;
6579 init_unistr2_from_datablob(&usr->uni_munged_dial, &blob);
6580 init_uni_hdr(&usr->hdr_munged_dial, &usr->uni_munged_dial);
6581 data_blob_free(&blob);
6584 /*******************************************************************
6585 reads or writes a structure.
6586 ********************************************************************/
6588 static BOOL sam_io_user_info20(const char *desc, SAM_USER_INFO_20 *usr,
6589 prs_struct *ps, int depth)
6591 if (usr == NULL)
6592 return False;
6594 prs_debug(ps, depth, desc, "sam_io_user_info20");
6595 depth++;
6597 if(!prs_align(ps))
6598 return False;
6600 if(!smb_io_unihdr("hdr_munged_dial ", &usr->hdr_munged_dial, ps, depth)) /* wkstas user can log on from */
6601 return False;
6603 if(!smb_io_unistr2("uni_munged_dial ", &usr->uni_munged_dial,usr->hdr_munged_dial.buffer, ps, depth)) /* worksations user can log on from */
6604 return False;
6606 return True;
6609 /*******************************************************************
6610 inits a SAM_USERINFO_CTR structure.
6611 ********************************************************************/
6613 NTSTATUS make_samr_userinfo_ctr_usr21(TALLOC_CTX *ctx, SAM_USERINFO_CTR * ctr,
6614 uint16 switch_value,
6615 SAM_USER_INFO_21 * usr)
6617 DEBUG(5, ("make_samr_userinfo_ctr_usr21\n"));
6619 ctr->switch_value = switch_value;
6620 ctr->info.id = NULL;
6622 switch (switch_value) {
6623 case 16:
6624 ctr->info.id16 = TALLOC_ZERO_P(ctx,SAM_USER_INFO_16);
6625 if (ctr->info.id16 == NULL)
6626 return NT_STATUS_NO_MEMORY;
6628 init_sam_user_info16(ctr->info.id16, usr->acb_info);
6629 break;
6630 #if 0
6631 /* whoops - got this wrong. i think. or don't understand what's happening. */
6632 case 17:
6634 NTTIME expire;
6635 info = (void *)&id11;
6637 expire.low = 0xffffffff;
6638 expire.high = 0x7fffffff;
6640 ctr->info.id = TALLOC_ZERO_P(ctx,SAM_USER_INFO_17);
6641 init_sam_user_info11(ctr->info.id17, &expire,
6642 "BROOKFIELDS$", /* name */
6643 0x03ef, /* user rid */
6644 0x201, /* group rid */
6645 0x0080); /* acb info */
6647 break;
6649 #endif
6650 case 18:
6651 ctr->info.id18 = TALLOC_ZERO_P(ctx,SAM_USER_INFO_18);
6652 if (ctr->info.id18 == NULL)
6653 return NT_STATUS_NO_MEMORY;
6655 init_sam_user_info18(ctr->info.id18, usr->lm_pwd, usr->nt_pwd);
6656 break;
6657 case 21:
6659 SAM_USER_INFO_21 *cusr;
6660 cusr = TALLOC_ZERO_P(ctx,SAM_USER_INFO_21);
6661 ctr->info.id21 = cusr;
6662 if (ctr->info.id21 == NULL)
6663 return NT_STATUS_NO_MEMORY;
6664 memcpy(cusr, usr, sizeof(*usr));
6665 memset(cusr->lm_pwd, 0, sizeof(cusr->lm_pwd));
6666 memset(cusr->nt_pwd, 0, sizeof(cusr->nt_pwd));
6667 break;
6669 default:
6670 DEBUG(4,("make_samr_userinfo_ctr: unsupported info\n"));
6671 return NT_STATUS_INVALID_INFO_CLASS;
6674 return NT_STATUS_OK;
6677 /*******************************************************************
6678 inits a SAM_USERINFO_CTR structure.
6679 ********************************************************************/
6681 static void init_samr_userinfo_ctr(SAM_USERINFO_CTR * ctr, DATA_BLOB *sess_key,
6682 uint16 switch_value, void *info)
6684 DEBUG(5, ("init_samr_userinfo_ctr\n"));
6686 ctr->switch_value = switch_value;
6687 ctr->info.id = info;
6689 switch (switch_value) {
6690 case 0x18:
6691 SamOEMhashBlob(ctr->info.id24->pass, 516, sess_key);
6692 dump_data(100, sess_key->data, sess_key->length);
6693 dump_data(100, ctr->info.id24->pass, 516);
6694 break;
6695 case 0x17:
6696 SamOEMhashBlob(ctr->info.id23->pass, 516, sess_key);
6697 dump_data(100, sess_key->data, sess_key->length);
6698 dump_data(100, ctr->info.id23->pass, 516);
6699 break;
6700 case 0x07:
6701 break;
6702 default:
6703 DEBUG(4,("init_samr_userinfo_ctr: unsupported switch level: %d\n", switch_value));
6707 /*******************************************************************
6708 reads or writes a structure.
6709 ********************************************************************/
6711 static BOOL samr_io_userinfo_ctr(const char *desc, SAM_USERINFO_CTR **ppctr,
6712 prs_struct *ps, int depth)
6714 BOOL ret;
6715 SAM_USERINFO_CTR *ctr;
6717 prs_debug(ps, depth, desc, "samr_io_userinfo_ctr");
6718 depth++;
6720 if (UNMARSHALLING(ps)) {
6721 ctr = PRS_ALLOC_MEM(ps,SAM_USERINFO_CTR,1);
6722 if (ctr == NULL)
6723 return False;
6724 *ppctr = ctr;
6725 } else {
6726 ctr = *ppctr;
6729 /* lkclXXXX DO NOT ALIGN BEFORE READING SWITCH VALUE! */
6731 if(!prs_uint16("switch_value", ps, depth, &ctr->switch_value))
6732 return False;
6733 if(!prs_align(ps))
6734 return False;
6736 ret = False;
6738 switch (ctr->switch_value) {
6739 case 7:
6740 if (UNMARSHALLING(ps))
6741 ctr->info.id7 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_7,1);
6742 if (ctr->info.id7 == NULL) {
6743 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6744 return False;
6746 ret = sam_io_user_info7("", ctr->info.id7, ps, depth);
6747 break;
6748 case 9:
6749 if (UNMARSHALLING(ps))
6750 ctr->info.id9 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_9,1);
6751 if (ctr->info.id9 == NULL) {
6752 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6753 return False;
6755 ret = sam_io_user_info9("", ctr->info.id9, ps, depth);
6756 break;
6757 case 16:
6758 if (UNMARSHALLING(ps))
6759 ctr->info.id16 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_16,1);
6760 if (ctr->info.id16 == NULL) {
6761 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6762 return False;
6764 ret = sam_io_user_info16("", ctr->info.id16, ps, depth);
6765 break;
6766 case 17:
6767 if (UNMARSHALLING(ps))
6768 ctr->info.id17 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_17,1);
6770 if (ctr->info.id17 == NULL) {
6771 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6772 return False;
6774 ret = sam_io_user_info17("", ctr->info.id17, ps, depth);
6775 break;
6776 case 18:
6777 if (UNMARSHALLING(ps))
6778 ctr->info.id18 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_18,1);
6780 if (ctr->info.id18 == NULL) {
6781 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6782 return False;
6784 ret = sam_io_user_info18("", ctr->info.id18, ps, depth);
6785 break;
6786 case 20:
6787 if (UNMARSHALLING(ps))
6788 ctr->info.id20 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_20,1);
6790 if (ctr->info.id20 == NULL) {
6791 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6792 return False;
6794 ret = sam_io_user_info20("", ctr->info.id20, ps, depth);
6795 break;
6796 case 21:
6797 if (UNMARSHALLING(ps))
6798 ctr->info.id21 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_21,1);
6800 if (ctr->info.id21 == NULL) {
6801 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6802 return False;
6804 ret = sam_io_user_info21("", ctr->info.id21, ps, depth);
6805 break;
6806 case 23:
6807 if (UNMARSHALLING(ps))
6808 ctr->info.id23 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_23,1);
6810 if (ctr->info.id23 == NULL) {
6811 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6812 return False;
6814 ret = sam_io_user_info23("", ctr->info.id23, ps, depth);
6815 break;
6816 case 24:
6817 if (UNMARSHALLING(ps))
6818 ctr->info.id24 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_24,1);
6820 if (ctr->info.id24 == NULL) {
6821 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6822 return False;
6824 ret = sam_io_user_info24("", ctr->info.id24, ps, depth);
6825 break;
6826 case 25:
6827 if (UNMARSHALLING(ps))
6828 ctr->info.id25 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_25,1);
6830 if (ctr->info.id25 == NULL) {
6831 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6832 return False;
6834 ret = sam_io_user_info25("", ctr->info.id25, ps, depth);
6835 break;
6836 case 26:
6837 if (UNMARSHALLING(ps))
6838 ctr->info.id26 = PRS_ALLOC_MEM(ps,SAM_USER_INFO_26,1);
6840 if (ctr->info.id26 == NULL) {
6841 DEBUG(2,("samr_io_userinfo_ctr: info pointer not initialised\n"));
6842 return False;
6844 ret = sam_io_user_info26("", ctr->info.id26, ps, depth);
6845 break;
6846 default:
6847 DEBUG(2, ("samr_io_userinfo_ctr: unknown switch level 0x%x\n", ctr->switch_value));
6848 ret = False;
6849 break;
6852 return ret;
6855 /*******************************************************************
6856 inits a SAMR_R_QUERY_USERINFO structure.
6857 ********************************************************************/
6859 void init_samr_r_query_userinfo(SAMR_R_QUERY_USERINFO * r_u,
6860 SAM_USERINFO_CTR * ctr, NTSTATUS status)
6862 DEBUG(5, ("init_samr_r_query_userinfo\n"));
6864 r_u->ptr = 0;
6865 r_u->ctr = NULL;
6867 if (NT_STATUS_IS_OK(status)) {
6868 r_u->ptr = 1;
6869 r_u->ctr = ctr;
6872 r_u->status = status; /* return status */
6875 /*******************************************************************
6876 reads or writes a structure.
6877 ********************************************************************/
6879 BOOL samr_io_r_query_userinfo(const char *desc, SAMR_R_QUERY_USERINFO * r_u,
6880 prs_struct *ps, int depth)
6882 if (r_u == NULL)
6883 return False;
6885 prs_debug(ps, depth, desc, "samr_io_r_query_userinfo");
6886 depth++;
6888 if(!prs_align(ps))
6889 return False;
6891 if(!prs_uint32("ptr", ps, depth, &r_u->ptr))
6892 return False;
6894 if (r_u->ptr != 0) {
6895 if(!samr_io_userinfo_ctr("ctr", &r_u->ctr, ps, depth))
6896 return False;
6899 if(!prs_align(ps))
6900 return False;
6901 if(!prs_ntstatus("status", ps, depth, &r_u->status))
6902 return False;
6904 return True;
6907 /*******************************************************************
6908 inits a SAMR_Q_SET_USERINFO structure.
6909 ********************************************************************/
6911 void init_samr_q_set_userinfo(SAMR_Q_SET_USERINFO * q_u,
6912 const POLICY_HND *hnd, DATA_BLOB *sess_key,
6913 uint16 switch_value, void *info)
6915 DEBUG(5, ("init_samr_q_set_userinfo\n"));
6917 q_u->pol = *hnd;
6918 q_u->switch_value = switch_value;
6919 init_samr_userinfo_ctr(q_u->ctr, sess_key, switch_value, info);
6922 /*******************************************************************
6923 reads or writes a structure.
6924 ********************************************************************/
6926 BOOL samr_io_q_set_userinfo(const char *desc, SAMR_Q_SET_USERINFO * q_u,
6927 prs_struct *ps, int depth)
6929 if (q_u == NULL)
6930 return False;
6932 prs_debug(ps, depth, desc, "samr_io_q_set_userinfo");
6933 depth++;
6935 if(!prs_align(ps))
6936 return False;
6938 smb_io_pol_hnd("pol", &(q_u->pol), ps, depth);
6940 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value))
6941 return False;
6942 if(!samr_io_userinfo_ctr("ctr", &q_u->ctr, ps, depth))
6943 return False;
6945 return True;
6948 /*******************************************************************
6949 inits a SAMR_R_SET_USERINFO structure.
6950 ********************************************************************/
6952 void init_samr_r_set_userinfo(SAMR_R_SET_USERINFO * r_u, NTSTATUS status)
6954 DEBUG(5, ("init_samr_r_set_userinfo\n"));
6956 r_u->status = status; /* return status */
6959 /*******************************************************************
6960 reads or writes a structure.
6961 ********************************************************************/
6963 BOOL samr_io_r_set_userinfo(const char *desc, SAMR_R_SET_USERINFO * r_u,
6964 prs_struct *ps, int depth)
6966 if (r_u == NULL)
6967 return False;
6969 prs_debug(ps, depth, desc, "samr_io_r_set_userinfo");
6970 depth++;
6972 if(!prs_align(ps))
6973 return False;
6975 if(!prs_ntstatus("status", ps, depth, &r_u->status))
6976 return False;
6978 return True;
6981 /*******************************************************************
6982 inits a SAMR_Q_SET_USERINFO2 structure.
6983 ********************************************************************/
6985 void init_samr_q_set_userinfo2(SAMR_Q_SET_USERINFO2 * q_u,
6986 const POLICY_HND *hnd, DATA_BLOB *sess_key,
6987 uint16 switch_value, SAM_USERINFO_CTR * ctr)
6989 DEBUG(5, ("init_samr_q_set_userinfo2\n"));
6991 q_u->pol = *hnd;
6992 q_u->switch_value = switch_value;
6993 q_u->ctr = ctr;
6995 q_u->ctr->switch_value = switch_value;
6997 switch (switch_value) {
6998 case 18:
6999 SamOEMhashBlob(ctr->info.id18->lm_pwd, 16, sess_key);
7000 SamOEMhashBlob(ctr->info.id18->nt_pwd, 16, sess_key);
7001 dump_data(100, sess_key->data, sess_key->length);
7002 dump_data(100, ctr->info.id18->lm_pwd, 16);
7003 dump_data(100, ctr->info.id18->nt_pwd, 16);
7004 break;
7008 /*******************************************************************
7009 reads or writes a structure.
7010 ********************************************************************/
7012 BOOL samr_io_q_set_userinfo2(const char *desc, SAMR_Q_SET_USERINFO2 * q_u,
7013 prs_struct *ps, int depth)
7015 if (q_u == NULL)
7016 return False;
7018 prs_debug(ps, depth, desc, "samr_io_q_set_userinfo2");
7019 depth++;
7021 if(!prs_align(ps))
7022 return False;
7024 if(!smb_io_pol_hnd("pol", &q_u->pol, ps, depth))
7025 return False;
7027 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value))
7028 return False;
7029 if(!samr_io_userinfo_ctr("ctr", &q_u->ctr, ps, depth))
7030 return False;
7032 return True;
7035 /*******************************************************************
7036 inits a SAMR_R_SET_USERINFO2 structure.
7037 ********************************************************************/
7039 void init_samr_r_set_userinfo2(SAMR_R_SET_USERINFO2 * r_u, NTSTATUS status)
7041 DEBUG(5, ("init_samr_r_set_userinfo2\n"));
7043 r_u->status = status; /* return status */
7046 /*******************************************************************
7047 reads or writes a structure.
7048 ********************************************************************/
7050 BOOL samr_io_r_set_userinfo2(const char *desc, SAMR_R_SET_USERINFO2 * r_u,
7051 prs_struct *ps, int depth)
7053 if (r_u == NULL)
7054 return False;
7056 prs_debug(ps, depth, desc, "samr_io_r_set_userinfo2");
7057 depth++;
7059 if(!prs_align(ps))
7060 return False;
7062 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7063 return False;
7065 return True;
7068 /*******************************************************************
7069 inits a SAMR_Q_CONNECT structure.
7070 ********************************************************************/
7072 void init_samr_q_connect(SAMR_Q_CONNECT * q_u,
7073 char *srv_name, uint32 access_mask)
7075 DEBUG(5, ("init_samr_q_connect\n"));
7077 /* make PDC server name \\server */
7078 q_u->ptr_srv_name = (srv_name != NULL && *srv_name) ? 1 : 0;
7079 init_unistr2(&q_u->uni_srv_name, srv_name, UNI_STR_TERMINATE);
7081 /* example values: 0x0000 0002 */
7082 q_u->access_mask = access_mask;
7085 /*******************************************************************
7086 reads or writes a structure.
7087 ********************************************************************/
7089 BOOL samr_io_q_connect(const char *desc, SAMR_Q_CONNECT * q_u,
7090 prs_struct *ps, int depth)
7092 if (q_u == NULL)
7093 return False;
7095 prs_debug(ps, depth, desc, "samr_io_q_connect");
7096 depth++;
7098 if(!prs_align(ps))
7099 return False;
7101 if(!prs_uint32("ptr_srv_name", ps, depth, &q_u->ptr_srv_name))
7102 return False;
7103 if(!smb_io_unistr2("", &q_u->uni_srv_name, q_u->ptr_srv_name, ps, depth))
7104 return False;
7106 if(!prs_align(ps))
7107 return False;
7108 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
7109 return False;
7111 return True;
7114 /*******************************************************************
7115 reads or writes a structure.
7116 ********************************************************************/
7118 BOOL samr_io_r_connect(const char *desc, SAMR_R_CONNECT * r_u,
7119 prs_struct *ps, int depth)
7121 if (r_u == NULL)
7122 return False;
7124 prs_debug(ps, depth, desc, "samr_io_r_connect");
7125 depth++;
7127 if(!prs_align(ps))
7128 return False;
7130 if(!smb_io_pol_hnd("connect_pol", &r_u->connect_pol, ps, depth))
7131 return False;
7133 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7134 return False;
7136 return True;
7139 /*******************************************************************
7140 inits a SAMR_Q_CONNECT4 structure.
7141 ********************************************************************/
7143 void init_samr_q_connect4(SAMR_Q_CONNECT4 * q_u,
7144 char *srv_name, uint32 access_mask)
7146 DEBUG(5, ("init_samr_q_connect4\n"));
7148 /* make PDC server name \\server */
7149 q_u->ptr_srv_name = (srv_name != NULL && *srv_name) ? 1 : 0;
7150 init_unistr2(&q_u->uni_srv_name, srv_name, UNI_STR_TERMINATE);
7152 /* Only value we've seen, possibly an address type ? */
7153 q_u->unk_0 = 2;
7155 /* example values: 0x0000 0002 */
7156 q_u->access_mask = access_mask;
7159 /*******************************************************************
7160 reads or writes a structure.
7161 ********************************************************************/
7163 BOOL samr_io_q_connect4(const char *desc, SAMR_Q_CONNECT4 * q_u,
7164 prs_struct *ps, int depth)
7166 if (q_u == NULL)
7167 return False;
7169 prs_debug(ps, depth, desc, "samr_io_q_connect4");
7170 depth++;
7172 if(!prs_align(ps))
7173 return False;
7175 if(!prs_uint32("ptr_srv_name", ps, depth, &q_u->ptr_srv_name))
7176 return False;
7177 if(!smb_io_unistr2("", &q_u->uni_srv_name, q_u->ptr_srv_name, ps, depth))
7178 return False;
7180 if(!prs_align(ps))
7181 return False;
7182 if(!prs_uint32("unk_0", ps, depth, &q_u->unk_0))
7183 return False;
7184 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
7185 return False;
7187 return True;
7190 /*******************************************************************
7191 reads or writes a structure.
7192 ********************************************************************/
7194 BOOL samr_io_r_connect4(const char *desc, SAMR_R_CONNECT4 * r_u,
7195 prs_struct *ps, int depth)
7197 if (r_u == NULL)
7198 return False;
7200 prs_debug(ps, depth, desc, "samr_io_r_connect4");
7201 depth++;
7203 if(!prs_align(ps))
7204 return False;
7206 if(!smb_io_pol_hnd("connect_pol", &r_u->connect_pol, ps, depth))
7207 return False;
7209 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7210 return False;
7212 return True;
7215 /*******************************************************************
7216 inits a SAMR_Q_CONNECT5 structure.
7217 ********************************************************************/
7219 void init_samr_q_connect5(SAMR_Q_CONNECT5 * q_u,
7220 char *srv_name, uint32 access_mask)
7222 DEBUG(5, ("init_samr_q_connect5\n"));
7224 /* make PDC server name \\server */
7225 q_u->ptr_srv_name = (srv_name != NULL && *srv_name) ? 1 : 0;
7226 init_unistr2(&q_u->uni_srv_name, srv_name, UNI_STR_TERMINATE);
7228 /* example values: 0x0000 0002 */
7229 q_u->access_mask = access_mask;
7231 q_u->level = 1;
7232 q_u->info1_unk1 = 3;
7233 q_u->info1_unk2 = 0;
7236 /*******************************************************************
7237 inits a SAMR_R_CONNECT5 structure.
7238 ********************************************************************/
7240 void init_samr_r_connect5(SAMR_R_CONNECT5 * r_u, POLICY_HND *pol, NTSTATUS status)
7242 DEBUG(5, ("init_samr_q_connect5\n"));
7244 r_u->level = 1;
7245 r_u->info1_unk1 = 3;
7246 r_u->info1_unk2 = 0;
7248 r_u->connect_pol = *pol;
7249 r_u->status = status;
7252 /*******************************************************************
7253 reads or writes a structure.
7254 ********************************************************************/
7256 BOOL samr_io_q_connect5(const char *desc, SAMR_Q_CONNECT5 * q_u,
7257 prs_struct *ps, int depth)
7259 if (q_u == NULL)
7260 return False;
7262 prs_debug(ps, depth, desc, "samr_io_q_connect5");
7263 depth++;
7265 if(!prs_align(ps))
7266 return False;
7268 if(!prs_uint32("ptr_srv_name", ps, depth, &q_u->ptr_srv_name))
7269 return False;
7270 if(!smb_io_unistr2("", &q_u->uni_srv_name, q_u->ptr_srv_name, ps, depth))
7271 return False;
7273 if(!prs_align(ps))
7274 return False;
7275 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
7276 return False;
7278 if(!prs_uint32("level", ps, depth, &q_u->level))
7279 return False;
7280 if(!prs_uint32("level", ps, depth, &q_u->level))
7281 return False;
7283 if(!prs_uint32("info1_unk1", ps, depth, &q_u->info1_unk1))
7284 return False;
7285 if(!prs_uint32("info1_unk2", ps, depth, &q_u->info1_unk2))
7286 return False;
7288 return True;
7291 /*******************************************************************
7292 reads or writes a structure.
7293 ********************************************************************/
7295 BOOL samr_io_r_connect5(const char *desc, SAMR_R_CONNECT5 * r_u,
7296 prs_struct *ps, int depth)
7298 if (r_u == NULL)
7299 return False;
7301 prs_debug(ps, depth, desc, "samr_io_r_connect5");
7302 depth++;
7304 if(!prs_align(ps))
7305 return False;
7307 if(!prs_uint32("level", ps, depth, &r_u->level))
7308 return False;
7309 if(!prs_uint32("level", ps, depth, &r_u->level))
7310 return False;
7311 if(!prs_uint32("info1_unk1", ps, depth, &r_u->info1_unk1))
7312 return False;
7313 if(!prs_uint32("info1_unk2", ps, depth, &r_u->info1_unk2))
7314 return False;
7316 if(!smb_io_pol_hnd("connect_pol", &r_u->connect_pol, ps, depth))
7317 return False;
7319 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7320 return False;
7322 return True;
7325 /*******************************************************************
7326 inits a SAMR_Q_CONNECT_ANON structure.
7327 ********************************************************************/
7329 void init_samr_q_connect_anon(SAMR_Q_CONNECT_ANON * q_u)
7331 DEBUG(5, ("init_samr_q_connect_anon\n"));
7333 q_u->ptr = 1;
7334 q_u->unknown_0 = 0x5c; /* server name (?!!) */
7335 q_u->access_mask = MAXIMUM_ALLOWED_ACCESS;
7338 /*******************************************************************
7339 reads or writes a structure.
7340 ********************************************************************/
7342 BOOL samr_io_q_connect_anon(const char *desc, SAMR_Q_CONNECT_ANON * q_u,
7343 prs_struct *ps, int depth)
7345 if (q_u == NULL)
7346 return False;
7348 prs_debug(ps, depth, desc, "samr_io_q_connect_anon");
7349 depth++;
7351 if(!prs_align(ps))
7352 return False;
7354 if(!prs_uint32("ptr ", ps, depth, &q_u->ptr))
7355 return False;
7356 if (q_u->ptr) {
7357 if(!prs_uint16("unknown_0", ps, depth, &q_u->unknown_0))
7358 return False;
7360 if(!prs_align(ps))
7361 return False;
7362 if(!prs_uint32("access_mask", ps, depth, &q_u->access_mask))
7363 return False;
7365 return True;
7368 /*******************************************************************
7369 reads or writes a structure.
7370 ********************************************************************/
7372 BOOL samr_io_r_connect_anon(const char *desc, SAMR_R_CONNECT_ANON * r_u,
7373 prs_struct *ps, int depth)
7375 if (r_u == NULL)
7376 return False;
7378 prs_debug(ps, depth, desc, "samr_io_r_connect_anon");
7379 depth++;
7381 if(!prs_align(ps))
7382 return False;
7384 if(!smb_io_pol_hnd("connect_pol", &r_u->connect_pol, ps, depth))
7385 return False;
7387 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7388 return False;
7390 return True;
7393 /*******************************************************************
7394 inits a SAMR_Q_GET_DOM_PWINFO structure.
7395 ********************************************************************/
7397 void init_samr_q_get_dom_pwinfo(SAMR_Q_GET_DOM_PWINFO * q_u,
7398 char *srv_name)
7400 DEBUG(5, ("init_samr_q_get_dom_pwinfo\n"));
7402 q_u->ptr = 1;
7403 init_unistr2(&q_u->uni_srv_name, srv_name, UNI_FLAGS_NONE);
7404 init_uni_hdr(&q_u->hdr_srv_name, &q_u->uni_srv_name);
7407 /*******************************************************************
7408 reads or writes a structure.
7409 ********************************************************************/
7411 BOOL samr_io_q_get_dom_pwinfo(const char *desc, SAMR_Q_GET_DOM_PWINFO * q_u,
7412 prs_struct *ps, int depth)
7414 if (q_u == NULL)
7415 return False;
7417 prs_debug(ps, depth, desc, "samr_io_q_get_dom_pwinfo");
7418 depth++;
7420 if(!prs_align(ps))
7421 return False;
7423 if(!prs_uint32("ptr", ps, depth, &q_u->ptr))
7424 return False;
7425 if (q_u->ptr != 0) {
7426 if(!smb_io_unihdr("", &q_u->hdr_srv_name, ps, depth))
7427 return False;
7428 if(!smb_io_unistr2("", &q_u->uni_srv_name, q_u->hdr_srv_name.buffer, ps, depth))
7429 return False;
7432 return True;
7435 /*******************************************************************
7436 reads or writes a structure.
7437 ********************************************************************/
7439 BOOL samr_io_r_get_dom_pwinfo(const char *desc, SAMR_R_GET_DOM_PWINFO * r_u,
7440 prs_struct *ps, int depth)
7442 if (r_u == NULL)
7443 return False;
7445 prs_debug(ps, depth, desc, "samr_io_r_get_dom_pwinfo");
7446 depth++;
7448 if(!prs_align(ps))
7449 return False;
7451 if(!prs_uint16("min_pwd_length", ps, depth, &r_u->min_pwd_length))
7452 return False;
7453 if(!prs_align(ps))
7454 return False;
7455 if(!prs_uint32("password_properties", ps, depth, &r_u->password_properties))
7456 return False;
7458 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7459 return False;
7461 return True;
7464 /*******************************************************************
7465 make a SAMR_ENC_PASSWD structure.
7466 ********************************************************************/
7468 void init_enc_passwd(SAMR_ENC_PASSWD * pwd, const char pass[512])
7470 ZERO_STRUCTP(pwd);
7472 if (pass == NULL) {
7473 pwd->ptr = 0;
7474 } else {
7475 pwd->ptr = 1;
7476 memcpy(pwd->pass, pass, sizeof(pwd->pass));
7480 /*******************************************************************
7481 reads or writes a SAMR_ENC_PASSWD structure.
7482 ********************************************************************/
7484 BOOL samr_io_enc_passwd(const char *desc, SAMR_ENC_PASSWD * pwd,
7485 prs_struct *ps, int depth)
7487 if (pwd == NULL)
7488 return False;
7490 prs_debug(ps, depth, desc, "samr_io_enc_passwd");
7491 depth++;
7493 if(!prs_align(ps))
7494 return False;
7496 if(!prs_uint32("ptr", ps, depth, &pwd->ptr))
7497 return False;
7499 if (pwd->ptr != 0) {
7500 if(!prs_uint8s(False, "pwd", ps, depth, pwd->pass, sizeof(pwd->pass)))
7501 return False;
7504 return True;
7507 /*******************************************************************
7508 inits a SAMR_ENC_HASH structure.
7509 ********************************************************************/
7511 void init_enc_hash(SAMR_ENC_HASH * hsh, const uchar hash[16])
7513 ZERO_STRUCTP(hsh);
7515 if (hash == NULL) {
7516 hsh->ptr = 0;
7517 } else {
7518 hsh->ptr = 1;
7519 memcpy(hsh->hash, hash, sizeof(hsh->hash));
7523 /*******************************************************************
7524 reads or writes a SAMR_ENC_HASH structure.
7525 ********************************************************************/
7527 BOOL samr_io_enc_hash(const char *desc, SAMR_ENC_HASH * hsh,
7528 prs_struct *ps, int depth)
7530 if (hsh == NULL)
7531 return False;
7533 prs_debug(ps, depth, desc, "samr_io_enc_hash");
7534 depth++;
7536 if(!prs_align(ps))
7537 return False;
7539 if(!prs_uint32("ptr ", ps, depth, &hsh->ptr))
7540 return False;
7541 if (hsh->ptr != 0) {
7542 if(!prs_uint8s(False, "hash", ps, depth, hsh->hash,sizeof(hsh->hash)))
7543 return False;
7546 return True;
7549 /*******************************************************************
7550 inits a SAMR_Q_CHGPASSWD_USER structure.
7551 ********************************************************************/
7553 void init_samr_q_chgpasswd_user(SAMR_Q_CHGPASSWD_USER * q_u,
7554 const char *dest_host, const char *user_name,
7555 const uchar nt_newpass[516],
7556 const uchar nt_oldhash[16],
7557 const uchar lm_newpass[516],
7558 const uchar lm_oldhash[16])
7560 DEBUG(5, ("init_samr_q_chgpasswd_user\n"));
7562 q_u->ptr_0 = 1;
7563 init_unistr2(&q_u->uni_dest_host, dest_host, UNI_FLAGS_NONE);
7564 init_uni_hdr(&q_u->hdr_dest_host, &q_u->uni_dest_host);
7566 init_unistr2(&q_u->uni_user_name, user_name, UNI_FLAGS_NONE);
7567 init_uni_hdr(&q_u->hdr_user_name, &q_u->uni_user_name);
7569 init_enc_passwd(&q_u->nt_newpass, (const char *)nt_newpass);
7570 init_enc_hash(&q_u->nt_oldhash, nt_oldhash);
7572 q_u->unknown = 0x01;
7574 init_enc_passwd(&q_u->lm_newpass, (const char *)lm_newpass);
7575 init_enc_hash(&q_u->lm_oldhash, lm_oldhash);
7578 /*******************************************************************
7579 reads or writes a structure.
7580 ********************************************************************/
7582 BOOL samr_io_q_chgpasswd_user(const char *desc, SAMR_Q_CHGPASSWD_USER * q_u,
7583 prs_struct *ps, int depth)
7585 if (q_u == NULL)
7586 return False;
7588 prs_debug(ps, depth, desc, "samr_io_q_chgpasswd_user");
7589 depth++;
7591 if(!prs_align(ps))
7592 return False;
7594 if(!prs_uint32("ptr_0", ps, depth, &q_u->ptr_0))
7595 return False;
7597 if(!smb_io_unihdr("", &q_u->hdr_dest_host, ps, depth))
7598 return False;
7599 if(!smb_io_unistr2("", &q_u->uni_dest_host, q_u->hdr_dest_host.buffer, ps, depth))
7600 return False;
7602 if(!prs_align(ps))
7603 return False;
7604 if(!smb_io_unihdr("", &q_u->hdr_user_name, ps, depth))
7605 return False;
7606 if(!smb_io_unistr2("", &q_u->uni_user_name, q_u->hdr_user_name.buffer,ps, depth))
7607 return False;
7609 if(!samr_io_enc_passwd("nt_newpass", &q_u->nt_newpass, ps, depth))
7610 return False;
7611 if(!samr_io_enc_hash("nt_oldhash", &q_u->nt_oldhash, ps, depth))
7612 return False;
7614 if(!prs_uint32("unknown", ps, depth, &q_u->unknown))
7615 return False;
7617 if(!samr_io_enc_passwd("lm_newpass", &q_u->lm_newpass, ps, depth))
7618 return False;
7619 if(!samr_io_enc_hash("lm_oldhash", &q_u->lm_oldhash, ps, depth))
7620 return False;
7622 return True;
7625 /*******************************************************************
7626 inits a SAMR_R_CHGPASSWD_USER structure.
7627 ********************************************************************/
7629 void init_samr_r_chgpasswd_user(SAMR_R_CHGPASSWD_USER * r_u, NTSTATUS status)
7631 DEBUG(5, ("init_samr_r_chgpasswd_user\n"));
7633 r_u->status = status;
7636 /*******************************************************************
7637 reads or writes a structure.
7638 ********************************************************************/
7640 BOOL samr_io_r_chgpasswd_user(const char *desc, SAMR_R_CHGPASSWD_USER * r_u,
7641 prs_struct *ps, int depth)
7643 if (r_u == NULL)
7644 return False;
7646 prs_debug(ps, depth, desc, "samr_io_r_chgpasswd_user");
7647 depth++;
7649 if(!prs_align(ps))
7650 return False;
7652 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7653 return False;
7655 return True;
7658 /*******************************************************************
7659 inits a SAMR_Q_CHGPASSWD3 structure.
7660 ********************************************************************/
7662 void init_samr_q_chgpasswd_user3(SAMR_Q_CHGPASSWD_USER3 * q_u,
7663 const char *dest_host, const char *user_name,
7664 const uchar nt_newpass[516],
7665 const uchar nt_oldhash[16],
7666 const uchar lm_newpass[516],
7667 const uchar lm_oldhash[16])
7669 DEBUG(5, ("init_samr_q_chgpasswd_user3\n"));
7671 q_u->ptr_0 = 1;
7672 init_unistr2(&q_u->uni_dest_host, dest_host, UNI_FLAGS_NONE);
7673 init_uni_hdr(&q_u->hdr_dest_host, &q_u->uni_dest_host);
7675 init_unistr2(&q_u->uni_user_name, user_name, UNI_FLAGS_NONE);
7676 init_uni_hdr(&q_u->hdr_user_name, &q_u->uni_user_name);
7678 init_enc_passwd(&q_u->nt_newpass, (const char *)nt_newpass);
7679 init_enc_hash(&q_u->nt_oldhash, nt_oldhash);
7681 q_u->lm_change = 0x01;
7683 init_enc_passwd(&q_u->lm_newpass, (const char *)lm_newpass);
7684 init_enc_hash(&q_u->lm_oldhash, lm_oldhash);
7686 init_enc_passwd(&q_u->password3, NULL);
7689 /*******************************************************************
7690 reads or writes a structure.
7691 ********************************************************************/
7693 BOOL samr_io_q_chgpasswd_user3(const char *desc, SAMR_Q_CHGPASSWD_USER3 * q_u,
7694 prs_struct *ps, int depth)
7696 if (q_u == NULL)
7697 return False;
7699 prs_debug(ps, depth, desc, "samr_io_q_chgpasswd_user3");
7700 depth++;
7702 if(!prs_align(ps))
7703 return False;
7705 if(!prs_uint32("ptr_0", ps, depth, &q_u->ptr_0))
7706 return False;
7708 if(!smb_io_unihdr("", &q_u->hdr_dest_host, ps, depth))
7709 return False;
7710 if(!smb_io_unistr2("", &q_u->uni_dest_host, q_u->hdr_dest_host.buffer, ps, depth))
7711 return False;
7713 if(!prs_align(ps))
7714 return False;
7715 if(!smb_io_unihdr("", &q_u->hdr_user_name, ps, depth))
7716 return False;
7717 if(!smb_io_unistr2("", &q_u->uni_user_name, q_u->hdr_user_name.buffer,ps, depth))
7718 return False;
7720 if(!samr_io_enc_passwd("nt_newpass", &q_u->nt_newpass, ps, depth))
7721 return False;
7722 if(!samr_io_enc_hash("nt_oldhash", &q_u->nt_oldhash, ps, depth))
7723 return False;
7725 if(!prs_uint32("lm_change", ps, depth, &q_u->lm_change))
7726 return False;
7728 if(!samr_io_enc_passwd("lm_newpass", &q_u->lm_newpass, ps, depth))
7729 return False;
7730 if(!samr_io_enc_hash("lm_oldhash", &q_u->lm_oldhash, ps, depth))
7731 return False;
7733 if(!samr_io_enc_passwd("password3", &q_u->password3, ps, depth))
7734 return False;
7736 return True;
7739 /*******************************************************************
7740 inits a SAMR_R_CHGPASSWD_USER3 structure.
7741 ********************************************************************/
7743 void init_samr_r_chgpasswd_user3(SAMR_R_CHGPASSWD_USER3 *r_u, NTSTATUS status,
7744 SAMR_CHANGE_REJECT *reject, SAM_UNK_INFO_1 *info)
7746 DEBUG(5, ("init_samr_r_chgpasswd_user3\n"));
7748 r_u->status = status;
7749 r_u->info = 0;
7750 r_u->ptr_info = 0;
7751 r_u->reject = 0;
7752 r_u->ptr_reject = 0;
7754 if (info) {
7755 r_u->info = info;
7756 r_u->ptr_info = 1;
7758 if (reject && (reject->reject_reason != Undefined)) {
7759 r_u->reject = reject;
7760 r_u->ptr_reject = 1;
7764 /*******************************************************************
7765 Reads or writes an SAMR_CHANGE_REJECT structure.
7766 ********************************************************************/
7768 BOOL samr_io_change_reject(const char *desc, SAMR_CHANGE_REJECT *reject, prs_struct *ps, int depth)
7770 if (reject == NULL)
7771 return False;
7773 prs_debug(ps, depth, desc, "samr_io_change_reject");
7774 depth++;
7776 if(!prs_align(ps))
7777 return False;
7779 if(UNMARSHALLING(ps))
7780 ZERO_STRUCTP(reject);
7782 if (!prs_uint32("reject_reason", ps, depth, &reject->reject_reason))
7783 return False;
7785 if (!prs_uint32("unknown1", ps, depth, &reject->unknown1))
7786 return False;
7788 if (!prs_uint32("unknown2", ps, depth, &reject->unknown2))
7789 return False;
7791 return True;
7794 /*******************************************************************
7795 reads or writes a structure.
7796 ********************************************************************/
7798 BOOL samr_io_r_chgpasswd_user3(const char *desc, SAMR_R_CHGPASSWD_USER3 *r_u,
7799 prs_struct *ps, int depth)
7801 if (r_u == NULL)
7802 return False;
7804 prs_debug(ps, depth, desc, "samr_io_r_chgpasswd_user3");
7805 depth++;
7807 if (!prs_align(ps))
7808 return False;
7810 if (!prs_uint32("ptr_info", ps, depth, &r_u->ptr_info))
7811 return False;
7813 /* special case: Windows 2000 can return stub data here saying
7814 NT_STATUS_NOT_SUPPORTED */
7816 if ( NT_STATUS_EQUAL( NT_STATUS_NOT_SUPPORTED, NT_STATUS(r_u->ptr_info)) ) {
7817 r_u->status = NT_STATUS_NOT_SUPPORTED;
7818 return True;
7821 if (r_u->ptr_info && r_u->info != NULL) {
7822 /* SAM_UNK_INFO_1 */
7823 if (!sam_io_unk_info1("info", r_u->info, ps, depth))
7824 return False;
7827 if (!prs_uint32("ptr_reject", ps, depth, &r_u->ptr_reject))
7828 return False;
7830 if (r_u->ptr_reject && r_u->reject != NULL) {
7831 /* SAMR_CHANGE_REJECT */
7832 if (!samr_io_change_reject("reject", r_u->reject, ps, depth))
7833 return False;
7836 if (!prs_ntstatus("status", ps, depth, &r_u->status))
7837 return False;
7839 return True;
7842 /*******************************************************************
7843 reads or writes a structure.
7844 ********************************************************************/
7846 void init_samr_q_query_domain_info2(SAMR_Q_QUERY_DOMAIN_INFO2 *q_u,
7847 POLICY_HND *domain_pol, uint16 switch_value)
7849 DEBUG(5, ("init_samr_q_query_domain_info2\n"));
7851 q_u->domain_pol = *domain_pol;
7852 q_u->switch_value = switch_value;
7855 /*******************************************************************
7856 reads or writes a structure.
7857 ********************************************************************/
7859 BOOL samr_io_q_query_domain_info2(const char *desc, SAMR_Q_QUERY_DOMAIN_INFO2 *q_u,
7860 prs_struct *ps, int depth)
7862 if (q_u == NULL)
7863 return False;
7865 prs_debug(ps, depth, desc, "samr_io_q_query_domain_info2");
7866 depth++;
7868 if(!prs_align(ps))
7869 return False;
7871 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
7872 return False;
7874 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value))
7875 return False;
7877 return True;
7880 /*******************************************************************
7881 inits a SAMR_R_QUERY_DOMAIN_INFO structure.
7882 ********************************************************************/
7884 void init_samr_r_query_domain_info2(SAMR_R_QUERY_DOMAIN_INFO2 * r_u,
7885 uint16 switch_value, SAM_UNK_CTR * ctr,
7886 NTSTATUS status)
7888 DEBUG(5, ("init_samr_r_query_domain_info2\n"));
7890 r_u->ptr_0 = 0;
7891 r_u->switch_value = 0;
7892 r_u->status = status; /* return status */
7894 if (NT_STATUS_IS_OK(status)) {
7895 r_u->switch_value = switch_value;
7896 r_u->ptr_0 = 1;
7897 r_u->ctr = ctr;
7901 /*******************************************************************
7902 reads or writes a structure.
7903 ********************************************************************/
7905 BOOL samr_io_r_query_domain_info2(const char *desc, SAMR_R_QUERY_DOMAIN_INFO2 * r_u,
7906 prs_struct *ps, int depth)
7908 if (r_u == NULL)
7909 return False;
7911 prs_debug(ps, depth, desc, "samr_io_r_query_domain_info2");
7912 depth++;
7914 if(!prs_align(ps))
7915 return False;
7917 if(!prs_uint32("ptr_0 ", ps, depth, &r_u->ptr_0))
7918 return False;
7920 if (r_u->ptr_0 != 0 && r_u->ctr != NULL) {
7921 if(!prs_uint16("switch_value", ps, depth, &r_u->switch_value))
7922 return False;
7923 if(!prs_align(ps))
7924 return False;
7926 switch (r_u->switch_value) {
7927 case 0x0d:
7928 if(!sam_io_unk_info13("unk_inf13", &r_u->ctr->info.inf13, ps, depth))
7929 return False;
7930 break;
7931 case 0x0c:
7932 if(!sam_io_unk_info12("unk_inf12", &r_u->ctr->info.inf12, ps, depth))
7933 return False;
7934 break;
7935 case 0x09:
7936 if(!sam_io_unk_info9("unk_inf9",&r_u->ctr->info.inf9, ps,depth))
7937 return False;
7938 break;
7939 case 0x08:
7940 if(!sam_io_unk_info8("unk_inf8",&r_u->ctr->info.inf8, ps,depth))
7941 return False;
7942 break;
7943 case 0x07:
7944 if(!sam_io_unk_info7("unk_inf7",&r_u->ctr->info.inf7, ps,depth))
7945 return False;
7946 break;
7947 case 0x06:
7948 if(!sam_io_unk_info6("unk_inf6",&r_u->ctr->info.inf6, ps,depth))
7949 return False;
7950 break;
7951 case 0x05:
7952 if(!sam_io_unk_info5("unk_inf5",&r_u->ctr->info.inf5, ps,depth))
7953 return False;
7954 break;
7955 case 0x04:
7956 if(!sam_io_unk_info4("unk_inf4",&r_u->ctr->info.inf4, ps,depth))
7957 return False;
7958 break;
7959 case 0x03:
7960 if(!sam_io_unk_info3("unk_inf3",&r_u->ctr->info.inf3, ps,depth))
7961 return False;
7962 break;
7963 case 0x02:
7964 if(!sam_io_unk_info2("unk_inf2",&r_u->ctr->info.inf2, ps,depth))
7965 return False;
7966 break;
7967 case 0x01:
7968 if(!sam_io_unk_info1("unk_inf1",&r_u->ctr->info.inf1, ps,depth))
7969 return False;
7970 break;
7971 default:
7972 DEBUG(0, ("samr_io_r_query_domain_info2: unknown switch level 0x%x\n",
7973 r_u->switch_value));
7974 r_u->status = NT_STATUS_INVALID_INFO_CLASS;
7975 return False;
7979 if(!prs_align(ps))
7980 return False;
7982 if(!prs_ntstatus("status", ps, depth, &r_u->status))
7983 return False;
7985 return True;
7989 /*******************************************************************
7990 reads or writes a structure.
7991 ********************************************************************/
7993 void init_samr_q_set_domain_info(SAMR_Q_SET_DOMAIN_INFO *q_u,
7994 POLICY_HND *domain_pol, uint16 switch_value, SAM_UNK_CTR *ctr)
7996 DEBUG(5, ("init_samr_q_set_domain_info\n"));
7998 q_u->domain_pol = *domain_pol;
7999 q_u->switch_value0 = switch_value;
8001 q_u->switch_value = switch_value;
8002 q_u->ctr = ctr;
8006 /*******************************************************************
8007 reads or writes a structure.
8008 ********************************************************************/
8010 BOOL samr_io_q_set_domain_info(const char *desc, SAMR_Q_SET_DOMAIN_INFO *q_u,
8011 prs_struct *ps, int depth)
8013 if (q_u == NULL)
8014 return False;
8016 prs_debug(ps, depth, desc, "samr_io_q_set_domain_info");
8017 depth++;
8019 if(!prs_align(ps))
8020 return False;
8022 if(!smb_io_pol_hnd("domain_pol", &q_u->domain_pol, ps, depth))
8023 return False;
8025 if(!prs_uint16("switch_value0", ps, depth, &q_u->switch_value0))
8026 return False;
8028 if(!prs_uint16("switch_value", ps, depth, &q_u->switch_value))
8029 return False;
8031 if(!prs_align(ps))
8032 return False;
8034 if (UNMARSHALLING(ps)) {
8035 if ((q_u->ctr = PRS_ALLOC_MEM(ps, SAM_UNK_CTR, 1)) == NULL)
8036 return False;
8039 switch (q_u->switch_value) {
8041 case 0x0c:
8042 if(!sam_io_unk_info12("unk_inf12", &q_u->ctr->info.inf12, ps, depth))
8043 return False;
8044 break;
8045 case 0x07:
8046 if(!sam_io_unk_info7("unk_inf7",&q_u->ctr->info.inf7, ps,depth))
8047 return False;
8048 break;
8049 case 0x06:
8050 if(!sam_io_unk_info6("unk_inf6",&q_u->ctr->info.inf6, ps,depth))
8051 return False;
8052 break;
8053 case 0x05:
8054 if(!sam_io_unk_info5("unk_inf5",&q_u->ctr->info.inf5, ps,depth))
8055 return False;
8056 break;
8057 case 0x03:
8058 if(!sam_io_unk_info3("unk_inf3",&q_u->ctr->info.inf3, ps,depth))
8059 return False;
8060 break;
8061 case 0x02:
8062 if(!sam_io_unk_info2("unk_inf2",&q_u->ctr->info.inf2, ps,depth))
8063 return False;
8064 break;
8065 case 0x01:
8066 if(!sam_io_unk_info1("unk_inf1",&q_u->ctr->info.inf1, ps,depth))
8067 return False;
8068 break;
8069 default:
8070 DEBUG(0, ("samr_io_r_samr_unknown_2e: unknown switch level 0x%x\n",
8071 q_u->switch_value));
8072 return False;
8075 return True;
8078 /*******************************************************************
8079 inits a SAMR_R_QUERY_DOMAIN_INFO structure.
8080 ********************************************************************/
8082 void init_samr_r_set_domain_info(SAMR_R_SET_DOMAIN_INFO * r_u, NTSTATUS status)
8084 DEBUG(5, ("init_samr_r_set_domain_info\n"));
8086 r_u->status = status; /* return status */
8089 /*******************************************************************
8090 reads or writes a structure.
8091 ********************************************************************/
8093 BOOL samr_io_r_set_domain_info(const char *desc, SAMR_R_SET_DOMAIN_INFO * r_u,
8094 prs_struct *ps, int depth)
8096 if (r_u == NULL)
8097 return False;
8099 prs_debug(ps, depth, desc, "samr_io_r_samr_unknown_2e");
8100 depth++;
8102 if(!prs_align(ps))
8103 return False;
8105 if(!prs_ntstatus("status", ps, depth, &r_u->status))
8106 return False;
8108 return True;