0
0
Fork 0
mirror of https://github.com/dani-garcia/vaultwarden synced 2025-01-05 20:34:17 +01:00

Fix issue with postgres

This commit is contained in:
Daniel García 2020-03-14 23:35:34 +01:00
parent afd9f4e278
commit 819f340f39
No known key found for this signature in database
GPG key ID: FC8A7D14C3CD543A

View file

@ -57,14 +57,14 @@ impl OrgPolicy {
/// Database methods /// Database methods
impl OrgPolicy { impl OrgPolicy {
#[cfg(feature = "postgresql")] #[cfg(feature = "postgresql")]
pub fn save(&mut self, conn: &DbConn) -> EmptyResult { pub fn save(&self, conn: &DbConn) -> EmptyResult {
// We need to make sure we're not going to violate the unique constraint on org_uuid and atype. // We need to make sure we're not going to violate the unique constraint on org_uuid and atype.
// This happens automatically on other DBMS backends due to replace_into(). PostgreSQL does // This happens automatically on other DBMS backends due to replace_into(). PostgreSQL does
// not support multiple constraints on ON CONFLICT clauses. // not support multiple constraints on ON CONFLICT clauses.
diesel::delete( diesel::delete(
org_policies::table org_policies::table
.filter(org_policies::org_uuid.eq(&self.org_uuid)) .filter(org_policies::org_uuid.eq(self.org_uuid))
.filter(org_policies::atype.eq(&self.atype)), .filter(org_policies::atype.eq(self.atype)),
) )
.execute(&**conn) .execute(&**conn)
.map_res("Error deleting org_policy for insert")?; .map_res("Error deleting org_policy for insert")?;
@ -79,7 +79,7 @@ impl OrgPolicy {
} }
#[cfg(not(feature = "postgresql"))] #[cfg(not(feature = "postgresql"))]
pub fn save(&mut self, conn: &DbConn) -> EmptyResult { pub fn save(&self, conn: &DbConn) -> EmptyResult {
diesel::replace_into(org_policies::table) diesel::replace_into(org_policies::table)
.values(&*self) .values(&*self)
.execute(&**conn) .execute(&**conn)