mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 16:00:02 +02:00 
			
		
		
		
	Update Rust, crates and web-vault (#4328)
- Updated Rust to v1.76.0 - Updated crates - Updated web-vault to v2024.1.2b - Fixed some Clippy lints - Moved lint check configuration Cargo.toml - Fixed issue with Reset Password Enrollment when logged-in via device
This commit is contained in:
		
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			
						parent
						
							897bdf8343
						
					
				
				
					commit
					b9bdc9b8e2
				
			
							
								
								
									
										143
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										143
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -99,13 +99,13 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "async-channel" | name = "async-channel" | ||||||
| version = "2.1.1" | version = "2.2.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "1ca33f4bc4ed1babef42cad36cc1f51fa88be00420404e5b1e80ab1b18f7678c" | checksum = "f28243a43d821d11341ab73c80bed182dc015c514b951616cf79bd4af39af0c3" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "concurrent-queue", |  "concurrent-queue", | ||||||
|  "event-listener 4.0.3", |  "event-listener 5.0.0", | ||||||
|  "event-listener-strategy", |  "event-listener-strategy 0.5.0", | ||||||
|  "futures-core", |  "futures-core", | ||||||
|  "pin-project-lite", |  "pin-project-lite", | ||||||
| ] | ] | ||||||
| @@ -144,7 +144,7 @@ version = "2.4.1" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "05b1b633a2115cd122d73b955eadd9916c18c8f510ec9cd1686404c60ad1c29c" | checksum = "05b1b633a2115cd122d73b955eadd9916c18c8f510ec9cd1686404c60ad1c29c" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "async-channel 2.1.1", |  "async-channel 2.2.0", | ||||||
|  "async-executor", |  "async-executor", | ||||||
|  "async-io 2.3.1", |  "async-io 2.3.1", | ||||||
|  "async-lock 3.3.0", |  "async-lock 3.3.0", | ||||||
| @@ -185,7 +185,7 @@ dependencies = [ | |||||||
|  "futures-io", |  "futures-io", | ||||||
|  "futures-lite 2.2.0", |  "futures-lite 2.2.0", | ||||||
|  "parking", |  "parking", | ||||||
|  "polling 3.3.2", |  "polling 3.4.0", | ||||||
|  "rustix 0.38.31", |  "rustix 0.38.31", | ||||||
|  "slab", |  "slab", | ||||||
|  "tracing", |  "tracing", | ||||||
| @@ -208,7 +208,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| checksum = "d034b430882f8381900d3fe6f0aaa3ad94f2cb4ac519b429692a1bc2dda4ae7b" | checksum = "d034b430882f8381900d3fe6f0aaa3ad94f2cb4ac519b429692a1bc2dda4ae7b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "event-listener 4.0.3", |  "event-listener 4.0.3", | ||||||
|  "event-listener-strategy", |  "event-listener-strategy 0.4.0", | ||||||
|  "pin-project-lite", |  "pin-project-lite", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| @@ -428,7 +428,7 @@ version = "1.5.1" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "6a37913e8dc4ddcc604f0c6d3bf2887c995153af3611de9e23c352b44c1b9118" | checksum = "6a37913e8dc4ddcc604f0c6d3bf2887c995153af3611de9e23c352b44c1b9118" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "async-channel 2.1.1", |  "async-channel 2.2.0", | ||||||
|  "async-lock 3.3.0", |  "async-lock 3.3.0", | ||||||
|  "async-task", |  "async-task", | ||||||
|  "fastrand 2.0.1", |  "fastrand 2.0.1", | ||||||
| @@ -467,9 +467,9 @@ checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "bytemuck" | name = "bytemuck" | ||||||
| version = "1.14.1" | version = "1.14.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "ed2490600f404f2b94c167e31d3ed1d5f3c225a0f3b80230053b3e0b7b962bd9" | checksum = "ea31d69bda4949c1c1562c1e6f042a1caefac98cdc8a298260a2ff41c1e2d42b" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "byteorder" | name = "byteorder" | ||||||
| @@ -972,6 +972,17 @@ dependencies = [ | |||||||
|  "pin-project-lite", |  "pin-project-lite", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "event-listener" | ||||||
|  | version = "5.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "b72557800024fabbaa2449dd4bf24e37b93702d457a4d4f2b0dd1f0f039f20c1" | ||||||
|  | dependencies = [ | ||||||
|  |  "concurrent-queue", | ||||||
|  |  "parking", | ||||||
|  |  "pin-project-lite", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "event-listener-strategy" | name = "event-listener-strategy" | ||||||
| version = "0.4.0" | version = "0.4.0" | ||||||
| @@ -982,6 +993,16 @@ dependencies = [ | |||||||
|  "pin-project-lite", |  "pin-project-lite", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "event-listener-strategy" | ||||||
|  | version = "0.5.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "feedafcaa9b749175d5ac357452a9d41ea2911da598fde46ce1fe02c37751291" | ||||||
|  | dependencies = [ | ||||||
|  |  "event-listener 5.0.0", | ||||||
|  |  "pin-project-lite", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "fastrand" | name = "fastrand" | ||||||
| version = "1.9.0" | version = "1.9.0" | ||||||
| @@ -1018,7 +1039,7 @@ dependencies = [ | |||||||
|  "atomic 0.6.0", |  "atomic 0.6.0", | ||||||
|  "pear", |  "pear", | ||||||
|  "serde", |  "serde", | ||||||
|  "toml 0.8.9", |  "toml 0.8.10", | ||||||
|  "uncased", |  "uncased", | ||||||
|  "version_check", |  "version_check", | ||||||
| ] | ] | ||||||
| @@ -1322,9 +1343,9 @@ checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "hermit-abi" | name = "hermit-abi" | ||||||
| version = "0.3.4" | version = "0.3.5" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "5d3d0e0f38255e7fa3cf31335b3a56f05febd18025f4db5ef7a0cfb4f8da651f" | checksum = "d0c62115964e08cb8039170eb33c1d0e2388a256930279edca206fff675f82c3" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "hmac" | name = "hmac" | ||||||
| @@ -1437,9 +1458,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "iana-time-zone" | name = "iana-time-zone" | ||||||
| version = "0.1.59" | version = "0.1.60" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "b6a67363e2aa4443928ce15e57ebae94fd8949958fd1223c4cfc0cd473ad7539" | checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "android_system_properties", |  "android_system_properties", | ||||||
|  "core-foundation-sys", |  "core-foundation-sys", | ||||||
| @@ -1585,9 +1606,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "js-sys" | name = "js-sys" | ||||||
| version = "0.3.67" | version = "0.3.68" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "9a1d36f1235bc969acba30b7f5990b864423a6068a10f7c90ae8f0112e3a59d1" | checksum = "406cda4b368d531c842222cf9d2600a9a4acce8d29423695379c6868a143a9ee" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "wasm-bindgen", |  "wasm-bindgen", | ||||||
| ] | ] | ||||||
| @@ -1821,9 +1842,9 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "miniz_oxide" | name = "miniz_oxide" | ||||||
| version = "0.7.1" | version = "0.7.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7" | checksum = "9d811f3e15f28568be3407c8e7fdb6514c1cda3cb30683f15b6a1a1dc4ea14a7" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "adler", |  "adler", | ||||||
| ] | ] | ||||||
| @@ -1938,9 +1959,9 @@ checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "num-derive" | name = "num-derive" | ||||||
| version = "0.4.1" | version = "0.4.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "cfb77679af88f8b125209d354a202862602672222e7f2313fdd6dc349bad4712" | checksum = "ed3955f1a9c7c0c15e092f9c887db08b1fc683305fdf6eb6684f22555355e202" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2", |  "proc-macro2", | ||||||
|  "quote", |  "quote", | ||||||
| @@ -1949,19 +1970,18 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "num-integer" | name = "num-integer" | ||||||
| version = "0.1.45" | version = "0.1.46" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" | checksum = "7969661fd2958a5cb096e56c8e1ad0444ac2bbcd0061bd28660485a44879858f" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "autocfg", |  | ||||||
|  "num-traits", |  "num-traits", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "num-traits" | name = "num-traits" | ||||||
| version = "0.2.17" | version = "0.2.18" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" | checksum = "da0df0e5185db44f69b44f26786fe401b6c293d1907744beaa7fa62b2e5a517a" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "autocfg", |  "autocfg", | ||||||
| ] | ] | ||||||
| @@ -2156,9 +2176,9 @@ checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pest" | name = "pest" | ||||||
| version = "2.7.6" | version = "2.7.7" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "1f200d8d83c44a45b21764d1916299752ca035d15ecd46faca3e9a2a2bf6ad06" | checksum = "219c0dcc30b6a27553f9cc242972b67f75b60eb0db71f0b5462f38b058c41546" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "memchr", |  "memchr", | ||||||
|  "thiserror", |  "thiserror", | ||||||
| @@ -2167,9 +2187,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pest_derive" | name = "pest_derive" | ||||||
| version = "2.7.6" | version = "2.7.7" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bcd6ab1236bbdb3a49027e920e693192ebfe8913f6d60e294de57463a493cfde" | checksum = "22e1288dbd7786462961e69bfd4df7848c1e37e8b74303dbdab82c3a9cdd2809" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "pest", |  "pest", | ||||||
|  "pest_generator", |  "pest_generator", | ||||||
| @@ -2177,9 +2197,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pest_generator" | name = "pest_generator" | ||||||
| version = "2.7.6" | version = "2.7.7" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2a31940305ffc96863a735bef7c7994a00b325a7138fdbc5bda0f1a0476d3275" | checksum = "1381c29a877c6d34b8c176e734f35d7f7f5b3adaefe940cb4d1bb7af94678e2e" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "pest", |  "pest", | ||||||
|  "pest_meta", |  "pest_meta", | ||||||
| @@ -2190,9 +2210,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pest_meta" | name = "pest_meta" | ||||||
| version = "2.7.6" | version = "2.7.7" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "a7ff62f5259e53b78d1af898941cdcdccfae7385cf7d793a6e55de5d05bb4b7d" | checksum = "d0934d6907f148c22a3acbda520c7eed243ad7487a30f51f6ce52b58b7077a8a" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "once_cell", |  "once_cell", | ||||||
|  "pest", |  "pest", | ||||||
| @@ -2290,9 +2310,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "polling" | name = "polling" | ||||||
| version = "3.3.2" | version = "3.4.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "545c980a3880efd47b2e262f6a4bb6daad6555cf3367aa9c4e52895f69537a41" | checksum = "30054e72317ab98eddd8561db0f6524df3367636884b7b21b703e4b280a84a14" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "concurrent-queue", |  "concurrent-queue", | ||||||
| @@ -3181,13 +3201,12 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tempfile" | name = "tempfile" | ||||||
| version = "3.9.0" | version = "3.10.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "01ce4141aa927a6d1bd34a041795abd0db1cccba5d5f24b009f694bdf3a1f3fa" | checksum = "a365e8cd18e44762ef95d87f284f4b5cd04107fec2ff3052bd6a3e6069669e67" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "fastrand 2.0.1", |  "fastrand 2.0.1", | ||||||
|  "redox_syscall", |  | ||||||
|  "rustix 0.38.31", |  "rustix 0.38.31", | ||||||
|  "windows-sys 0.52.0", |  "windows-sys 0.52.0", | ||||||
| ] | ] | ||||||
| @@ -3233,9 +3252,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "time" | name = "time" | ||||||
| version = "0.3.32" | version = "0.3.34" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "fe80ced77cbfb4cb91a94bf72b378b4b6791a0d9b7f09d0be747d1bdff4e68bd" | checksum = "c8248b6521bb14bc45b4067159b9b6ad792e2d6d754d6c41fb50e29fefe38749" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "deranged", |  "deranged", | ||||||
|  "itoa", |  "itoa", | ||||||
| @@ -3392,14 +3411,14 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "toml" | name = "toml" | ||||||
| version = "0.8.9" | version = "0.8.10" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "c6a4b9e8023eb94392d3dca65d717c53abc5dad49c07cb65bb8fcd87115fa325" | checksum = "9a9aad4a3066010876e8dcf5a8a06e70a558751117a145c6ce2b82c2e2054290" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "serde", |  "serde", | ||||||
|  "serde_spanned", |  "serde_spanned", | ||||||
|  "toml_datetime", |  "toml_datetime", | ||||||
|  "toml_edit 0.21.1", |  "toml_edit 0.22.4", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -3426,9 +3445,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "toml_edit" | name = "toml_edit" | ||||||
| version = "0.21.1" | version = "0.22.4" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "6a8534fd7f78b5405e860340ad6575217ce99f38d4d5c8f2442cb5ecb50090e1" | checksum = "0c9ffdf896f8daaabf9b66ba8e77ea1ed5ed0f72821b398aba62352e95062951" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "indexmap", |  "indexmap", | ||||||
|  "serde", |  "serde", | ||||||
| @@ -3798,9 +3817,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen" | name = "wasm-bindgen" | ||||||
| version = "0.2.90" | version = "0.2.91" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "b1223296a201415c7fad14792dbefaace9bd52b62d33453ade1c5b5f07555406" | checksum = "c1e124130aee3fb58c5bdd6b639a0509486b0338acaaae0c84a5124b0f588b7f" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "wasm-bindgen-macro", |  "wasm-bindgen-macro", | ||||||
| @@ -3808,9 +3827,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen-backend" | name = "wasm-bindgen-backend" | ||||||
| version = "0.2.90" | version = "0.2.91" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "fcdc935b63408d58a32f8cc9738a0bffd8f05cc7c002086c6ef20b7312ad9dcd" | checksum = "c9e7e1900c352b609c8488ad12639a311045f40a35491fb69ba8c12f758af70b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bumpalo", |  "bumpalo", | ||||||
|  "log", |  "log", | ||||||
| @@ -3823,9 +3842,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen-futures" | name = "wasm-bindgen-futures" | ||||||
| version = "0.4.40" | version = "0.4.41" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bde2032aeb86bdfaecc8b261eef3cba735cc426c1f3a3416d1e0791be95fc461" | checksum = "877b9c3f61ceea0e56331985743b13f3d25c406a7098d45180fb5f09bc19ed97" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
|  "js-sys", |  "js-sys", | ||||||
| @@ -3835,9 +3854,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen-macro" | name = "wasm-bindgen-macro" | ||||||
| version = "0.2.90" | version = "0.2.91" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3e4c238561b2d428924c49815533a8b9121c664599558a5d9ec51f8a1740a999" | checksum = "b30af9e2d358182b5c7449424f017eba305ed32a7010509ede96cdc4696c46ed" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "quote", |  "quote", | ||||||
|  "wasm-bindgen-macro-support", |  "wasm-bindgen-macro-support", | ||||||
| @@ -3845,9 +3864,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen-macro-support" | name = "wasm-bindgen-macro-support" | ||||||
| version = "0.2.90" | version = "0.2.91" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bae1abb6806dc1ad9e560ed242107c0f6c84335f1749dd4e8ddb012ebd5e25a7" | checksum = "642f325be6301eb8107a83d12a8ac6c1e1c54345a7ef1a9261962dfefda09e66" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2", |  "proc-macro2", | ||||||
|  "quote", |  "quote", | ||||||
| @@ -3858,9 +3877,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-bindgen-shared" | name = "wasm-bindgen-shared" | ||||||
| version = "0.2.90" | version = "0.2.91" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "4d91413b1c31d7539ba5ef2451af3f0b833a005eb27a631cec32bc0635a8602b" | checksum = "4f186bd2dcf04330886ce82d6f33dd75a7bfcf69ecf5763b89fcde53b6ac9838" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "wasm-streams" | name = "wasm-streams" | ||||||
| @@ -3877,9 +3896,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "web-sys" | name = "web-sys" | ||||||
| version = "0.3.67" | version = "0.3.68" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "58cd2333b6e0be7a39605f0e255892fd7418a682d8da8fe042fe25128794d2ed" | checksum = "96565907687f7aceb35bc5fc03770a8a0471d82e479f25832f54a0e3f4b28446" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "js-sys", |  "js-sys", | ||||||
|  "wasm-bindgen", |  "wasm-bindgen", | ||||||
| @@ -4106,9 +4125,9 @@ checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "winnow" | name = "winnow" | ||||||
| version = "0.5.36" | version = "0.5.39" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "818ce546a11a9986bc24f93d0cdf38a8a1a400f1473ea8c82e59f6e0ffab9249" | checksum = "5389a154b01683d28c77f8f68f49dea75f0a4da32557a58f68ee51ebba472d29" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "memchr", |  "memchr", | ||||||
| ] | ] | ||||||
|   | |||||||
							
								
								
									
										65
									
								
								Cargo.toml
									
									
									
									
									
								
							
							
						
						
									
										65
									
								
								Cargo.toml
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ name = "vaultwarden" | |||||||
| version = "1.0.0" | version = "1.0.0" | ||||||
| authors = ["Daniel García <dani-garcia@users.noreply.github.com>"] | authors = ["Daniel García <dani-garcia@users.noreply.github.com>"] | ||||||
| edition = "2021" | edition = "2021" | ||||||
| rust-version = "1.73.0" | rust-version = "1.74.0" | ||||||
| resolver = "2" | resolver = "2" | ||||||
|  |  | ||||||
| repository = "https://github.com/dani-garcia/vaultwarden" | repository = "https://github.com/dani-garcia/vaultwarden" | ||||||
| @@ -51,8 +51,8 @@ dotenvy = { version = "0.15.7", default-features = false } | |||||||
| once_cell = "1.19.0" | once_cell = "1.19.0" | ||||||
|  |  | ||||||
| # Numerical libraries | # Numerical libraries | ||||||
| num-traits = "0.2.17" | num-traits = "0.2.18" | ||||||
| num-derive = "0.4.1" | num-derive = "0.4.2" | ||||||
| bigdecimal = "0.4.2" | bigdecimal = "0.4.2" | ||||||
|  |  | ||||||
| # Web framework | # Web framework | ||||||
| @@ -92,7 +92,7 @@ uuid = { version = "1.7.0", features = ["v4"] } | |||||||
| # Date and time libraries | # Date and time libraries | ||||||
| chrono = { version = "0.4.33", features = ["clock", "serde"], default-features = false } | chrono = { version = "0.4.33", features = ["clock", "serde"], default-features = false } | ||||||
| chrono-tz = "0.8.5" | chrono-tz = "0.8.5" | ||||||
| time = "0.3.32" | time = "0.3.34" | ||||||
|  |  | ||||||
| # Job scheduler | # Job scheduler | ||||||
| job_scheduler_ng = "2.0.4" | job_scheduler_ng = "2.0.4" | ||||||
| @@ -190,3 +190,60 @@ strip = "symbols" | |||||||
| lto = "fat" | lto = "fat" | ||||||
| codegen-units = 1 | codegen-units = 1 | ||||||
| panic = "abort" | panic = "abort" | ||||||
|  |  | ||||||
|  | # Profile for systems with low resources | ||||||
|  | # It will use less resources during build | ||||||
|  | [profile.release-low] | ||||||
|  | inherits = "release" | ||||||
|  | strip = "symbols" | ||||||
|  | lto = "thin" | ||||||
|  | codegen-units = 1 | ||||||
|  |  | ||||||
|  | # Linting config | ||||||
|  | [lints.rust] | ||||||
|  | # Forbid | ||||||
|  | unsafe_code = "forbid" | ||||||
|  | non_ascii_idents = "forbid" | ||||||
|  |  | ||||||
|  | # Deny | ||||||
|  | future_incompatible = "deny" | ||||||
|  | noop_method_call = "deny" | ||||||
|  | pointer_structural_match = "deny" | ||||||
|  | rust_2018_idioms = "deny" | ||||||
|  | rust_2021_compatibility = "deny" | ||||||
|  | trivial_casts = "deny" | ||||||
|  | trivial_numeric_casts = "deny" | ||||||
|  | unused = "deny" | ||||||
|  | unused_import_braces = "deny" | ||||||
|  | unused_lifetimes = "deny" | ||||||
|  | deprecated_in_future = "deny" | ||||||
|  |  | ||||||
|  | [lints.clippy] | ||||||
|  | # Allow | ||||||
|  | # We need this since Rust v1.76+, since it has some bugs | ||||||
|  | # https://github.com/rust-lang/rust-clippy/issues/12016 | ||||||
|  | blocks_in_conditions = "allow" | ||||||
|  |  | ||||||
|  | # Deny | ||||||
|  | cast_lossless = "deny" | ||||||
|  | clone_on_ref_ptr = "deny" | ||||||
|  | equatable_if_let = "deny" | ||||||
|  | float_cmp_const = "deny" | ||||||
|  | inefficient_to_string = "deny" | ||||||
|  | iter_on_empty_collections = "deny" | ||||||
|  | iter_on_single_items = "deny" | ||||||
|  | linkedlist = "deny" | ||||||
|  | macro_use_imports = "deny" | ||||||
|  | manual_assert = "deny" | ||||||
|  | manual_instant_elapsed = "deny" | ||||||
|  | manual_string_new = "deny" | ||||||
|  | match_wildcard_for_single_variants = "deny" | ||||||
|  | mem_forget = "deny" | ||||||
|  | needless_lifetimes = "deny" | ||||||
|  | string_add_assign = "deny" | ||||||
|  | string_to_string = "deny" | ||||||
|  | unnecessary_join = "deny" | ||||||
|  | unnecessary_self_imports = "deny" | ||||||
|  | unused_async = "deny" | ||||||
|  | verbose_file_reads = "deny" | ||||||
|  | zero_sized_map_values = "deny" | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								build.rs
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								build.rs
									
									
									
									
									
								
							| @@ -49,11 +49,11 @@ fn run(args: &[&str]) -> Result<String, std::io::Error> { | |||||||
|  |  | ||||||
| /// This method reads info from Git, namely tags, branch, and revision | /// This method reads info from Git, namely tags, branch, and revision | ||||||
| /// To access these values, use: | /// To access these values, use: | ||||||
| ///    - env!("GIT_EXACT_TAG") | ///    - `env!("GIT_EXACT_TAG")` | ||||||
| ///    - env!("GIT_LAST_TAG") | ///    - `env!("GIT_LAST_TAG")` | ||||||
| ///    - env!("GIT_BRANCH") | ///    - `env!("GIT_BRANCH")` | ||||||
| ///    - env!("GIT_REV") | ///    - `env!("GIT_REV")` | ||||||
| ///    - env!("VW_VERSION") | ///    - `env!("VW_VERSION")` | ||||||
| fn version_from_git_info() -> Result<String, std::io::Error> { | fn version_from_git_info() -> Result<String, std::io::Error> { | ||||||
|     // The exact tag for the current commit, can be empty when |     // The exact tag for the current commit, can be empty when | ||||||
|     // the current commit doesn't have an associated tag |     // the current commit doesn't have an associated tag | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| --- | --- | ||||||
| vault_version: "v2024.1.2" | vault_version: "v2024.1.2b" | ||||||
| vault_image_digest: "sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b" | vault_image_digest: "sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08" | ||||||
| # Cross Compile Docker Helper Scripts v1.3.0 | # Cross Compile Docker Helper Scripts v1.3.0 | ||||||
| # We use the linux/amd64 platform shell scripts since there is no difference between the different platform scripts | # We use the linux/amd64 platform shell scripts since there is no difference between the different platform scripts | ||||||
| xx_image_digest: "sha256:c9609ace652bbe51dd4ce90e0af9d48a4590f1214246da5bc70e46f6dd586edc" | xx_image_digest: "sha256:c9609ace652bbe51dd4ce90e0af9d48a4590f1214246da5bc70e46f6dd586edc" | ||||||
| rust_version: 1.75.0 # Rust version to be used | rust_version: 1.76.0 # Rust version to be used | ||||||
| debian_version: bookworm # Debian release name to be used | debian_version: bookworm # Debian release name to be used | ||||||
| alpine_version: 3.19 # Alpine version to be used | alpine_version: 3.19 # Alpine version to be used | ||||||
| # For which platforms/architectures will we try to build images | # For which platforms/architectures will we try to build images | ||||||
|   | |||||||
| @@ -18,23 +18,23 @@ | |||||||
| # - From https://hub.docker.com/r/vaultwarden/web-vault/tags, | # - From https://hub.docker.com/r/vaultwarden/web-vault/tags, | ||||||
| #   click the tag name to view the digest of the image it currently points to. | #   click the tag name to view the digest of the image it currently points to. | ||||||
| # - From the command line: | # - From the command line: | ||||||
| #     $ docker pull docker.io/vaultwarden/web-vault:v2024.1.2 | #     $ docker pull docker.io/vaultwarden/web-vault:v2024.1.2b | ||||||
| #     $ docker image inspect --format "{{.RepoDigests}}" docker.io/vaultwarden/web-vault:v2024.1.2 | #     $ docker image inspect --format "{{.RepoDigests}}" docker.io/vaultwarden/web-vault:v2024.1.2b | ||||||
| #     [docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b] | #     [docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08] | ||||||
| # | # | ||||||
| # - Conversely, to get the tag name from the digest: | # - Conversely, to get the tag name from the digest: | ||||||
| #     $ docker image inspect --format "{{.RepoTags}}" docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b | #     $ docker image inspect --format "{{.RepoTags}}" docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08 | ||||||
| #     [docker.io/vaultwarden/web-vault:v2024.1.2] | #     [docker.io/vaultwarden/web-vault:v2024.1.2b] | ||||||
| # | # | ||||||
| FROM --platform=linux/amd64 docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b as vault | FROM --platform=linux/amd64 docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08 as vault | ||||||
|  |  | ||||||
| ########################## ALPINE BUILD IMAGES ########################## | ########################## ALPINE BUILD IMAGES ########################## | ||||||
| ## NOTE: The Alpine Base Images do not support other platforms then linux/amd64 | ## NOTE: The Alpine Base Images do not support other platforms then linux/amd64 | ||||||
| ## And for Alpine we define all build images here, they will only be loaded when actually used | ## And for Alpine we define all build images here, they will only be loaded when actually used | ||||||
| FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:x86_64-musl-stable-1.75.0 as build_amd64 | FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:x86_64-musl-stable-1.76.0 as build_amd64 | ||||||
| FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:aarch64-musl-stable-1.75.0 as build_arm64 | FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:aarch64-musl-stable-1.76.0 as build_arm64 | ||||||
| FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:armv7-musleabihf-stable-1.75.0 as build_armv7 | FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:armv7-musleabihf-stable-1.76.0 as build_armv7 | ||||||
| FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:arm-musleabi-stable-1.75.0 as build_armv6 | FROM --platform=linux/amd64 ghcr.io/blackdex/rust-musl:arm-musleabi-stable-1.76.0 as build_armv6 | ||||||
|  |  | ||||||
| ########################## BUILD IMAGE ########################## | ########################## BUILD IMAGE ########################## | ||||||
| # hadolint ignore=DL3006 | # hadolint ignore=DL3006 | ||||||
|   | |||||||
| @@ -18,15 +18,15 @@ | |||||||
| # - From https://hub.docker.com/r/vaultwarden/web-vault/tags, | # - From https://hub.docker.com/r/vaultwarden/web-vault/tags, | ||||||
| #   click the tag name to view the digest of the image it currently points to. | #   click the tag name to view the digest of the image it currently points to. | ||||||
| # - From the command line: | # - From the command line: | ||||||
| #     $ docker pull docker.io/vaultwarden/web-vault:v2024.1.2 | #     $ docker pull docker.io/vaultwarden/web-vault:v2024.1.2b | ||||||
| #     $ docker image inspect --format "{{.RepoDigests}}" docker.io/vaultwarden/web-vault:v2024.1.2 | #     $ docker image inspect --format "{{.RepoDigests}}" docker.io/vaultwarden/web-vault:v2024.1.2b | ||||||
| #     [docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b] | #     [docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08] | ||||||
| # | # | ||||||
| # - Conversely, to get the tag name from the digest: | # - Conversely, to get the tag name from the digest: | ||||||
| #     $ docker image inspect --format "{{.RepoTags}}" docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b | #     $ docker image inspect --format "{{.RepoTags}}" docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08 | ||||||
| #     [docker.io/vaultwarden/web-vault:v2024.1.2] | #     [docker.io/vaultwarden/web-vault:v2024.1.2b] | ||||||
| # | # | ||||||
| FROM --platform=linux/amd64 docker.io/vaultwarden/web-vault@sha256:ac07a71cbcd199e3c9a0639c04234ba2f1ba16cfa2a45b08a7ae27eb82f8e13b as vault | FROM --platform=linux/amd64 docker.io/vaultwarden/web-vault@sha256:798c0c893b6d16728878ff280b49da08863334d1f8dd88895580dc3dba622f08 as vault | ||||||
|  |  | ||||||
| ########################## Cross Compile Docker Helper Scripts ########################## | ########################## Cross Compile Docker Helper Scripts ########################## | ||||||
| ## We use the linux/amd64 no matter which Build Platform, since these are all bash scripts | ## We use the linux/amd64 no matter which Build Platform, since these are all bash scripts | ||||||
| @@ -35,7 +35,7 @@ FROM --platform=linux/amd64 docker.io/tonistiigi/xx@sha256:c9609ace652bbe51dd4ce | |||||||
|  |  | ||||||
| ########################## BUILD IMAGE ########################## | ########################## BUILD IMAGE ########################## | ||||||
| # hadolint ignore=DL3006 | # hadolint ignore=DL3006 | ||||||
| FROM --platform=$BUILDPLATFORM docker.io/library/rust:1.75.0-slim-bookworm as build | FROM --platform=$BUILDPLATFORM docker.io/library/rust:1.76.0-slim-bookworm as build | ||||||
| COPY --from=xx / / | COPY --from=xx / / | ||||||
| ARG TARGETARCH | ARG TARGETARCH | ||||||
| ARG TARGETVARIANT | ARG TARGETVARIANT | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| [toolchain] | [toolchain] | ||||||
| channel = "1.75.0" | channel = "1.76.0" | ||||||
| components = [ "rustfmt", "clippy" ] | components = [ "rustfmt", "clippy" ] | ||||||
| profile = "minimal" | profile = "minimal" | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ async fn get_user_events( | |||||||
|     }))) |     }))) | ||||||
| } | } | ||||||
|  |  | ||||||
| fn get_continuation_token(events_json: &Vec<Value>) -> Option<&str> { | fn get_continuation_token(events_json: &[Value]) -> Option<&str> { | ||||||
|     // When the length of the vec equals the max page_size there probably is more data |     // When the length of the vec equals the max page_size there probably is more data | ||||||
|     // When it is less, then all events are loaded. |     // When it is less, then all events are loaded. | ||||||
|     if events_json.len() as i64 == Event::PAGE_SIZE { |     if events_json.len() as i64 == Event::PAGE_SIZE { | ||||||
|   | |||||||
| @@ -2659,6 +2659,7 @@ async fn delete_group_user( | |||||||
| struct OrganizationUserResetPasswordEnrollmentRequest { | struct OrganizationUserResetPasswordEnrollmentRequest { | ||||||
|     ResetPasswordKey: Option<String>, |     ResetPasswordKey: Option<String>, | ||||||
|     MasterPasswordHash: Option<String>, |     MasterPasswordHash: Option<String>, | ||||||
|  |     Otp: Option<String>, | ||||||
| } | } | ||||||
|  |  | ||||||
| #[derive(Deserialize)] | #[derive(Deserialize)] | ||||||
| @@ -2841,14 +2842,12 @@ async fn put_reset_password_enrollment( | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     if reset_request.ResetPasswordKey.is_some() { |     if reset_request.ResetPasswordKey.is_some() { | ||||||
|         match reset_request.MasterPasswordHash { |         PasswordOrOtpData { | ||||||
|             Some(password) => { |             MasterPasswordHash: reset_request.MasterPasswordHash, | ||||||
|                 if !headers.user.check_valid_password(&password) { |             Otp: reset_request.Otp, | ||||||
|                     err!("Invalid or wrong password") |         } | ||||||
|                 } |         .validate(&headers.user, true, &mut conn) | ||||||
|             } |         .await?; | ||||||
|             None => err!("No password provided"), |  | ||||||
|         }; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     org_user.reset_password_key = reset_request.ResetPasswordKey; |     org_user.reset_password_key = reset_request.ResetPasswordKey; | ||||||
|   | |||||||
							
								
								
									
										31
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								src/main.rs
									
									
									
									
									
								
							| @@ -1,34 +1,3 @@ | |||||||
| #![forbid(unsafe_code, non_ascii_idents)] |  | ||||||
| #![deny( |  | ||||||
|     rust_2018_idioms, |  | ||||||
|     rust_2021_compatibility, |  | ||||||
|     noop_method_call, |  | ||||||
|     pointer_structural_match, |  | ||||||
|     trivial_casts, |  | ||||||
|     trivial_numeric_casts, |  | ||||||
|     unused_import_braces, |  | ||||||
|     clippy::cast_lossless, |  | ||||||
|     clippy::clone_on_ref_ptr, |  | ||||||
|     clippy::equatable_if_let, |  | ||||||
|     clippy::float_cmp_const, |  | ||||||
|     clippy::inefficient_to_string, |  | ||||||
|     clippy::iter_on_empty_collections, |  | ||||||
|     clippy::iter_on_single_items, |  | ||||||
|     clippy::linkedlist, |  | ||||||
|     clippy::macro_use_imports, |  | ||||||
|     clippy::manual_assert, |  | ||||||
|     clippy::manual_instant_elapsed, |  | ||||||
|     clippy::manual_string_new, |  | ||||||
|     clippy::match_wildcard_for_single_variants, |  | ||||||
|     clippy::mem_forget, |  | ||||||
|     clippy::string_add_assign, |  | ||||||
|     clippy::string_to_string, |  | ||||||
|     clippy::unnecessary_join, |  | ||||||
|     clippy::unnecessary_self_imports, |  | ||||||
|     clippy::unused_async, |  | ||||||
|     clippy::verbose_file_reads, |  | ||||||
|     clippy::zero_sized_map_values |  | ||||||
| )] |  | ||||||
| #![cfg_attr(feature = "unstable", feature(ip))] | #![cfg_attr(feature = "unstable", feature(ip))] | ||||||
| // The recursion_limit is mainly triggered by the json!() macro. | // The recursion_limit is mainly triggered by the json!() macro. | ||||||
| // The more key/value pairs there are the more recursion occurs. | // The more key/value pairs there are the more recursion occurs. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user