use std::ops::DerefMut; use chrono::{DateTime, Local, NaiveDateTime, TimeZone, Utc}; use serde::{Deserialize, Serialize}; use sqlx::{FromRow, Sqlite, SqlitePool, Transaction}; #[derive(FromRow, Debug, Serialize, Deserialize)] pub struct Log { pub msg: String, pub created_at: NaiveDateTime, } impl Log { pub async fn create(db: &SqlitePool, msg: String) -> bool { sqlx::query!("INSERT INTO log(msg) VALUES (?)", msg,) .execute(db) .await .is_ok() } pub async fn create_with_tx(db: &mut Transaction<'_, Sqlite>, msg: String) -> bool { sqlx::query!("INSERT INTO log(msg) VALUES (?)", msg,) .execute(db.deref_mut()) .await .is_ok() } async fn last(db: &SqlitePool) -> Vec { sqlx::query_as!( Log, " SELECT msg, created_at FROM log ORDER BY id DESC LIMIT 1000 " ) .fetch_all(db) .await .unwrap() } pub async fn generate_feed(db: &SqlitePool) -> String { let mut ret = String::from( r#" Ruder App Admin Feed app.rudernlinz.at An RSS feed with activities from app.rudernlinz.at"#, ); for log in Self::last(db).await { let utc_time: DateTime = Utc::from_utc_datetime(&Utc, &log.created_at); let local_time = utc_time.with_timezone(&Local); ret.push_str(""); ret.push_str(&format!("({}) {}", local_time, log.msg)); ret.push_str(""); } ret.push_str(""); ret.push_str(""); ret.replace('\n', "") } pub async fn show(db: &SqlitePool) -> String { let mut ret = String::new(); for log in Self::last(db).await { let utc_time: DateTime = Utc::from_utc_datetime(&Utc, &log.created_at); let local_time = utc_time.with_timezone(&Local); ret.push_str(&format!("- {} - {}\n", local_time, log.msg)); } ret } }