mirror of
https://github.com/matrix-construct/construct
synced 2025-01-13 16:33:53 +01:00
modules/vm_fetch: Checkpoint cruft removal.
This commit is contained in:
parent
450ec3523e
commit
88dfc8841d
4 changed files with 12 additions and 107 deletions
|
@ -4574,41 +4574,21 @@ console_cmd__event__fetch(opt &out, const string_view &line)
|
|||
m::room_id(param.at("room_id"))
|
||||
};
|
||||
|
||||
const unique_buffer<mutable_buffer> buf
|
||||
const net::hostport hostport
|
||||
{
|
||||
64_KiB
|
||||
room_id.host()
|
||||
};
|
||||
|
||||
using prototype = json::object (const m::room::id &,
|
||||
const m::event::id &,
|
||||
const mutable_buffer &);
|
||||
const net::hostport &);
|
||||
|
||||
static mods::import<prototype> acquire
|
||||
{
|
||||
"vm_fetch", "acquire"
|
||||
"vm_fetch", "state_fetch"
|
||||
};
|
||||
|
||||
const m::event event
|
||||
{
|
||||
acquire(room_id, event_id, buf)
|
||||
};
|
||||
|
||||
m::vm::opts vmopts;
|
||||
vmopts.non_conform.set(m::event::conforms::MISSING_PREV_STATE);
|
||||
vmopts.non_conform.set(m::event::conforms::MISSING_MEMBERSHIP);
|
||||
vmopts.prev_check_exists = false;
|
||||
vmopts.head_must_exist = false;
|
||||
vmopts.history = false;
|
||||
vmopts.notify = false;
|
||||
vmopts.verify = false;
|
||||
m::vm::eval eval
|
||||
{
|
||||
vmopts
|
||||
};
|
||||
|
||||
eval(event);
|
||||
|
||||
out << event << std::endl;
|
||||
acquire(room_id, event_id, hostport);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -10,7 +10,6 @@
|
|||
|
||||
namespace ircd::m::vm
|
||||
{
|
||||
|
||||
extern hook::site<eval &> commit_hook; ///< Called when this server issues event
|
||||
extern hook::site<eval &> fetch_hook; ///< Called to resolve dependencies
|
||||
extern hook::site<eval &> eval_hook; ///< Called when evaluating event
|
||||
|
|
|
@ -130,77 +130,9 @@ m::vm::fetch::enter(const event &event,
|
|||
// API interface
|
||||
//
|
||||
|
||||
json::object
|
||||
m::vm::fetch::acquire(const m::room::id &room_id,
|
||||
const m::event::id &event_id,
|
||||
const mutable_buffer &buf)
|
||||
{
|
||||
auto &request
|
||||
{
|
||||
_fetch(room_id, event_id)
|
||||
};
|
||||
|
||||
request.dock.wait([&request]
|
||||
{
|
||||
return request.finished;
|
||||
});
|
||||
|
||||
const unwind _remove_{[&event_id]
|
||||
{
|
||||
remove(event_id);
|
||||
}};
|
||||
|
||||
if(request.eptr)
|
||||
std::rethrow_exception(request.eptr);
|
||||
|
||||
const json::object &event
|
||||
{
|
||||
request
|
||||
};
|
||||
|
||||
return json::object
|
||||
{
|
||||
data(buf), copy(buf, event)
|
||||
};
|
||||
}
|
||||
|
||||
bool
|
||||
m::vm::fetch::prefetch(const m::room::id &room_id,
|
||||
const m::event::id &event_id)
|
||||
{
|
||||
_fetch(room_id, event_id);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool
|
||||
ircd::m::vm::fetch::remove(const m::event::id &event_id)
|
||||
{
|
||||
const auto it
|
||||
{
|
||||
fetching.find(event_id)
|
||||
};
|
||||
|
||||
if(it == end(fetching))
|
||||
return false;
|
||||
|
||||
const request &r{*it};
|
||||
if(!r.dock.empty())
|
||||
return false;
|
||||
|
||||
for(auto it(begin(fetched)); it != end(fetched); ++it)
|
||||
if(*it == &r)
|
||||
{
|
||||
fetched.erase(it);
|
||||
break;
|
||||
}
|
||||
|
||||
fetching.erase(it);
|
||||
return true;
|
||||
}
|
||||
|
||||
m::vm::fetch::request &
|
||||
m::vm::fetch::_fetch(const m::room::id &room_id,
|
||||
const m::event::id &event_id)
|
||||
m::vm::fetch::fetch(const m::room::id &room_id,
|
||||
const m::event::id &event_id)
|
||||
{
|
||||
auto it
|
||||
{
|
||||
|
@ -232,9 +164,6 @@ m::vm::fetch::dock;
|
|||
decltype(m::vm::fetch::fetching)
|
||||
m::vm::fetch::fetching;
|
||||
|
||||
decltype(m::vm::fetch::fetched)
|
||||
m::vm::fetch::fetched;
|
||||
|
||||
/// The fetch context is an internal worker which drives the fetch process
|
||||
/// and then indicates completion to anybody waiting on a fetch. This involves
|
||||
/// handling errors/timeouts from a fetch attempt and retrying with another
|
||||
|
@ -381,6 +310,10 @@ ircd::m::vm::fetch::request::select_random_origin()
|
|||
const auto proffer{[this]
|
||||
(const string_view &origin)
|
||||
{
|
||||
// Don't want to request from myself.
|
||||
if(my_host(origin))
|
||||
return false;
|
||||
|
||||
// Don't want to use a peer we already tried and failed with.
|
||||
if(attempted.count(origin))
|
||||
return false;
|
||||
|
@ -456,7 +389,6 @@ void
|
|||
ircd::m::vm::fetch::request::finish()
|
||||
{
|
||||
finished = ircd::time();
|
||||
fetched.emplace_back(this);
|
||||
dock.notify_all();
|
||||
}
|
||||
|
||||
|
|
|
@ -26,7 +26,6 @@ namespace ircd::m::vm::fetch
|
|||
|
||||
extern ctx::dock dock;
|
||||
extern std::set<request, request> fetching;
|
||||
extern std::deque<request *> fetched;
|
||||
extern hookfn<eval &> hook;
|
||||
extern ctx::context context;
|
||||
|
||||
|
@ -35,13 +34,8 @@ namespace ircd::m::vm::fetch
|
|||
static bool handle();
|
||||
static void worker();
|
||||
|
||||
// interface stack
|
||||
static request &_fetch(const m::room::id &, const m::event::id &);
|
||||
static bool remove(const m::event::id &);
|
||||
extern "C" bool prefetch(const m::room::id &, const m::event::id &);
|
||||
extern "C" json::object acquire(const m::room::id &, const m::event::id &, const mutable_buffer &);
|
||||
static request &fetch(const m::room::id &, const m::event::id &);
|
||||
|
||||
// phase stack
|
||||
static void enter(const event &, vm::eval &);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue