2024-04-20 19:55:14 -04:00
|
|
|
use ruma::events::room::message::RoomMessageEventContent;
|
2024-04-20 17:02:24 -04:00
|
|
|
|
2024-04-20 19:55:14 -04:00
|
|
|
use super::Globals;
|
2024-04-20 17:02:24 -04:00
|
|
|
use crate::{services, Result};
|
|
|
|
|
|
|
|
/// All the getters and iterators from src/database/key_value/globals.rs
|
2024-06-16 22:26:52 +00:00
|
|
|
pub(super) async fn globals(subcommand: Globals) -> Result<RoomMessageEventContent> {
|
2024-04-20 17:02:24 -04:00
|
|
|
match subcommand {
|
|
|
|
Globals::DatabaseVersion => {
|
|
|
|
let timer = tokio::time::Instant::now();
|
|
|
|
let results = services().globals.db.database_version();
|
|
|
|
let query_time = timer.elapsed();
|
|
|
|
|
2024-06-17 10:12:44 +00:00
|
|
|
Ok(RoomMessageEventContent::notice_markdown(format!(
|
|
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
|
|
)))
|
2024-04-20 17:02:24 -04:00
|
|
|
},
|
|
|
|
Globals::CurrentCount => {
|
|
|
|
let timer = tokio::time::Instant::now();
|
|
|
|
let results = services().globals.db.current_count();
|
|
|
|
let query_time = timer.elapsed();
|
|
|
|
|
2024-06-17 10:12:44 +00:00
|
|
|
Ok(RoomMessageEventContent::notice_markdown(format!(
|
|
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
|
|
)))
|
2024-04-20 17:02:24 -04:00
|
|
|
},
|
|
|
|
Globals::LastCheckForUpdatesId => {
|
|
|
|
let timer = tokio::time::Instant::now();
|
2024-07-13 08:07:49 +00:00
|
|
|
let results = services().updates.last_check_for_updates_id();
|
2024-04-20 17:02:24 -04:00
|
|
|
let query_time = timer.elapsed();
|
|
|
|
|
2024-06-17 10:12:44 +00:00
|
|
|
Ok(RoomMessageEventContent::notice_markdown(format!(
|
|
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
|
|
)))
|
2024-04-20 17:02:24 -04:00
|
|
|
},
|
|
|
|
Globals::LoadKeypair => {
|
|
|
|
let timer = tokio::time::Instant::now();
|
|
|
|
let results = services().globals.db.load_keypair();
|
|
|
|
let query_time = timer.elapsed();
|
|
|
|
|
2024-06-17 10:12:44 +00:00
|
|
|
Ok(RoomMessageEventContent::notice_markdown(format!(
|
|
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
|
|
)))
|
2024-04-20 17:02:24 -04:00
|
|
|
},
|
|
|
|
Globals::SigningKeysFor {
|
|
|
|
origin,
|
|
|
|
} => {
|
|
|
|
let timer = tokio::time::Instant::now();
|
2024-06-17 07:21:51 +00:00
|
|
|
let results = services().globals.db.verify_keys_for(&origin);
|
2024-04-20 17:02:24 -04:00
|
|
|
let query_time = timer.elapsed();
|
|
|
|
|
2024-06-17 10:12:44 +00:00
|
|
|
Ok(RoomMessageEventContent::notice_markdown(format!(
|
|
|
|
"Query completed in {query_time:?}:\n\n```rs\n{results:#?}\n```"
|
|
|
|
)))
|
2024-04-20 17:02:24 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|