Arthur de Jong

Open Source / Free Software developer

summaryrefslogtreecommitdiffstats
path: root/ldap-sldap.h
diff options
context:
space:
mode:
authorArthur de Jong <arthur@arthurdejong.org>2006-10-11 15:34:15 +0200
committerArthur de Jong <arthur@arthurdejong.org>2006-10-11 15:34:15 +0200
commit6f17403298cf33747a45fb5ecbe78bf7632531f9 (patch)
treea5fc4cfdc3b091a0ee86f3c5c8d5e0ea8fc2c564 /ldap-sldap.h
import release 251 of nss-ldap
git-svn-id: http://arthurdejong.org/svn/nss-pam-ldapd/nss_ldap-251@1 ef36b2f9-881f-0410-afb5-c4e39611909c
Diffstat (limited to 'ldap-sldap.h')
-rw-r--r--ldap-sldap.h172
1 files changed, 172 insertions, 0 deletions
diff --git a/ldap-sldap.h b/ldap-sldap.h
new file mode 100644
index 0000000..f2278fc
--- /dev/null
+++ b/ldap-sldap.h
@@ -0,0 +1,172 @@
+/* Copyright (C) 1997-2006 Luke Howard.
+ This file is part of the nss_ldap library.
+ Contributed by Luke Howard, <lukeh@padl.com>, 2006.
+
+ The nss_ldap library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public License as
+ published by the Free Software Foundation; either version 2 of the
+ License, or (at your option) any later version.
+
+ The nss_ldap library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public
+ License along with the nss_ldap library; see the file COPYING.LIB. If not,
+ write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ Boston, MA 02111-1307, USA.
+
+ $Id: ldap-sldap.h,v 2.4 2006/01/12 13:06:23 lukeh Exp $
+ */
+
+#ifndef _LDAP_NSS_LDAP_LDAP_SLDAP_H
+#define _LDAP_NSS_LDAP_LDAP_SLDAP_H
+
+#define NS_LDAP_VERSION NS_LDAP_VERSION_2
+#define NS_LDAP_VERSION_1 "1.0"
+#define NS_LDAP_VERSION_2 "2.0"
+
+typedef enum {
+ NS_LDAP_FILE_VERSION_P = 0
+} ParamIndexType;
+
+typedef enum {
+ NS_LDAP_SUCCESS = 0,
+ NS_LDAP_OP_FAILED,
+ NS_LDAP_NOTFOUND,
+ NS_LDAP_MEMORY,
+ NS_LDAP_CONFIG,
+ NS_LDAP_PARTIAL,
+ NS_LDAP_INTERNAL,
+ NS_LDAP_INVALID_PARAM,
+ NS_LDAP_SUCCESS_WITH_INFO
+} ns_ldap_return_code;
+
+typedef struct ns_ldap_search_desc {
+ char *basedn;
+ int scope;
+ char *filter;
+} ns_ldap_search_desc_t;
+
+typedef struct ns_ldap_attribute_map {
+ char *origAttr;
+ char **mappedAttr;
+} ns_ldap_attribute_map_t;
+
+typedef struct ns_ldap_objectclass_map {
+ char *origOC;
+ char *mappedOC;
+} ns_ldap_objectclass_map_t;
+
+typedef struct ns_ldap_passwd_mgmt {
+ int pad[2];
+} ns_ldap_passwd_mgmt_t;
+
+typedef struct ns_ldap_error {
+ int status;
+ char *message;
+ ns_ldap_passwd_mgmt_t pwd_mgmt;
+} ns_ldap_error_t;
+
+typedef struct ns_ldap_attr {
+ char *attrname;
+ unsigned int value_count;
+ char **attrvalue;
+} ns_ldap_attr_t;
+
+typedef struct ns_ldap_entry {
+ unsigned int attr_count;
+ ns_ldap_attr_t **attr_pair;
+ struct ns_ldap_entry *next;
+} ns_ldap_entry_t;
+
+typedef struct ns_ldap_result {
+ unsigned int entries_count;
+ ns_ldap_entry_t *entry;
+} ns_ldap_result_t;
+
+#define NS_LDAP_HARD 0x001
+#define NS_LDAP_ALL_RES 0x002
+#define NS_LDAP_FOLLOWREF 0x004
+#define NS_LDAP_NOREF 0x008
+#define NS_LDAP_SCOPE_BASE 0x010
+#define NS_LDAP_SCOPE_ONELEVEL 0x020
+#define NS_LDAP_SCOPE_SUBTREE 0x040
+#define NS_LDAP_KEEP_CONN 0x080
+#define NS_LDAP_NEW_CONN 0x400
+#define NS_LDAP_NOMAP 0x800
+
+#define NS_LDAP_CB_NEXT 0
+#define NS_LDAP_CB_DONE 1
+
+typedef struct ns_ldap_cookie {
+ char *map;
+ char *filter;
+ char **attribute;
+ int flags;
+
+ int (*init_filter_cb)(const ns_ldap_search_desc_t *desc, char **realfilter, const void *userdata);
+ int (*callback)(const ns_ldap_entry_t *entry, const void *userdata);
+ const void *userdata;
+
+ char *mapped_filter;
+ const char **mapped_attribute;
+
+ int ret;
+ int cb_ret;
+ int erange;
+ ldap_map_selector_t sel;
+ ent_context_t *state;
+ ldap_automount_context_t *am_state;
+
+ ns_ldap_result_t *result;
+ ns_ldap_entry_t *entry;
+} ns_ldap_cookie_t;
+
+char **__ns_ldap_getMappedAttributes(const char *service, const char *attribute);
+char **__ns_ldap_getMappedObjectClass(const char *service, const char *attribute);
+
+ns_ldap_return_code __ns_ldap_getParam(const ParamIndexType type, void ***data, ns_ldap_error_t **errorp);
+ns_ldap_return_code __ns_ldap_freeError(ns_ldap_error_t **errorp);
+ns_ldap_return_code __ns_ldap_freeEntry(ns_ldap_entry_t **pentry);
+ns_ldap_return_code __ns_ldap_freeResult(ns_ldap_result_t **result);
+
+typedef void ns_cred_t;
+
+ns_ldap_return_code __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);
+
+ns_ldap_return_code __ns_ldap_nextEntry(
+ void *cookie,
+ ns_ldap_result_t ** result,
+ ns_ldap_error_t **errorp);
+
+ns_ldap_return_code __ns_ldap_endEntry(
+ void **cookie,
+ ns_ldap_error_t **errorp);
+
+ns_ldap_return_code __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);
+
+ns_ldap_return_code __ns_ldap_err2str(ns_ldap_return_code err, char **strmsg);
+
+#endif /* _LDAP_NSS_LDAP_LDAP_SLDAP_H */