Browse Source
Allow to increase the note size to 100_000 (#4772 )
This PR adds a config option to allow the note size to increase to 100_000, instead of the default 10_000.
Since this might cause issues with the clients (in the future), and will cause issues with importing into a Bitwarden server, i added warnings regarding this.
Closes #3168
pull/4779/head
Mathijs van Veluw
6 months ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with
27 additions and
11 deletions
.env.template
src/api/core/ciphers.rs
src/config.rs
src/db/models/cipher.rs
@ -414,6 +414,12 @@
## KNOW WHAT YOU ARE DOING!
## KNOW WHAT YOU ARE DOING!
# ORG_GROUPS_ENABLED=false
# ORG_GROUPS_ENABLED=false
## Increase secure note size limit (Know the risks!)
## Sets the secure note size limit to 100_000 instead of the default 10_000.
## WARNING: This could cause issues with clients. Also exports will not work on Bitwarden servers!
## KNOW WHAT YOU ARE DOING!
# INCREASE_NOTE_SIZE_LIMIT=false
########################
########################
### MFA/2FA settings ###
### MFA/2FA settings ###
########################
########################
@ -377,8 +377,9 @@ pub async fn update_cipher_from_data(
}
}
if let Some ( note ) = & data . notes {
if let Some ( note ) = & data . notes {
if note . len ( ) > 10_000 {
let max_note_size = CONFIG . _max_note_size ( ) ;
err ! ( "The field Notes exceeds the maximum encrypted value length of 10000 characters." )
if note . len ( ) > max_note_size {
err ! ( format ! ( "The field Notes exceeds the maximum encrypted value length of {max_note_size} characters." ) )
}
}
}
}
@ -619,6 +619,12 @@ make_config! {
/// Enable groups (BETA!) (Know the risks!) |> Enables groups support for organizations (Currently contains known issues!).
/// Enable groups (BETA!) (Know the risks!) |> Enables groups support for organizations (Currently contains known issues!).
org_groups_enabled : bool , false , def , false ;
org_groups_enabled : bool , false , def , false ;
/// Increase note size limit (Know the risks!) |> Sets the secure note size limit to 100_000 instead of the default 10_000.
/// WARNING: This could cause issues with clients. Also exports will not work on Bitwarden servers!
increase_note_size_limit : bool , true , def , false ;
/// Generated max_note_size value to prevent if..else matching during every check
_max_note_size : usize , false , gen , | c | if c . increase_note_size_limit { 100_000 } else { 10_000 } ;
} ,
} ,
/// Yubikey settings
/// Yubikey settings
@ -1001,6 +1007,11 @@ fn validate_config(cfg: &ConfigItems) -> Result<(), Error> {
_ = > { }
_ = > { }
}
}
}
}
if cfg . increase_note_size_limit {
println ! ( "[WARNING] Secure Note size limit is increased to 100_000!" ) ;
println ! ( "[WARNING] This could cause issues with clients. Also exports will not work on Bitwarden servers!." ) ;
}
Ok ( ( ) )
Ok ( ( ) )
}
}
@ -81,16 +81,14 @@ impl Cipher {
pub fn validate_notes ( cipher_data : & [ CipherData ] ) -> EmptyResult {
pub fn validate_notes ( cipher_data : & [ CipherData ] ) -> EmptyResult {
let mut validation_errors = serde_json ::Map ::new ( ) ;
let mut validation_errors = serde_json ::Map ::new ( ) ;
let max_note_size = CONFIG . _max_note_size ( ) ;
let max_note_size_msg =
format ! ( "The field Notes exceeds the maximum encrypted value length of {} characters." , & max_note_size ) ;
for ( index , cipher ) in cipher_data . iter ( ) . enumerate ( ) {
for ( index , cipher ) in cipher_data . iter ( ) . enumerate ( ) {
if let Some ( note ) = & cipher . notes {
if let Some ( note ) = & cipher . notes {
if note . len ( ) > 10_000 {
if note . len ( ) > max_note_size {
validation_errors . insert (
validation_errors
format ! ( "Ciphers[{index}].Notes" ) ,
. insert ( format ! ( "Ciphers[{index}].Notes" ) , serde_json ::to_value ( [ & max_note_size_msg ] ) . unwrap ( ) ) ;
serde_json ::to_value ( [
"The field Notes exceeds the maximum encrypted value length of 10000 characters." ,
] )
. unwrap ( ) ,
) ;
}
}
}
}
}
}