/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (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 * or http://www.opensolaris.org/os/licensing. * 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 */ /* LINTLIBRARY */ /* PROTOLIB1 */ /* * Copyright 2003 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #pragma ident "%Z%%M% %I% %E% SMI" #include #include #include #include #include "ns_sldap.h" /* * Simplified LDAP Naming APIs */ int __ns_ldap_list( const char *service, const char *filter, int (*init_filter_cb)(const ns_ldap_search_desc_t *desc, char **realfilter, const void *userdata), const char * const *attribute, const ns_cred_t *cred, const int flags, ns_ldap_result_t ** result, ns_ldap_error_t ** errorp, int (*callback)(const ns_ldap_entry_t *entry, const void *userdata), const void *userdata); int __ns_ldap_addAttr( const char *service, const char *dn, const ns_ldap_attr_t * const *attr, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_delAttr( const char *service, const char *dn, const ns_ldap_attr_t * const *attr, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_repAttr( const char *service, const char *dn, const ns_ldap_attr_t * const *attr, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_addEntry( const char *service, const char *dn, const ns_ldap_entry_t *entry, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_addTypedEntry( const char *servicetype, const char *basedn, const void *data, const int create, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_delEntry( const char *service, const char *dn, const ns_cred_t *cred, const int flags, ns_ldap_error_t **errorp); int __ns_ldap_firstEntry( const char *service, const char *filter, int (*init_filter_cb)(const ns_ldap_search_desc_t *desc, char **realfilter, const void *userdata), const char * const *attribute, const ns_cred_t *cred, const int flags, void **cookie, ns_ldap_result_t ** result, ns_ldap_error_t **errorp, const void *userdata); int __ns_ldap_nextEntry( void *cookie, ns_ldap_result_t ** result, ns_ldap_error_t **errorp); int __ns_ldap_endEntry( void **cookie, ns_ldap_error_t **errorp); int __ns_ldap_freeResult( ns_ldap_result_t **result); int __ns_ldap_freeError( ns_ldap_error_t **errorp); int __ns_ldap_freeCookie( void **cookie); int __ns_ldap_uid2dn( const char *uid, char **userDN, const ns_cred_t *cred, ns_ldap_error_t ** errorp); int __ns_ldap_host2dn( const char *host, const char *domain, char **hostDN, const ns_cred_t *cred, ns_ldap_error_t ** errorp); int __ns_ldap_dn2domain( const char *dn, char **domain, const ns_cred_t *cred, ns_ldap_error_t **errorp); int __ns_ldap_auth( const ns_cred_t *cred, const int flag, ns_ldap_error_t **errorp, LDAPControl **serverctrls, LDAPControl **clientctrls); int __ns_ldap_err2str( int err, char **strmsg); int __ns_ldap_setParam( const ParamIndexType type, const void *data, ns_ldap_error_t **errorp); int __ns_ldap_getParam( const ParamIndexType type, void ***data, ns_ldap_error_t **errorp); int __ns_ldap_freeParam( void ***data); char **__ns_ldap_getAttr( const ns_ldap_entry_t *entry, const char *attrname); int __s_api_prepend_automountmapname_to_dn( const char *service, char **basedn, ns_ldap_error_t ** errorp); char *__s_api_get_canonical_name( ns_ldap_entry_t *entry, ns_ldap_attr_t *attrptr, int case_ignore);