s3-dbwrap: Implement db_ctdb_parse_record in terms of db_ctdb_fetch
authorVolker Lendecke <vl@samba.org>
Thu, 8 Dec 2011 14:56:35 +0000 (15:56 +0100)
committerMichael Adam <obnox@samba.org>
Thu, 15 Dec 2011 15:00:45 +0000 (16:00 +0100)
Signed-off-by: Michael Adam <obnox@samba.org>
source3/lib/dbwrap/dbwrap_ctdb.c

index 7262b873fa6e541c9a7456c22f8b27012293c440..6246829400fa2bf00c84fa7f29661d1a5e8887e1 100644 (file)
@@ -1196,6 +1196,24 @@ static NTSTATUS db_ctdb_fetch(struct db_context *db, TALLOC_CTX *mem_ctx,
        return status;
 }
 
+static NTSTATUS db_ctdb_parse_record(struct db_context *db, TDB_DATA key,
+                                    void (*parser)(TDB_DATA key,
+                                                   TDB_DATA data,
+                                                   void *private_data),
+                                    void *private_data)
+{
+       NTSTATUS status;
+       TDB_DATA data;
+
+       status = db_ctdb_fetch(db, talloc_tos(), key, &data);
+       if (!NT_STATUS_IS_OK(status)) {
+               return status;
+       }
+       parser(key, data, private_data);
+       TALLOC_FREE(data.dptr);
+       return NT_STATUS_OK;
+}
+
 struct traverse_state {
        struct db_context *db;
        int (*fn)(struct db_record *rec, void *private_data);
@@ -1491,6 +1509,7 @@ struct db_context *db_open_ctdb(TALLOC_CTX *mem_ctx,
        result->private_data = (void *)db_ctdb;
        result->fetch_locked = db_ctdb_fetch_locked;
        result->fetch = db_ctdb_fetch;
+       result->parse_record = db_ctdb_parse_record;
        result->traverse = db_ctdb_traverse;
        result->traverse_read = db_ctdb_traverse_read;
        result->get_seqnum = db_ctdb_get_seqnum;