You've already forked AstralRinth
forked from didirus/AstralRinth
* Add launcher_feature_version to Profile * Misc fixes - Add typing to theme and settings stuff - Push instance route on creation from installing a modpack - Fixed servers not reloading properly when first added * Make old instances scan the logs folder for joined servers on launcher startup * Create AttachedWorldData * Change AttachedWorldData interface * Rename WorldType::World to WorldType::Singleplayer * Implement world display status system * Fix Minecraft font * Fix set_world_display_status Tauri error * Add 'Play instance' option * Add option to disable worlds showing in Home * Fixes - Fix available server filter only showing if there are some available - Fixed server and singleplayer filters sometimes showing when there are only servers or singleplayer worlds - Fixed new worlds not being automatically added when detected - Rephrased Jump back into worlds option description * Fixed sometimes more than 6 items showing up in Jump back in * Fix servers.dat issue with instances you haven't played before * Fix too large of bulk requests being made, limit max to 800 #3430 * Add hiding from home page, add types to Mods.vue * Make recent worlds go into grid when display is huge * Fix lint * Remove redundant media query * Fix protocol version on home page, and home page being blocked by pinging servers * Clippy fix * More Clippy fixes * Fix Prettier lints * Undo `from_string` changes --------- Co-authored-by: Josiah Glosson <soujournme@gmail.com> Co-authored-by: Alejandro González <me@alegon.dev>
66 lines
1.5 KiB
Rust
66 lines
1.5 KiB
Rust
use std::collections::HashMap;
|
|
|
|
use chrono::{DateTime, TimeZone, Utc};
|
|
|
|
#[derive(Default)]
|
|
pub struct JoinLogEntry {
|
|
pub profile_path: String,
|
|
pub host: String,
|
|
pub port: u16,
|
|
pub join_time: DateTime<Utc>,
|
|
}
|
|
|
|
impl JoinLogEntry {
|
|
pub async fn upsert(
|
|
&self,
|
|
exec: impl sqlx::Executor<'_, Database = sqlx::Sqlite>,
|
|
) -> crate::Result<()> {
|
|
let join_time = self.join_time.timestamp();
|
|
|
|
sqlx::query!(
|
|
"
|
|
INSERT INTO join_log (profile_path, host, port, join_time)
|
|
VALUES ($1, $2, $3, $4)
|
|
ON CONFLICT (profile_path, host, port) DO UPDATE SET
|
|
join_time = $4
|
|
",
|
|
self.profile_path,
|
|
self.host,
|
|
self.port,
|
|
join_time
|
|
)
|
|
.execute(exec)
|
|
.await?;
|
|
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
pub async fn get_joins(
|
|
instance: &str,
|
|
exec: impl sqlx::Executor<'_, Database = sqlx::Sqlite>,
|
|
) -> crate::Result<HashMap<(String, u16), DateTime<Utc>>> {
|
|
let joins = sqlx::query!(
|
|
"
|
|
SELECT profile_path, host, port, join_time
|
|
FROM join_log
|
|
WHERE profile_path = $1
|
|
",
|
|
instance
|
|
)
|
|
.fetch_all(exec)
|
|
.await?;
|
|
|
|
Ok(joins
|
|
.into_iter()
|
|
.map(|x| {
|
|
(
|
|
(x.host, x.port as u16),
|
|
Utc.timestamp_opt(x.join_time, 0)
|
|
.single()
|
|
.unwrap_or_else(Utc::now),
|
|
)
|
|
})
|
|
.collect())
|
|
}
|