use crate::{naive_now, schema::site, Crud}; use diesel::{dsl::*, result::Error, *}; #[derive(Queryable, Identifiable, PartialEq, Debug)] #[table_name = "site"] pub struct Site { pub id: i32, pub name: String, pub description: Option, pub creator_id: i32, pub published: chrono::NaiveDateTime, pub updated: Option, pub enable_downvotes: bool, pub open_registration: bool, pub enable_nsfw: bool, pub icon: Option, pub banner: Option, } #[derive(Insertable, AsChangeset)] #[table_name = "site"] pub struct SiteForm { pub name: String, pub description: Option, pub creator_id: i32, pub updated: Option, pub enable_downvotes: bool, pub open_registration: bool, pub enable_nsfw: bool, // when you want to null out a column, you have to send Some(None)), since sending None means you just don't want to update that column. pub icon: Option>, pub banner: Option>, } impl Crud for Site { fn read(conn: &PgConnection, _site_id: i32) -> Result { use crate::schema::site::dsl::*; site.first::(conn) } fn create(conn: &PgConnection, new_site: &SiteForm) -> Result { use crate::schema::site::dsl::*; insert_into(site).values(new_site).get_result::(conn) } fn update(conn: &PgConnection, site_id: i32, new_site: &SiteForm) -> Result { use crate::schema::site::dsl::*; diesel::update(site.find(site_id)) .set(new_site) .get_result::(conn) } } impl Site { pub fn transfer(conn: &PgConnection, new_creator_id: i32) -> Result { use crate::schema::site::dsl::*; diesel::update(site.find(1)) .set((creator_id.eq(new_creator_id), updated.eq(naive_now()))) .get_result::(conn) } }