2018-01-17 18:14:13 -08:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
|
|
|
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
|
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
2018-02-03 18:22:01 -08:00
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
2017-09-18 19:19:02 -07:00
|
|
|
|
|
|
|
#pragma once
|
2018-01-30 09:58:36 -08:00
|
|
|
#define HAVE_IRCD_DB_TXN_H
|
2017-09-18 19:19:02 -07:00
|
|
|
|
|
|
|
namespace ircd::db
|
|
|
|
{
|
2018-01-30 09:58:36 -08:00
|
|
|
struct txn;
|
2017-09-18 19:19:02 -07:00
|
|
|
|
2019-05-09 16:28:17 -07:00
|
|
|
using delta_closure = std::function<void (const delta &)>;
|
|
|
|
using delta_closure_bool = std::function<bool (const delta &)>;
|
2018-03-27 15:21:00 -07:00
|
|
|
using seq_closure = std::function<void (txn &, const uint64_t &)>;
|
2019-05-09 16:28:17 -07:00
|
|
|
using seq_closure_bool = std::function<bool (txn &, const uint64_t &)>;
|
|
|
|
|
|
|
|
bool for_each(const txn &, const delta_closure_bool &);
|
|
|
|
void for_each(const txn &, const delta_closure &);
|
2018-03-22 20:49:11 -07:00
|
|
|
bool for_each(database &d, const uint64_t &seq, const seq_closure_bool &);
|
|
|
|
void for_each(database &d, const uint64_t &seq, const seq_closure &);
|
2018-03-27 15:21:30 -07:00
|
|
|
void get(database &d, const uint64_t &seq, const seq_closure &);
|
2019-05-09 16:28:17 -07:00
|
|
|
std::string debug(const txn &);
|
2017-09-18 19:19:02 -07:00
|
|
|
}
|
|
|
|
|
2018-03-22 20:48:23 -07:00
|
|
|
struct ircd::db::txn
|
2017-09-18 19:19:02 -07:00
|
|
|
{
|
2019-05-09 16:28:17 -07:00
|
|
|
struct opts;
|
|
|
|
struct checkpoint;
|
|
|
|
struct append;
|
|
|
|
struct handler;
|
2019-03-19 13:13:16 -07:00
|
|
|
enum state :uint8_t;
|
2019-05-09 16:28:17 -07:00
|
|
|
using value_closure = std::function<void (const string_view &)>;
|
2019-03-19 13:13:16 -07:00
|
|
|
|
2017-09-18 19:19:02 -07:00
|
|
|
database *d {nullptr};
|
|
|
|
std::unique_ptr<rocksdb::WriteBatch> wb;
|
2019-03-19 13:13:16 -07:00
|
|
|
enum state state {0};
|
2017-09-18 19:19:02 -07:00
|
|
|
|
|
|
|
public:
|
|
|
|
explicit operator const rocksdb::WriteBatch &() const;
|
|
|
|
explicit operator const database &() const;
|
|
|
|
explicit operator rocksdb::WriteBatch &();
|
|
|
|
explicit operator database &();
|
|
|
|
|
2019-05-09 19:02:06 -07:00
|
|
|
template<class T = string_view> T val(const op &, const string_view &col, const string_view &key, T def = {}) const;
|
|
|
|
template<class T = string_view> T at(const op &, const string_view &col, const string_view &key) const;
|
2018-04-16 15:16:51 -07:00
|
|
|
bool get(const op &, const string_view &col, const string_view &key, const value_closure &) const;
|
|
|
|
void at(const op &, const string_view &col, const string_view &key, const value_closure &) const;
|
2017-09-18 20:40:13 -07:00
|
|
|
bool has(const op &, const string_view &col, const string_view &key) const;
|
|
|
|
|
2018-04-16 15:16:51 -07:00
|
|
|
bool get(const op &, const string_view &col, const delta_closure &) const;
|
|
|
|
void at(const op &, const string_view &col, const delta_closure &) const;
|
2017-09-18 20:40:13 -07:00
|
|
|
bool has(const op &, const string_view &col) const;
|
2017-09-18 19:19:02 -07:00
|
|
|
bool has(const op &) const;
|
2017-09-18 20:40:13 -07:00
|
|
|
|
2018-09-26 15:28:36 -07:00
|
|
|
size_t bytes() const; // size of data in txn.
|
|
|
|
size_t size() const; // count of updates in txn.
|
2017-09-18 19:19:02 -07:00
|
|
|
|
|
|
|
// commit
|
|
|
|
void operator()(database &, const sopts & = {});
|
|
|
|
void operator()(const sopts & = {});
|
|
|
|
|
|
|
|
// clear
|
|
|
|
void clear();
|
|
|
|
|
2018-01-30 09:58:36 -08:00
|
|
|
txn() = default;
|
|
|
|
txn(database &);
|
|
|
|
txn(database &, const opts &);
|
2018-03-22 20:48:23 -07:00
|
|
|
txn(database &, std::unique_ptr<rocksdb::WriteBatch> &&);
|
2018-01-30 09:58:36 -08:00
|
|
|
~txn() noexcept;
|
2017-09-18 19:19:02 -07:00
|
|
|
};
|
|
|
|
|
2019-03-19 13:13:16 -07:00
|
|
|
enum ircd::db::txn::state
|
|
|
|
:uint8_t
|
|
|
|
{
|
|
|
|
BUILD = 0,
|
|
|
|
COMMIT = 1,
|
|
|
|
COMMITTED = 2,
|
|
|
|
};
|
|
|
|
|
2018-01-30 09:58:36 -08:00
|
|
|
struct ircd::db::txn::append
|
2017-09-18 19:19:02 -07:00
|
|
|
{
|
2018-01-30 09:58:36 -08:00
|
|
|
append(txn &, database &, const delta &);
|
|
|
|
append(txn &, column &, const column::delta &);
|
|
|
|
append(txn &, const cell::delta &);
|
|
|
|
append(txn &, const row::delta &);
|
|
|
|
append(txn &, const delta &);
|
|
|
|
append(txn &, const string_view &key, const json::iov &);
|
2017-09-18 19:19:02 -07:00
|
|
|
};
|
|
|
|
|
2018-01-30 09:58:36 -08:00
|
|
|
struct ircd::db::txn::checkpoint
|
2017-09-18 19:19:02 -07:00
|
|
|
{
|
2018-01-30 09:58:36 -08:00
|
|
|
txn &t;
|
2017-09-18 20:43:32 -07:00
|
|
|
|
2018-01-30 09:58:36 -08:00
|
|
|
checkpoint(txn &);
|
2017-09-18 20:43:32 -07:00
|
|
|
~checkpoint() noexcept;
|
2017-09-18 19:19:02 -07:00
|
|
|
};
|
|
|
|
|
2018-01-30 09:58:36 -08:00
|
|
|
struct ircd::db::txn::opts
|
2017-09-18 19:19:02 -07:00
|
|
|
{
|
|
|
|
size_t reserve_bytes = 0;
|
|
|
|
size_t max_bytes = 0;
|
|
|
|
};
|
2019-05-09 19:02:06 -07:00
|
|
|
|
|
|
|
template<class T>
|
|
|
|
T
|
|
|
|
ircd::db::txn::at(const op &op,
|
|
|
|
const string_view &col,
|
|
|
|
const string_view &key)
|
|
|
|
const
|
|
|
|
{
|
|
|
|
T ret;
|
|
|
|
at(op, col, key, [&ret](const string_view &val)
|
|
|
|
{
|
|
|
|
ret = byte_view<T>(val);
|
|
|
|
});
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
T
|
|
|
|
ircd::db::txn::val(const op &op,
|
|
|
|
const string_view &col,
|
|
|
|
const string_view &key,
|
|
|
|
T ret)
|
|
|
|
const
|
|
|
|
{
|
|
|
|
get(op, col, key, value_closure{[&ret](const string_view &val)
|
|
|
|
{
|
|
|
|
ret = byte_view<T>(val);
|
|
|
|
}});
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|