2018-01-26 12:26:09 -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
|
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_M_DBS_H
|
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
/// Database Schema
|
|
|
|
///
|
2018-01-26 12:26:09 -08:00
|
|
|
namespace ircd::m::dbs
|
|
|
|
{
|
2018-02-08 13:23:01 -08:00
|
|
|
struct init;
|
2018-03-02 22:03:06 -08:00
|
|
|
struct write_opts;
|
2018-02-08 13:23:01 -08:00
|
|
|
|
|
|
|
// Database instance
|
|
|
|
extern std::shared_ptr<db::database> events;
|
|
|
|
|
|
|
|
// Event property columns
|
|
|
|
constexpr const auto event_columns{event::size()};
|
|
|
|
extern std::array<db::column, event_columns> event_column;
|
|
|
|
|
|
|
|
// Event metadata columns
|
2018-05-04 13:58:49 -07:00
|
|
|
extern db::column event_idx; // event_id => event_idx
|
2018-05-04 15:02:32 -07:00
|
|
|
extern db::column event_bad; // event_id => event_idx
|
2018-05-04 19:47:39 -07:00
|
|
|
extern db::index room_head; // room_id | event_id => event_idx
|
2018-05-04 13:58:49 -07:00
|
|
|
extern db::index room_events; // room_id | depth, event_idx => state_root
|
|
|
|
extern db::index room_joined; // room_id | origin, member => event_idx
|
|
|
|
extern db::index room_state; // room_id | type, state_key => event_idx
|
|
|
|
extern db::column state_node; // node_id => state::node
|
2018-02-08 13:23:01 -08:00
|
|
|
|
|
|
|
// Lowlevel util
|
2018-05-04 19:47:39 -07:00
|
|
|
constexpr size_t ROOM_HEAD_KEY_MAX_SIZE {id::MAX_SIZE + 1 + id::MAX_SIZE};
|
|
|
|
string_view room_head_key(const mutable_buffer &out, const id::room &, const id::event &);
|
|
|
|
string_view room_head_key(const string_view &amalgam);
|
|
|
|
|
2018-05-01 16:51:35 -07:00
|
|
|
constexpr size_t ROOM_STATE_KEY_MAX_SIZE {id::MAX_SIZE + 256 + 256};
|
2018-03-03 23:39:24 -08:00
|
|
|
string_view room_state_key(const mutable_buffer &out, const id::room &, const string_view &type, const string_view &state_key);
|
|
|
|
string_view room_state_key(const mutable_buffer &out, const id::room &, const string_view &type);
|
2018-04-12 14:08:48 -07:00
|
|
|
std::pair<string_view, string_view> room_state_key(const string_view &amalgam);
|
2018-03-03 23:39:24 -08:00
|
|
|
|
2018-05-01 16:51:35 -07:00
|
|
|
constexpr size_t ROOM_JOINED_KEY_MAX_SIZE {id::MAX_SIZE + 256 + id::MAX_SIZE};
|
2018-04-15 14:40:10 -07:00
|
|
|
string_view room_joined_key(const mutable_buffer &out, const id::room &, const string_view &origin, const id::user &member);
|
|
|
|
string_view room_joined_key(const mutable_buffer &out, const id::room &, const string_view &origin);
|
|
|
|
std::pair<string_view, string_view> room_joined_key(const string_view &amalgam);
|
2018-03-04 00:08:30 -08:00
|
|
|
|
2018-05-01 16:51:35 -07:00
|
|
|
constexpr size_t ROOM_EVENTS_KEY_MAX_SIZE {id::MAX_SIZE + 1 + 8 + 8};
|
2018-04-17 19:14:39 -07:00
|
|
|
string_view room_events_key(const mutable_buffer &out, const id::room &, const uint64_t &depth, const event::idx &);
|
2018-02-13 14:21:57 -08:00
|
|
|
string_view room_events_key(const mutable_buffer &out, const id::room &, const uint64_t &depth);
|
2018-04-17 19:14:39 -07:00
|
|
|
std::pair<uint64_t, event::idx> room_events_key(const string_view &amalgam);
|
|
|
|
|
|
|
|
// [GET] the state root for an event (with as much information as you have)
|
|
|
|
string_view state_root(const mutable_buffer &out, const id::room &, const event::idx &, const uint64_t &depth);
|
|
|
|
string_view state_root(const mutable_buffer &out, const id::room &, const event::id &, const uint64_t &depth);
|
|
|
|
string_view state_root(const mutable_buffer &out, const id::room &, const event::idx &);
|
|
|
|
string_view state_root(const mutable_buffer &out, const id::room &, const event::id &);
|
|
|
|
string_view state_root(const mutable_buffer &out, const event::idx &);
|
|
|
|
string_view state_root(const mutable_buffer &out, const event::id &);
|
2018-02-08 13:23:01 -08:00
|
|
|
string_view state_root(const mutable_buffer &out, const event &);
|
|
|
|
|
|
|
|
// [SET (txn)] Basic write suite
|
2018-03-02 22:03:06 -08:00
|
|
|
string_view write(db::txn &, const event &, const write_opts &);
|
2018-05-04 15:14:19 -07:00
|
|
|
void blacklist(db::txn &, const event::id &, const write_opts &);
|
2018-01-26 12:26:09 -08:00
|
|
|
}
|
|
|
|
|
2018-03-02 22:03:06 -08:00
|
|
|
struct ircd::m::dbs::write_opts
|
|
|
|
{
|
2018-05-17 23:47:05 -07:00
|
|
|
uint64_t event_idx {0};
|
2018-03-02 22:03:06 -08:00
|
|
|
string_view root_in;
|
|
|
|
mutable_buffer root_out;
|
2018-03-24 22:46:43 -07:00
|
|
|
db::op op {db::op::SET};
|
2018-03-02 22:03:06 -08:00
|
|
|
bool present {true};
|
2018-03-03 23:39:24 -08:00
|
|
|
bool history {true};
|
2018-04-28 19:05:17 -07:00
|
|
|
bool indexer {true};
|
2018-05-04 20:10:35 -07:00
|
|
|
bool head {true};
|
|
|
|
bool refs {true};
|
2018-03-02 22:03:06 -08:00
|
|
|
};
|
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
/// Database Schema Descriptors
|
|
|
|
///
|
2018-02-08 13:23:01 -08:00
|
|
|
namespace ircd::m::dbs::desc
|
2018-01-26 12:26:09 -08:00
|
|
|
{
|
2018-02-08 13:23:01 -08:00
|
|
|
// Full description
|
|
|
|
extern const database::description events;
|
2018-01-26 12:26:09 -08:00
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
//
|
2018-02-08 13:23:01 -08:00
|
|
|
// Direct columns
|
2018-04-12 19:26:33 -07:00
|
|
|
//
|
|
|
|
|
2018-02-08 13:23:01 -08:00
|
|
|
extern const database::descriptor events_auth_events;
|
|
|
|
extern const database::descriptor events_content;
|
|
|
|
extern const database::descriptor events_depth;
|
|
|
|
extern const database::descriptor events_event_id;
|
|
|
|
extern const database::descriptor events_hashes;
|
|
|
|
extern const database::descriptor events_membership;
|
|
|
|
extern const database::descriptor events_origin;
|
|
|
|
extern const database::descriptor events_origin_server_ts;
|
|
|
|
extern const database::descriptor events_prev_events;
|
|
|
|
extern const database::descriptor events_prev_state;
|
2018-02-15 14:57:56 -08:00
|
|
|
extern const database::descriptor events_redacts;
|
2018-02-08 13:23:01 -08:00
|
|
|
extern const database::descriptor events_room_id;
|
|
|
|
extern const database::descriptor events_sender;
|
|
|
|
extern const database::descriptor events_signatures;
|
|
|
|
extern const database::descriptor events_state_key;
|
|
|
|
extern const database::descriptor events_type;
|
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
//
|
2018-02-08 13:23:01 -08:00
|
|
|
// Metadata columns
|
2018-04-12 19:26:33 -07:00
|
|
|
//
|
2018-03-04 00:08:30 -08:00
|
|
|
|
2018-04-17 19:14:39 -07:00
|
|
|
// events index
|
|
|
|
extern const database::descriptor events__event_idx;
|
|
|
|
|
2018-05-04 15:02:32 -07:00
|
|
|
// events blacklist
|
|
|
|
extern const database::descriptor events__event_bad;
|
|
|
|
|
2018-05-04 19:47:39 -07:00
|
|
|
// room head mapping sequence
|
|
|
|
extern const db::prefix_transform events__room_head__pfx;
|
|
|
|
extern const database::descriptor events__room_head;
|
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
// room events sequence
|
2018-02-08 13:23:01 -08:00
|
|
|
extern const db::prefix_transform events__room_events__pfx;
|
2018-02-08 15:15:48 -08:00
|
|
|
extern const db::comparator events__room_events__cmp;
|
2018-02-08 13:23:01 -08:00
|
|
|
extern const database::descriptor events__room_events;
|
2018-03-04 00:08:30 -08:00
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
// room present joined members sequence
|
2018-04-15 14:40:10 -07:00
|
|
|
extern const db::prefix_transform events__room_joined__pfx;
|
|
|
|
extern const database::descriptor events__room_joined;
|
2018-03-03 23:39:24 -08:00
|
|
|
|
2018-04-16 14:20:50 -07:00
|
|
|
// room present state mapping sequence
|
|
|
|
extern const db::prefix_transform events__room_state__pfx;
|
|
|
|
extern const database::descriptor events__room_state;
|
|
|
|
|
2018-04-12 19:26:33 -07:00
|
|
|
// state btree node key-value store
|
|
|
|
extern const database::descriptor events__state_node;
|
2018-01-26 12:26:09 -08:00
|
|
|
}
|
|
|
|
|
2018-05-05 18:54:02 -07:00
|
|
|
// Internal interface; not for public.
|
|
|
|
namespace ircd::m::dbs
|
|
|
|
{
|
|
|
|
void _index__room_state(db::txn &, const event &, const write_opts &);
|
|
|
|
void _index__room_events(db::txn &, const event &, const write_opts &, const string_view &);
|
|
|
|
void _index__room_joined(db::txn &, const event &, const write_opts &);
|
|
|
|
void _index__room_head(db::txn &, const event &, const write_opts &);
|
|
|
|
string_view _index_state(db::txn &, const event &, const write_opts &);
|
|
|
|
string_view _index_redact(db::txn &, const event &, const write_opts &);
|
|
|
|
string_view _index_ephem(db::txn &, const event &, const write_opts &);
|
2018-05-17 23:47:05 -07:00
|
|
|
void _index__event(db::txn &, const event &, const write_opts &);
|
2018-05-05 18:54:02 -07:00
|
|
|
}
|
|
|
|
|
2018-02-08 13:23:01 -08:00
|
|
|
struct ircd::m::dbs::init
|
|
|
|
{
|
2018-04-09 12:56:43 -07:00
|
|
|
init(std::string dbopts = {});
|
2018-02-08 13:23:01 -08:00
|
|
|
~init() noexcept;
|
|
|
|
};
|