|
|
@ -1,6 +1,7 @@ |
|
|
|
use serde_json::Value as JsonValue; |
|
|
|
|
|
|
|
use uuid::Uuid; |
|
|
|
use super::{User, CollectionUser}; |
|
|
|
|
|
|
|
#[derive(Debug, Identifiable, Queryable, Insertable)] |
|
|
|
#[table_name = "organizations"] |
|
|
@ -114,6 +115,12 @@ use db::schema::users_organizations; |
|
|
|
/// Database methods
|
|
|
|
impl Organization { |
|
|
|
pub fn save(&mut self, conn: &DbConn) -> bool { |
|
|
|
UserOrganization::find_by_org(&self.uuid, conn) |
|
|
|
.iter() |
|
|
|
.for_each(|user_org| { |
|
|
|
User::update_uuid_revision(&user_org.user_uuid, conn); |
|
|
|
}); |
|
|
|
|
|
|
|
match diesel::replace_into(organizations::table) |
|
|
|
.values(&*self) |
|
|
|
.execute(&**conn) { |
|
|
@ -172,7 +179,6 @@ impl UserOrganization { |
|
|
|
} |
|
|
|
|
|
|
|
pub fn to_json_user_details(&self, conn: &DbConn) -> JsonValue { |
|
|
|
use super::User; |
|
|
|
let user = User::find_by_uuid(&self.user_uuid, conn).unwrap(); |
|
|
|
|
|
|
|
json!({ |
|
|
@ -190,7 +196,6 @@ impl UserOrganization { |
|
|
|
} |
|
|
|
|
|
|
|
pub fn to_json_collection_user_details(&self, read_only: &bool, conn: &DbConn) -> JsonValue { |
|
|
|
use super::User; |
|
|
|
let user = User::find_by_uuid(&self.user_uuid, conn).unwrap(); |
|
|
|
|
|
|
|
json!({ |
|
|
@ -209,7 +214,6 @@ impl UserOrganization { |
|
|
|
let coll_uuids = if self.access_all {
|
|
|
|
vec![] // If we have complete access, no need to fill the array
|
|
|
|
} else { |
|
|
|
use super::CollectionUser; |
|
|
|
let collections = CollectionUser::find_by_organization_and_user_uuid(&self.org_uuid, &self.user_uuid, conn); |
|
|
|
collections.iter().map(|c| json!({"Id": c.collection_uuid, "ReadOnly": c.read_only})).collect() |
|
|
|
}; |
|
|
@ -228,6 +232,8 @@ impl UserOrganization { |
|
|
|
} |
|
|
|
|
|
|
|
pub fn save(&mut self, conn: &DbConn) -> bool { |
|
|
|
User::update_uuid_revision(&self.user_uuid, conn); |
|
|
|
|
|
|
|
match diesel::replace_into(users_organizations::table) |
|
|
|
.values(&*self) |
|
|
|
.execute(&**conn) { |
|
|
@ -237,7 +243,7 @@ impl UserOrganization { |
|
|
|
} |
|
|
|
|
|
|
|
pub fn delete(self, conn: &DbConn) -> QueryResult<()> { |
|
|
|
use super::CollectionUser; |
|
|
|
User::update_uuid_revision(&self.user_uuid, conn); |
|
|
|
|
|
|
|
CollectionUser::delete_all_by_user(&self.user_uuid, &conn)?; |
|
|
|
|
|
|
|