Files
ohrwurm/src/db/track.rs
Johannes Heuel 440201e153
All checks were successful
tests / fmt (push) Successful in 36s
tests / build (push) Successful in 2m3s
tests / test (push) Successful in 55s
tests / clippy (push) Successful in 41s
tests / pre-commit (push) Successful in 2m40s
deploy / release-image (push) Successful in 7m2s
fix warning while persisting tracks
2024-08-09 11:18:38 +02:00

168 lines
4.0 KiB
Rust

use chrono::{DateTime, Utc};
use sqlx::FromRow;
#[derive(Debug, FromRow)]
pub(crate) struct Track {
#[allow(dead_code)]
pub(crate) id: i64,
pub(crate) url: String,
pub(crate) title: String,
pub(crate) channel: String,
pub(crate) duration: String,
pub(crate) thumbnail: String,
pub(crate) updated: DateTime<Utc>,
}
impl Track {
pub(crate) fn new(
url: String,
title: String,
channel: String,
duration: String,
thumbnail: String,
) -> Self {
Self {
id: 0,
url,
title,
channel,
duration,
thumbnail,
updated: chrono::offset::Utc::now(),
}
}
}
pub(crate) async fn insert_track(
pool: &sqlx::SqlitePool,
track: Track,
) -> Result<i64, sqlx::Error> {
let query = r#"
INSERT INTO tracks (url, title, channel, duration, thumbnail, updated)
VALUES (?, ?, ?, ?, ?, ?)
ON CONFLICT (url) DO UPDATE SET
title = EXCLUDED.title,
channel = EXCLUDED.channel,
duration = EXCLUDED.duration,
thumbnail = EXCLUDED.thumbnail,
updated = EXCLUDED.updated
RETURNING id
"#;
let id = sqlx::query_scalar(query)
.bind(&track.url)
.bind(track.title)
.bind(track.channel)
.bind(track.duration)
.bind(track.thumbnail)
.bind(track.updated)
.fetch_one(pool)
.await?;
Ok(id)
}
#[derive(Debug, FromRow)]
pub(crate) struct User {
pub(crate) id: String,
pub(crate) name: String,
pub(crate) global_name: Option<String>,
pub(crate) updated: DateTime<Utc>,
}
impl User {
pub(crate) fn new(id: String, name: String, global_name: Option<String>) -> Self {
Self {
id,
name,
global_name,
updated: chrono::offset::Utc::now(),
}
}
}
pub(crate) async fn insert_user(pool: &sqlx::SqlitePool, user: User) -> Result<(), sqlx::Error> {
let query = r#"
INSERT INTO users (id, name, global_name, updated)
VALUES (?, ?, ?, ?)
ON CONFLICT (id) DO UPDATE SET
name = EXCLUDED.name,
global_name = EXCLUDED.global_name,
updated = EXCLUDED.updated
"#;
sqlx::query(query)
.bind(user.id)
.bind(user.name)
.bind(user.global_name)
.bind(user.updated)
.execute(pool)
.await?;
Ok(())
}
#[derive(Debug, FromRow)]
pub(crate) struct Query {
#[allow(dead_code)]
pub(crate) id: i64,
pub(crate) user_id: String,
pub(crate) guild_id: String,
pub(crate) track_id: i64,
pub(crate) updated: DateTime<Utc>,
}
impl Query {
pub(crate) fn new(user_id: String, guild_id: String, track_id: i64) -> Self {
Self {
id: 0,
user_id,
guild_id,
track_id,
updated: chrono::offset::Utc::now(),
}
}
}
pub(crate) async fn insert_query(pool: &sqlx::SqlitePool, q: Query) -> Result<i64, sqlx::Error> {
let query = r#"
INSERT INTO queries (user_id, guild_id, track_id, updated)
VALUES (?, ?, ?, ?)
"#;
let res = sqlx::query(query)
.bind(q.user_id)
.bind(q.guild_id)
.bind(q.track_id)
.bind(q.updated)
.execute(pool)
.await?;
Ok(res.last_insert_rowid())
}
#[derive(Debug, FromRow)]
pub(crate) struct Guild {
pub(crate) id: String,
pub(crate) updated: DateTime<Utc>,
}
impl Guild {
pub(crate) fn new(id: String) -> Self {
Self {
id,
updated: chrono::offset::Utc::now(),
}
}
}
pub(crate) async fn insert_guild(pool: &sqlx::SqlitePool, guild: Guild) -> Result<(), sqlx::Error> {
let query = r#"
INSERT INTO guilds (id, updated)
VALUES (?, ?)
ON CONFLICT (id) DO UPDATE SET
updated = EXCLUDED.updated
"#;
sqlx::query(query)
.bind(guild.id)
.bind(guild.updated)
.execute(pool)
.await?;
Ok(())
}