]> Untitled Git - lemmy.git/blobdiff - crates/db_schema/src/source/site.rs
First pass at invite-only migration. (#1949)
[lemmy.git] / crates / db_schema / src / source / site.rs
index 19c41bf73303ca16c23950784b41375563a1d7f1..f99ffd8873d04280298b008056ee07c42064e0fb 100644 (file)
@@ -1,7 +1,10 @@
-use crate::{schema::site, DbUrl, PersonId};
-use serde::Serialize;
+use crate::{
+  newtypes::{DbUrl, PersonId},
+  schema::site,
+};
+use serde::{Deserialize, Serialize};
 
-#[derive(Queryable, Identifiable, PartialEq, Debug, Clone, Serialize)]
+#[derive(Queryable, Identifiable, PartialEq, Debug, Clone, Serialize, Deserialize)]
 #[table_name = "site"]
 pub struct Site {
   pub id: i32,
@@ -17,9 +20,13 @@ pub struct Site {
   pub banner: Option<DbUrl>,
   pub description: Option<String>,
   pub community_creation_admin_only: bool,
+  pub require_email_verification: bool,
+  pub require_application: bool,
+  pub application_question: Option<String>,
+  pub private_instance: bool,
 }
 
-#[derive(Insertable, AsChangeset)]
+#[derive(Insertable, AsChangeset, Default)]
 #[table_name = "site"]
 pub struct SiteForm {
   pub name: String,
@@ -34,4 +41,8 @@ pub struct SiteForm {
   pub banner: Option<Option<DbUrl>>,
   pub description: Option<Option<String>>,
   pub community_creation_admin_only: Option<bool>,
+  pub require_email_verification: Option<bool>,
+  pub require_application: Option<bool>,
+  pub application_question: Option<Option<String>>,
+  pub private_instance: Option<bool>,
 }