samlib.h revision 1ed6b69a5ca1ca3ee5e9a4931f74e2237c7e1c9f
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2009 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
* Copyright 2012 Nexenta Systems, Inc. All rights reserved.
*/
#ifndef _SAMLIB_H
#define _SAMLIB_H
/*
* Prototypes for the SAM library and RPC client side library interface.
* There are two levels of interface defined here: sam_xxx and samr_xxx.
* The sam_xxx functions provide a high level interface which make
* multiple RPC calls and do all the work necessary to obtain and return
* the requested information. The samr_xxx functions provide a low level
* interface in which each function maps to a single underlying RPC.
*/
#ifdef __cplusplus
extern "C" {
#endif
/*
* Account Control Flags
* Use in SAMR Query Display Information RPC
*/
/*
* samlib.c
*/
DWORD sam_create_trust_account(char *, char *);
DWORD sam_remove_trust_account(char *, char *);
DWORD sam_delete_account(char *, char *, char *);
DWORD sam_get_local_domains(char *, char *);
DWORD sam_check_user(char *, char *, char *);
/*
*/
void samr_close_handle(mlsvc_handle_t *);
mlsvc_handle_t *);
mlsvc_handle_t *);
/*
*/
union samr_user_info {
struct info1 {
char *username;
char *fullname;
char *description;
char *unknown;
} info1;
struct info6 {
char *username;
char *fullname;
} info6;
struct info7 {
char *username;
} info7;
struct info8 {
char *fullname;
} info8;
struct info9 {
} info9;
struct info16 {
} info16;
};
char *server,
char *account,
struct samr_encr_passwd *newpw,
struct samr_encr_hash *oldpw);
int info_level,
void *info_buf);
char *new_pw_clear);
char *server,
char *account,
char *old_password,
char *new_password);
#ifdef __cplusplus
}
#endif
#endif /* _SAMLIB_H */