0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-14 16:46:50 +01:00

ircd:Ⓜ️ Add additional horizon rebuilders.

This commit is contained in:
Jason Volk 2019-08-30 22:56:54 -07:00
parent 91cc12db84
commit 217b2d51d5
5 changed files with 126 additions and 7 deletions

View file

@ -111,6 +111,8 @@ struct ircd::m::room::events::missing
bool for_each(const closure &) const; bool for_each(const closure &) const;
size_t count() const; size_t count() const;
size_t rebuild();
missing() = default; missing() = default;
missing(const m::room &room) missing(const m::room &room)
:room{room} :room{room}

View file

@ -246,7 +246,7 @@ namespace ircd::m::dbs
static void _index_event_type(db::txn &, const event &, const write_opts &); static void _index_event_type(db::txn &, const event &, const write_opts &);
static void _index_event_sender(db::txn &, const event &, const write_opts &); static void _index_event_sender(db::txn &, const event &, const write_opts &);
static void _index_event_horizon_resolve(db::txn &, const event &, const write_opts &); //query static void _index_event_horizon_resolve(db::txn &, const event &, const write_opts &); //query
static void _index_event_horizon(db::txn &, const event &, const write_opts &, const id::event &); void _index_event_horizon(db::txn &, const event &, const write_opts &, const id::event &);
static void _index_event_refs_m_room_redaction(db::txn &, const event &, const write_opts &); //query static void _index_event_refs_m_room_redaction(db::txn &, const event &, const write_opts &); //query
static void _index_event_refs_m_receipt_m_read(db::txn &, const event &, const write_opts &); //query static void _index_event_refs_m_receipt_m_read(db::txn &, const event &, const write_opts &); //query
static void _index_event_refs_m_relates_m_reply(db::txn &, const event &, const write_opts &); //query static void _index_event_refs_m_relates_m_reply(db::txn &, const event &, const write_opts &); //query

View file

@ -1671,12 +1671,6 @@ ircd::m::index(const event::id &event_id,
// event/horizon.h // event/horizon.h
// //
size_t
ircd::m::event::horizon::rebuild()
{
throw not_implemented{};
}
bool bool
ircd::m::event::horizon::has(const event::id &event_id) ircd::m::event::horizon::has(const event::id &event_id)
{ {

View file

@ -9631,6 +9631,33 @@ console_cmd__room__events__missing(opt &out, const string_view &line)
return true; return true;
} }
bool
console_cmd__room__events__missing__rebuild(opt &out, const string_view &line)
{
const params param{line, " ",
{
"room_id"
}};
const auto &room_id
{
m::room_id(param.at("room_id"))
};
const m::room room
{
room_id
};
m::room::events::missing missing
{
room
};
out << "done " << missing.rebuild() << std::endl;
return true;
}
bool bool
console_cmd__room__messages(opt &out, const string_view &line) console_cmd__room__messages(opt &out, const string_view &line)
{ {

View file

@ -147,3 +147,99 @@ ircd::m::pretty_stateline(std::ostream &out,
out << std::endl; out << std::endl;
return out; return out;
} }
///////////////////////////////////////////////////////////////////////////////
//
// event/horizon.h
//
//TODO: XXX remove fwd decl
namespace ircd::m::dbs
{
void _index_event_horizon(db::txn &, const event &, const write_opts &, const m::event::id &);
}
size_t
ircd::m::event::horizon::rebuild()
{
m::dbs::write_opts opts;
opts.appendix.reset();
opts.appendix.set(dbs::appendix::EVENT_HORIZON);
db::txn txn
{
*dbs::events
};
size_t ret(0);
m::events::for_each({0UL, -1UL}, [&ret, &txn, &opts]
(const m::event::idx &event_idx, const m::event &event)
{
const m::event::prev prev
{
event
};
m::for_each(prev, [&ret, &txn, &opts, &event_idx, &event]
(const m::event::id &event_id)
{
if(m::exists(event_id))
return true;
opts.event_idx = event_idx;
m::dbs::_index_event_horizon(txn, event, opts, event_id);
if(++ret % 1024 == 0)
log::info
{
m::log, "event::horizon rebuild @ %lu/%lu",
event_idx,
m::vm::sequence::retired,
};
return true;
});
return true;
});
txn();
return ret;
}
size_t
ircd::m::room::events::missing::rebuild()
{
m::dbs::write_opts opts;
opts.appendix.reset();
opts.appendix.set(dbs::appendix::EVENT_HORIZON);
db::txn txn
{
*dbs::events
};
size_t ret(0);
m::room::events it
{
room
};
for(; it; --it)
{
const m::event &event{*it};
const event::prev prev_events{event};
opts.event_idx = it.event_idx();
m::for_each(prev_events, [&]
(const m::event::id &event_id)
{
if(m::exists(event_id))
return true;
m::dbs::_index_event_horizon(txn, event, opts, event_id);
++ret;
return true;
});
}
txn();
return ret;
}