1 /* back-ldap.h - ldap backend header file */
3 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
5 * Copyright 1999-2004 The OpenLDAP Foundation.
6 * Portions Copyright 2000-2003 Pierangelo Masarati.
7 * Portions Copyright 1999-2003 Howard Chu.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted only as authorized by the OpenLDAP
14 * A copy of this license is available in the file LICENSE in the
15 * top-level directory of the distribution or, alternatively, at
16 * <http://www.OpenLDAP.org/license.html>.
19 * This work was initially developed by the Howard Chu for inclusion
20 * in OpenLDAP Software and subsequently enhanced by Pierangelo
29 /* String rewrite library */
32 #endif /* ENABLE_REWRITE */
35 #define LDAP_BACK_PROXY_AUTHZ
42 struct slap_backend_db;
45 struct slap_conn *conn;
48 struct berval bound_dn;
49 struct berval local_dn;
51 ldap_pvt_thread_mutex_t lc_mutex;
71 struct rewrite_info *rwm_rw;
72 #else /* !ENABLE_REWRITE */
73 /* some time the suffix massaging without librewrite
75 BerVarray rwm_suffix_massage;
76 #endif /* !ENABLE_REWRITE */
79 * Attribute/objectClass mapping
81 struct ldapmap rwm_oc;
82 struct ldapmap rwm_at;
86 struct slap_backend_db *be;
91 #ifdef LDAP_BACK_PROXY_AUTHZ
92 struct berval proxyauthzdn;
93 struct berval proxyauthzpw;
97 #define LDAP_BACK_IDASSERT_LEGACY 0
98 #define LDAP_BACK_IDASSERT_NOASSERT 1
99 #define LDAP_BACK_IDASSERT_ANONYMOUS 2
100 #define LDAP_BACK_IDASSERT_SELF 3
101 #define LDAP_BACK_IDASSERT_OTHERDN 4
102 #define LDAP_BACK_IDASSERT_OTHERID 5
103 struct berval idassert_id;
104 BerVarray idassert_authz;
105 /* end of ID assert stuff */
106 #endif /* LDAP_BACK_PROXY_AUTHZ */
108 ldap_pvt_thread_mutex_t conn_mutex;
113 #ifdef ENABLE_REWRITE
114 struct rewrite_info *rwinfo;
115 #else /* !ENABLE_REWRITE */
116 BerVarray suffix_massage;
117 #endif /* !ENABLE_REWRITE */
119 struct ldapmap oc_map;
120 struct ldapmap at_map;
123 struct ldaprwmap rwmap;
126 /* Whatever context ldap_back_dn_massage needs... */
127 typedef struct dncookie {
128 struct ldaprwmap *rwmap;
130 #ifdef ENABLE_REWRITE
140 struct ldapconn *ldap_back_getconn(struct slap_op *op, struct slap_rep *rs);
141 int ldap_back_dobind(struct ldapconn *lc, Operation *op, SlapReply *rs);
142 int ldap_back_map_result(SlapReply *rs);
143 int ldap_back_op_result(struct ldapconn *lc, Operation *op, SlapReply *rs,
144 ber_int_t msgid, int sendok);
145 int back_ldap_LTX_init_module(int argc, char *argv[]);
147 int ldap_back_dn_massage(dncookie *dc, struct berval *dn,
150 extern int ldap_back_conn_cmp( const void *c1, const void *c2);
151 extern int ldap_back_conn_dup( void *c1, void *c2 );
152 extern void ldap_back_conn_free( void *c );
154 /* attributeType/objectClass mapping */
155 int mapping_cmp (const void *, const void *);
156 int mapping_dup (void *, void *);
158 void ldap_back_map_init ( struct ldapmap *lm, struct ldapmapping ** );
159 void ldap_back_map ( struct ldapmap *map, struct berval *s, struct berval *m,
161 #define BACKLDAP_MAP 0
162 #define BACKLDAP_REMAP 1
164 ldap_back_map_filter(
165 struct ldapmap *at_map,
166 struct ldapmap *oc_map,
173 struct ldapmap *at_map,
179 extern void mapping_free ( void *mapping );
181 extern int ldap_back_map_config(
182 struct ldapmap *oc_map,
183 struct ldapmap *at_map,
190 ldap_back_filter_map_rewrite(
196 /* suffix massaging by means of librewrite */
197 #ifdef ENABLE_REWRITE
198 extern int suffix_massage_config( struct rewrite_info *info,
199 struct berval *pvnc, struct berval *nvnc,
200 struct berval *prnc, struct berval *nrnc);
201 #endif /* ENABLE_REWRITE */
202 extern int ldap_dnattr_rewrite( dncookie *dc, BerVarray a_vals );
203 extern int ldap_dnattr_result_rewrite( dncookie *dc, BerVarray a_vals );
205 #ifdef LDAP_BACK_PROXY_AUTHZ
207 ldap_back_proxy_authz_ctrl(
211 LDAPControl ***pctrls );
212 #endif /* LDAP_BACK_PROXY_AUTHZ */
216 #endif /* SLAPD_LDAP_H */