xref: /illumos-gate/usr/src/lib/smbsrv/libmlsvc/common/samlib.h (revision 1ed6b69a5ca1ca3ee5e9a4931f74e2237c7e1c9f)
18d7e4166Sjose borrego /*
28d7e4166Sjose borrego  * CDDL HEADER START
38d7e4166Sjose borrego  *
48d7e4166Sjose borrego  * The contents of this file are subject to the terms of the
58d7e4166Sjose borrego  * Common Development and Distribution License (the "License").
68d7e4166Sjose borrego  * You may not use this file except in compliance with the License.
78d7e4166Sjose borrego  *
88d7e4166Sjose borrego  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
98d7e4166Sjose borrego  * or http://www.opensolaris.org/os/licensing.
108d7e4166Sjose borrego  * See the License for the specific language governing permissions
118d7e4166Sjose borrego  * and limitations under the License.
128d7e4166Sjose borrego  *
138d7e4166Sjose borrego  * When distributing Covered Code, include this CDDL HEADER in each
148d7e4166Sjose borrego  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
158d7e4166Sjose borrego  * If applicable, add the following below this CDDL HEADER, with the
168d7e4166Sjose borrego  * fields enclosed by brackets "[]" replaced with your own identifying
178d7e4166Sjose borrego  * information: Portions Copyright [yyyy] [name of copyright owner]
188d7e4166Sjose borrego  *
198d7e4166Sjose borrego  * CDDL HEADER END
208d7e4166Sjose borrego  */
218d7e4166Sjose borrego /*
227f667e74Sjose borrego  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
238d7e4166Sjose borrego  * Use is subject to license terms.
24*1ed6b69aSGordon Ross  * Copyright 2012 Nexenta Systems, Inc.  All rights reserved.
258d7e4166Sjose borrego  */
268d7e4166Sjose borrego 
277f667e74Sjose borrego #ifndef _SAMLIB_H
287f667e74Sjose borrego #define	_SAMLIB_H
298d7e4166Sjose borrego 
308d7e4166Sjose borrego /*
318d7e4166Sjose borrego  * Prototypes for the SAM library and RPC client side library interface.
328d7e4166Sjose borrego  * There are two levels of interface defined here: sam_xxx and samr_xxx.
338d7e4166Sjose borrego  * The sam_xxx functions provide a high level interface which make
348d7e4166Sjose borrego  * multiple RPC calls and do all the work necessary to obtain and return
358d7e4166Sjose borrego  * the requested information. The samr_xxx functions provide a low level
368d7e4166Sjose borrego  * interface in which each function maps to a single underlying RPC.
378d7e4166Sjose borrego  */
388d7e4166Sjose borrego 
398d7e4166Sjose borrego #include <smbsrv/ndl/samrpc.ndl>
408d7e4166Sjose borrego 
418d7e4166Sjose borrego 
428d7e4166Sjose borrego #ifdef __cplusplus
438d7e4166Sjose borrego extern "C" {
448d7e4166Sjose borrego #endif
458d7e4166Sjose borrego 
468d7e4166Sjose borrego /*
478d7e4166Sjose borrego  * Account Control Flags
488d7e4166Sjose borrego  * Use in SAMR Query Display Information RPC
498d7e4166Sjose borrego  */
508d7e4166Sjose borrego #define	ACF_DISABLED	0x001	/* account disable */
518d7e4166Sjose borrego #define	ACF_HOMEDIRREQ	0x002	/* home dir required */
528d7e4166Sjose borrego #define	ACF_PWDNOTREQ	0x004	/* password not required */
538d7e4166Sjose borrego #define	ACF_TEMPDUP	0x008	/* temp dup account */
548d7e4166Sjose borrego #define	ACF_NORMUSER	0x010	/* normal user */
558d7e4166Sjose borrego #define	ACF_MNS		0x020	/* MNS account */
568d7e4166Sjose borrego #define	ACF_DOMTRUST	0x040	/* Domain trust acct */
578d7e4166Sjose borrego #define	ACF_WSTRUST	0x080	/* WKST trust acct */
588d7e4166Sjose borrego #define	ACF_SVRTRUST	0x100	/* Server trust acct */
598d7e4166Sjose borrego #define	ACF_PWDNOEXP	0x200	/* password no expire */
608d7e4166Sjose borrego #define	ACF_AUTOLOCK	0x400	/* acct auto lock */
618d7e4166Sjose borrego 
628d7e4166Sjose borrego /*
638d7e4166Sjose borrego  * samlib.c
648d7e4166Sjose borrego  */
65e3f2c991SKeyur Desai DWORD sam_create_trust_account(char *, char *);
66e3f2c991SKeyur Desai DWORD sam_create_account(char *, char *, char *, DWORD);
677f667e74Sjose borrego DWORD sam_remove_trust_account(char *, char *);
687f667e74Sjose borrego DWORD sam_delete_account(char *, char *, char *);
697f667e74Sjose borrego DWORD sam_get_local_domains(char *, char *);
707f667e74Sjose borrego DWORD sam_check_user(char *, char *, char *);
718d7e4166Sjose borrego 
728d7e4166Sjose borrego /*
738d7e4166Sjose borrego  * samr_open.c
748d7e4166Sjose borrego  */
75*1ed6b69aSGordon Ross DWORD samr_open(char *, char *, char *, DWORD, mlsvc_handle_t *);
76*1ed6b69aSGordon Ross DWORD samr_connect(char *, char *, char *, DWORD, mlsvc_handle_t *);
77*1ed6b69aSGordon Ross void samr_close_handle(mlsvc_handle_t *);
787f667e74Sjose borrego DWORD samr_open_domain(mlsvc_handle_t *, DWORD, struct samr_sid *,
797f667e74Sjose borrego     mlsvc_handle_t *);
807f667e74Sjose borrego DWORD samr_open_user(mlsvc_handle_t *, DWORD, DWORD, mlsvc_handle_t *);
817f667e74Sjose borrego DWORD samr_delete_user(mlsvc_handle_t *);
827f667e74Sjose borrego int samr_open_group(mlsvc_handle_t *, DWORD, mlsvc_handle_t *);
837f667e74Sjose borrego DWORD samr_create_user(mlsvc_handle_t *, char *, DWORD, DWORD *,
847f667e74Sjose borrego     mlsvc_handle_t *);
858d7e4166Sjose borrego 
868d7e4166Sjose borrego /*
878d7e4166Sjose borrego  * samr_lookup.c
888d7e4166Sjose borrego  */
898d7e4166Sjose borrego union samr_user_info {
908d7e4166Sjose borrego 	struct info1 {
918d7e4166Sjose borrego 		char *username;
928d7e4166Sjose borrego 		char *fullname;
938d7e4166Sjose borrego 		DWORD group_rid;
948d7e4166Sjose borrego 		char *description;
958d7e4166Sjose borrego 		char *unknown;
968d7e4166Sjose borrego 	} info1;
978d7e4166Sjose borrego 
988d7e4166Sjose borrego 	struct info6 {
998d7e4166Sjose borrego 		char *username;
1008d7e4166Sjose borrego 		char *fullname;
1018d7e4166Sjose borrego 	} info6;
1028d7e4166Sjose borrego 
1038d7e4166Sjose borrego 	struct info7 {
1048d7e4166Sjose borrego 		char *username;
1058d7e4166Sjose borrego 	} info7;
1068d7e4166Sjose borrego 
1078d7e4166Sjose borrego 	struct info8 {
1088d7e4166Sjose borrego 		char *fullname;
1098d7e4166Sjose borrego 	} info8;
1108d7e4166Sjose borrego 
1118d7e4166Sjose borrego 	struct info9 {
1128d7e4166Sjose borrego 		DWORD group_rid;
1138d7e4166Sjose borrego 	} info9;
1148d7e4166Sjose borrego 
1158d7e4166Sjose borrego 	struct info16 {
116*1ed6b69aSGordon Ross 		DWORD acct_ctrl;
1178d7e4166Sjose borrego 	} info16;
1188d7e4166Sjose borrego };
1198d7e4166Sjose borrego 
1208d7e4166Sjose borrego 
1217f667e74Sjose borrego smb_sid_t *samr_lookup_domain(mlsvc_handle_t *, char *);
1227f667e74Sjose borrego DWORD samr_enum_local_domains(mlsvc_handle_t *);
1237f667e74Sjose borrego uint32_t samr_lookup_domain_names(mlsvc_handle_t *, char *, smb_account_t *);
124*1ed6b69aSGordon Ross DWORD samr_query_user_info(mlsvc_handle_t *, WORD, union samr_user_info *);
1257f667e74Sjose borrego DWORD samr_get_user_pwinfo(mlsvc_handle_t *);
1268d7e4166Sjose borrego 
127*1ed6b69aSGordon Ross DWORD
128*1ed6b69aSGordon Ross samr_change_password(
129*1ed6b69aSGordon Ross 	mlsvc_handle_t *handle,
130*1ed6b69aSGordon Ross 	char *server,
131*1ed6b69aSGordon Ross 	char *account,
132*1ed6b69aSGordon Ross 	struct samr_encr_passwd *newpw,
133*1ed6b69aSGordon Ross 	struct samr_encr_hash *oldpw);
1348d7e4166Sjose borrego 
135*1ed6b69aSGordon Ross DWORD
136*1ed6b69aSGordon Ross samr_set_user_info(
137*1ed6b69aSGordon Ross 	mlsvc_handle_t *user_handle,
138*1ed6b69aSGordon Ross 	int info_level,
139*1ed6b69aSGordon Ross 	void *info_buf);
1408d7e4166Sjose borrego 
141*1ed6b69aSGordon Ross DWORD
142*1ed6b69aSGordon Ross netr_set_user_control(
143*1ed6b69aSGordon Ross 	mlsvc_handle_t *user_handle,
144*1ed6b69aSGordon Ross 	DWORD UserAccountControl);
145*1ed6b69aSGordon Ross 
146*1ed6b69aSGordon Ross DWORD
147*1ed6b69aSGordon Ross netr_set_user_password(
148*1ed6b69aSGordon Ross 	mlsvc_handle_t *user_handle,
149*1ed6b69aSGordon Ross 	char *new_pw_clear);
150*1ed6b69aSGordon Ross 
151*1ed6b69aSGordon Ross DWORD
152*1ed6b69aSGordon Ross netr_change_password(
153*1ed6b69aSGordon Ross 	char *server,
154*1ed6b69aSGordon Ross 	char *account,
155*1ed6b69aSGordon Ross 	char *old_password,
156*1ed6b69aSGordon Ross 	char *new_password);
1578d7e4166Sjose borrego 
1588d7e4166Sjose borrego #ifdef __cplusplus
1598d7e4166Sjose borrego }
1608d7e4166Sjose borrego #endif
1618d7e4166Sjose borrego 
1628d7e4166Sjose borrego 
1637f667e74Sjose borrego #endif /* _SAMLIB_H */
164