implement admin command to force join all local users to room

Signed-off-by: strawberry <strawberry@puppygock.gay>
This commit is contained in:
strawberry 2024-10-28 19:06:53 -04:00
parent c71db93e22
commit 567a4cb441
2 changed files with 109 additions and 5 deletions

View File

@ -18,7 +18,7 @@ use ruma::{
tag::{TagEvent, TagEventContent, TagInfo}, tag::{TagEvent, TagEventContent, TagInfo},
RoomAccountDataEventType, StateEventType, RoomAccountDataEventType, StateEventType,
}, },
EventId, OwnedRoomId, OwnedRoomOrAliasId, OwnedUserId, RoomId, EventId, OwnedRoomId, OwnedRoomOrAliasId, OwnedUserId, RoomId, UserId,
}; };
use crate::{ use crate::{
@ -27,6 +27,7 @@ use crate::{
}; };
const AUTO_GEN_PASSWORD_LENGTH: usize = 25; const AUTO_GEN_PASSWORD_LENGTH: usize = 25;
const BULK_JOIN_REASON: &str = "Bulk force joining this room as initiated by the server admin.";
#[admin_command] #[admin_command]
pub(super) async fn list_users(&self) -> Result<RoomMessageEventContent> { pub(super) async fn list_users(&self) -> Result<RoomMessageEventContent> {
@ -384,8 +385,6 @@ pub(super) async fn list_joined_rooms(&self, user_id: String) -> Result<RoomMess
pub(super) async fn force_join_list_of_local_users( pub(super) async fn force_join_list_of_local_users(
&self, room_id: OwnedRoomOrAliasId, yes_i_want_to_do_this: bool, &self, room_id: OwnedRoomOrAliasId, yes_i_want_to_do_this: bool,
) -> Result<RoomMessageEventContent> { ) -> Result<RoomMessageEventContent> {
const REASON: &str = "Bulk force joining this room as initiated by the server admin.";
if self.body.len() < 2 || !self.body[0].trim().starts_with("```") || self.body.last().unwrap_or(&"").trim() != "```" if self.body.len() < 2 || !self.body[0].trim().starts_with("```") || self.body.last().unwrap_or(&"").trim() != "```"
{ {
return Ok(RoomMessageEventContent::text_plain( return Ok(RoomMessageEventContent::text_plain(
@ -491,7 +490,100 @@ pub(super) async fn force_join_list_of_local_users(
self.services, self.services,
&user_id, &user_id,
&room_id, &room_id,
Some(String::from(REASON)), Some(String::from(BULK_JOIN_REASON)),
&servers,
None,
&None,
)
.await
{
Ok(_res) => {
successful_joins = successful_joins.saturating_add(1);
},
Err(e) => {
debug_warn!("Failed force joining {user_id} to {room_id} during bulk join: {e}");
failed_joins = failed_joins.saturating_add(1);
},
};
}
Ok(RoomMessageEventContent::notice_markdown(format!(
"{successful_joins} local users have been joined to {room_id}. {failed_joins} joins failed.",
)))
}
#[admin_command]
pub(super) async fn force_join_all_local_users(
&self, room_id: OwnedRoomOrAliasId, yes_i_want_to_do_this: bool,
) -> Result<RoomMessageEventContent> {
if !yes_i_want_to_do_this {
return Ok(RoomMessageEventContent::notice_markdown(
"You must pass the --yes-i-want-to-do-this-flag to ensure you really want to force bulk join all local \
users.",
));
}
let Ok(admin_room) = self.services.admin.get_admin_room().await else {
return Ok(RoomMessageEventContent::notice_markdown(
"There is not an admin room to check for server admins.",
));
};
let (room_id, servers) = self
.services
.rooms
.alias
.resolve_with_servers(&room_id, None)
.await?;
if !self
.services
.rooms
.state_cache
.server_in_room(self.services.globals.server_name(), &room_id)
.await
{
return Ok(RoomMessageEventContent::notice_markdown("We are not joined in this room."));
}
let server_admins: Vec<_> = self
.services
.rooms
.state_cache
.active_local_users_in_room(&admin_room)
.map(ToOwned::to_owned)
.collect()
.await;
if !self
.services
.rooms
.state_cache
.room_members(&room_id)
.ready_any(|user_id| server_admins.contains(&user_id.to_owned()))
.await
{
return Ok(RoomMessageEventContent::notice_markdown(
"There is not a single server admin in the room.",
));
}
let mut failed_joins: usize = 0;
let mut successful_joins: usize = 0;
for user_id in &self
.services
.users
.list_local_users()
.map(UserId::to_owned)
.collect::<Vec<_>>()
.await
{
match join_room_by_id_helper(
self.services,
user_id,
&room_id,
Some(String::from(BULK_JOIN_REASON)),
&servers, &servers,
None, None,
&None, &None,

View File

@ -130,7 +130,7 @@ pub(super) enum UserCommand {
/// ///
/// Specify a codeblock of usernames. /// Specify a codeblock of usernames.
/// ///
/// At least 1 server admin must be in the room to prevent abuse. /// At least 1 server admin must be in the room to reduce abuse.
/// ///
/// Requires the `--yes-i-want-to-do-this` flag. /// Requires the `--yes-i-want-to-do-this` flag.
ForceJoinListOfLocalUsers { ForceJoinListOfLocalUsers {
@ -139,4 +139,16 @@ pub(super) enum UserCommand {
#[arg(long)] #[arg(long)]
yes_i_want_to_do_this: bool, yes_i_want_to_do_this: bool,
}, },
/// - Force joins all local users to the specified room.
///
/// At least 1 server admin must be in the room to reduce abuse.
///
/// Requires the `--yes-i-want-to-do-this` flag.
ForceJoinAllLocalUsers {
room_id: OwnedRoomOrAliasId,
#[arg(long)]
yes_i_want_to_do_this: bool,
},
} }