r25084: Move samba-specific code out of lib/ldb directory.
[kai/samba.git] / source4 / lib / ldb / ldb_tdb / ldb_tdb.h
index 891522f3008118c3235cb478c34b424b42a7e608..61b5f789d768f462dd05c7354aade87a34e6fdbf 100644 (file)
@@ -1,7 +1,5 @@
-
-#ifdef _SAMBA_BUILD_
-#include "system/filesys.h"
-#include "lib/tdb/include/tdb.h"
+#if (_SAMBA_BUILD_ == 3)
+#include "tdb/include/tdb.h"
 #else
 #include "tdb.h"
 #endif
@@ -14,10 +12,13 @@ struct ltdb_private {
        
        /* a double is used for portability and ease of string
           handling. It has plenty of digits of precision */
-       double sequence_number;
+       unsigned long long sequence_number;
+
+       /* the low level tdb seqnum - used to avoid loading BASEINFO when
+          possible */
+       int tdb_seqnum;
 
        struct ltdb_cache {
-               struct ldb_message *baseinfo;
                struct ldb_message *indexlist;
                struct ldb_message *attributes;
                struct ldb_message *subclasses;
@@ -27,9 +28,24 @@ struct ltdb_private {
                        int flags;
                } last_attribute;
        } *cache;
+};
 
-       /* error if an internal ldb+tdb error */
-       const char *last_err_string;
+/*
+  the async local context
+  holds also internal search state during a full db search
+*/
+struct ltdb_context {
+       struct ldb_module *module;
+
+       /* search stuff */
+       const struct ldb_parse_tree *tree;
+       struct ldb_dn *base;
+       enum ldb_scope scope;
+       const char * const *attrs;
+
+       /* async stuff */
+       void *context;
+       int (*callback)(struct ldb_context *, void *, struct ldb_reply *);
 };
 
 /* special record types */
@@ -37,41 +53,31 @@ struct ltdb_private {
 #define LTDB_INDEXLIST  "@INDEXLIST"
 #define LTDB_IDX        "@IDX"
 #define LTDB_IDXATTR    "@IDXATTR"
+#define LTDB_IDXONE     "@IDXONE"
 #define LTDB_BASEINFO   "@BASEINFO"
 #define LTDB_ATTRIBUTES "@ATTRIBUTES"
 #define LTDB_SUBCLASSES "@SUBCLASSES"
 
 /* special attribute types */
 #define LTDB_SEQUENCE_NUMBER "sequenceNumber"
+#define LTDB_MOD_TIMESTAMP "whenChanged"
 #define LTDB_OBJECTCLASS "objectClass"
 
-/* well known attribute flags */
-#define LTDB_FLAG_CASE_INSENSITIVE (1<<0)
-#define LTDB_FLAG_INTEGER          (1<<1)
-#define LTDB_FLAG_WILDCARD         (1<<2)
-#define LTDB_FLAG_OBJECTCLASS      (1<<3)
-#define LTDB_FLAG_HIDDEN           (1<<4)
-#define LTDB_FLAG_NONE             0 
-
 /* The following definitions come from lib/ldb/ldb_tdb/ldb_cache.c  */
 
 int ltdb_cache_reload(struct ldb_module *module);
 int ltdb_cache_load(struct ldb_module *module);
 int ltdb_increase_sequence_number(struct ldb_module *module);
-int ltdb_attribute_flags(struct ldb_module *module, const char *attr_name);
 int ltdb_check_at_attributes_values(const struct ldb_val *value);
 
 /* The following definitions come from lib/ldb/ldb_tdb/ldb_index.c  */
 
 struct ldb_parse_tree;
 
-int ltdb_search_indexed(struct ldb_module *module, 
-                       const char *base,
-                       enum ldb_scope scope,
-                       struct ldb_parse_tree *tree,
-                       const char * const attrs[], struct ldb_message ***res);
+int ltdb_search_indexed(struct ldb_handle *handle);
 int ltdb_index_add(struct ldb_module *module, const struct ldb_message *msg);
 int ltdb_index_del(struct ldb_module *module, const struct ldb_message *msg);
+int ltdb_index_one(struct ldb_module *module, const struct ldb_message *msg, int add);
 int ltdb_reindex(struct ldb_module *module);
 
 /* The following definitions come from lib/ldb/ldb_tdb/ldb_pack.c  */
@@ -90,39 +96,29 @@ int ltdb_unpack_data(struct ldb_module *module,
 int ltdb_has_wildcard(struct ldb_module *module, const char *attr_name, 
                      const struct ldb_val *val);
 void ltdb_search_dn1_free(struct ldb_module *module, struct ldb_message *msg);
-int ltdb_search_dn1(struct ldb_module *module, const char *dn, struct ldb_message *msg);
-int ltdb_search_dn(struct ldb_module *module, char *dn,
-                  const char * const attrs[], struct ldb_message ***res);
-int ltdb_add_attr_results(struct ldb_module *module, struct ldb_message *msg,
+int ltdb_search_dn1(struct ldb_module *module, struct ldb_dn *dn, struct ldb_message *msg);
+int ltdb_add_attr_results(struct ldb_module *module,
+                         TALLOC_CTX *mem_ctx, 
+                         struct ldb_message *msg,
                          const char * const attrs[], 
-                         int *count, 
+                         unsigned int *count, 
                          struct ldb_message ***res);
-int ltdb_search(struct ldb_module *module, const char *base,
-               enum ldb_scope scope, const char *expression,
-               const char * const attrs[], struct ldb_message ***res);
-int ltdb_search_bytree(struct ldb_module *module, const char *base,
-                      enum ldb_scope scope, struct ldb_parse_tree *tree,
-                      const char * const attrs[], struct ldb_message ***res);
-
+int ltdb_filter_attrs(struct ldb_message *msg, const char * const *attrs);
+int ltdb_search(struct ldb_module *module, struct ldb_request *req);
 
 /* The following definitions come from lib/ldb/ldb_tdb/ldb_tdb.c  */
-struct TDB_DATA ltdb_key(struct ldb_module *module, const char *dn);
+struct ldb_handle *init_ltdb_handle(struct ltdb_private *ltdb, struct ldb_module *module,
+                                   struct ldb_request *req);
+struct TDB_DATA ltdb_key(struct ldb_module *module, struct ldb_dn *dn);
 int ltdb_store(struct ldb_module *module, const struct ldb_message *msg, int flgs);
-int ltdb_delete_noindex(struct ldb_module *module, const char *dn);
+int ltdb_delete_noindex(struct ldb_module *module, struct ldb_dn *dn);
 int ltdb_modify_internal(struct ldb_module *module, const struct ldb_message *msg);
-int ltdb_lock_read(struct ldb_module *module);
-int ltdb_unlock_read(struct ldb_module *module);
-
-/* The following definitions come from lib/ldb/ldb_tdb/ldb_match.c  */
-int ltdb_val_equal(struct ldb_module *module,
-                 const char *attr_name,
-                 const struct ldb_val *v1, const struct ldb_val *v2);
-int ltdb_message_match(struct ldb_module *module, 
-                     struct ldb_message *msg,
-                     struct ldb_parse_tree *tree,
-                     const char *base,
-                     enum ldb_scope scope);
 
 int ltdb_index_del_value(struct ldb_module *module, const char *dn, 
                         struct ldb_message_element *el, int v_idx);
 
+struct tdb_context *ltdb_wrap_open(TALLOC_CTX *mem_ctx,
+                                  const char *path, int hash_size, int tdb_flags,
+                                  int open_flags, mode_t mode,
+                                  struct ldb_context *ldb);
+