use crate::{
error::Result,
manager::{binded::Binded, PostArchiverConnection},
query::FromQuery,
Platform, PlatformId, PostId, TagId,
};
#[derive(Debug, Clone, Default)]
pub struct UpdatePlatform {
pub name: Option<String>,
}
impl UpdatePlatform {
pub fn name(mut self, name: String) -> Self {
self.name = Some(name);
self
}
}
impl<'a, C: PostArchiverConnection> Binded<'a, PlatformId, C> {
pub fn value(&self) -> Result<Platform> {
let mut stmt = self
.conn()
.prepare_cached("SELECT * FROM platforms WHERE id = ?")?;
Ok(stmt.query_row([self.id()], Platform::from_row)?)
}
pub fn delete(self) -> Result<()> {
let mut stmt = self
.conn()
.prepare_cached("DELETE FROM platforms WHERE id = ?")?;
stmt.execute([self.id()])?;
Ok(())
}
pub fn update(&self, update: UpdatePlatform) -> Result<()> {
use rusqlite::types::ToSql;
let mut sets: Vec<&str> = Vec::new();
let mut params: Vec<&dyn ToSql> = Vec::new();
macro_rules! push {
($field:expr, $col:expr) => {
if let Some(ref v) = $field {
sets.push($col);
params.push(v);
}
};
}
push!(update.name, "name = ?");
if sets.is_empty() {
return Ok(());
}
let id = self.id();
params.push(&id);
let sql = format!("UPDATE platforms SET {} WHERE id = ?", sets.join(", "));
self.conn().execute(&sql, params.as_slice())?;
Ok(())
}
}
impl<'a, C: PostArchiverConnection> Binded<'a, PlatformId, C> {
pub fn list_tags(&self) -> Result<Vec<TagId>> {
let mut stmt = self
.conn()
.prepare_cached("SELECT id FROM tags WHERE platform = ?")?;
let rows = stmt.query_map([self.id()], |row| row.get(0))?;
rows.collect::<std::result::Result<_, _>>()
.map_err(Into::into)
}
pub fn list_posts(&self) -> Result<Vec<PostId>> {
let mut stmt = self
.conn()
.prepare_cached("SELECT id FROM posts WHERE platform = ?")?;
let rows = stmt.query_map([self.id()], |row| row.get(0))?;
rows.collect::<std::result::Result<_, _>>()
.map_err(Into::into)
}
}