2019-12-09 20:45:58 -05:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include "../IStorage.h"
|
|
|
|
#include <rocksdb/db.h>
|
2020-02-17 19:00:31 -05:00
|
|
|
#include "../fastlock.h"
|
2019-12-09 20:45:58 -05:00
|
|
|
|
2020-03-23 18:06:47 -04:00
|
|
|
#define INTERNAL_KEY_PREFIX "\x00\x04\x03\x00\x05\x02\x04"
|
|
|
|
static const char count_key[] = INTERNAL_KEY_PREFIX "__keydb__count\1";
|
|
|
|
static const char version_key[] = INTERNAL_KEY_PREFIX "__keydb__version\1";
|
2020-03-17 17:11:41 -04:00
|
|
|
|
2019-12-09 20:45:58 -05:00
|
|
|
class RocksDBStorageProvider : public IStorage
|
|
|
|
{
|
|
|
|
std::shared_ptr<rocksdb::DB> m_spdb; // Note: This must be first so it is deleted last
|
|
|
|
std::unique_ptr<rocksdb::WriteBatch> m_spbatch;
|
|
|
|
const rocksdb::Snapshot *m_psnapshot = nullptr;
|
|
|
|
std::shared_ptr<rocksdb::ColumnFamilyHandle> m_spcolfamily;
|
|
|
|
rocksdb::ReadOptions m_readOptionsTemplate;
|
2019-12-22 18:38:10 -05:00
|
|
|
size_t m_count = 0;
|
2020-07-11 21:23:48 +00:00
|
|
|
mutable fastlock m_lock {"RocksDBStorageProvider"};
|
2019-12-09 20:45:58 -05:00
|
|
|
|
|
|
|
public:
|
2019-12-22 18:38:10 -05:00
|
|
|
RocksDBStorageProvider(std::shared_ptr<rocksdb::DB> &spdb, std::shared_ptr<rocksdb::ColumnFamilyHandle> &spcolfam, const rocksdb::Snapshot *psnapshot, size_t count);
|
2019-12-09 20:45:58 -05:00
|
|
|
~RocksDBStorageProvider();
|
|
|
|
|
2019-12-23 23:32:04 -05:00
|
|
|
virtual void insert(const char *key, size_t cchKey, void *data, size_t cb, bool fOverwrite) override;
|
2019-12-20 17:45:07 -05:00
|
|
|
virtual bool erase(const char *key, size_t cchKey) override;
|
|
|
|
virtual void retrieve(const char *key, size_t cchKey, callbackSingle fn) const override;
|
2019-12-09 20:45:58 -05:00
|
|
|
virtual size_t clear() override;
|
2019-12-20 17:45:07 -05:00
|
|
|
virtual bool enumerate(callback fn) const override;
|
2019-12-09 20:45:58 -05:00
|
|
|
|
|
|
|
virtual const IStorage *clone() const override;
|
|
|
|
|
|
|
|
virtual void beginWriteBatch() override;
|
|
|
|
virtual void endWriteBatch() override;
|
|
|
|
|
2020-06-04 22:18:03 -04:00
|
|
|
virtual void batch_lock() override;
|
|
|
|
virtual void batch_unlock() override;
|
|
|
|
|
2019-12-09 20:45:58 -05:00
|
|
|
virtual void flush() override;
|
|
|
|
|
2019-12-22 18:38:10 -05:00
|
|
|
size_t count() const;
|
2019-12-09 20:45:58 -05:00
|
|
|
|
|
|
|
protected:
|
2019-12-22 19:41:36 -05:00
|
|
|
bool FKeyExists(const char *key, size_t cchKey) const;
|
2019-12-09 20:45:58 -05:00
|
|
|
|
|
|
|
const rocksdb::ReadOptions &ReadOptions() const { return m_readOptionsTemplate; }
|
|
|
|
rocksdb::WriteOptions WriteOptions() const;
|
2020-03-23 19:47:48 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
bool FInternalKey(const char *key, size_t cch);
|