musicus/crates/database/src/persons.rs

90 lines
2.4 KiB
Rust
Raw Normal View History

2020-11-17 15:52:47 +01:00
use super::schema::persons;
2021-02-04 21:47:22 +01:00
use super::{Database, Result};
2022-04-10 13:43:31 +02:00
use chrono::Utc;
2020-11-17 15:52:47 +01:00
use diesel::prelude::*;
2021-04-25 23:12:19 +02:00
use log::info;
2020-11-17 15:52:47 +01:00
/// A person that is a composer, an interpret or both.
2022-01-23 14:33:35 +01:00
#[derive(Insertable, Queryable, PartialEq, Eq, Hash, Debug, Clone)]
2020-11-17 15:52:47 +01:00
pub struct Person {
2020-11-28 21:45:22 +01:00
pub id: String,
2020-11-17 15:52:47 +01:00
pub first_name: String,
pub last_name: String,
2022-04-10 13:43:31 +02:00
pub last_used: Option<i64>,
pub last_played: Option<i64>,
2020-11-17 15:52:47 +01:00
}
impl Person {
2022-04-10 13:43:31 +02:00
pub fn new(id: String, first_name: String, last_name: String) -> Self {
Self {
id,
first_name,
last_name,
last_used: Some(Utc::now().timestamp()),
last_played: None,
}
}
2020-11-17 15:52:47 +01:00
/// Get the full name in the form "First Last".
pub fn name_fl(&self) -> String {
format!("{} {}", self.first_name, self.last_name)
}
/// Get the full name in the form "Last, First".
pub fn name_lf(&self) -> String {
format!("{}, {}", self.last_name, self.first_name)
}
}
impl Database {
/// Update an existing person or insert a new one.
2022-04-10 13:43:31 +02:00
pub fn update_person(&self, mut person: Person) -> Result<()> {
2021-04-25 23:12:19 +02:00
info!("Updating person {:?}", person);
2020-11-17 15:52:47 +01:00
self.defer_foreign_keys()?;
2022-04-10 13:43:31 +02:00
person.last_used = Some(Utc::now().timestamp());
2020-11-17 15:52:47 +01:00
self.connection.transaction(|| {
diesel::replace_into(persons::table)
2020-11-28 21:45:22 +01:00
.values(person)
2020-11-17 15:52:47 +01:00
.execute(&self.connection)
})?;
Ok(())
}
/// Get an existing person.
2021-02-04 21:47:22 +01:00
pub fn get_person(&self, id: &str) -> Result<Option<Person>> {
2020-11-28 21:45:22 +01:00
let person = persons::table
.filter(persons::id.eq(id))
.load::<Person>(&self.connection)?
.into_iter()
.next();
2020-11-17 15:52:47 +01:00
Ok(person)
}
/// Delete an existing person.
2021-02-04 21:47:22 +01:00
pub fn delete_person(&self, id: &str) -> Result<()> {
2021-04-25 23:12:19 +02:00
info!("Deleting person {}", id);
2020-11-28 21:45:22 +01:00
diesel::delete(persons::table.filter(persons::id.eq(id))).execute(&self.connection)?;
2020-11-17 15:52:47 +01:00
Ok(())
}
/// Get all existing persons.
2021-02-04 21:47:22 +01:00
pub fn get_persons(&self) -> Result<Vec<Person>> {
2020-11-28 21:45:22 +01:00
let persons = persons::table.load::<Person>(&self.connection)?;
2020-11-17 15:52:47 +01:00
Ok(persons)
}
/// Get recently used persons.
pub fn get_recent_persons(&self) -> Result<Vec<Person>> {
let persons = persons::table
.order(persons::last_used.desc())
.load::<Person>(&self.connection)?;
Ok(persons)
}
2020-11-17 15:52:47 +01:00
}