mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 16:00:02 +02:00 
			
		
		
		
	Some fixes for the new mobile apps (#4526)
This commit is contained in:
		| @@ -10,6 +10,7 @@ use rocket::{ | |||||||
| }; | }; | ||||||
| use serde_json::Value; | use serde_json::Value; | ||||||
|  |  | ||||||
|  | use crate::util::NumberOrString; | ||||||
| use crate::{ | use crate::{ | ||||||
|     api::{self, core::log_event, EmptyResult, JsonResult, JsonUpcase, Notify, PasswordOrOtpData, UpdateType}, |     api::{self, core::log_event, EmptyResult, JsonResult, JsonUpcase, Notify, PasswordOrOtpData, UpdateType}, | ||||||
|     auth::Headers, |     auth::Headers, | ||||||
| @@ -964,7 +965,7 @@ async fn get_attachment(uuid: &str, attachment_id: &str, headers: Headers, mut c | |||||||
| struct AttachmentRequestData { | struct AttachmentRequestData { | ||||||
|     Key: String, |     Key: String, | ||||||
|     FileName: String, |     FileName: String, | ||||||
|     FileSize: i64, |     FileSize: NumberOrString, | ||||||
|     AdminRequest: Option<bool>, // true when attaching from an org vault view |     AdminRequest: Option<bool>, // true when attaching from an org vault view | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -994,12 +995,14 @@ async fn post_attachment_v2( | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     let data: AttachmentRequestData = data.into_inner().data; |     let data: AttachmentRequestData = data.into_inner().data; | ||||||
|     if data.FileSize < 0 { |     let file_size = data.FileSize.into_i64()?; | ||||||
|  |  | ||||||
|  |     if file_size < 0 { | ||||||
|         err!("Attachment size can't be negative") |         err!("Attachment size can't be negative") | ||||||
|     } |     } | ||||||
|     let attachment_id = crypto::generate_attachment_id(); |     let attachment_id = crypto::generate_attachment_id(); | ||||||
|     let attachment = |     let attachment = | ||||||
|         Attachment::new(attachment_id.clone(), cipher.uuid.clone(), data.FileName, data.FileSize, Some(data.Key)); |         Attachment::new(attachment_id.clone(), cipher.uuid.clone(), data.FileName, file_size, Some(data.Key)); | ||||||
|     attachment.save(&mut conn).await.expect("Error saving attachment"); |     attachment.save(&mut conn).await.expect("Error saving attachment"); | ||||||
|  |  | ||||||
|     let url = format!("/ciphers/{}/attachment/{}", cipher.uuid, attachment_id); |     let url = format!("/ciphers/{}/attachment/{}", cipher.uuid, attachment_id); | ||||||
|   | |||||||
| @@ -295,7 +295,12 @@ async fn _password_login( | |||||||
|         "KdfIterations": user.client_kdf_iter, |         "KdfIterations": user.client_kdf_iter, | ||||||
|         "KdfMemory": user.client_kdf_memory, |         "KdfMemory": user.client_kdf_memory, | ||||||
|         "KdfParallelism": user.client_kdf_parallelism, |         "KdfParallelism": user.client_kdf_parallelism, | ||||||
|         "ResetMasterPassword": false,// TODO: Same as above |         "ResetMasterPassword": false, // TODO: Same as above | ||||||
|  |         "ForcePasswordReset": false, | ||||||
|  |         "MasterPasswordPolicy": { | ||||||
|  |             "object": "masterPasswordPolicy", | ||||||
|  |         }, | ||||||
|  |  | ||||||
|         "scope": scope, |         "scope": scope, | ||||||
|         "unofficialServer": true, |         "unofficialServer": true, | ||||||
|         "UserDecryptionOptions": { |         "UserDecryptionOptions": { | ||||||
|   | |||||||
| @@ -344,6 +344,25 @@ impl UserOrganization { | |||||||
|     pub async fn to_json(&self, conn: &mut DbConn) -> Value { |     pub async fn to_json(&self, conn: &mut DbConn) -> Value { | ||||||
|         let org = Organization::find_by_uuid(&self.org_uuid, conn).await.unwrap(); |         let org = Organization::find_by_uuid(&self.org_uuid, conn).await.unwrap(); | ||||||
|  |  | ||||||
|  |         let permissions = json!({ | ||||||
|  |                 // TODO: Add support for Custom User Roles | ||||||
|  |                 // See: https://bitwarden.com/help/article/user-types-access-control/#custom-role | ||||||
|  |                 "accessEventLogs": false, | ||||||
|  |                 "accessImportExport": false, | ||||||
|  |                 "accessReports": false, | ||||||
|  |                 "createNewCollections": false, | ||||||
|  |                 "editAnyCollection": false, | ||||||
|  |                 "deleteAnyCollection": false, | ||||||
|  |                 "editAssignedCollections": false, | ||||||
|  |                 "deleteAssignedCollections": false, | ||||||
|  |                 "manageGroups": false, | ||||||
|  |                 "managePolicies": false, | ||||||
|  |                 "manageSso": false, // Not supported | ||||||
|  |                 "manageUsers": false, | ||||||
|  |                 "manageResetPassword": false, | ||||||
|  |                 "manageScim": false // Not supported (Not AGPLv3 Licensed) | ||||||
|  |         }); | ||||||
|  |  | ||||||
|         // https://github.com/bitwarden/server/blob/13d1e74d6960cf0d042620b72d85bf583a4236f7/src/Api/Models/Response/ProfileOrganizationResponseModel.cs |         // https://github.com/bitwarden/server/blob/13d1e74d6960cf0d042620b72d85bf583a4236f7/src/Api/Models/Response/ProfileOrganizationResponseModel.cs | ||||||
|         json!({ |         json!({ | ||||||
|             "Id": self.org_uuid, |             "Id": self.org_uuid, | ||||||
| @@ -371,27 +390,7 @@ impl UserOrganization { | |||||||
|             // "KeyConnectorEnabled": false, |             // "KeyConnectorEnabled": false, | ||||||
|             // "KeyConnectorUrl": null, |             // "KeyConnectorUrl": null, | ||||||
|  |  | ||||||
|             // TODO: Add support for Custom User Roles |             "permissions": permissions, | ||||||
|             // See: https://bitwarden.com/help/article/user-types-access-control/#custom-role |  | ||||||
|             // "Permissions": { |  | ||||||
|             //     "AccessEventLogs": false, |  | ||||||
|             //     "AccessImportExport": false, |  | ||||||
|             //     "AccessReports": false, |  | ||||||
|             //     "ManageAllCollections": false, |  | ||||||
|             //     "CreateNewCollections": false, |  | ||||||
|             //     "EditAnyCollection": false, |  | ||||||
|             //     "DeleteAnyCollection": false, |  | ||||||
|             //     "ManageAssignedCollections": false, |  | ||||||
|             //     "editAssignedCollections": false, |  | ||||||
|             //     "deleteAssignedCollections": false, |  | ||||||
|             //     "ManageCiphers": false, |  | ||||||
|             //     "ManageGroups": false, |  | ||||||
|             //     "ManagePolicies": false, |  | ||||||
|             //     "ManageResetPassword": false, |  | ||||||
|             //     "ManageSso": false, // Not supported |  | ||||||
|             //     "ManageUsers": false, |  | ||||||
|             //     "ManageScim": false, // Not supported (Not AGPLv3 Licensed) |  | ||||||
|             // }, |  | ||||||
|  |  | ||||||
|             "MaxStorageGb": 10, // The value doesn't matter, we don't check server-side |             "MaxStorageGb": 10, // The value doesn't matter, we don't check server-side | ||||||
|  |  | ||||||
|   | |||||||
| @@ -246,6 +246,7 @@ impl User { | |||||||
|             "Email": self.email, |             "Email": self.email, | ||||||
|             "EmailVerified": !CONFIG.mail_enabled() || self.verified_at.is_some(), |             "EmailVerified": !CONFIG.mail_enabled() || self.verified_at.is_some(), | ||||||
|             "Premium": true, |             "Premium": true, | ||||||
|  |             "PremiumFromOrganization": false, | ||||||
|             "MasterPasswordHint": self.password_hint, |             "MasterPasswordHint": self.password_hint, | ||||||
|             "Culture": "en-US", |             "Culture": "en-US", | ||||||
|             "TwoFactorEnabled": twofactor_enabled, |             "TwoFactorEnabled": twofactor_enabled, | ||||||
| @@ -257,6 +258,7 @@ impl User { | |||||||
|             "ProviderOrganizations": [], |             "ProviderOrganizations": [], | ||||||
|             "ForcePasswordReset": false, |             "ForcePasswordReset": false, | ||||||
|             "AvatarColor": self.avatar_color, |             "AvatarColor": self.avatar_color, | ||||||
|  |             "UsesKeyConnector": false, | ||||||
|             "Object": "profile", |             "Object": "profile", | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| // The more key/value pairs there are the more recursion occurs. | // The more key/value pairs there are the more recursion occurs. | ||||||
| // We want to keep this as low as possible, but not higher then 128. | // We want to keep this as low as possible, but not higher then 128. | ||||||
| // If you go above 128 it will cause rust-analyzer to fail, | // If you go above 128 it will cause rust-analyzer to fail, | ||||||
| #![recursion_limit = "87"] | #![recursion_limit = "90"] | ||||||
|  |  | ||||||
| // When enabled use MiMalloc as malloc instead of the default malloc | // When enabled use MiMalloc as malloc instead of the default malloc | ||||||
| #[cfg(feature = "enable_mimalloc")] | #[cfg(feature = "enable_mimalloc")] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user