338 lines
7.4 KiB
Rust
338 lines
7.4 KiB
Rust
use clap::Subcommand;
|
|
use conduwuit::Result;
|
|
use futures::StreamExt;
|
|
use ruma::{OwnedRoomId, OwnedServerName, OwnedUserId};
|
|
|
|
use crate::Context;
|
|
|
|
#[derive(Debug, Subcommand)]
|
|
pub(crate) enum RoomStateCacheCommand {
|
|
ServerInRoom {
|
|
server: OwnedServerName,
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
RoomServers {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
ServerRooms {
|
|
server: OwnedServerName,
|
|
},
|
|
|
|
RoomMembers {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
LocalUsersInRoom {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
ActiveLocalUsersInRoom {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
RoomJoinedCount {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
RoomInvitedCount {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
RoomUserOnceJoined {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
RoomMembersInvited {
|
|
room_id: OwnedRoomId,
|
|
},
|
|
|
|
GetInviteCount {
|
|
room_id: OwnedRoomId,
|
|
user_id: OwnedUserId,
|
|
},
|
|
|
|
GetLeftCount {
|
|
room_id: OwnedRoomId,
|
|
user_id: OwnedUserId,
|
|
},
|
|
|
|
RoomsJoined {
|
|
user_id: OwnedUserId,
|
|
},
|
|
|
|
RoomsLeft {
|
|
user_id: OwnedUserId,
|
|
},
|
|
|
|
RoomsInvited {
|
|
user_id: OwnedUserId,
|
|
},
|
|
|
|
InviteState {
|
|
user_id: OwnedUserId,
|
|
room_id: OwnedRoomId,
|
|
},
|
|
}
|
|
|
|
pub(super) async fn process(subcommand: RoomStateCacheCommand, context: &Context<'_>) -> Result {
|
|
let services = context.services;
|
|
|
|
match subcommand {
|
|
| RoomStateCacheCommand::ServerInRoom { server, room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let result = services
|
|
.rooms
|
|
.state_cache
|
|
.server_in_room(&server, &room_id)
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{result:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomServers { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.room_servers(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::ServerRooms { server } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.server_rooms(&server)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomMembers { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.room_members(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::LocalUsersInRoom { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.local_users_in_room(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::ActiveLocalUsersInRoom { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.active_local_users_in_room(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomJoinedCount { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results = services.rooms.state_cache.room_joined_count(&room_id).await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomInvitedCount { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results = services
|
|
.rooms
|
|
.state_cache
|
|
.room_invited_count(&room_id)
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomUserOnceJoined { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.room_useroncejoined(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomMembersInvited { room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.room_members_invited(&room_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::GetInviteCount { room_id, user_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results = services
|
|
.rooms
|
|
.state_cache
|
|
.get_invite_count(&room_id, &user_id)
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::GetLeftCount { room_id, user_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results = services
|
|
.rooms
|
|
.state_cache
|
|
.get_left_count(&room_id, &user_id)
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomsJoined { user_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.rooms_joined(&user_id)
|
|
.map(ToOwned::to_owned)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomsInvited { user_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.rooms_invited(&user_id)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::RoomsLeft { user_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results: Vec<_> = services
|
|
.rooms
|
|
.state_cache
|
|
.rooms_left(&user_id)
|
|
.collect()
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
| RoomStateCacheCommand::InviteState { user_id, room_id } => {
|
|
let timer = tokio::time::Instant::now();
|
|
let results = services
|
|
.rooms
|
|
.state_cache
|
|
.invite_state(&user_id, &room_id)
|
|
.await;
|
|
let query_time = timer.elapsed();
|
|
|
|
context
|
|
.write_str(&format!(
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
))
|
|
.await
|
|
},
|
|
}
|
|
}
|