mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Macro recursion decrease and other optimizations
- Decreased `recursion_limit` from 512 to 87 Mainly done by optimizing the config macro's. This fixes an issue with the rust-analyzer which doesn't go beyond 128 - Removed Regex for masking sensitive values and replaced it with a map() This is much faster then using a Regex. - Refactored the get_support_json macro's - All items above also lowered the binary size and possibly compile-time - Removed `_conn: DbConn` from several functions, these caused unnecessary database connections for functions who didn't used that at all - Decreased json response for `/plans` - Updated libraries and where needed some code changes This also fixes some rare issues with SMTP https://github.com/lettre/lettre/issues/678 - Using Rust 2021 instead of 2018 - Updated rust nightly
This commit is contained in:
		
							
								
								
									
										169
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										169
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -4,9 +4,9 @@ version = 3 | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "addr2line" | name = "addr2line" | ||||||
| version = "0.16.0" | version = "0.17.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3e61f2b7f93d2c7d2b08263acaa4a363b3e276806c68af6134c44f523bf1aacd" | checksum = "b9ecd88a8c8378ca913a680cd98f0f13ac67383d35993f86c90a70e3f137816b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "gimli", |  "gimli", | ||||||
| ] | ] | ||||||
| @@ -74,9 +74,9 @@ checksum = "cdb031dd78e28731d87d56cc8ffef4a8f36ca26c38fe2de700543e627f8a464a" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "backtrace" | name = "backtrace" | ||||||
| version = "0.3.62" | version = "0.3.63" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "091bcdf2da9950f96aa522681ce805e6857f6ca8df73833d35736ab2dc78e152" | checksum = "321629d8ba6513061f26707241fa9bc89524ff1cd7a915a97ef0c62c666ce1b6" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "addr2line", |  "addr2line", | ||||||
|  "cc", |  "cc", | ||||||
| @@ -133,18 +133,6 @@ version = "1.3.2" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" | checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "bitvec" |  | ||||||
| version = "0.19.5" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "8942c8d352ae1838c9dda0b0ca2ab657696ef2232a20147cf1b30ae1a9cb4321" |  | ||||||
| dependencies = [ |  | ||||||
|  "funty", |  | ||||||
|  "radium", |  | ||||||
|  "tap", |  | ||||||
|  "wyz", |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "block-buffer" | name = "block-buffer" | ||||||
| version = "0.7.3" | version = "0.7.3" | ||||||
| @@ -451,9 +439,9 @@ version = "0.3.0" | |||||||
| source = "git+https://github.com/SergioBenitez/Devise.git?rev=e58b3ac9a#e58b3ac9afc3b6ff10a8aaf02a3e768a8f530089" | source = "git+https://github.com/SergioBenitez/Devise.git?rev=e58b3ac9a#e58b3ac9afc3b6ff10a8aaf02a3e768a8f530089" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags", |  "bitflags", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -479,9 +467,9 @@ version = "1.4.1" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "45f5098f628d02a7a0f68ddba586fb61e80edec3bdc1be3b921f4ceec60858d3" | checksum = "45f5098f628d02a7a0f68ddba586fb61e80edec3bdc1be3b921f4ceec60858d3" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -638,12 +626,6 @@ version = "0.3.3" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3dcaa9ae7725d12cdb85b3ad99a434db70b468c09ded17e012d86b5c1010f7a7" | checksum = "3dcaa9ae7725d12cdb85b3ad99a434db70b468c09ded17e012d86b5c1010f7a7" | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "funty" |  | ||||||
| version = "1.1.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "fed34cd105917e91daa4da6b3728c47b068749d6a62c59811f06ed2ac71d9da7" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "futf" | name = "futf" | ||||||
| version = "0.1.4" | version = "0.1.4" | ||||||
| @@ -710,9 +692,9 @@ checksum = "18e4a4b95cea4b4ccbcf1c5675ca7c4ee4e9e75eb79944d07defde18068f79bb" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "autocfg", |  "autocfg", | ||||||
|  "proc-macro-hack", |  "proc-macro-hack", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -791,9 +773,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "gimli" | name = "gimli" | ||||||
| version = "0.25.0" | version = "0.26.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "f0a01e0497841a3b2db4f8afa483cce65f7e96a3498bd6c541734792aeac8fe7" | checksum = "78cc372d058dcf6d5ecd98510e7fbc9e5aec4d21de70f65fea8fecebcd881bd4" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "glob" | name = "glob" | ||||||
| @@ -896,9 +878,9 @@ dependencies = [ | |||||||
|  "log 0.4.14", |  "log 0.4.14", | ||||||
|  "mac", |  "mac", | ||||||
|  "markup5ever", |  "markup5ever", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -1128,9 +1110,9 @@ checksum = "830d08ce1d1d941e6b30645f1a0eb5643013d835ce3779a5fc208261dbe10f55" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "lettre" | name = "lettre" | ||||||
| version = "0.10.0-rc.3" | version = "0.10.0-rc.4" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "d8697ded52353bdd6fec234b3135972433397e86d0493d9fc38fbf407b7c106a" | checksum = "71d8da8f34d086b081c9cc3b57d3bb3b51d16fc06b5c848a188e2f14d58ac2a5" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "base64 0.13.0", |  "base64 0.13.0", | ||||||
|  "fastrand", |  "fastrand", | ||||||
| @@ -1139,7 +1121,7 @@ dependencies = [ | |||||||
|  "idna 0.2.3", |  "idna 0.2.3", | ||||||
|  "mime 0.3.16", |  "mime 0.3.16", | ||||||
|  "native-tls", |  "native-tls", | ||||||
|  "nom 6.1.2", |  "nom 7.1.0", | ||||||
|  "once_cell", |  "once_cell", | ||||||
|  "quoted_printable", |  "quoted_printable", | ||||||
|  "regex", |  "regex", | ||||||
| @@ -1149,9 +1131,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "libc" | name = "libc" | ||||||
| version = "0.2.105" | version = "0.2.106" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "869d572136620d55835903746bcb5cdc54cb2851fd0aeec53220b4bb65ef3013" | checksum = "a60553f9a9e039a333b4e9b20573b9e9b9c0bb3a11e201ccc48ef4283456d673" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "libsqlite3-sys" | name = "libsqlite3-sys" | ||||||
| @@ -1269,9 +1251,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| checksum = "9753f12909fd8d923f75ae5c3258cae1ed3c8ec052e1b38c93c21a6d157f789c" | checksum = "9753f12909fd8d923f75ae5c3258cae1ed3c8ec052e1b38c93c21a6d157f789c" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "migrations_internals", |  "migrations_internals", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -1299,6 +1281,12 @@ dependencies = [ | |||||||
|  "unicase 2.6.0", |  "unicase 2.6.0", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "minimal-lexical" | ||||||
|  | version = "0.2.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "miniz_oxide" | name = "miniz_oxide" | ||||||
| version = "0.4.4" | version = "0.4.4" | ||||||
| @@ -1448,13 +1436,12 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "nom" | name = "nom" | ||||||
| version = "6.1.2" | version = "7.1.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "e7413f999671bd4745a7b624bd370a569fb6bc574b23c83a3c5ed2e453f3d5e2" | checksum = "1b1d11e1ef389c76fe5b81bcaf2ea32cf88b62bc494e19f493d0b30e7a930109" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitvec", |  | ||||||
|  "funty", |  | ||||||
|  "memchr", |  "memchr", | ||||||
|  |  "minimal-lexical", | ||||||
|  "version_check 0.9.3", |  "version_check 0.9.3", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| @@ -1484,9 +1471,9 @@ version = "0.3.3" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "876a53fff98e03a936a674b29568b0e605f06b29372c2489ff4de23f1949743d" | checksum = "876a53fff98e03a936a674b29568b0e605f06b29372c2489ff4de23f1949743d" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -1547,9 +1534,9 @@ checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "openssl" | name = "openssl" | ||||||
| version = "0.10.36" | version = "0.10.38" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "8d9facdb76fec0b73c406f125d44d86fdad818d66fef0531eec9233ca425ff4a" | checksum = "0c7ae222234c30df141154f159066c5093ff73b63204dcda7121eb082fc56a95" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags", |  "bitflags", | ||||||
|  "cfg-if 1.0.0", |  "cfg-if 1.0.0", | ||||||
| @@ -1567,18 +1554,18 @@ checksum = "28988d872ab76095a6e6ac88d99b54fd267702734fd7ffe610ca27f533ddb95a" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "openssl-src" | name = "openssl-src" | ||||||
| version = "111.16.0+1.1.1l" | version = "300.0.2+3.0.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "7ab2173f69416cf3ec12debb5823d244127d23a9b127d5a5189aa97c5fa2859f" | checksum = "14a760a11390b1a5daf72074d4f6ff1a6e772534ae191f999f57e9ee8146d1fb" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cc", |  "cc", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "openssl-sys" | name = "openssl-sys" | ||||||
| version = "0.9.67" | version = "0.9.70" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "69df2d8dfc6ce3aaf44b40dec6f487d5a886516cf6879c49e98e0710f310a058" | checksum = "c6517987b3f8226b5da3661dad65ff7f300cc59fb5ea8333ca191fc65fde3edf" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "autocfg", |  "autocfg", | ||||||
|  "cc", |  "cc", | ||||||
| @@ -1599,9 +1586,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "parity-ws" | name = "parity-ws" | ||||||
| version = "0.11.0" | version = "0.11.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "d0ab8a461779bd022964cae2b4989fa9c99deb270bec162da2125ec03c09fcaa" | checksum = "5983d3929ad50f12c3eb9a6743f19d691866ecd44da74c0a3308c3f8a56df0c6" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "byteorder", |  "byteorder", | ||||||
|  "bytes 0.4.12", |  "bytes 0.4.12", | ||||||
| @@ -1749,9 +1736,9 @@ checksum = "99b8db626e31e5b81787b9783425769681b347011cc59471e33ea46d2ea0cf55" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "pest", |  "pest", | ||||||
|  "pest_meta", |  "pest_meta", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -1910,9 +1897,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "proc-macro2" | name = "proc-macro2" | ||||||
| version = "1.0.30" | version = "1.0.32" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "edc3358ebc67bc8b7fa0c007f945b0b18226f78437d61bec735a9eb96b61ee70" | checksum = "ba508cc11742c0dc5c1659771673afbab7a0efab23aa17e854cbab0837ed0b43" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "unicode-xid 0.2.2", |  "unicode-xid 0.2.2", | ||||||
| ] | ] | ||||||
| @@ -1962,7 +1949,7 @@ version = "1.0.10" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "38bc8cc6a5f2e3655e0899c1b848643b2562f853f114bfec7be120678e3ace05" | checksum = "38bc8cc6a5f2e3655e0899c1b848643b2562f853f114bfec7be120678e3ace05" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -1982,12 +1969,6 @@ dependencies = [ | |||||||
|  "scheduled-thread-pool", |  "scheduled-thread-pool", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "radium" |  | ||||||
| version = "0.5.3" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "941ba9d78d8e2f7ce474c015eea4d9c6d25b6a3327f9832ee29a4de27f91bbb8" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "rand" | name = "rand" | ||||||
| version = "0.4.6" | version = "0.4.6" | ||||||
| @@ -2446,9 +2427,9 @@ version = "1.0.130" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "d7bc1a1ab1961464eae040d96713baa5a724a8152c1222492465b54322ec508b" | checksum = "d7bc1a1ab1961464eae040d96713baa5a724a8152c1222492465b54322ec508b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2613,11 +2594,11 @@ version = "0.5.3" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "c87a60a40fccc84bef0652345bbbbbe20a605bf5d0ce81719fc476f5c03b50ef" | checksum = "c87a60a40fccc84bef0652345bbbbbe20a605bf5d0ce81719fc476f5c03b50ef" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "serde", |  "serde", | ||||||
|  "serde_derive", |  "serde_derive", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2627,13 +2608,13 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| checksum = "58fa5ff6ad0d98d1ffa8cb115892b6e69d67799f6763e162a1c9db421dc22e11" | checksum = "58fa5ff6ad0d98d1ffa8cb115892b6e69d67799f6763e162a1c9db421dc22e11" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "base-x", |  "base-x", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "serde", |  "serde", | ||||||
|  "serde_derive", |  "serde_derive", | ||||||
|  "serde_json", |  "serde_json", | ||||||
|  "sha1", |  "sha1", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2664,7 +2645,7 @@ checksum = "f24c8e5e19d22a726626f1a5e16fe15b132dcf21d10177fa5a45ce7962996b97" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "phf_generator 0.8.0", |  "phf_generator 0.8.0", | ||||||
|  "phf_shared 0.8.0", |  "phf_shared 0.8.0", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| @@ -2687,11 +2668,11 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "syn" | name = "syn" | ||||||
| version = "1.0.80" | version = "1.0.81" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "d010a1623fbd906d51d650a9916aaefc05ffa0e4053ff7fe601167f3e715d194" | checksum = "f2afee18b8beb5a596ecb4a2dce128c719b4ba399d34126b9e4396e3f9860966" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "unicode-xid 0.2.2", |  "unicode-xid 0.2.2", | ||||||
| ] | ] | ||||||
| @@ -2708,12 +2689,6 @@ dependencies = [ | |||||||
|  "time 0.1.44", |  "time 0.1.44", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "tap" |  | ||||||
| version = "1.0.1" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "55937e1799185b12863d447f42597ed69d9928686b8d88a1df17376a097d8369" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tempfile" | name = "tempfile" | ||||||
| version = "3.2.0" | version = "3.2.0" | ||||||
| @@ -2754,9 +2729,9 @@ version = "1.0.30" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "aa32fd3f627f367fe16f893e2597ae3c05020f8bba2666a4e6ea73d377e5714b" | checksum = "aa32fd3f627f367fe16f893e2597ae3c05020f8bba2666a4e6ea73d377e5714b" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2811,10 +2786,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| checksum = "fd3c141a1b43194f3f56a1411225df8646c55781d5f26db825b3d98507eb482f" | checksum = "fd3c141a1b43194f3f56a1411225df8646c55781d5f26db825b3d98507eb482f" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro-hack", |  "proc-macro-hack", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "standback", |  "standback", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2834,9 +2809,9 @@ checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tokio" | name = "tokio" | ||||||
| version = "1.12.0" | version = "1.13.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "c2c2416fdedca8443ae44b4527de1ea633af61d8f7169ffa6e72c5b53d24efcc" | checksum = "588b2d10a336da58d877567cd8fb8a14b463e2104910f8132cd054b4b96e29ee" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "autocfg", |  "autocfg", | ||||||
|  "bytes 1.1.0", |  "bytes 1.1.0", | ||||||
| @@ -2872,9 +2847,9 @@ dependencies = [ | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tokio-util" | name = "tokio-util" | ||||||
| version = "0.6.8" | version = "0.6.9" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "08d3725d3efa29485e87311c5b699de63cde14b00ed4d256b8318aa30ca452cd" | checksum = "9e99e1983e5d376cd8eb4b66604d2e99e79f5bd988c3055891dcd8c9e2604cc0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bytes 1.1.0", |  "bytes 1.1.0", | ||||||
|  "futures-core", |  "futures-core", | ||||||
| @@ -2930,9 +2905,9 @@ version = "0.1.18" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "f4f480b8f81512e825f337ad51e94c1eb5d3bbdf2b363dcd01e2b19a9ffe3f8e" | checksum = "f4f480b8f81512e825f337ad51e94c1eb5d3bbdf2b363dcd01e2b19a9ffe3f8e" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -3224,9 +3199,9 @@ dependencies = [ | |||||||
|  "bumpalo", |  "bumpalo", | ||||||
|  "lazy_static", |  "lazy_static", | ||||||
|  "log 0.4.14", |  "log 0.4.14", | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
|  "wasm-bindgen-shared", |  "wasm-bindgen-shared", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| @@ -3258,9 +3233,9 @@ version = "0.2.78" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "7803e0eea25835f8abdc585cd3021b3deb11543c6fe226dcd30b228857c5c5ab" | checksum = "7803e0eea25835f8abdc585cd3021b3deb11543c6fe226dcd30b228857c5c5ab" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "proc-macro2 1.0.30", |  "proc-macro2 1.0.32", | ||||||
|  "quote 1.0.10", |  "quote 1.0.10", | ||||||
|  "syn 1.0.80", |  "syn 1.0.81", | ||||||
|  "wasm-bindgen-backend", |  "wasm-bindgen-backend", | ||||||
|  "wasm-bindgen-shared", |  "wasm-bindgen-shared", | ||||||
| ] | ] | ||||||
| @@ -3382,12 +3357,6 @@ dependencies = [ | |||||||
|  "winapi-build", |  "winapi-build", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "wyz" |  | ||||||
| version = "0.2.0" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| checksum = "85e60b0d1b5f99db2556934e21937020776a5d31520bf169e851ac44e6420214" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "xml5ever" | name = "xml5ever" | ||||||
| version = "0.16.2" | version = "0.16.2" | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								Cargo.toml
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								Cargo.toml
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
| name = "vaultwarden" | 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 = "2018" | edition = "2021" | ||||||
| rust-version = "1.57" | rust-version = "1.57" | ||||||
| resolver = "2" | resolver = "2" | ||||||
|  |  | ||||||
| @@ -46,7 +46,7 @@ url = "2.2.2" | |||||||
| multipart = { version = "0.18.0", features = ["server"], default-features = false } | multipart = { version = "0.18.0", features = ["server"], default-features = false } | ||||||
|  |  | ||||||
| # WebSockets library | # WebSockets library | ||||||
| ws = { version = "0.11.0", package = "parity-ws" } | ws = { version = "0.11.1", package = "parity-ws" } | ||||||
|  |  | ||||||
| # MessagePack library | # MessagePack library | ||||||
| rmpv = "1.0.0" | rmpv = "1.0.0" | ||||||
| @@ -112,7 +112,7 @@ num-derive = "0.3.3" | |||||||
|  |  | ||||||
| # Email libraries | # Email libraries | ||||||
| tracing = { version = "0.1.29", features = ["log"] } # Needed to have lettre trace logging used when SMTP_DEBUG is enabled. | tracing = { version = "0.1.29", features = ["log"] } # Needed to have lettre trace logging used when SMTP_DEBUG is enabled. | ||||||
| lettre = { version = "0.10.0-rc.3", features = ["smtp-transport", "builder", "serde", "native-tls", "hostname", "tracing"], default-features = false } | lettre = { version = "0.10.0-rc.4", features = ["smtp-transport", "builder", "serde", "native-tls", "hostname", "tracing"], default-features = false } | ||||||
|  |  | ||||||
| # Template library | # Template library | ||||||
| handlebars = { version = "4.1.3", features = ["dir_source"] } | handlebars = { version = "4.1.3", features = ["dir_source"] } | ||||||
| @@ -124,7 +124,7 @@ regex = { version = "1.5.4", features = ["std", "perf", "unicode-perl"], default | |||||||
| data-url = "0.1.0" | data-url = "0.1.0" | ||||||
|  |  | ||||||
| # Used by U2F, JWT and Postgres | # Used by U2F, JWT and Postgres | ||||||
| openssl = "0.10.36" | openssl = "0.10.38" | ||||||
|  |  | ||||||
| # URL encoding library | # URL encoding library | ||||||
| percent-encoding = "2.1.0" | percent-encoding = "2.1.0" | ||||||
| @@ -135,7 +135,7 @@ idna = "0.2.3" | |||||||
| pico-args = "0.4.2" | pico-args = "0.4.2" | ||||||
|  |  | ||||||
| # Logging panics to logfile instead stderr only | # Logging panics to logfile instead stderr only | ||||||
| backtrace = "0.3.62" | backtrace = "0.3.63" | ||||||
|  |  | ||||||
| # Macro ident concatenation | # Macro ident concatenation | ||||||
| paste = "1.0.5" | paste = "1.0.5" | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
| {% set build_stage_base_image = "rust:1.55-buster" %} | {% set build_stage_base_image = "rust:1.55-buster" %} | ||||||
| {% if "alpine" in target_file %} | {% if "alpine" in target_file %} | ||||||
| {%   if "amd64" in target_file %} | {%   if "amd64" in target_file %} | ||||||
| {%     set build_stage_base_image = "clux/muslrust:nightly-2021-10-06" %} | {%     set build_stage_base_image = "clux/muslrust:nightly-2021-10-23" %} | ||||||
| {%     set runtime_stage_base_image = "alpine:3.14" %} | {%     set runtime_stage_base_image = "alpine:3.14" %} | ||||||
| {%     set package_arch_target = "x86_64-unknown-linux-musl" %} | {%     set package_arch_target = "x86_64-unknown-linux-musl" %} | ||||||
| {%   elif "armv7" in target_file %} | {%   elif "armv7" in target_file %} | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ | |||||||
| FROM vaultwarden/web-vault@sha256:0e8daf80abb73ebca69d1971847450d24da45a74a525fd643246ee1dfa02108b as vault | FROM vaultwarden/web-vault@sha256:0e8daf80abb73ebca69d1971847450d24da45a74a525fd643246ee1dfa02108b as vault | ||||||
|  |  | ||||||
| ########################## BUILD IMAGE  ########################## | ########################## BUILD IMAGE  ########################## | ||||||
| FROM clux/muslrust:nightly-2021-10-06 as build | FROM clux/muslrust:nightly-2021-10-23 as build | ||||||
|  |  | ||||||
| # Alpine-based AMD64 (musl) does not support mysql/mariadb during compile time. | # Alpine-based AMD64 (musl) does not support mysql/mariadb during compile time. | ||||||
| ARG DB=sqlite,postgresql | ARG DB=sqlite,postgresql | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ | |||||||
| FROM vaultwarden/web-vault@sha256:0e8daf80abb73ebca69d1971847450d24da45a74a525fd643246ee1dfa02108b as vault | FROM vaultwarden/web-vault@sha256:0e8daf80abb73ebca69d1971847450d24da45a74a525fd643246ee1dfa02108b as vault | ||||||
|  |  | ||||||
| ########################## BUILD IMAGE  ########################## | ########################## BUILD IMAGE  ########################## | ||||||
| FROM clux/muslrust:nightly-2021-10-06 as build | FROM clux/muslrust:nightly-2021-10-23 as build | ||||||
|  |  | ||||||
| # Alpine-based AMD64 (musl) does not support mysql/mariadb during compile time. | # Alpine-based AMD64 (musl) does not support mysql/mariadb during compile time. | ||||||
| ARG DB=sqlite,postgresql | ARG DB=sqlite,postgresql | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| nightly-2021-10-14 | nightly-2021-11-05 | ||||||
|   | |||||||
| @@ -236,7 +236,7 @@ impl AdminTemplateData { | |||||||
| } | } | ||||||
|  |  | ||||||
| #[get("/", rank = 1)] | #[get("/", rank = 1)] | ||||||
| fn admin_page(_token: AdminToken, _conn: DbConn) -> ApiResult<Html<String>> { | fn admin_page(_token: AdminToken) -> ApiResult<Html<String>> { | ||||||
|     let text = AdminTemplateData::new().render()?; |     let text = AdminTemplateData::new().render()?; | ||||||
|     Ok(Html(text)) |     Ok(Html(text)) | ||||||
| } | } | ||||||
| @@ -494,7 +494,6 @@ fn diagnostics(_token: AdminToken, ip_header: IpHeader, conn: DbConn) -> ApiResu | |||||||
|  |  | ||||||
|     // Execute some environment checks |     // Execute some environment checks | ||||||
|     let running_within_docker = is_running_in_docker(); |     let running_within_docker = is_running_in_docker(); | ||||||
|     let docker_base_image = docker_base_image(); |  | ||||||
|     let has_http_access = has_http_access(); |     let has_http_access = has_http_access(); | ||||||
|     let uses_proxy = env::var_os("HTTP_PROXY").is_some() |     let uses_proxy = env::var_os("HTTP_PROXY").is_some() | ||||||
|         || env::var_os("http_proxy").is_some() |         || env::var_os("http_proxy").is_some() | ||||||
| @@ -552,7 +551,7 @@ fn diagnostics(_token: AdminToken, ip_header: IpHeader, conn: DbConn) -> ApiResu | |||||||
|         "web_vault_version": web_vault_version.version, |         "web_vault_version": web_vault_version.version, | ||||||
|         "latest_web_build": latest_web_build, |         "latest_web_build": latest_web_build, | ||||||
|         "running_within_docker": running_within_docker, |         "running_within_docker": running_within_docker, | ||||||
|         "docker_base_image": docker_base_image, |         "docker_base_image": docker_base_image(), | ||||||
|         "has_http_access": has_http_access, |         "has_http_access": has_http_access, | ||||||
|         "ip_header_exists": &ip_header.0.is_some(), |         "ip_header_exists": &ip_header.0.is_some(), | ||||||
|         "ip_header_match": ip_header_name == CONFIG.ip_header(), |         "ip_header_match": ip_header_name == CONFIG.ip_header(), | ||||||
|   | |||||||
| @@ -454,7 +454,7 @@ fn post_email(data: JsonUpcase<ChangeEmailData>, headers: Headers, conn: DbConn) | |||||||
| } | } | ||||||
|  |  | ||||||
| #[post("/accounts/verify-email")] | #[post("/accounts/verify-email")] | ||||||
| fn post_verify_email(headers: Headers, _conn: DbConn) -> EmptyResult { | fn post_verify_email(headers: Headers) -> EmptyResult { | ||||||
|     let user = headers.user; |     let user = headers.user; | ||||||
|  |  | ||||||
|     if !CONFIG.mail_enabled() { |     if !CONFIG.mail_enabled() { | ||||||
| @@ -654,7 +654,7 @@ struct VerifyPasswordData { | |||||||
| } | } | ||||||
|  |  | ||||||
| #[post("/accounts/verify-password", data = "<data>")] | #[post("/accounts/verify-password", data = "<data>")] | ||||||
| fn verify_password(data: JsonUpcase<VerifyPasswordData>, headers: Headers, _conn: DbConn) -> EmptyResult { | fn verify_password(data: JsonUpcase<VerifyPasswordData>, headers: Headers) -> EmptyResult { | ||||||
|     let data: VerifyPasswordData = data.into_inner().data; |     let data: VerifyPasswordData = data.into_inner().data; | ||||||
|     let user = headers.user; |     let user = headers.user; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1294,71 +1294,43 @@ fn put_policy( | |||||||
|  |  | ||||||
| #[allow(unused_variables)] | #[allow(unused_variables)] | ||||||
| #[get("/organizations/<org_id>/tax")] | #[get("/organizations/<org_id>/tax")] | ||||||
| fn get_organization_tax(org_id: String, _headers: Headers, _conn: DbConn) -> EmptyResult { | fn get_organization_tax(org_id: String, _headers: Headers) -> Json<Value> { | ||||||
|     // Prevent a 404 error, which also causes Javascript errors. |     // Prevent a 404 error, which also causes Javascript errors. | ||||||
|     err!("Only allowed when not self hosted.") |     // Upstream sends "Only allowed when not self hosted." As an error message. | ||||||
|  |     // If we do the same it will also output this to the log, which is overkill. | ||||||
|  |     // An empty list/data also works fine. | ||||||
|  |     Json(_empty_data_json()) | ||||||
| } | } | ||||||
|  |  | ||||||
| #[get("/plans")] | #[get("/plans")] | ||||||
| fn get_plans(_headers: Headers, _conn: DbConn) -> Json<Value> { | fn get_plans(_headers: Headers) -> Json<Value> { | ||||||
|  |     // Respond with a minimal json just enough to allow the creation of an new organization. | ||||||
|     Json(json!({ |     Json(json!({ | ||||||
|         "Object": "list", |         "Object": "list", | ||||||
|         "Data": [ |         "Data": [{ | ||||||
|         { |  | ||||||
|             "Object": "plan", |             "Object": "plan", | ||||||
|             "Type": 0, |             "Type": 0, | ||||||
|             "Product": 0, |             "Product": 0, | ||||||
|             "Name": "Free", |             "Name": "Free", | ||||||
|             "IsAnnual": false, |  | ||||||
|             "NameLocalizationKey": "planNameFree", |             "NameLocalizationKey": "planNameFree", | ||||||
|             "DescriptionLocalizationKey": "planDescFree", |             "DescriptionLocalizationKey": "planDescFree" | ||||||
|             "CanBeUsedByBusiness": false, |         }], | ||||||
|             "BaseSeats": 2, |  | ||||||
|             "BaseStorageGb": null, |  | ||||||
|             "MaxCollections": 2, |  | ||||||
|             "MaxUsers": 2, |  | ||||||
|             "HasAdditionalSeatsOption": false, |  | ||||||
|             "MaxAdditionalSeats": null, |  | ||||||
|             "HasAdditionalStorageOption": false, |  | ||||||
|             "MaxAdditionalStorage": null, |  | ||||||
|             "HasPremiumAccessOption": false, |  | ||||||
|             "TrialPeriodDays": null, |  | ||||||
|             "HasSelfHost": false, |  | ||||||
|             "HasPolicies": false, |  | ||||||
|             "HasGroups": false, |  | ||||||
|             "HasDirectory": false, |  | ||||||
|             "HasEvents": false, |  | ||||||
|             "HasTotp": false, |  | ||||||
|             "Has2fa": false, |  | ||||||
|             "HasApi": false, |  | ||||||
|             "HasSso": false, |  | ||||||
|             "UsersGetPremium": false, |  | ||||||
|             "UpgradeSortOrder": -1, |  | ||||||
|             "DisplaySortOrder": -1, |  | ||||||
|             "LegacyYear": null, |  | ||||||
|             "Disabled": false, |  | ||||||
|             "StripePlanId": null, |  | ||||||
|             "StripeSeatPlanId": null, |  | ||||||
|             "StripeStoragePlanId": null, |  | ||||||
|             "StripePremiumAccessPlanId": null, |  | ||||||
|             "BasePrice": 0.0, |  | ||||||
|             "SeatPrice": 0.0, |  | ||||||
|             "AdditionalStoragePricePerGb": 0.0, |  | ||||||
|             "PremiumAccessOptionPrice": 0.0 |  | ||||||
|             } |  | ||||||
|         ], |  | ||||||
|         "ContinuationToken": null |         "ContinuationToken": null | ||||||
|     })) |     })) | ||||||
| } | } | ||||||
|  |  | ||||||
| #[get("/plans/sales-tax-rates")] | #[get("/plans/sales-tax-rates")] | ||||||
| fn get_plans_tax_rates(_headers: Headers, _conn: DbConn) -> Json<Value> { | fn get_plans_tax_rates(_headers: Headers) -> Json<Value> { | ||||||
|     // Prevent a 404 error, which also causes Javascript errors. |     // Prevent a 404 error, which also causes Javascript errors. | ||||||
|     Json(json!({ |     Json(_empty_data_json()) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fn _empty_data_json() -> Value { | ||||||
|  |     json!({ | ||||||
|         "Object": "list", |         "Object": "list", | ||||||
|         "Data": [], |         "Data": [], | ||||||
|         "ContinuationToken": null |         "ContinuationToken": null | ||||||
|     })) |     }) | ||||||
| } | } | ||||||
|  |  | ||||||
| #[derive(Deserialize, Debug)] | #[derive(Deserialize, Debug)] | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ use rocket::Route; | |||||||
| use rocket_contrib::json::Json; | use rocket_contrib::json::Json; | ||||||
| use serde_json::Value as JsonValue; | use serde_json::Value as JsonValue; | ||||||
|  |  | ||||||
| use crate::{api::EmptyResult, auth::Headers, db::DbConn, Error, CONFIG}; | use crate::{api::EmptyResult, auth::Headers, Error, CONFIG}; | ||||||
|  |  | ||||||
| pub fn routes() -> Vec<Route> { | pub fn routes() -> Vec<Route> { | ||||||
|     routes![negotiate, websockets_err] |     routes![negotiate, websockets_err] | ||||||
| @@ -30,7 +30,7 @@ fn websockets_err() -> EmptyResult { | |||||||
| } | } | ||||||
|  |  | ||||||
| #[post("/hub/negotiate")] | #[post("/hub/negotiate")] | ||||||
| fn negotiate(_headers: Headers, _conn: DbConn) -> Json<JsonValue> { | fn negotiate(_headers: Headers) -> Json<JsonValue> { | ||||||
|     use crate::crypto; |     use crate::crypto; | ||||||
|     use data_encoding::BASE64URL; |     use data_encoding::BASE64URL; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -165,7 +165,6 @@ pub fn generate_invite_claims( | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| //           var token = _dataProtector.Protect($"EmergencyAccessInvite {emergencyAccess.Id} {emergencyAccess.Email} {nowMillis}"); |  | ||||||
| #[derive(Debug, Serialize, Deserialize)] | #[derive(Debug, Serialize, Deserialize)] | ||||||
| pub struct EmergencyAccessInviteJwtClaims { | pub struct EmergencyAccessInviteJwtClaims { | ||||||
|     // Not before |     // Not before | ||||||
|   | |||||||
							
								
								
									
										153
									
								
								src/config.rs
									
									
									
									
									
								
							
							
						
						
									
										153
									
								
								src/config.rs
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ use std::process::exit; | |||||||
| use std::sync::RwLock; | use std::sync::RwLock; | ||||||
|  |  | ||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use regex::Regex; |  | ||||||
| use reqwest::Url; | use reqwest::Url; | ||||||
|  |  | ||||||
| use crate::{ | use crate::{ | ||||||
| @@ -23,21 +22,6 @@ pub static CONFIG: Lazy<Config> = Lazy::new(|| { | |||||||
|     }) |     }) | ||||||
| }); | }); | ||||||
|  |  | ||||||
| static PRIVACY_REGEX: Lazy<Regex> = Lazy::new(|| Regex::new(r"[\w]").unwrap()); |  | ||||||
| const PRIVACY_CONFIG: &[&str] = &[ |  | ||||||
|     "allowed_iframe_ancestors", |  | ||||||
|     "database_url", |  | ||||||
|     "domain_origin", |  | ||||||
|     "domain_path", |  | ||||||
|     "domain", |  | ||||||
|     "helo_name", |  | ||||||
|     "org_creation_users", |  | ||||||
|     "signups_domains_whitelist", |  | ||||||
|     "smtp_from", |  | ||||||
|     "smtp_host", |  | ||||||
|     "smtp_username", |  | ||||||
| ]; |  | ||||||
|  |  | ||||||
| pub type Pass = String; | pub type Pass = String; | ||||||
|  |  | ||||||
| macro_rules! make_config { | macro_rules! make_config { | ||||||
| @@ -61,7 +45,7 @@ macro_rules! make_config { | |||||||
|             _overrides: Vec<String>, |             _overrides: Vec<String>, | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         #[derive(Debug, Clone, Default, Deserialize, Serialize)] |         #[derive(Clone, Default, Deserialize, Serialize)] | ||||||
|         pub struct ConfigBuilder { |         pub struct ConfigBuilder { | ||||||
|             $($( |             $($( | ||||||
|                 #[serde(skip_serializing_if = "Option::is_none")] |                 #[serde(skip_serializing_if = "Option::is_none")] | ||||||
| @@ -133,19 +117,6 @@ macro_rules! make_config { | |||||||
|                 builder |                 builder | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             /// Returns a new builder with all the elements from self, |  | ||||||
|             /// except those that are equal in both sides |  | ||||||
|             fn _remove(&self, other: &Self) -> Self { |  | ||||||
|                 let mut builder = ConfigBuilder::default(); |  | ||||||
|                 $($( |  | ||||||
|                     if &self.$name != &other.$name { |  | ||||||
|                         builder.$name = self.$name.clone(); |  | ||||||
|                     } |  | ||||||
|  |  | ||||||
|                 )+)+ |  | ||||||
|                 builder |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             fn build(&self) -> ConfigItems { |             fn build(&self) -> ConfigItems { | ||||||
|                 let mut config = ConfigItems::default(); |                 let mut config = ConfigItems::default(); | ||||||
|                 let _domain_set = self.domain.is_some(); |                 let _domain_set = self.domain.is_some(); | ||||||
| @@ -161,7 +132,7 @@ macro_rules! make_config { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         #[derive(Debug, Clone, Default)] |         #[derive(Clone, Default)] | ||||||
|         struct ConfigItems { $($( $name: make_config!{@type $ty, $none_action}, )+)+ } |         struct ConfigItems { $($( $name: make_config!{@type $ty, $none_action}, )+)+ } | ||||||
|  |  | ||||||
|         #[allow(unused)] |         #[allow(unused)] | ||||||
| @@ -190,38 +161,91 @@ macro_rules! make_config { | |||||||
|  |  | ||||||
|                 fn _get_doc(doc: &str) -> serde_json::Value { |                 fn _get_doc(doc: &str) -> serde_json::Value { | ||||||
|                     let mut split = doc.split("|>").map(str::trim); |                     let mut split = doc.split("|>").map(str::trim); | ||||||
|                     json!({ |  | ||||||
|                         "name": split.next(), |                     // We do not use the json!() macro here since that causes a lot of macro recursion. | ||||||
|                         "description": split.next() |                     // This slows down compile time and it also causes issues with rust-analyzer | ||||||
|  |                     serde_json::Value::Object({ | ||||||
|  |                         let mut doc_json = serde_json::Map::new(); | ||||||
|  |                         doc_json.insert("name".into(), serde_json::to_value(split.next()).unwrap()); | ||||||
|  |                         doc_json.insert("description".into(), serde_json::to_value(split.next()).unwrap()); | ||||||
|  |                         doc_json | ||||||
|                     }) |                     }) | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 json!([ $({ |                 // We do not use the json!() macro here since that causes a lot of macro recursion. | ||||||
|                     "group": stringify!($group), |                 // This slows down compile time and it also causes issues with rust-analyzer | ||||||
|                     "grouptoggle": stringify!($($group_enabled)?), |                 serde_json::Value::Array(<[_]>::into_vec(Box::new([ | ||||||
|                     "groupdoc": make_config!{ @show $($groupdoc)? }, |                 $( | ||||||
|                     "elements": [ |                     serde_json::Value::Object({ | ||||||
|                     $( { |                         let mut group = serde_json::Map::new(); | ||||||
|                         "editable": $editable, |                         group.insert("group".into(), (stringify!($group)).into()); | ||||||
|                         "name": stringify!($name), |                         group.insert("grouptoggle".into(), (stringify!($($group_enabled)?)).into()); | ||||||
|                         "value": cfg.$name, |                         group.insert("groupdoc".into(), (make_config!{ @show $($groupdoc)? }).into()); | ||||||
|                         "default": def.$name, |  | ||||||
|                         "type":  _get_form_type(stringify!($ty)), |                         group.insert("elements".into(), serde_json::Value::Array(<[_]>::into_vec(Box::new([ | ||||||
|                         "doc": _get_doc(concat!($($doc),+)), |                         $( | ||||||
|                         "overridden": overriden.contains(&stringify!($name).to_uppercase()), |                             serde_json::Value::Object({ | ||||||
|                     }, )+ |                                 let mut element = serde_json::Map::new(); | ||||||
|                     ]}, )+ ]) |                                 element.insert("editable".into(), ($editable).into()); | ||||||
|  |                                 element.insert("name".into(), (stringify!($name)).into()); | ||||||
|  |                                 element.insert("value".into(), serde_json::to_value(cfg.$name).unwrap()); | ||||||
|  |                                 element.insert("default".into(), serde_json::to_value(def.$name).unwrap()); | ||||||
|  |                                 element.insert("type".into(), (_get_form_type(stringify!($ty))).into()); | ||||||
|  |                                 element.insert("doc".into(), (_get_doc(concat!($($doc),+))).into()); | ||||||
|  |                                 element.insert("overridden".into(), (overriden.contains(&stringify!($name).to_uppercase())).into()); | ||||||
|  |                                 element | ||||||
|  |                             }), | ||||||
|  |                         )+ | ||||||
|  |                         ])))); | ||||||
|  |                         group | ||||||
|  |                     }), | ||||||
|  |                 )+ | ||||||
|  |                 ]))) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             pub fn get_support_json(&self) -> serde_json::Value { |             pub fn get_support_json(&self) -> serde_json::Value { | ||||||
|  |                 // Define which config keys need to be masked. | ||||||
|  |                 // Pass types will always be masked and no need to put them in the list. | ||||||
|  |                 // Besides Pass, only String types will be masked via _privacy_mask. | ||||||
|  |                 const PRIVACY_CONFIG: &[&str] = &[ | ||||||
|  |                     "allowed_iframe_ancestors", | ||||||
|  |                     "database_url", | ||||||
|  |                     "domain_origin", | ||||||
|  |                     "domain_path", | ||||||
|  |                     "domain", | ||||||
|  |                     "helo_name", | ||||||
|  |                     "org_creation_users", | ||||||
|  |                     "signups_domains_whitelist", | ||||||
|  |                     "smtp_from", | ||||||
|  |                     "smtp_host", | ||||||
|  |                     "smtp_username", | ||||||
|  |                 ]; | ||||||
|  |  | ||||||
|                 let cfg = { |                 let cfg = { | ||||||
|                     let inner = &self.inner.read().unwrap(); |                     let inner = &self.inner.read().unwrap(); | ||||||
|                     inner.config.clone() |                     inner.config.clone() | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
|                 json!({ $($( |                 /// We map over the string and remove all alphanumeric, _ and - characters. | ||||||
|                     stringify!($name): make_config!{ @supportstr $name, cfg.$name, $ty, $none_action }, |                 /// This is the fastest way (within micro-seconds) instead of using a regex (which takes mili-seconds) | ||||||
|                 )+)+ }) |                 fn _privacy_mask(value: &str) -> String { | ||||||
|  |                     value.chars().map(|c| | ||||||
|  |                         match c { | ||||||
|  |                             c if c.is_alphanumeric() => '*', | ||||||
|  |                             '_' => '*', | ||||||
|  |                             '-' => '*', | ||||||
|  |                             _ => c | ||||||
|  |                         } | ||||||
|  |                     ).collect::<String>() | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 serde_json::Value::Object({ | ||||||
|  |                     let mut json = serde_json::Map::new(); | ||||||
|  |                     $($( | ||||||
|  |                         json.insert(stringify!($name).into(), make_config!{ @supportstr $name, cfg.$name, $ty, $none_action }); | ||||||
|  |                     )+)+; | ||||||
|  |                     json | ||||||
|  |                 }) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             pub fn get_overrides(&self) -> Vec<String> { |             pub fn get_overrides(&self) -> Vec<String> { | ||||||
| @@ -229,29 +253,30 @@ macro_rules! make_config { | |||||||
|                     let inner = &self.inner.read().unwrap(); |                     let inner = &self.inner.read().unwrap(); | ||||||
|                     inner._overrides.clone() |                     inner._overrides.clone() | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
|                 overrides |                 overrides | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     // Support string print |     // Support string print | ||||||
|     ( @supportstr $name:ident, $value:expr, Pass, option ) => { $value.as_ref().map(|_| String::from("***")) }; // Optional pass, we map to an Option<String> with "***" |     ( @supportstr $name:ident, $value:expr, Pass, option ) => { serde_json::to_value($value.as_ref().map(|_| String::from("***"))).unwrap() }; // Optional pass, we map to an Option<String> with "***" | ||||||
|     ( @supportstr $name:ident, $value:expr, Pass, $none_action:ident ) => { String::from("***") }; // Required pass, we return "***" |     ( @supportstr $name:ident, $value:expr, Pass, $none_action:ident ) => { "***".into() }; // Required pass, we return "***" | ||||||
|     ( @supportstr $name:ident, $value:expr, $ty:ty, option ) => { // Optional other value, we return as is or convert to string to apply the privacy config |     ( @supportstr $name:ident, $value:expr, String, option ) => { // Optional other value, we return as is or convert to string to apply the privacy config | ||||||
|         if PRIVACY_CONFIG.contains(&stringify!($name)) { |         if PRIVACY_CONFIG.contains(&stringify!($name)) { | ||||||
|             json!($value.as_ref().map(|x| PRIVACY_REGEX.replace_all(&x.to_string(), "${1}*").to_string())) |             serde_json::to_value($value.as_ref().map(|x| _privacy_mask(x) )).unwrap() | ||||||
|         } else { |         } else { | ||||||
|             json!($value) |             serde_json::to_value($value).unwrap() | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|     ( @supportstr $name:ident, $value:expr, $ty:ty, $none_action:ident ) => { // Required other value, we return as is or convert to string to apply the privacy config |     ( @supportstr $name:ident, $value:expr, String, $none_action:ident ) => { // Required other value, we return as is or convert to string to apply the privacy config | ||||||
|         if PRIVACY_CONFIG.contains(&stringify!($name)) { |         if PRIVACY_CONFIG.contains(&stringify!($name)) { | ||||||
|              json!(PRIVACY_REGEX.replace_all(&$value.to_string(), "${1}*").to_string()) |             _privacy_mask(&$value).into() | ||||||
|          } else { |         } else { | ||||||
|              json!($value) |             ($value).into() | ||||||
|          } |         } | ||||||
|     }; |     }; | ||||||
|  |     ( @supportstr $name:ident, $value:expr, $ty:ty, option ) => { serde_json::to_value($value).unwrap() }; // Optional other value, we return as is or convert to string to apply the privacy config | ||||||
|  |     ( @supportstr $name:ident, $value:expr, $ty:ty, $none_action:ident ) => { ($value).into() }; // Required other value, we return as is or convert to string to apply the privacy config | ||||||
|  |  | ||||||
|     // Group or empty string |     // Group or empty string | ||||||
|     ( @show ) => { "" }; |     ( @show ) => { "" }; | ||||||
| @@ -627,7 +652,7 @@ fn validate_config(cfg: &ConfigItems) -> Result<(), Error> { | |||||||
|  |  | ||||||
|     // Check if the icon blacklist regex is valid |     // Check if the icon blacklist regex is valid | ||||||
|     if let Some(ref r) = cfg.icon_blacklist_regex { |     if let Some(ref r) = cfg.icon_blacklist_regex { | ||||||
|         let validate_regex = Regex::new(r); |         let validate_regex = regex::Regex::new(r); | ||||||
|         match validate_regex { |         match validate_regex { | ||||||
|             Ok(_) => (), |             Ok(_) => (), | ||||||
|             Err(e) => err!(format!("`ICON_BLACKLIST_REGEX` is invalid: {:#?}", e)), |             Err(e) => err!(format!("`ICON_BLACKLIST_REGEX` is invalid: {:#?}", e)), | ||||||
|   | |||||||
| @@ -159,7 +159,6 @@ impl TwoFactor { | |||||||
|  |  | ||||||
|         use crate::api::core::two_factor::u2f::U2FRegistration; |         use crate::api::core::two_factor::u2f::U2FRegistration; | ||||||
|         use crate::api::core::two_factor::webauthn::{get_webauthn_registrations, WebauthnRegistration}; |         use crate::api::core::two_factor::webauthn::{get_webauthn_registrations, WebauthnRegistration}; | ||||||
|         use std::convert::TryInto; |  | ||||||
|         use webauthn_rs::proto::*; |         use webauthn_rs::proto::*; | ||||||
|  |  | ||||||
|         for mut u2f in u2f_factors { |         for mut u2f in u2f_factors { | ||||||
|   | |||||||
| @@ -73,7 +73,7 @@ make_error! { | |||||||
|     Serde(SerdeErr): _has_source, _api_error, |     Serde(SerdeErr): _has_source, _api_error, | ||||||
|     JWt(JwtErr):     _has_source, _api_error, |     JWt(JwtErr):     _has_source, _api_error, | ||||||
|     Handlebars(HbErr): _has_source, _api_error, |     Handlebars(HbErr): _has_source, _api_error, | ||||||
|     //WsError(ws::Error): _has_source, _api_error, |  | ||||||
|     Io(IoErr):       _has_source, _api_error, |     Io(IoErr):       _has_source, _api_error, | ||||||
|     Time(TimeErr):   _has_source, _api_error, |     Time(TimeErr):   _has_source, _api_error, | ||||||
|     Req(ReqErr):     _has_source, _api_error, |     Req(ReqErr):     _has_source, _api_error, | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								src/mail.rs
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/mail.rs
									
									
									
									
									
								
							| @@ -505,10 +505,10 @@ fn send_email(address: &str, subject: &str, body_html: String, body_text: String | |||||||
|         Err(e) => { |         Err(e) => { | ||||||
|             if e.is_client() { |             if e.is_client() { | ||||||
|                 debug!("SMTP Client error: {:#?}", e); |                 debug!("SMTP Client error: {:#?}", e); | ||||||
|                 err!(format!("SMTP Client error: {}", e.to_string())); |                 err!(format!("SMTP Client error: {}", e)); | ||||||
|             } else if e.is_transient() { |             } else if e.is_transient() { | ||||||
|                 debug!("SMTP 4xx error: {:#?}", e); |                 debug!("SMTP 4xx error: {:#?}", e); | ||||||
|                 err!(format!("SMTP 4xx error: {}", e.to_string())); |                 err!(format!("SMTP 4xx error: {}", e)); | ||||||
|             } else if e.is_permanent() { |             } else if e.is_permanent() { | ||||||
|                 debug!("SMTP 5xx error: {:#?}", e); |                 debug!("SMTP 5xx error: {:#?}", e); | ||||||
|                 let mut msg = e.to_string(); |                 let mut msg = e.to_string(); | ||||||
| @@ -519,13 +519,13 @@ fn send_email(address: &str, subject: &str, body_html: String, body_text: String | |||||||
|                 err!(format!("SMTP 5xx error: {}", msg)); |                 err!(format!("SMTP 5xx error: {}", msg)); | ||||||
|             } else if e.is_timeout() { |             } else if e.is_timeout() { | ||||||
|                 debug!("SMTP timeout error: {:#?}", e); |                 debug!("SMTP timeout error: {:#?}", e); | ||||||
|                 err!(format!("SMTP timeout error: {}", e.to_string())); |                 err!(format!("SMTP timeout error: {}", e)); | ||||||
|             } else if e.is_tls() { |             } else if e.is_tls() { | ||||||
|                 debug!("SMTP Encryption error: {:#?}", e); |                 debug!("SMTP Encryption error: {:#?}", e); | ||||||
|                 err!(format!("SMTP Encryption error: {}", e.to_string())); |                 err!(format!("SMTP Encryption error: {}", e)); | ||||||
|             } else { |             } else { | ||||||
|                 debug!("SMTP {:#?}", e); |                 debug!("SMTP {:#?}", e); | ||||||
|                 err!(format!("SMTP {}", e.to_string())); |                 err!(format!("SMTP {}", e)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,6 +1,10 @@ | |||||||
| #![forbid(unsafe_code)] | #![forbid(unsafe_code)] | ||||||
| #![cfg_attr(feature = "unstable", feature(ip))] | #![cfg_attr(feature = "unstable", feature(ip))] | ||||||
| #![recursion_limit = "512"] | // The recursion_limit is mainly triggered by the json!() macro. | ||||||
|  | // 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. | ||||||
|  | // If you go above 128 it will cause rust-analyzer to fail, | ||||||
|  | #![recursion_limit = "87"] | ||||||
|  |  | ||||||
| extern crate openssl; | extern crate openssl; | ||||||
| #[macro_use] | #[macro_use] | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								src/util.rs
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								src/util.rs
									
									
									
									
									
								
							| @@ -282,9 +282,9 @@ pub fn delete_file(path: &str) -> IOResult<()> { | |||||||
|     res |     res | ||||||
| } | } | ||||||
|  |  | ||||||
| const UNITS: [&str; 6] = ["bytes", "KB", "MB", "GB", "TB", "PB"]; |  | ||||||
|  |  | ||||||
| pub fn get_display_size(size: i32) -> String { | pub fn get_display_size(size: i32) -> String { | ||||||
|  |     const UNITS: [&str; 6] = ["bytes", "KB", "MB", "GB", "TB", "PB"]; | ||||||
|  |  | ||||||
|     let mut size: f64 = size.into(); |     let mut size: f64 = size.into(); | ||||||
|     let mut unit_counter = 0; |     let mut unit_counter = 0; | ||||||
|  |  | ||||||
| @@ -359,10 +359,10 @@ where | |||||||
|     try_parse_string(get_env_str_value(key)) |     try_parse_string(get_env_str_value(key)) | ||||||
| } | } | ||||||
|  |  | ||||||
| const TRUE_VALUES: &[&str] = &["true", "t", "yes", "y", "1"]; |  | ||||||
| const FALSE_VALUES: &[&str] = &["false", "f", "no", "n", "0"]; |  | ||||||
|  |  | ||||||
| pub fn get_env_bool(key: &str) -> Option<bool> { | pub fn get_env_bool(key: &str) -> Option<bool> { | ||||||
|  |     const TRUE_VALUES: &[&str] = &["true", "t", "yes", "y", "1"]; | ||||||
|  |     const FALSE_VALUES: &[&str] = &["false", "f", "no", "n", "0"]; | ||||||
|  |  | ||||||
|     match get_env_str_value(key) { |     match get_env_str_value(key) { | ||||||
|         Some(val) if TRUE_VALUES.contains(&val.to_lowercase().as_ref()) => Some(true), |         Some(val) if TRUE_VALUES.contains(&val.to_lowercase().as_ref()) => Some(true), | ||||||
|         Some(val) if FALSE_VALUES.contains(&val.to_lowercase().as_ref()) => Some(false), |         Some(val) if FALSE_VALUES.contains(&val.to_lowercase().as_ref()) => Some(false), | ||||||
| @@ -375,7 +375,6 @@ pub fn get_env_bool(key: &str) -> Option<bool> { | |||||||
| // | // | ||||||
|  |  | ||||||
| use chrono::{DateTime, Local, NaiveDateTime, TimeZone}; | use chrono::{DateTime, Local, NaiveDateTime, TimeZone}; | ||||||
| use chrono_tz::Tz; |  | ||||||
|  |  | ||||||
| /// Formats a UTC-offset `NaiveDateTime` in the format used by Bitwarden API | /// Formats a UTC-offset `NaiveDateTime` in the format used by Bitwarden API | ||||||
| /// responses with "date" fields (`CreationDate`, `RevisionDate`, etc.). | /// responses with "date" fields (`CreationDate`, `RevisionDate`, etc.). | ||||||
| @@ -393,7 +392,7 @@ pub fn format_datetime_local(dt: &DateTime<Local>, fmt: &str) -> String { | |||||||
|     // Try parsing the `TZ` environment variable to enable formatting `%Z` as |     // Try parsing the `TZ` environment variable to enable formatting `%Z` as | ||||||
|     // a time zone abbreviation. |     // a time zone abbreviation. | ||||||
|     if let Ok(tz) = env::var("TZ") { |     if let Ok(tz) = env::var("TZ") { | ||||||
|         if let Ok(tz) = tz.parse::<Tz>() { |         if let Ok(tz) = tz.parse::<chrono_tz::Tz>() { | ||||||
|             return dt.with_timezone(&tz).format(fmt).to_string(); |             return dt.with_timezone(&tz).format(fmt).to_string(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -442,7 +441,7 @@ use serde_json::{self, Value}; | |||||||
|  |  | ||||||
| pub type JsonMap = serde_json::Map<String, Value>; | pub type JsonMap = serde_json::Map<String, Value>; | ||||||
|  |  | ||||||
| #[derive(PartialEq, Serialize, Deserialize)] | #[derive(Serialize, Deserialize)] | ||||||
| pub struct UpCase<T: DeserializeOwned> { | pub struct UpCase<T: DeserializeOwned> { | ||||||
|     #[serde(deserialize_with = "upcase_deserialize")] |     #[serde(deserialize_with = "upcase_deserialize")] | ||||||
|     #[serde(flatten)] |     #[serde(flatten)] | ||||||
| @@ -517,6 +516,8 @@ fn upcase_value(value: Value) -> Value { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Inner function to handle some speciale case for the 'ssn' key. | ||||||
|  | // This key is part of the Identity Cipher (Social Security Number) | ||||||
| fn _process_key(key: &str) -> String { | fn _process_key(key: &str) -> String { | ||||||
|     match key.to_lowercase().as_ref() { |     match key.to_lowercase().as_ref() { | ||||||
|         "ssn" => "SSN".into(), |         "ssn" => "SSN".into(), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user