modules/console: Refactor feds auth output into grid report; add type filter.

This commit is contained in:
Jason Volk 2023-03-11 15:22:05 -08:00
parent fb9f2b0bcc
commit 7e28a27549
1 changed files with 50 additions and 7 deletions

View File

@ -14895,7 +14895,7 @@ console_cmd__feds__auth(opt &out, const string_view &line)
{
const params param{line, " ",
{
"room_id", "event_id"
"room_id", "event_id", "type"
}};
const auto &room_id
@ -14908,30 +14908,73 @@ console_cmd__feds__auth(opt &out, const string_view &line)
param.at("event_id")
};
const auto type
{
param["type"]
};
size_t count[2] {0};
std::set<string_view> origins;
std::map<std::string, std::set<std::string>, std::less<>> grid;
m::feds::opts opts;
opts.op = m::feds::op::auth;
opts.room_id = room_id;
opts.event_id = event_id;
m::feds::execute(opts, [&out](const auto &result)
m::feds::execute(opts, [&]
(const auto &result)
{
count[bool(result.eptr)]++;
if(result.eptr)
return true;
const json::array auth_chain
{
result.object.at("auth_chain")
result.object["auth_chain"]
};
out << "+ " << std::setw(40) << std::left << result.origin;
for(const json::object auth_event : auth_chain)
{
out << " " << unquote(auth_event.at("event_id"));
};
if(type && json::string(auth_event["type"]) != type)
continue;
const json::string event_id
{
auth_event.at("event_id")
};
auto it(grid.lower_bound(event_id));
if(it == end(grid) || it->first != event_id)
it = grid.emplace_hint(it, event_id, std::set<std::string>{});
auto &set(it->second);
const auto iit(set.emplace(result.origin));
origins.emplace(*iit.first);
}
out << std::endl;
return true;
});
size_t i(0);
for(const auto &p : grid)
out << i++ << " " << p.first << std::endl;
for(size_t j(0); j < i; ++j)
out << "| " << std::left << std::setw(2) << j;
out << "|" << std::endl;
for(const auto &origin : origins)
{
for(const auto &p : grid)
out << "| " << (p.second.count(origin)? '+' : ' ') << " ";
out << "| " << origin << std::endl;
}
out
<< '\n'
<< count[0] << ':' << count[1]
<< std::endl;
return true;
}