rowt/src/model/log.rs
2023-05-24 09:07:20 +02:00

47 lines
1.2 KiB
Rust

use serde::{Deserialize, Serialize};
use sqlx::{FromRow, SqlitePool};
#[derive(FromRow, Debug, Serialize, Deserialize)]
pub struct Log {
pub msg: String,
pub created_at: String,
}
impl Log {
pub async fn create(db: &SqlitePool, msg: String) -> bool {
sqlx::query!("INSERT INTO log(msg) VALUES (?)", msg,)
.execute(db)
.await
.is_ok()
}
async fn last(db: &SqlitePool) -> Vec<Log> {
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("<?xml version=\"1.0\" encoding=\"utf-8\"?>
<rss version=\"2.0\">
<channel>
<title>Ruder App Admin Feed</title>
<description>An RSS feed with activities from app.rudernlinz.at</description>");
for log in Self::last(db).await {
ret.push_str("<item>");
ret.push_str(&format!("({}) {}", log.created_at, log.msg));
ret.push_str("</item>");
}
ret
}
}