Fix bug #6195 - Migrating from 3.0.x to 3.3.x can fail to update passdb.tdb correctly...
[ira/wip.git] / source3 / include / dbwrap.h
index c175f69c4dec04f54b8a410325a68d7f67c628ce..1803587c4aca12ac7ea4f8041614f0d28605e6f9 100644 (file)
@@ -34,21 +34,70 @@ struct db_context {
        int (*fetch)(struct db_context *db, TALLOC_CTX *mem_ctx,
                     TDB_DATA key, TDB_DATA *data);
        int (*traverse)(struct db_context *db,
-                       int (*f)(struct db_record *db,
+                       int (*f)(struct db_record *rec,
                                 void *private_data),
                        void *private_data);
        int (*traverse_read)(struct db_context *db,
-                            int (*f)(struct db_record *db,
+                            int (*f)(struct db_record *rec,
                                      void *private_data),
                             void *private_data);
        int (*get_seqnum)(struct db_context *db);
+       int (*get_flags)(struct db_context *db);
+       int (*transaction_start)(struct db_context *db);
+       int (*transaction_commit)(struct db_context *db);
+       int (*transaction_cancel)(struct db_context *db);
+       int (*parse_record)(struct db_context *db, TDB_DATA key,
+                           int (*parser)(TDB_DATA key, TDB_DATA data,
+                                         void *private_data),
+                           void *private_data);
        void *private_data;
+       bool persistent;
 };
 
+bool db_is_local(const char *name);
+
 struct db_context *db_open(TALLOC_CTX *mem_ctx,
                           const char *name,
                           int hash_size, int tdb_flags,
                           int open_flags, mode_t mode);
 
+struct db_context *db_open_rbt(TALLOC_CTX *mem_ctx);
+
+struct db_context *db_open_tdb(TALLOC_CTX *mem_ctx,
+                              const char *name,
+                              int hash_size, int tdb_flags,
+                              int open_flags, mode_t mode);
+
+struct db_context *db_open_tdb2(TALLOC_CTX *mem_ctx,
+                               const char *name,
+                               int hash_size, int tdb_flags,
+                               int open_flags, mode_t mode);
+
+struct messaging_context;
+
+#ifdef CLUSTER_SUPPORT
+struct db_context *db_open_ctdb(TALLOC_CTX *mem_ctx,
+                               const char *name,
+                               int hash_size, int tdb_flags,
+                               int open_flags, mode_t mode);
+#endif
+
+struct db_context *db_open_file(TALLOC_CTX *mem_ctx,
+                               struct messaging_context *msg_ctx,
+                               const char *name,
+                               int hash_size, int tdb_flags,
+                               int open_flags, mode_t mode);
+
+
+NTSTATUS dbwrap_delete(struct db_context *db, TDB_DATA key);
+NTSTATUS dbwrap_store(struct db_context *db, TDB_DATA key,
+                     TDB_DATA data, int flags);
+TDB_DATA dbwrap_fetch(struct db_context *db, TALLOC_CTX *mem_ctx,
+                     TDB_DATA key);
+NTSTATUS dbwrap_delete_bystring(struct db_context *db, const char *key);
+NTSTATUS dbwrap_store_bystring(struct db_context *db, const char *key,
+                              TDB_DATA data, int flags);
+TDB_DATA dbwrap_fetch_bystring(struct db_context *db, TALLOC_CTX *mem_ctx,
+                              const char *key);
 
 #endif /* __DBWRAP_H__ */