mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Fix #468 - Percent-encode the email address in invite link
This commit is contained in:
		
							
								
								
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -118,6 +118,7 @@ dependencies = [ | |||||||
|  "num-derive 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", |  "num-derive 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "num-traits 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "oath 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "oath 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "percent-encoding 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "quoted_printable 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "quoted_printable 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex 1.1.7 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "reqwest 0.9.18 (registry+https://github.com/rust-lang/crates.io-index)", |  "reqwest 0.9.18 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|   | |||||||
| @@ -105,6 +105,9 @@ handlebars = "1.1.0" | |||||||
| soup = "0.4.1" | soup = "0.4.1" | ||||||
| regex = "1.1.7" | regex = "1.1.7" | ||||||
|  |  | ||||||
|  | # URL encoding library | ||||||
|  | percent-encoding = "1.0.1" | ||||||
|  |  | ||||||
| [patch.crates-io] | [patch.crates-io] | ||||||
| # Add support for Timestamp type | # Add support for Timestamp type | ||||||
| rmp = { git = 'https://github.com/dani-garcia/msgpack-rust' } | rmp = { git = 'https://github.com/dani-garcia/msgpack-rust' } | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ use lettre::{ClientSecurity, ClientTlsParameters, SmtpClient, SmtpTransport, Tra | |||||||
| use lettre_email::{EmailBuilder, MimeMultipartType, PartBuilder}; | use lettre_email::{EmailBuilder, MimeMultipartType, PartBuilder}; | ||||||
| use native_tls::{Protocol, TlsConnector}; | use native_tls::{Protocol, TlsConnector}; | ||||||
| use quoted_printable::encode_to_str; | use quoted_printable::encode_to_str; | ||||||
|  | use percent_encoding::{percent_encode, DEFAULT_ENCODE_SET}; | ||||||
|  |  | ||||||
| use crate::api::EmptyResult; | use crate::api::EmptyResult; | ||||||
| use crate::auth::{encode_jwt, generate_invite_claims}; | use crate::auth::{encode_jwt, generate_invite_claims}; | ||||||
| @@ -101,7 +102,7 @@ pub fn send_invite( | |||||||
|             "url": CONFIG.domain(), |             "url": CONFIG.domain(), | ||||||
|             "org_id": org_id.unwrap_or_else(|| "_".to_string()), |             "org_id": org_id.unwrap_or_else(|| "_".to_string()), | ||||||
|             "org_user_id": org_user_id.unwrap_or_else(|| "_".to_string()), |             "org_user_id": org_user_id.unwrap_or_else(|| "_".to_string()), | ||||||
|             "email": address, |             "email": percent_encode(address.as_bytes(), DEFAULT_ENCODE_SET).to_string().replace("+", "%2b"), | ||||||
|             "org_name": org_name, |             "org_name": org_name, | ||||||
|             "token": invite_token, |             "token": invite_token, | ||||||
|         }), |         }), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user