mirror of
https://github.com/matrix-construct/construct
synced 2024-10-01 21:28:53 +02:00
modules/console: Add room members read cmd.
This commit is contained in:
parent
2b7358aa60
commit
44b72023af
1 changed files with 67 additions and 0 deletions
|
@ -2587,6 +2587,73 @@ console_cmd__room__members__origin(opt &out, const string_view &line)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
console_cmd__room__members__read(opt &out, const string_view &line)
|
||||||
|
{
|
||||||
|
const params param{line, " ",
|
||||||
|
{
|
||||||
|
"room_id", "[membership]", "[event_id]"
|
||||||
|
}};
|
||||||
|
|
||||||
|
const auto &room_id
|
||||||
|
{
|
||||||
|
m::room_id(param.at(0))
|
||||||
|
};
|
||||||
|
|
||||||
|
const string_view membership
|
||||||
|
{
|
||||||
|
param[1]
|
||||||
|
};
|
||||||
|
|
||||||
|
const string_view event_id
|
||||||
|
{
|
||||||
|
param[2]
|
||||||
|
};
|
||||||
|
|
||||||
|
const m::room room
|
||||||
|
{
|
||||||
|
room_id
|
||||||
|
};
|
||||||
|
|
||||||
|
const m::room::members members
|
||||||
|
{
|
||||||
|
room
|
||||||
|
};
|
||||||
|
|
||||||
|
const m::event::closure event_closure{[&out, &event_id]
|
||||||
|
(const m::event &event)
|
||||||
|
{
|
||||||
|
if(event_id)
|
||||||
|
if(unquote(at<"content"_>(event).get("event_id")) != event_id)
|
||||||
|
return;
|
||||||
|
|
||||||
|
out << timestr(at<"origin_server_ts"_>(event) / 1000)
|
||||||
|
<< " " << at<"sender"_>(event)
|
||||||
|
<< " " << at<"content"_>(event)
|
||||||
|
<< " " << at<"event_id"_>(event)
|
||||||
|
<< std::endl;
|
||||||
|
}};
|
||||||
|
|
||||||
|
const auto member_closure{[&room_id, event_closure]
|
||||||
|
(const m::event &event)
|
||||||
|
{
|
||||||
|
const m::user user
|
||||||
|
{
|
||||||
|
at<"state_key"_>(event)
|
||||||
|
};
|
||||||
|
|
||||||
|
const m::user::room user_room{user};
|
||||||
|
user_room.get(std::nothrow, "ircd.read", room_id, event_closure);
|
||||||
|
}};
|
||||||
|
|
||||||
|
if(membership)
|
||||||
|
members.for_each(membership, member_closure);
|
||||||
|
else
|
||||||
|
members.for_each(member_closure);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
console_cmd__room__origins(opt &out, const string_view &line)
|
console_cmd__room__origins(opt &out, const string_view &line)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue