]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-sql/proto-sql.h
ITS#3576 use actual backend (not glue instance) for restriction and
[openldap] / servers / slapd / back-sql / proto-sql.h
index 2f623900c4ba9ec2cd73d56cee28f562443d4650..8019284223d1e0e0712fcc321fbfe705c86273c4 100644 (file)
@@ -1,6 +1,6 @@
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *
- * Copyright 1999-2004 The OpenLDAP Foundation.
+ * Copyright 1999-2005 The OpenLDAP Foundation.
  * Portions Copyright 1999 Dmitry Kovalev.
  * Portions Copyright 2002 Pierangelo Mararati.
  * All rights reserved.
@@ -16,7 +16,7 @@
 /* ACKNOWLEDGEMENTS:
  * This work was initially developed by Dmitry Kovalev for inclusion
  * by OpenLDAP Software.  Additional significant contributors include
- *    Pierangelo Mararati
+ * Pierangelo Masarati
  */
 
 /*
@@ -74,7 +74,6 @@
 #define PROTO_SQL_H
 
 #include "back-sql.h"
-#include "sql-types.h"
 
 /*
  * add.c
@@ -97,7 +96,9 @@ int backsql_modify_internal(
 /*
  * api.c
  */
-int backsql_api_config( backsql_info *si, const char *name );
+int backsql_api_config( backsql_info *bi, const char *name,
+               int argc, char *argv[] );
+int backsql_api_destroy( backsql_info *bi );
 int backsql_api_register( backsql_api *ba );
 int backsql_api_dn2odbc( Operation *op, SlapReply *rs, struct berval *dn );
 int backsql_api_odbc2dn( Operation *op, SlapReply *rs, struct berval *dn );
@@ -105,10 +106,14 @@ int backsql_api_odbc2dn( Operation *op, SlapReply *rs, struct berval *dn );
 /*
  * entry-id.c
  */
+#ifdef BACKSQL_ARBITRARY_KEY
+extern struct berval   backsql_baseObject_bv;
+#endif /* BACKSQL_ARBITRARY_KEY */
 
 /* stores in *id the ID in table ldap_entries corresponding to DN, if any */
-int backsql_dn2id( backsql_info *bi, backsql_entryID *id,
-               SQLHDBC dbh, struct berval *dn );
+int backsql_dn2id( Operation *op, SlapReply *rs, SQLHDBC dbh,
+               struct berval *ndn, backsql_entryID *id,
+               int matched, int muck );
 
 /* stores in *nchildren the count of children for an entry */
 int backsql_count_children( backsql_info *bi, SQLHDBC dbh,
@@ -119,11 +124,20 @@ int backsql_count_children( backsql_info *bi, SQLHDBC dbh,
 int backsql_has_children( backsql_info *bi, SQLHDBC dbh, struct berval *dn );
 
 /* frees *id and returns next in list */
-backsql_entryID *backsql_free_entryID( backsql_entryID *id, int freeit );
+backsql_entryID *backsql_free_entryID( Operation *op, backsql_entryID *id,
+               int freeit );
 
 /* turns an ID into an entry */
 int backsql_id2entry( backsql_srch_info *bsi, backsql_entryID *id );
 
+/*
+ * operational.c
+ */
+
+Attribute *backsql_operational_entryUUID( backsql_info *bi, backsql_entryID *id );
+
+Attribute *backsql_operational_entryCSN( Operation *op );
+
 /*
  * schema-map.c
  */
@@ -153,7 +167,7 @@ int backsql_init_search( backsql_srch_info *bsi,
                struct berval *nbase, int scope, int slimit, int tlimit,
                time_t stoptime, Filter *filter, SQLHDBC dbh,
                Operation *op, SlapReply *rs, AttributeName *attrs,
-               int get_base_id );
+               unsigned flags );
 
 /*
  * sql-wrap.h
@@ -209,10 +223,10 @@ extern char
        backsql_def_oc_query[],
        backsql_def_needs_select_oc_query[],
        backsql_def_at_query[],
-       backsql_def_delentry_query[],
-       backsql_def_insentry_query[],
-       backsql_def_delobjclasses_query[],
-       backsql_def_delreferrals_query[],
+       backsql_def_delentry_stmt[],
+       backsql_def_renentry_stmt[],
+       backsql_def_insentry_stmt[],
+       backsql_def_delobjclasses_stmt[],
        backsql_def_subtree_cond[],
        backsql_def_upper_subtree_cond[],
        backsql_id_query[],
@@ -223,7 +237,7 @@ extern char
 struct berbuf * backsql_strcat( struct berbuf *dest, ... );
 struct berbuf * backsql_strfcat( struct berbuf *dest, const char *fmt, ... );
 
-int backsql_entry_addattr( Entry *e, struct berval *at_name
+int backsql_entry_addattr( Entry *e, AttributeDescription *ad
                struct berval *at_val, void *memctx );
 
 int backsql_merge_from_clause( struct berbuf *dest_from, 
@@ -235,4 +249,41 @@ int backsql_split_pattern( const char *pattern, BerVarray *split_pattern,
 int backsql_prepare_pattern( BerVarray split_pattern, BerVarray values,
                struct berval *res );
 
+int backsql_entryUUID( backsql_info *bi, backsql_entryID *id,
+               struct berval *entryUUID, void *memctx );
+int backsql_entryUUID_decode( struct berval *entryUUID, unsigned long *oc_id,
+#ifdef BACKSQL_ARBITRARY_KEY
+       struct berval   *keyval
+#else /* ! BACKSQL_ARBITRARY_KEY */
+       unsigned long   *keyval
+#endif /* ! BACKSQL_ARBITRARY_KEY */
+       );
+
+/*
+ * former external.h
+ */
+
+extern BI_init                 sql_back_initialize;
+
+extern BI_destroy              backsql_destroy;
+
+extern BI_db_init              backsql_db_init;
+extern BI_db_open              backsql_db_open;
+extern BI_db_close             backsql_db_close;
+extern BI_db_destroy           backsql_db_destroy;
+extern BI_db_config            backsql_db_config;
+
+extern BI_op_bind              backsql_bind;
+extern BI_op_search            backsql_search;
+extern BI_op_compare           backsql_compare;
+extern BI_op_modify            backsql_modify;
+extern BI_op_modrdn            backsql_modrdn;
+extern BI_op_add               backsql_add;
+extern BI_op_delete            backsql_delete;
+
+extern BI_operational          backsql_operational;
+extern BI_entry_get_rw         backsql_entry_get;
+
+extern BI_connection_destroy   backsql_connection_destroy;
+
 #endif /* PROTO_SQL_H */