common: Allow padding when decoding the Base64 type from a string
				
					
				
			This commit is contained in:
		
							parent
							
								
									5040aa2a93
								
							
						
					
					
						commit
						1b6240286f
					
				| @ -17,6 +17,7 @@ Breaking changes: | ||||
| 
 | ||||
| Improvements: | ||||
| 
 | ||||
| - Allow padding when decoding the `Base64` type from a string | ||||
| - Add convenience methods for `push::Ruleset`: | ||||
|   - To update the server-default push rules | ||||
|   - To remove a user-defined push rule | ||||
|  | ||||
| @ -3,7 +3,7 @@ | ||||
| use std::{fmt, marker::PhantomData}; | ||||
| 
 | ||||
| use base64::{ | ||||
|     engine::{general_purpose, GeneralPurpose, GeneralPurposeConfig}, | ||||
|     engine::{general_purpose, DecodePaddingMode, GeneralPurpose, GeneralPurposeConfig}, | ||||
|     Engine, | ||||
| }; | ||||
| use serde::{de, Deserialize, Deserializer, Serialize, Serializer}; | ||||
| @ -56,9 +56,10 @@ impl Base64Config for UrlSafe { | ||||
| } | ||||
| 
 | ||||
| impl<C: Base64Config, B> Base64<C, B> { | ||||
|     // See https://github.com/matrix-org/matrix-spec/issues/838
 | ||||
|     const CONFIG: GeneralPurposeConfig = | ||||
|         general_purpose::NO_PAD.with_decode_allow_trailing_bits(true); | ||||
|     const CONFIG: GeneralPurposeConfig = general_purpose::NO_PAD | ||||
|         // See https://github.com/matrix-org/matrix-spec/issues/838
 | ||||
|         .with_decode_allow_trailing_bits(true) | ||||
|         .with_decode_padding_mode(DecodePaddingMode::Indifferent); | ||||
|     const ENGINE: GeneralPurpose = GeneralPurpose::new(&C::CONF.0, Self::CONFIG); | ||||
| } | ||||
| 
 | ||||
| @ -155,6 +156,10 @@ mod tests { | ||||
|     fn slightly_malformed_base64() { | ||||
|         const INPUT: &str = "3UmJnEIzUr2xWyaUnJg5fXwRybwG5FVC6Gq\ | ||||
|             MHverEUn0ztuIsvVxX89JXX2pvdTsOBbLQx+4TVL02l4Cp5wPCm";
 | ||||
|         const INPUT_WITH_PADDING: &str = "im9+knCkMNQNh9o6sbdcZw=="; | ||||
| 
 | ||||
|         Base64::<Standard>::parse(INPUT).unwrap(); | ||||
|         Base64::<Standard>::parse(INPUT_WITH_PADDING) | ||||
|             .expect("We should be able to decode padded Base64"); | ||||
|     } | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user