2 Unix SMB/Netbios implementation.
4 NT Domain Authentication SMB / MSRPC client
5 Copyright (C) Andrew Tridgell 1994-1997
6 Copyright (C) Luke Kenneth Casson Leighton 1996-1997
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
32 extern int DEBUGLEVEL;
36 /****************************************************************************
37 do a SAMR create domain alias
38 ****************************************************************************/
39 BOOL create_samr_domain_alias(struct cli_state *cli,
40 POLICY_HND *pol_open_domain,
41 const char *acct_name, const char *acct_desc,
44 POLICY_HND pol_open_alias;
46 if (pol_open_domain == NULL || acct_name == NULL || acct_desc == NULL) return False;
48 /* send create alias */
49 if (!samr_create_dom_alias(cli,
52 &pol_open_alias, rid))
57 DEBUG(5,("create_samr_domain_alias: name: %s rid 0x%x\n",
60 ctr.switch_value1 = 3;
61 make_samr_alias_info3(&ctr.alias.info3, acct_desc);
63 /* send set alias info */
64 if (!samr_set_aliasinfo(cli,
68 DEBUG(5,("create_samr_domain_alias: error in samr_set_aliasinfo\n"));
71 return samr_close(cli, &pol_open_alias);
74 /****************************************************************************
75 do a SAMR create domain group
76 ****************************************************************************/
77 BOOL create_samr_domain_group(struct cli_state *cli,
78 POLICY_HND *pol_open_domain,
79 const char *acct_name, const char *acct_desc,
82 POLICY_HND pol_open_group;
84 if (pol_open_domain == NULL || acct_name == NULL || acct_desc == NULL) return False;
86 /* send create group*/
87 if (!samr_create_dom_group(cli,
90 &pol_open_group, rid))
95 DEBUG(5,("create_samr_domain_group: name: %s rid 0x%x\n",
98 ctr.switch_value1 = 4;
99 ctr.switch_value2 = 4;
100 make_samr_group_info4(&ctr.group.info4, acct_desc);
102 /* send user groups query */
103 if (!samr_set_groupinfo(cli,
107 DEBUG(5,("create_samr_domain_group: error in samr_set_groupinfo\n"));
110 return samr_close(cli, &pol_open_group);
113 /****************************************************************************
114 do a SAMR query user groups
115 ****************************************************************************/
116 BOOL get_samr_query_usergroups(struct cli_state *cli,
117 POLICY_HND *pol_open_domain, uint32 user_rid,
118 uint32 *num_groups, DOM_GID *gid)
120 POLICY_HND pol_open_user;
121 if (pol_open_domain == NULL || num_groups == NULL || gid == NULL) return False;
123 /* send open domain (on user sid) */
124 if (!samr_open_user(cli,
132 /* send user groups query */
133 if (!samr_query_usergroups(cli,
137 DEBUG(5,("samr_query_usergroups: error in query user groups\n"));
140 return samr_close(cli, &pol_open_user);
143 /****************************************************************************
144 do a SAMR query user info
145 ****************************************************************************/
146 BOOL get_samr_query_userinfo(struct cli_state *cli,
147 POLICY_HND *pol_open_domain,
149 uint32 user_rid, SAM_USER_INFO_21 *usr)
151 POLICY_HND pol_open_user;
152 if (pol_open_domain == NULL || usr == NULL) return False;
154 bzero(usr, sizeof(*usr));
156 /* send open domain (on user sid) */
157 if (!samr_open_user(cli,
165 /* send user info query */
166 if (!samr_query_userinfo(cli,
168 info_level, (void*)usr))
170 DEBUG(5,("samr_query_userinfo: error in query user info, level 0x%x\n",
174 return samr_close(cli, &pol_open_user);
177 /****************************************************************************
178 do a SAMR change user password command
179 ****************************************************************************/
180 BOOL samr_chgpasswd_user(struct cli_state *cli,
181 char *srv_name, char *user_name,
182 char nt_newpass[516], uchar nt_oldhash[16],
183 char lm_newpass[516], uchar lm_oldhash[16])
188 SAMR_Q_CHGPASSWD_USER q_e;
189 BOOL valid_pwc = False;
191 /* create and send a MSRPC command with api SAMR_CHGPASSWD_USER */
193 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
194 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
196 DEBUG(4,("SAMR Change User Password. server:%s username:%s\n",
197 srv_name, user_name));
199 make_samr_q_chgpasswd_user(&q_e, srv_name, user_name,
200 nt_newpass, nt_oldhash,
201 lm_newpass, lm_oldhash);
203 /* turn parameters into data stream */
204 samr_io_q_chgpasswd_user("", &q_e, &data, 0);
206 /* send the data on \PIPE\ */
207 if (rpc_api_pipe_req(cli, SAMR_CHGPASSWD_USER, &data, &rdata))
209 SAMR_R_CHGPASSWD_USER r_e;
212 samr_io_r_chgpasswd_user("", &r_e, &rdata, 0);
214 p = rdata.offset != 0;
215 if (p && r_e.status != 0)
217 /* report error code */
218 DEBUG(0,("SAMR_R_CHGPASSWD_USER: %s\n", get_nt_error_msg(r_e.status)));
228 prs_mem_free(&data );
229 prs_mem_free(&rdata );
234 /****************************************************************************
235 do a SAMR unknown 0x38 command
236 ****************************************************************************/
237 BOOL samr_unknown_38(struct cli_state *cli, char *srv_name)
242 SAMR_Q_UNKNOWN_38 q_e;
243 BOOL valid_un8 = False;
245 /* create and send a MSRPC command with api SAMR_ENUM_DOM_USERS */
247 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
248 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
250 DEBUG(4,("SAMR Unknown 38 server:%s\n", srv_name));
252 make_samr_q_unknown_38(&q_e, srv_name);
254 /* turn parameters into data stream */
255 samr_io_q_unknown_38("", &q_e, &data, 0);
257 /* send the data on \PIPE\ */
258 if (rpc_api_pipe_req(cli, SAMR_UNKNOWN_38, &data, &rdata))
260 SAMR_R_UNKNOWN_38 r_e;
263 samr_io_r_unknown_38("", &r_e, &rdata, 0);
265 p = rdata.offset != 0;
267 if (p && r_e.status != 0)
269 /* report error code */
270 DEBUG(0,("SAMR_R_UNKNOWN_38: %s\n", get_nt_error_msg(r_e.status)));
280 prs_mem_free(&data );
281 prs_mem_free(&rdata );
286 /****************************************************************************
287 do a SAMR unknown 0x8 command
288 ****************************************************************************/
289 BOOL samr_query_dom_info(struct cli_state *cli,
290 POLICY_HND *domain_pol, uint16 switch_value)
295 SAMR_Q_QUERY_DOMAIN_INFO q_e;
296 BOOL valid_un8 = False;
298 DEBUG(4,("SAMR Unknown 8 switch:%d\n", switch_value));
300 if (domain_pol == NULL) return False;
302 /* create and send a MSRPC command with api SAMR_ENUM_DOM_USERS */
304 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
305 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
307 /* store the parameters */
308 make_samr_q_query_dom_info(&q_e, domain_pol, switch_value);
310 /* turn parameters into data stream */
311 samr_io_q_query_dom_info("", &q_e, &data, 0);
313 /* send the data on \PIPE\ */
314 if (rpc_api_pipe_req(cli, SAMR_QUERY_DOMAIN_INFO, &data, &rdata))
317 SAMR_R_QUERY_DOMAIN_INFO r_e;
320 samr_io_r_query_dom_info("", &r_e, &rdata, 0);
322 p = rdata.offset != 0;
323 if (p && r_e.status != 0)
325 /* report error code */
326 DEBUG(0,("SAMR_R_QUERY_DOMAIN_INFO: %s\n", get_nt_error_msg(r_e.status)));
337 prs_mem_free(&data );
338 prs_mem_free(&rdata );
343 /****************************************************************************
344 do a SAMR enumerate users
345 ****************************************************************************/
346 BOOL samr_enum_dom_users(struct cli_state *cli,
347 POLICY_HND *pol, uint16 num_entries, uint16 unk_0,
348 uint16 acb_mask, uint16 unk_1, uint32 size,
349 struct acct_info **sam,
355 SAMR_Q_ENUM_DOM_USERS q_e;
356 BOOL valid_pol = False;
358 DEBUG(4,("SAMR Enum SAM DB max size:%x\n", size));
360 if (pol == NULL || num_sam_users == NULL) return False;
362 /* create and send a MSRPC command with api SAMR_ENUM_DOM_USERS */
364 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
365 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
367 /* store the parameters */
368 make_samr_q_enum_dom_users(&q_e, pol,
370 acb_mask, unk_1, size);
372 /* turn parameters into data stream */
373 samr_io_q_enum_dom_users("", &q_e, &data, 0);
375 /* send the data on \PIPE\ */
376 if (rpc_api_pipe_req(cli, SAMR_ENUM_DOM_USERS, &data, &rdata))
378 SAMR_R_ENUM_DOM_USERS r_e;
381 samr_io_r_enum_dom_users("", &r_e, &rdata, 0);
383 p = rdata.offset != 0;
384 if (p && r_e.status != 0)
386 /* report error code */
387 DEBUG(0,("SAMR_R_ENUM_DOM_USERS: %s\n", get_nt_error_msg(r_e.status)));
396 *num_sam_users = r_e.num_entries2;
397 if (*num_sam_users > MAX_SAM_ENTRIES)
399 *num_sam_users = MAX_SAM_ENTRIES;
400 DEBUG(2,("samr_enum_dom_users: sam user entries limited to %d\n",
404 *sam = (struct acct_info*) malloc(sizeof(struct acct_info) * (*num_sam_users));
411 for (i = 0; i < *num_sam_users; i++)
414 (*sam)[i].user_rid = r_e.sam[i].rid;
415 if (r_e.sam[i].hdr_name.buffer)
417 char *acct_name = unistrn2(r_e.uni_acct_name[name_idx].buffer,
418 r_e.uni_acct_name[name_idx].uni_str_len);
419 fstrcpy((*sam)[i].acct_name, acct_name);
424 bzero((*sam)[i].acct_name, sizeof((*sam)[i].acct_name));
426 DEBUG(5,("samr_enum_dom_users: idx: %4d rid: %8x acct: %s\n",
427 i, (*sam)[i].user_rid, (*sam)[i].acct_name));
433 prs_mem_free(&data );
434 prs_mem_free(&rdata );
439 /****************************************************************************
441 ****************************************************************************/
442 BOOL samr_connect(struct cli_state *cli,
443 char *srv_name, uint32 unknown_0,
444 POLICY_HND *connect_pol)
450 BOOL valid_pol = False;
452 DEBUG(4,("SAMR Open Policy server:%s undoc value:%x\n",
453 srv_name, unknown_0));
455 if (srv_name == NULL || connect_pol == NULL) return False;
457 /* create and send a MSRPC command with api SAMR_CONNECT */
459 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
460 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
462 /* store the parameters */
463 make_samr_q_connect(&q_o, srv_name, unknown_0);
465 /* turn parameters into data stream */
466 samr_io_q_connect("", &q_o, &data, 0);
468 /* send the data on \PIPE\ */
469 if (rpc_api_pipe_req(cli, SAMR_CONNECT, &data, &rdata))
474 samr_io_r_connect("", &r_o, &rdata, 0);
475 p = rdata.offset != 0;
477 if (p && r_o.status != 0)
479 /* report error code */
480 DEBUG(0,("SAMR_R_CONNECT: %s\n", get_nt_error_msg(r_o.status)));
486 memcpy(connect_pol, &r_o.connect_pol, sizeof(r_o.connect_pol));
491 prs_mem_free(&data );
492 prs_mem_free(&rdata );
497 /****************************************************************************
499 ****************************************************************************/
500 BOOL samr_open_user(struct cli_state *cli,
501 POLICY_HND *pol, uint32 unk_0, uint32 rid,
502 POLICY_HND *user_pol)
507 SAMR_Q_OPEN_USER q_o;
508 BOOL valid_pol = False;
510 DEBUG(4,("SAMR Open User. unk_0: %08x RID:%x\n",
513 if (pol == NULL || user_pol == NULL) return False;
515 /* create and send a MSRPC command with api SAMR_OPEN_USER */
517 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
518 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
520 /* store the parameters */
521 make_samr_q_open_user(&q_o, pol, unk_0, rid);
523 /* turn parameters into data stream */
524 samr_io_q_open_user("", &q_o, &data, 0);
526 /* send the data on \PIPE\ */
527 if (rpc_api_pipe_req(cli, SAMR_OPEN_USER, &data, &rdata))
529 SAMR_R_OPEN_USER r_o;
532 samr_io_r_open_user("", &r_o, &rdata, 0);
533 p = rdata.offset != 0;
535 if (p && r_o.status != 0)
537 /* report error code */
538 DEBUG(0,("SAMR_R_OPEN_USER: %s\n", get_nt_error_msg(r_o.status)));
544 memcpy(user_pol, &r_o.user_pol, sizeof(r_o.user_pol));
549 prs_mem_free(&data );
550 prs_mem_free(&rdata );
555 /****************************************************************************
557 ****************************************************************************/
558 BOOL samr_open_alias(struct cli_state *cli,
559 POLICY_HND *domain_pol, uint32 rid,
560 POLICY_HND *alias_pol)
565 SAMR_Q_OPEN_ALIAS q_o;
566 BOOL valid_pol = False;
568 DEBUG(4,("SAMR Open Alias. RID:%x\n", rid));
570 if (alias_pol == NULL || domain_pol == NULL) return False;
572 /* create and send a MSRPC command with api SAMR_OPEN_ALIAS */
574 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
575 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
577 /* store the parameters */
578 make_samr_q_open_alias(&q_o, domain_pol, 0x0008, rid);
580 /* turn parameters into data stream */
581 samr_io_q_open_alias("", &q_o, &data, 0);
583 /* send the data on \PIPE\ */
584 if (rpc_api_pipe_req(cli, SAMR_OPEN_ALIAS, &data, &rdata))
586 SAMR_R_OPEN_ALIAS r_o;
589 samr_io_r_open_alias("", &r_o, &rdata, 0);
590 p = rdata.offset != 0;
592 if (p && r_o.status != 0)
594 /* report error code */
595 DEBUG(0,("SAMR_R_OPEN_ALIAS: %s\n", get_nt_error_msg(r_o.status)));
601 memcpy(alias_pol, &r_o.pol, sizeof(r_o.pol));
606 prs_mem_free(&data );
607 prs_mem_free(&rdata );
612 /****************************************************************************
613 do a SAMR Create Domain Alias
614 ****************************************************************************/
615 BOOL samr_create_dom_alias(struct cli_state *cli,
616 POLICY_HND *domain_pol, const char *acct_name,
617 POLICY_HND *alias_pol, uint32 *rid)
622 SAMR_Q_CREATE_DOM_ALIAS q_o;
623 BOOL valid_pol = False;
625 if (alias_pol == NULL || domain_pol == NULL || acct_name == NULL || rid == NULL) return False;
627 /* create and send a MSRPC command with api SAMR_CREATE_DOM_ALIAS */
629 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
630 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
632 DEBUG(4,("SAMR Create Domain Alias. Name:%s\n", acct_name));
634 /* store the parameters */
635 make_samr_q_create_dom_alias(&q_o, domain_pol, acct_name);
637 /* turn parameters into data stream */
638 samr_io_q_create_dom_alias("", &q_o, &data, 0);
640 /* send the data on \PIPE\ */
641 if (rpc_api_pipe_req(cli, SAMR_CREATE_DOM_ALIAS, &data, &rdata))
643 SAMR_R_CREATE_DOM_ALIAS r_o;
646 samr_io_r_create_dom_alias("", &r_o, &rdata, 0);
647 p = rdata.offset != 0;
649 if (p && r_o.status != 0)
651 /* report error code */
652 DEBUG(0,("SAMR_R_CREATE_DOM_ALIAS: %s\n", get_nt_error_msg(r_o.status)));
658 memcpy(alias_pol, &r_o.alias_pol, sizeof(r_o.alias_pol));
664 prs_mem_free(&data );
665 prs_mem_free(&rdata );
670 /****************************************************************************
671 do a SAMR Set Alias Info
672 ****************************************************************************/
673 BOOL samr_set_aliasinfo(struct cli_state *cli,
674 POLICY_HND *alias_pol, ALIAS_INFO_CTR *ctr)
679 SAMR_Q_SET_ALIASINFO q_o;
680 BOOL valid_pol = False;
682 if (alias_pol == NULL || ctr == NULL) return False;
684 /* create and send a MSRPC command with api SAMR_SET_ALIASINFO */
686 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
687 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
689 DEBUG(4,("SAMR Set Alias Info\n"));
691 /* store the parameters */
692 make_samr_q_set_aliasinfo(&q_o, alias_pol, ctr);
694 /* turn parameters into data stream */
695 samr_io_q_set_aliasinfo("", &q_o, &data, 0);
697 /* send the data on \PIPE\ */
698 if (rpc_api_pipe_req(cli, SAMR_SET_ALIASINFO, &data, &rdata))
700 SAMR_R_SET_ALIASINFO r_o;
703 samr_io_r_set_aliasinfo("", &r_o, &rdata, 0);
704 p = rdata.offset != 0;
706 if (p && r_o.status != 0)
708 /* report error code */
709 DEBUG(0,("SAMR_R_SET_ALIASINFO: %s\n", get_nt_error_msg(r_o.status)));
719 prs_mem_free(&data );
720 prs_mem_free(&rdata );
725 /****************************************************************************
727 ****************************************************************************/
728 BOOL samr_open_group(struct cli_state *cli,
729 POLICY_HND *domain_pol, uint32 rid,
730 POLICY_HND *group_pol)
735 SAMR_Q_OPEN_GROUP q_o;
736 BOOL valid_pol = False;
738 DEBUG(4,("SAMR Open Group. RID:%x\n", rid));
740 if (group_pol == NULL || domain_pol == NULL) return False;
742 /* create and send a MSRPC command with api SAMR_OPEN_GROUP */
744 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
745 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
747 /* store the parameters */
748 make_samr_q_open_group(&q_o, domain_pol, 0x0001, rid);
750 /* turn parameters into data stream */
751 samr_io_q_open_group("", &q_o, &data, 0);
753 /* send the data on \PIPE\ */
754 if (rpc_api_pipe_req(cli, SAMR_OPEN_GROUP, &data, &rdata))
756 SAMR_R_OPEN_GROUP r_o;
759 samr_io_r_open_group("", &r_o, &rdata, 0);
760 p = rdata.offset != 0;
762 if (p && r_o.status != 0)
764 /* report error code */
765 DEBUG(0,("SAMR_R_OPEN_GROUP: %s\n", get_nt_error_msg(r_o.status)));
771 memcpy(group_pol, &r_o.pol, sizeof(r_o.pol));
776 prs_mem_free(&data );
777 prs_mem_free(&rdata );
782 /****************************************************************************
783 do a SAMR Create Domain Group
784 ****************************************************************************/
785 BOOL samr_create_dom_group(struct cli_state *cli,
786 POLICY_HND *domain_pol, const char *acct_name,
787 POLICY_HND *group_pol, uint32 *rid)
792 SAMR_Q_CREATE_DOM_GROUP q_o;
793 BOOL valid_pol = False;
795 if (group_pol == NULL || domain_pol == NULL || acct_name == NULL || rid == NULL) return False;
797 /* create and send a MSRPC command with api SAMR_CREATE_DOM_GROUP */
799 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
800 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
802 DEBUG(4,("SAMR Create Domain Group. Name:%s\n", acct_name));
804 /* store the parameters */
805 make_samr_q_create_dom_group(&q_o, domain_pol, acct_name);
807 /* turn parameters into data stream */
808 samr_io_q_create_dom_group("", &q_o, &data, 0);
810 /* send the data on \PIPE\ */
811 if (rpc_api_pipe_req(cli, SAMR_CREATE_DOM_GROUP, &data, &rdata))
813 SAMR_R_CREATE_DOM_GROUP r_o;
816 samr_io_r_create_dom_group("", &r_o, &rdata, 0);
817 p = rdata.offset != 0;
819 if (p && r_o.status != 0)
821 /* report error code */
822 DEBUG(0,("SAMR_R_CREATE_DOM_GROUP: %s\n", get_nt_error_msg(r_o.status)));
828 memcpy(group_pol, &r_o.pol, sizeof(r_o.pol));
834 prs_mem_free(&data );
835 prs_mem_free(&rdata );
840 /****************************************************************************
841 do a SAMR Set Group Info
842 ****************************************************************************/
843 BOOL samr_set_groupinfo(struct cli_state *cli,
844 POLICY_HND *group_pol, GROUP_INFO_CTR *ctr)
849 SAMR_Q_SET_GROUPINFO q_o;
850 BOOL valid_pol = False;
852 if (group_pol == NULL || ctr == NULL) return False;
854 /* create and send a MSRPC command with api SAMR_SET_GROUPINFO */
856 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
857 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
859 DEBUG(4,("SAMR Set Group Info\n"));
861 /* store the parameters */
862 make_samr_q_set_groupinfo(&q_o, group_pol, ctr);
864 /* turn parameters into data stream */
865 samr_io_q_set_groupinfo("", &q_o, &data, 0);
867 /* send the data on \PIPE\ */
868 if (rpc_api_pipe_req(cli, SAMR_SET_GROUPINFO, &data, &rdata))
870 SAMR_R_SET_GROUPINFO r_o;
873 samr_io_r_set_groupinfo("", &r_o, &rdata, 0);
874 p = rdata.offset != 0;
876 if (p && r_o.status != 0)
878 /* report error code */
879 DEBUG(0,("SAMR_R_SET_GROUPINFO: %s\n", get_nt_error_msg(r_o.status)));
889 prs_mem_free(&data );
890 prs_mem_free(&rdata );
895 /****************************************************************************
896 do a SAMR Open Domain
897 ****************************************************************************/
898 BOOL samr_open_domain(struct cli_state *cli,
899 POLICY_HND *connect_pol, uint32 rid, DOM_SID *sid,
900 POLICY_HND *domain_pol)
906 SAMR_Q_OPEN_DOMAIN q_o;
907 BOOL valid_pol = False;
909 sid_to_string(sid_str, sid);
910 DEBUG(4,("SAMR Open Domain. SID:%s RID:%x\n", sid_str, rid));
912 if (connect_pol == NULL || sid == NULL || domain_pol == NULL) return False;
914 /* create and send a MSRPC command with api SAMR_OPEN_DOMAIN */
916 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
917 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
919 /* store the parameters */
920 make_samr_q_open_domain(&q_o, connect_pol, rid, sid);
922 /* turn parameters into data stream */
923 samr_io_q_open_domain("", &q_o, &data, 0);
925 /* send the data on \PIPE\ */
926 if (rpc_api_pipe_req(cli, SAMR_OPEN_DOMAIN, &data, &rdata))
928 SAMR_R_OPEN_DOMAIN r_o;
931 samr_io_r_open_domain("", &r_o, &rdata, 0);
932 p = rdata.offset != 0;
934 if (p && r_o.status != 0)
936 /* report error code */
937 DEBUG(0,("SAMR_R_OPEN_DOMAIN: %s\n", get_nt_error_msg(r_o.status)));
943 memcpy(domain_pol, &r_o.domain_pol, sizeof(r_o.domain_pol));
948 prs_mem_free(&data );
949 prs_mem_free(&rdata );
954 /****************************************************************************
955 do a SAMR Query Unknown 12
956 ****************************************************************************/
957 BOOL samr_query_unknown_12(struct cli_state *cli,
958 POLICY_HND *pol, uint32 rid, uint32 num_gids, uint32 *gids,
960 fstring names[MAX_LOOKUP_SIDS],
961 uint32 type [MAX_LOOKUP_SIDS])
966 SAMR_Q_UNKNOWN_12 q_o;
967 BOOL valid_query = False;
969 if (pol == NULL || rid == 0 || num_gids == 0 || gids == NULL ||
970 num_names == NULL || names == NULL || type == NULL ) return False;
972 /* create and send a MSRPC command with api SAMR_UNKNOWN_12 */
974 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
975 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
977 DEBUG(4,("SAMR Query Unknown 12.\n"));
979 /* store the parameters */
980 make_samr_q_unknown_12(&q_o, pol, rid, num_gids, gids);
982 /* turn parameters into data stream */
983 samr_io_q_unknown_12("", &q_o, &data, 0);
985 /* send the data on \PIPE\ */
986 if (rpc_api_pipe_req(cli, SAMR_UNKNOWN_12, &data, &rdata))
988 SAMR_R_UNKNOWN_12 r_o;
991 samr_io_r_unknown_12("", &r_o, &rdata, 0);
992 p = rdata.offset != 0;
994 if (p && r_o.status != 0)
996 /* report error code */
997 DEBUG(0,("SAMR_R_UNKNOWN_12: %s\n", get_nt_error_msg(r_o.status)));
1003 if (r_o.ptr_names != 0 && r_o.ptr_types != 0 &&
1004 r_o.num_types1 == r_o.num_names1)
1009 *num_names = r_o.num_names1;
1011 for (i = 0; i < r_o.num_names1; i++)
1013 fstrcpy(names[i], unistr2_to_str(&r_o.uni_name[i]));
1015 for (i = 0; i < r_o.num_types1; i++)
1017 type[i] = r_o.type[i];
1020 else if (r_o.ptr_names == 0 && r_o.ptr_types == 0)
1032 prs_mem_free(&data );
1033 prs_mem_free(&rdata );
1038 /****************************************************************************
1039 do a SAMR Query User Aliases
1040 ****************************************************************************/
1041 BOOL samr_query_useraliases(struct cli_state *cli,
1042 POLICY_HND *pol, DOM_SID *sid,
1043 uint32 *num_aliases, uint32 *rid)
1048 SAMR_Q_QUERY_USERALIASES q_o;
1049 BOOL valid_query = False;
1051 DEBUG(4,("SAMR Query User Aliases.\n"));
1053 if (pol == NULL || sid == NULL || rid == NULL || num_aliases == 0) return False;
1055 /* create and send a MSRPC command with api SAMR_QUERY_USERALIASES */
1057 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
1058 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
1060 /* store the parameters */
1061 make_samr_q_query_useraliases(&q_o, pol, sid);
1063 /* turn parameters into data stream */
1064 samr_io_q_query_useraliases("", &q_o, &data, 0);
1066 /* send the data on \PIPE\ */
1067 if (rpc_api_pipe_req(cli, SAMR_QUERY_USERALIASES, &data, &rdata))
1069 SAMR_R_QUERY_USERALIASES r_o;
1075 samr_io_r_query_useraliases("", &r_o, &rdata, 0);
1076 p = rdata.offset != 0;
1078 if (p && r_o.status != 0)
1080 /* report error code */
1081 DEBUG(0,("SAMR_R_QUERY_USERALIASES: %s\n", get_nt_error_msg(r_o.status)));
1085 if (p && r_o.ptr != 0)
1088 *num_aliases = r_o.num_entries;
1093 prs_mem_free(&data );
1094 prs_mem_free(&rdata );
1099 /****************************************************************************
1100 do a SAMR Query User Groups
1101 ****************************************************************************/
1102 BOOL samr_query_usergroups(struct cli_state *cli,
1103 POLICY_HND *pol, uint32 *num_groups, DOM_GID *gid)
1108 SAMR_Q_QUERY_USERGROUPS q_o;
1109 BOOL valid_query = False;
1111 DEBUG(4,("SAMR Query User Groups.\n"));
1113 if (pol == NULL || gid == NULL || num_groups == 0) return False;
1115 /* create and send a MSRPC command with api SAMR_QUERY_USERGROUPS */
1117 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
1118 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
1120 /* store the parameters */
1121 make_samr_q_query_usergroups(&q_o, pol);
1123 /* turn parameters into data stream */
1124 samr_io_q_query_usergroups("", &q_o, &data, 0);
1126 /* send the data on \PIPE\ */
1127 if (rpc_api_pipe_req(cli, SAMR_QUERY_USERGROUPS, &data, &rdata))
1129 SAMR_R_QUERY_USERGROUPS r_o;
1135 samr_io_r_query_usergroups("", &r_o, &rdata, 0);
1136 p = rdata.offset != 0;
1138 if (p && r_o.status != 0)
1140 /* report error code */
1141 DEBUG(0,("SAMR_R_QUERY_USERGROUPS: %s\n", get_nt_error_msg(r_o.status)));
1145 if (p && r_o.ptr_0 != 0)
1148 *num_groups = r_o.num_entries;
1153 prs_mem_free(&data );
1154 prs_mem_free(&rdata );
1159 /****************************************************************************
1160 do a SAMR Query User Info
1161 ****************************************************************************/
1162 BOOL samr_query_userinfo(struct cli_state *cli,
1163 POLICY_HND *pol, uint16 switch_value, void* usr)
1168 SAMR_Q_QUERY_USERINFO q_o;
1169 BOOL valid_query = False;
1171 DEBUG(4,("SAMR Query User Info. level: %d\n", switch_value));
1173 if (pol == NULL || usr == NULL || switch_value == 0) return False;
1175 /* create and send a MSRPC command with api SAMR_QUERY_USERINFO */
1177 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
1178 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
1180 /* store the parameters */
1181 make_samr_q_query_userinfo(&q_o, pol, switch_value);
1183 /* turn parameters into data stream */
1184 samr_io_q_query_userinfo("", &q_o, &data, 0);
1186 /* send the data on \PIPE\ */
1187 if (rpc_api_pipe_req(cli, SAMR_QUERY_USERINFO, &data, &rdata))
1189 SAMR_R_QUERY_USERINFO r_o;
1195 samr_io_r_query_userinfo("", &r_o, &rdata, 0);
1196 p = rdata.offset != 0;
1198 if (p && r_o.status != 0)
1200 /* report error code */
1201 DEBUG(0,("SAMR_R_QUERY_USERINFO: %s\n", get_nt_error_msg(r_o.status)));
1205 if (p && r_o.switch_value != switch_value)
1207 DEBUG(0,("SAMR_R_QUERY_USERINFO: received incorrect level %d\n",
1211 if (p && r_o.ptr != 0)
1217 prs_mem_free(&data );
1218 prs_mem_free(&rdata );
1223 /****************************************************************************
1225 ****************************************************************************/
1226 BOOL samr_close(struct cli_state *cli, POLICY_HND *hnd)
1231 SAMR_Q_CLOSE_HND q_c;
1232 BOOL valid_close = False;
1234 DEBUG(4,("SAMR Close\n"));
1236 if (hnd == NULL) return False;
1238 prs_init(&data , 1024, 4, SAFETY_MARGIN, False);
1239 prs_init(&rdata, 0 , 4, SAFETY_MARGIN, True );
1241 /* create and send a MSRPC command with api SAMR_CLOSE_HND */
1243 /* store the parameters */
1244 make_samr_q_close_hnd(&q_c, hnd);
1246 /* turn parameters into data stream */
1247 samr_io_q_close_hnd("", &q_c, &data, 0);
1249 /* send the data on \PIPE\ */
1250 if (rpc_api_pipe_req(cli, SAMR_CLOSE_HND, &data, &rdata))
1252 SAMR_R_CLOSE_HND r_c;
1255 samr_io_r_close_hnd("", &r_c, &rdata, 0);
1256 p = rdata.offset != 0;
1258 if (p && r_c.status != 0)
1260 /* report error code */
1261 DEBUG(0,("SAMR_CLOSE_HND: %s\n", get_nt_error_msg(r_c.status)));
1267 /* check that the returned policy handle is all zeros */
1271 for (i = 0; i < sizeof(r_c.pol.data); i++)
1273 if (r_c.pol.data[i] != 0)
1275 valid_close = False;
1281 DEBUG(0,("SAMR_CLOSE_HND: non-zero handle returned\n"));
1286 prs_mem_free(&data );
1287 prs_mem_free(&rdata );