]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-ldap/back-ldap.h
remove #ifdef's for identity assertion
[openldap] / servers / slapd / back-ldap / back-ldap.h
index 0fd098642e6b5c75d85e0fd22c95ccf597daf133..3f5b109d371bf53fdbb2d79ff7e0b88ce733586f 100644 (file)
 /* back-ldap.h - ldap backend header file */
 /* $OpenLDAP$ */
-/*
- * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.
- * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
+ *
+ * Copyright 1999-2005 The OpenLDAP Foundation.
+ * Portions Copyright 2000-2003 Pierangelo Masarati.
+ * Portions Copyright 1999-2003 Howard Chu.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted only as authorized by the OpenLDAP
+ * Public License.
+ *
+ * A copy of this license is available in the file LICENSE in the
+ * top-level directory of the distribution or, alternatively, at
+ * <http://www.OpenLDAP.org/license.html>.
  */
-/* This is an altered version */
-/*
- * Copyright 1999, Howard Chu, All rights reserved. <hyc@highlandsun.com>
- * 
- * Permission is granted to anyone to use this software for any purpose
- * on any computer system, and to alter it and redistribute it, subject
- * to the following restrictions:
- * 
- * 1. The author is not responsible for the consequences of use of this
- *    software, no matter how awful, even if they arise from flaws in it.
- * 
- * 2. The origin of this software must not be misrepresented, either by
- *    explicit claim or by omission.  Since few users ever read sources,
- *    credits should appear in the documentation.
- * 
- * 3. Altered versions must be plainly marked as such, and must not be
- *    misrepresented as being the original software.  Since few users
- *    ever read sources, credits should appear in the documentation.
- * 
- * 4. This notice may not be removed or altered.
+/* ACKNOWLEDGEMENTS:
+ * This work was initially developed by the Howard Chu for inclusion
+ * in OpenLDAP Software and subsequently enhanced by Pierangelo
+ * Masarati.
  */
 
 #ifndef SLAPD_LDAP_H
 #define SLAPD_LDAP_H
 
-#include "external.h"
-
 LDAP_BEGIN_DECL
 
 struct slap_conn;
 struct slap_op;
+struct slap_backend_db;
 
 struct ldapconn {
-       struct ldapconn *next;
-       struct slap_conn        *conn;
-       LDAP            *ld;
-       int             bound;
+       struct slap_conn        *lc_conn;
+       LDAP                    *lc_ld;
+       struct berval           lc_cred;
+       struct berval           lc_bound_ndn;
+       struct berval           lc_local_ndn;
+       int                     lc_bound;
+       ldap_pvt_thread_mutex_t lc_mutex;
+};
+
+struct ldapauth {
+       struct berval   la_authcID;
+       struct berval   la_authcDN;
+       struct berval   la_passwd;
+
+       struct berval   la_authzID;
+       
+       int             la_authmethod;
+       int             la_sasl_flags;
+       struct berval   la_sasl_mech;
+       struct berval   la_sasl_realm;
+       
+#define LDAP_BACK_AUTH_NONE            0x00U
+#define        LDAP_BACK_AUTH_NATIVE_AUTHZ     0x01U
+#define        LDAP_BACK_AUTH_OVERRIDE         0x02U
+       unsigned        la_flags;
 };
 
 struct ldapinfo {
-       char *url;
-       char *suffix;
-       char *binddn;
-       char *bindpw;
+       char            *url;
+       LDAPURLDesc     *lud;
+       struct ldapauth acl_la;
+#define        acl_authcDN     acl_la.la_authcDN
+#define        acl_passwd      acl_la.la_passwd
+
+       /* ID assert stuff */
+       int             idassert_mode;
+#define        LDAP_BACK_IDASSERT_LEGACY       0
+#define        LDAP_BACK_IDASSERT_NOASSERT     1
+#define        LDAP_BACK_IDASSERT_ANONYMOUS    2
+#define        LDAP_BACK_IDASSERT_SELF         3
+#define        LDAP_BACK_IDASSERT_OTHERDN      4
+#define        LDAP_BACK_IDASSERT_OTHERID      5
+
+       struct ldapauth idassert_la;
+#define        idassert_authcID        idassert_la.la_authcID
+#define        idassert_authcDN        idassert_la.la_authcDN
+#define        idassert_passwd         idassert_la.la_passwd
+#define        idassert_authzID        idassert_la.la_authzID
+#define        idassert_authmethod     idassert_la.la_authmethod
+#define        idassert_sasl_flags     idassert_la.la_sasl_flags
+#define        idassert_sasl_mech      idassert_la.la_sasl_mech
+#define        idassert_sasl_realm     idassert_la.la_sasl_realm
+#define        idassert_flags          idassert_la.la_flags
+       BerVarray       idassert_authz;
+       
+       int             idassert_ppolicy;
+       /* end of ID assert stuff */
+
        ldap_pvt_thread_mutex_t         conn_mutex;
-       struct ldapconn *lcs;
-};
+       int             savecred;
+       Avlnode         *conntree;
 
-struct ldapconn *ldap_back_getconn(struct ldapinfo *li, struct slap_conn *conn,
-       struct slap_op *op);
-void ldap_back_dobind(struct ldapconn *lc, Operation *op);
-int ldap_back_map_result(int err);
-int ldap_back_op_result(struct ldapconn *lc, Operation *op);
-int    back_ldap_LTX_init_module(int argc, char *argv[]);
+       int             rwm_started;
+};
 
 LDAP_END_DECL
 
-#endif
+#include "proto-ldap.h"
+
+#endif /* SLAPD_LDAP_H */