|
@ -44,12 +44,7 @@ use crate::error::MapResult; |
|
|
/// Database methods
|
|
|
/// Database methods
|
|
|
impl Collection { |
|
|
impl Collection { |
|
|
pub fn save(&mut self, conn: &DbConn) -> EmptyResult { |
|
|
pub fn save(&mut self, conn: &DbConn) -> EmptyResult { |
|
|
// Update affected users revision
|
|
|
self.update_users_revision(conn); |
|
|
UserOrganization::find_by_collection_and_org(&self.uuid, &self.org_uuid, conn) |
|
|
|
|
|
.iter() |
|
|
|
|
|
.for_each(|user_org| { |
|
|
|
|
|
User::update_uuid_revision(&user_org.user_uuid, conn); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
diesel::replace_into(collections::table) |
|
|
diesel::replace_into(collections::table) |
|
|
.values(&*self) |
|
|
.values(&*self) |
|
@ -58,6 +53,7 @@ impl Collection { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
pub fn delete(self, conn: &DbConn) -> EmptyResult { |
|
|
pub fn delete(self, conn: &DbConn) -> EmptyResult { |
|
|
|
|
|
self.update_users_revision(conn); |
|
|
CollectionCipher::delete_all_by_collection(&self.uuid, &conn)?; |
|
|
CollectionCipher::delete_all_by_collection(&self.uuid, &conn)?; |
|
|
CollectionUser::delete_all_by_collection(&self.uuid, &conn)?; |
|
|
CollectionUser::delete_all_by_collection(&self.uuid, &conn)?; |
|
|
|
|
|
|
|
@ -73,6 +69,14 @@ impl Collection { |
|
|
Ok(()) |
|
|
Ok(()) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
pub fn update_users_revision(&self, conn: &DbConn) { |
|
|
|
|
|
UserOrganization::find_by_collection_and_org(&self.uuid, &self.org_uuid, conn) |
|
|
|
|
|
.iter() |
|
|
|
|
|
.for_each(|user_org| { |
|
|
|
|
|
User::update_uuid_revision(&user_org.user_uuid, conn); |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
pub fn find_by_uuid(uuid: &str, conn: &DbConn) -> Option<Self> { |
|
|
pub fn find_by_uuid(uuid: &str, conn: &DbConn) -> Option<Self> { |
|
|
collections::table |
|
|
collections::table |
|
|
.filter(collections::uuid.eq(uuid)) |
|
|
.filter(collections::uuid.eq(uuid)) |
|
|