0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-14 00:34:18 +01:00

ircd:Ⓜ️:keys: Fix response handling for feds parallel key request.

This commit is contained in:
Jason Volk 2020-05-05 13:25:45 -07:00
parent 3fe0729340
commit 8029d25c2d

View file

@ -391,7 +391,7 @@ ircd::m::keys::get(const queries &queries,
bool ret{true}; bool ret{true};
std::vector<m::feds::opts> opts; std::vector<m::feds::opts> opts;
opts.reserve(queries.size()); opts.reserve(queries.size());
for(const auto &[server_name, key_id] : queries) for(const auto &[server_name, key_id] : queries) try
{ {
assert(key_id); assert(key_id);
assert(server_name); assert(server_name);
@ -461,29 +461,44 @@ ircd::m::keys::get(const queries &queries,
result.object["server_keys"] result.object["server_keys"]
}; };
if(empty(server_keys)) for(const json::object &keys : server_keys)
return true;
const m::keys keys
{ {
server_keys const json::string &server_name
};
if(!verify(keys, std::nothrow))
{
log::derror
{ {
m::log, "Failed to verify key '%s' for '%s' from '%s'", keys["server_name"]
result.request->arg[0],
result.request->arg[1],
result.origin,
}; };
return true; if(server_name != result.request->arg[0] || server_name != result.origin)
{
log::derror
{
m::log, "Origin mismatch for '%s' got '%s' from '%s'",
result.request->arg[0],
server_name,
result.origin,
};
continue;
}
if(!verify(m::keys(keys), std::nothrow))
{
log::derror
{
m::log, "Failed to verify key '%s' for '%s' from '%s'",
result.request->arg[0],
result.request->arg[1],
result.origin,
};
continue;
}
cache::set(keys);
if(!(ret = closure(keys)))
return ret;
} }
cache::set(result.object);
ret = closure(result.object);
return ret; return ret;
}); });