X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=localdb.cc;h=9ec0c968cc55beaecb2f3a99de355269c6f62a4f;hb=def20364a3596d7b1fa4a07f3d3ee056cfff2d1e;hp=951f35ceb67063f8a627f2d564a39a97071ea317;hpb=58a0d3f8749111c15e9afa9d929016d65ed32250;p=cumulus.git diff --git a/localdb.cc b/localdb.cc index 951f35c..9ec0c96 100644 --- a/localdb.cc +++ b/localdb.cc @@ -38,7 +38,8 @@ sqlite3_stmt *LocalDb::Prepare(const char *sql) return stmt; } -void LocalDb::Open(const char *path, const char *snapshot_name) +void LocalDb::Open(const char *path, const char *snapshot_name, + const char *snapshot_scheme) { int rc; @@ -58,10 +59,16 @@ void LocalDb::Open(const char *path, const char *snapshot_name) /* Insert this snapshot into the database, and determine the integer key * which will be used to identify it. */ - sqlite3_stmt *stmt = Prepare("insert into snapshots(name, timestamp) " - "values (?, julianday('now'))"); + sqlite3_stmt *stmt = Prepare("insert into " + "snapshots(name, scheme, timestamp) " + "values (?, ?, julianday('now'))"); sqlite3_bind_text(stmt, 1, snapshot_name, strlen(snapshot_name), SQLITE_TRANSIENT); + if (snapshot_scheme == NULL) + sqlite3_bind_null(stmt, 2); + else + sqlite3_bind_text(stmt, 2, snapshot_scheme, strlen(snapshot_scheme), + SQLITE_TRANSIENT); rc = sqlite3_step(stmt); if (rc != SQLITE_DONE) { @@ -144,14 +151,21 @@ string LocalDb::IdToSegment(int64_t segmentid) } void LocalDb::StoreObject(const ObjectReference& ref, - const string &checksum, int64_t size) + const string &checksum, int64_t size, + double age) { int rc; sqlite3_stmt *stmt; - stmt = Prepare("insert into " - "block_index(segmentid, object, checksum, size, timestamp) " - "values (?, ?, ?, ?, julianday('now'))"); + if (age == 0.0) { + stmt = Prepare("insert into block_index(" + "segmentid, object, checksum, size, timestamp) " + "values (?, ?, ?, ?, julianday('now'))"); + } else { + stmt = Prepare("insert into block_index(" + "segmentid, object, checksum, size, timestamp) " + "values (?, ?, ?, ?, ?)"); + } sqlite3_bind_int64(stmt, 1, SegmentToId(ref.get_segment())); string obj = ref.get_sequence(); @@ -159,6 +173,8 @@ void LocalDb::StoreObject(const ObjectReference& ref, sqlite3_bind_text(stmt, 3, checksum.c_str(), checksum.size(), SQLITE_TRANSIENT); sqlite3_bind_int64(stmt, 4, size); + if (age != 0.0) + sqlite3_bind_double(stmt, 5, age); rc = sqlite3_step(stmt); if (rc != SQLITE_DONE) { @@ -194,13 +210,13 @@ ObjectReference LocalDb::FindObject(const string &checksum, int64_t size) return ref; } -bool LocalDb::IsOldObject(const string &checksum, int64_t size) +bool LocalDb::IsOldObject(const string &checksum, int64_t size, double *age) { int rc; sqlite3_stmt *stmt; bool found = false; - stmt = Prepare("select segmentid, object from block_index " + stmt = Prepare("select segmentid, object, timestamp from block_index " "where checksum = ? and size = ?"); sqlite3_bind_text(stmt, 1, checksum.c_str(), checksum.size(), SQLITE_TRANSIENT); @@ -211,6 +227,35 @@ bool LocalDb::IsOldObject(const string &checksum, int64_t size) found = false; } else if (rc == SQLITE_ROW) { found = true; + *age = sqlite3_column_double(stmt, 2); + } else { + fprintf(stderr, "Could not execute SELECT statement!\n"); + } + + sqlite3_finalize(stmt); + + return found; +} + +/* Does this object still exist in the database (and not expired)? */ +bool LocalDb::IsAvailable(const ObjectReference &ref) +{ + int rc; + sqlite3_stmt *stmt; + bool found = false; + + stmt = Prepare("select count(*) from block_index " + "where segmentid = ? and object = ? and expired is null"); + sqlite3_bind_int64(stmt, 1, SegmentToId(ref.get_segment())); + sqlite3_bind_text(stmt, 2, ref.get_sequence().c_str(), + ref.get_sequence().size(), SQLITE_TRANSIENT); + + rc = sqlite3_step(stmt); + if (rc == SQLITE_DONE) { + found = false; + } else if (rc == SQLITE_ROW) { + if (sqlite3_column_int(stmt, 0) > 0) + found = true; } else { fprintf(stderr, "Could not execute SELECT statement!\n"); }