diff --git a/Cargo.lock b/Cargo.lock index 151216144..9d9bc2d03 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -36,6 +36,7 @@ dependencies = [ "cfg-if", "cipher", "cpufeatures", + "zeroize", ] [[package]] @@ -45,7 +46,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" dependencies = [ "cfg-if", - "getrandom", + "getrandom 0.2.15", "once_cell", "version_check", "zerocopy", @@ -66,6 +67,65 @@ version = "0.2.18" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5c6cb57a04249c6480766f7f7cef5467412af1490f8d1e243141daddada3264f" +[[package]] +name = "amplify" +version = "4.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e711289a6cb28171b4f0e6c8019c69ff9476050508dc082167575d458ff74d0" +dependencies = [ + "amplify_derive", + "amplify_num", + "ascii", + "wasm-bindgen", +] + +[[package]] +name = "amplify_derive" +version = "4.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "759dcbfaf94d838367a86d493ec34ccc8aa6fe365cb7880d6bf89006de24d9c1" +dependencies = [ + "amplify_syn", + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "amplify_num" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "04c009c5c4de814911b177e2ea59e4930bb918978ed3cce4900d846a6ceb0838" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "amplify_syn" +version = "2.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7736fb8d473c0d83098b5bac44df6a561e20470375cd8bcae30516dc889fd62a" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "android-tzdata" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e999941b234f3131b00bc13c22d06e8c5ff726d1b6318ac7eb276997bbb4fef0" + +[[package]] +name = "android_system_properties" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "819e7219dbd41043ac279b19830f2efc897156490d7fd6ea916720117ee66311" +dependencies = [ + "libc", +] + [[package]] name = "anes" version = "0.1.6" @@ -138,12 +198,87 @@ version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" +[[package]] +name = "arti-client" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "20917bbfb3284158fb0d9f610b56528a8b5010f82ead92316bd4b2a42e33553d" +dependencies = [ + "cfg-if", + "derive_builder_fork_arti", + "derive_more", + "directories", + "educe", + "fs-mistrust", + "futures", + "hostname-validator", + "humantime-serde", + "libc", + "pin-project", + "postage", + "safelog", + "serde", + "thiserror", + "tor-async-utils", + "tor-basic-utils", + "tor-cell", + "tor-chanmgr", + "tor-checkable", + "tor-circmgr", + "tor-config", + "tor-dirmgr", + "tor-error", + "tor-guardmgr", + "tor-keymgr", + "tor-linkspec", + "tor-llcrypto", + "tor-netdir", + "tor-netdoc", + "tor-persist", + "tor-proto", + "tor-rtcompat", + "tracing", + "void", +] + +[[package]] +name = "ascii" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d92bec98840b8f03a5ff5413de5293bfcd8bf96467cf5452609f939ec6f5de16" + [[package]] name = "assert_matches" version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9b34d609dfbaf33d6889b2b7106d3ca345eacad44200913df5ba02bfd31d2ba9" +[[package]] +name = "async-compression" +version = "0.4.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cd066d0b4ef8ecb03a55319dc13aa6910616d0f44008a045bb1835af830abff5" +dependencies = [ + "flate2", + "futures-core", + "futures-io", + "memchr", + "pin-project-lite", + "xz2", + "zstd", + "zstd-safe", +] + +[[package]] +name = "async-rustls" +version = "0.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ecfa55659849ace733f86ccd219da40abd8bc14124e40b312433e85a5a266e77" +dependencies = [ + "futures-io", + "rustls", +] + [[package]] name = "async-stream" version = "0.3.5" @@ -177,6 +312,40 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "async_executors" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a982d2f86de6137cc05c9db9a915a19886c97911f9790d04f174cede74be01a5" +dependencies = [ + "blanket", + "futures-core", + "futures-task", + "futures-util", + "pin-project", + "rustc_version", + "tokio", +] + +[[package]] +name = "asynchronous-codec" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a860072022177f903e59730004fb5dc13db9275b79bb2aef7ba8ce831956c233" +dependencies = [ + "bytes", + "futures-sink", + "futures-util", + "memchr", + "pin-project-lite", +] + +[[package]] +name = "atomic" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c59bdb34bc650a32731b31bd8f0829cc15d24a708ee31559e0bb34f2bc320cba" + [[package]] name = "atomic-waker" version = "1.1.2" @@ -199,7 +368,7 @@ dependencies = [ "axum-core", "bytes", "futures-util", - "http", + "http 1.1.0", "http-body", "http-body-util", "itoa", @@ -225,7 +394,7 @@ dependencies = [ "async-trait", "bytes", "futures-util", - "http", + "http 1.1.0", "http-body", "http-body-util", "mime", @@ -251,6 +420,12 @@ dependencies = [ "rustc-demangle", ] +[[package]] +name = "base16ct" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" + [[package]] name = "base64" version = "0.21.7" @@ -263,6 +438,12 @@ version = "0.22.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6" +[[package]] +name = "base64ct" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b" + [[package]] name = "bech32" version = "0.9.1" @@ -285,7 +466,7 @@ dependencies = [ "log", "num_cpus", "pairing", - "rand_core", + "rand_core 0.6.4", "rayon", "subtle", ] @@ -298,10 +479,10 @@ checksum = "7e141fb0f8be1c7b45887af94c88b182472b57c96b56773250ae00cd6a14a164" dependencies = [ "bs58", "hmac", - "rand_core", + "rand_core 0.6.4", "ripemd", "secp256k1", - "sha2", + "sha2 0.10.8", "subtle", "zeroize", ] @@ -367,6 +548,26 @@ dependencies = [ "constant_time_eq", ] +[[package]] +name = "blanket" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e0b121a9fe0df916e362fb3271088d071159cdf11db0e4182d02152850756eff" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.63", +] + +[[package]] +name = "block-buffer" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4152116fd6e9dadb291ae18fc1ec3575ed6d84c29642d97890f4b4a3417297e4" +dependencies = [ + "generic-array", +] + [[package]] name = "block-buffer" version = "0.10.4" @@ -385,17 +586,23 @@ dependencies = [ "ff", "group", "pairing", - "rand_core", + "rand_core 0.6.4", "subtle", ] +[[package]] +name = "bounded-vec-deque" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2225b558afc76c596898f5f1b3fc35cfce0eb1b13635cbd7d1b2a7177dc10ccd" + [[package]] name = "bs58" version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bf88ba1141d185c399bee5288d850d63b8369520c1eafc32a0430b5b6c287bf4" dependencies = [ - "sha2", + "sha2 0.10.8", "tinyvec", ] @@ -405,6 +612,12 @@ version = "3.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" +[[package]] +name = "by_address" +version = "1.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "64fa3c856b712db6612c019f14756e64e4bcea13337a6b33b696333a9eaa2d06" + [[package]] name = "bytemuck" version = "1.16.0" @@ -423,6 +636,12 @@ version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "514de17de45fdb8dc022b1a7975556c53c86f9f0aa5f534b98977b171857c2c9" +[[package]] +name = "caret" +version = "0.4.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4ac3ae35de516b8ee4bfb6affc72bd6c121d2967206f307c026890f99c7875a0" + [[package]] name = "cast" version = "0.3.0" @@ -443,6 +662,11 @@ name = "cc" version = "1.0.97" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "099a5357d84c4c61eb35fc8eafa9a79a902c2f76911e5747ced4e032edd8d9b4" +dependencies = [ + "jobserver", + "libc", + "once_cell", +] [[package]] name = "cfg-if" @@ -474,6 +698,19 @@ dependencies = [ "zeroize", ] +[[package]] +name = "chrono" +version = "0.4.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a21f936df1771bf62b77f047b726c4625ff2e8aa607c01ec06e5a05bd8463401" +dependencies = [ + "android-tzdata", + "iana-time-zone", + "num-traits", + "serde", + "windows-targets 0.52.5", +] + [[package]] name = "ciborium" version = "0.2.2" @@ -530,7 +767,7 @@ dependencies = [ "anstream", "anstyle", "clap_lex", - "strsim", + "strsim 0.10.0", ] [[package]] @@ -539,18 +776,70 @@ version = "0.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "702fc72eb24e5a1e48ce58027a675bc24edd52096d5397d4aea7c6dd9eca0bd1" +[[package]] +name = "coarsetime" +version = "0.1.34" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "13b3839cf01bb7960114be3ccf2340f541b6d0c81f8690b007b2b39f750f7e5d" +dependencies = [ + "libc", + "wasix", + "wasm-bindgen", +] + [[package]] name = "colorchoice" version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "acbf1af155f9b9ef647e42cdc158db4b64a1b61f743629225fde6f3e0be2a7c7" +[[package]] +name = "concurrent-queue" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4ca0197aee26d1ae37445ee532fefce43251d24cc7c166799f4d46817f1d3973" +dependencies = [ + "crossbeam-utils", +] + +[[package]] +name = "config" +version = "0.13.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "23738e11972c7643e4ec947840fc463b6a571afcd3e735bdfce7d03c7a784aca" +dependencies = [ + "async-trait", + "lazy_static", + "nom", + "pathdiff", + "serde", + "toml 0.5.11", +] + +[[package]] +name = "const-oid" +version = "0.9.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c2459377285ad874054d797f3ccebf984978aa39129f6eafde5cdc8315b612f8" + [[package]] name = "constant_time_eq" version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f7144d30dcf0fafbce74250a3963025d8d52177934239851c917d29f1df280c2" +[[package]] +name = "convert_case" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6245d59a3e82a7fc217c5828a6692dbc6dfb63a0c8c90495621f7b9d79704a0e" + +[[package]] +name = "core-foundation-sys" +version = "0.8.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" + [[package]] name = "cpp_demangle" version = "0.4.3" @@ -569,6 +858,15 @@ dependencies = [ "libc", ] +[[package]] +name = "crc32fast" +version = "1.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a97769d94ddab943e4510d138150169a2758b5ef3eb191a9ee688de3e23ef7b3" +dependencies = [ + "cfg-if", +] + [[package]] name = "criterion" version = "0.5.1" @@ -581,7 +879,7 @@ dependencies = [ "clap", "criterion-plot", "is-terminal", - "itertools", + "itertools 0.10.5", "num-traits", "once_cell", "oorandom", @@ -602,7 +900,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6b50826342786a51a89e2da3a28f1c32b06e387201bc2d19791f622c673706b1" dependencies = [ "cast", - "itertools", + "itertools 0.10.5", ] [[package]] @@ -633,6 +931,16 @@ dependencies = [ "crossbeam-utils", ] +[[package]] +name = "crossbeam-queue" +version = "0.3.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d1cfb3ea8a53f37c40dea2c7bedcbd88bdfae54f5e2175d6ecaff1c988353add" +dependencies = [ + "cfg-if", + "crossbeam-utils", +] + [[package]] name = "crossbeam-utils" version = "0.8.19" @@ -645,6 +953,18 @@ version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7a81dae078cea95a014a339291cec439d2f232ebe854a9d672b796c6afafa9b7" +[[package]] +name = "crypto-bigint" +version = "0.5.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0dc92fb57ca44df6db8059111ab3af99a63d5d0f8375d9972e319a379c6bab76" +dependencies = [ + "generic-array", + "rand_core 0.6.4", + "subtle", + "zeroize", +] + [[package]] name = "crypto-common" version = "0.1.6" @@ -652,10 +972,32 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1bfb12502f3fc46cca1bb51ac28df9d618d813cdc3d2f25b9fe775a34af26bb3" dependencies = [ "generic-array", - "rand_core", + "rand_core 0.6.4", "typenum", ] +[[package]] +name = "ctr" +version = "0.9.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0369ee1ad671834580515889b80f2ea915f23b8be8d0daa4bbaf2ac5c7590835" +dependencies = [ + "cipher", +] + +[[package]] +name = "curve25519-dalek" +version = "3.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b9fdf9972b2bd6af2d913799d9ebc165ea4d2e65878e329d9c6b372c4491b61" +dependencies = [ + "byteorder", + "digest 0.9.0", + "rand_core 0.5.1", + "subtle", + "zeroize", +] + [[package]] name = "daggy" version = "0.8.0" @@ -665,6 +1007,82 @@ dependencies = [ "petgraph", ] +[[package]] +name = "darling" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b750cb3417fd1b327431a470f388520309479ab0bf5e323505daf0290cd3850" +dependencies = [ + "darling_core 0.14.4", + "darling_macro 0.14.4", +] + +[[package]] +name = "darling" +version = "0.20.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "83b2eb4d90d12bdda5ed17de686c2acb4c57914f8f921b8da7e112b5a36f3fe1" +dependencies = [ + "darling_core 0.20.9", + "darling_macro 0.20.9", +] + +[[package]] +name = "darling_core" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "109c1ca6e6b7f82cc233a97004ea8ed7ca123a9af07a8230878fcfda9b158bf0" +dependencies = [ + "fnv", + "ident_case", + "proc-macro2", + "quote", + "strsim 0.10.0", + "syn 1.0.109", +] + +[[package]] +name = "darling_core" +version = "0.20.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "622687fe0bac72a04e5599029151f5796111b90f1baaa9b544d807a5e31cd120" +dependencies = [ + "fnv", + "ident_case", + "proc-macro2", + "quote", + "strsim 0.11.1", + "syn 2.0.63", +] + +[[package]] +name = "darling_macro" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4aab4dbc9f7611d8b55048a3a16d2d010c2c8334e46304b40ac1cc14bf3b48e" +dependencies = [ + "darling_core 0.14.4", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "darling_macro" +version = "0.20.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "733cabb43482b1a1b53eee8583c2b9e8684d592215ea83efd305dd31bc2f0178" +dependencies = [ + "darling_core 0.20.9", + "quote", + "syn 2.0.63", +] + +[[package]] +name = "data-encoding" +version = "2.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e8566979429cf69b49a5c740c60791108e86440e8be149bbea4fe54d2c32d6e2" + [[package]] name = "debugid" version = "0.8.0" @@ -674,6 +1092,17 @@ dependencies = [ "uuid", ] +[[package]] +name = "der" +version = "0.7.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f55bf8e7b65898637379c1b74eb1551107c8294ed26d855ceb9fd1a09cfc9bc0" +dependencies = [ + "const-oid", + "pem-rfc7468", + "zeroize", +] + [[package]] name = "deranged" version = "0.3.11" @@ -681,6 +1110,87 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" dependencies = [ "powerfmt", + "serde", +] + +[[package]] +name = "derive-adhoc" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5283ac2881753c76c0892406705553f0d9ab30649f81e18964d3408f4501edb8" +dependencies = [ + "derive-adhoc-macros", + "heck", +] + +[[package]] +name = "derive-adhoc-macros" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c21b673a9b8c78c34908e6fcb42b922e11c4df2de5237f1c3f58d3285904a84b" +dependencies = [ + "heck", + "itertools 0.11.0", + "proc-macro-crate", + "proc-macro2", + "quote", + "sha3", + "strum", + "syn 1.0.109", + "void", +] + +[[package]] +name = "derive_builder_core_fork_arti" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "24c1b715c79be6328caa9a5e1a387a196ea503740f0722ec3dd8f67a9e72314d" +dependencies = [ + "darling 0.14.4", + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "derive_builder_fork_arti" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3eae24d595f4d0ecc90a9a5a6d11c2bd8dafe2375ec4a1ec63250e5ade7d228" +dependencies = [ + "derive_builder_macro_fork_arti", +] + +[[package]] +name = "derive_builder_macro_fork_arti" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69887769a2489cd946bf782eb2b1bb2cb7bc88551440c94a765d4f040c08ebf3" +dependencies = [ + "derive_builder_core_fork_arti", + "syn 1.0.109", +] + +[[package]] +name = "derive_more" +version = "0.99.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fb810d30a7c1953f91334de7244731fc3f3c10d7fe163338a35b9f640960321" +dependencies = [ + "convert_case", + "proc-macro2", + "quote", + "rustc_version", + "syn 1.0.109", +] + +[[package]] +name = "digest" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3dd60d1080a57a05ab032377049e0591415d2b31afd7028356dbf3cc6dcb066" +dependencies = [ + "generic-array", ] [[package]] @@ -689,11 +1199,53 @@ version = "0.10.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" dependencies = [ - "block-buffer", + "block-buffer 0.10.4", + "const-oid", "crypto-common", "subtle", ] +[[package]] +name = "directories" +version = "5.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a49173b84e034382284f27f1af4dcbbd231ffa358c0fe316541a7337f376a35" +dependencies = [ + "dirs-sys", +] + +[[package]] +name = "dirs" +version = "5.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "44c45a9d03d6676652bcb5e724c7e988de1acad23a711b5217ab9cbecbec2225" +dependencies = [ + "dirs-sys", +] + +[[package]] +name = "dirs-sys" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "520f05a5cbd335fae5a99ff7a6ab8627577660ee5cfd6a94a6a929b52ff0321c" +dependencies = [ + "libc", + "option-ext", + "redox_users", + "windows-sys 0.48.0", +] + +[[package]] +name = "displaydoc" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "487585f4d0c6655fe74905e2504d8ad6908e4db67f744eb140876906c2f3175d" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.63", +] + [[package]] name = "document-features" version = "0.2.8" @@ -703,12 +1255,106 @@ dependencies = [ "litrs", ] +[[package]] +name = "downcast-rs" +version = "1.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75b325c5dbd37f80359721ad39aca5a29fb04c89279657cffdda8736d0c0b9d2" + +[[package]] +name = "dyn-clone" +version = "1.0.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d6ef0072f8a535281e4876be788938b528e9a1d43900b82c2569af7da799125" + +[[package]] +name = "ecdsa" +version = "0.16.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee27f32b5c5292967d2d4a9d7f1e0b0aed2c15daded5a60300e4abb9d8020bca" +dependencies = [ + "der", + "digest 0.10.7", + "elliptic-curve", + "rfc6979", + "signature 2.2.0", + "spki", +] + +[[package]] +name = "ed25519" +version = "1.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "91cff35c70bba8a626e3185d8cd48cc11b5437e1a5bcd15b9b5fa3c64b6dfee7" +dependencies = [ + "signature 1.6.4", +] + +[[package]] +name = "ed25519-dalek" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c762bae6dcaf24c4c84667b8579785430908723d5c889f469d76a41d59cc7a9d" +dependencies = [ + "curve25519-dalek", + "ed25519", + "merlin", + "rand 0.7.3", + "serde", + "sha2 0.9.9", + "zeroize", +] + +[[package]] +name = "educe" +version = "0.4.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0f0042ff8246a363dbe77d2ceedb073339e85a804b9a47636c6e016a9a32c05f" +dependencies = [ + "enum-ordinalize", + "proc-macro2", + "quote", + "syn 1.0.109", +] + [[package]] name = "either" version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a47c1c47d2f5964e29c61246e81db715514cd532db6b5116a25ea3c03d6780a2" +[[package]] +name = "elliptic-curve" +version = "0.13.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5e6043086bf7973472e0c7dff2142ea0b680d30e18d9cc40f267efbf222bd47" +dependencies = [ + "base16ct", + "crypto-bigint", + "digest 0.10.7", + "ff", + "generic-array", + "group", + "pkcs8", + "rand_core 0.6.4", + "sec1", + "subtle", + "zeroize", +] + +[[package]] +name = "enum-ordinalize" +version = "3.1.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bf1fa3f06bbff1ea5b1a9c7b14aa992a39657db60a2759457328d7e058f49ee" +dependencies = [ + "num-bigint", + "num-traits", + "proc-macro2", + "quote", + "syn 2.0.63", +] + [[package]] name = "equihash" version = "0.2.0" @@ -733,6 +1379,17 @@ dependencies = [ "windows-sys 0.52.0", ] +[[package]] +name = "event-listener" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d93877bcde0eb80ca09131a08d23f0a5c18a620b01db137dba666d18cd9b30c2" +dependencies = [ + "concurrent-queue", + "parking", + "pin-project-lite", +] + [[package]] name = "f4jumble" version = "0.1.0" @@ -767,7 +1424,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ded41244b729663b1e574f1b4fb731469f69f79c17667b5d776b16cda0479449" dependencies = [ "bitvec", - "rand_core", + "rand_core 0.6.4", "subtle", ] @@ -798,6 +1455,22 @@ version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0ce7134b9999ecaf8bcd65542e436736ef32ddca1b3e06094cb6ec5755203b80" +[[package]] +name = "flate2" +version = "1.0.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5f54427cfd1c7829e2a139fcefea601bf088ebca651d2bf53ebc600eac295dae" +dependencies = [ + "crc32fast", + "miniz_oxide", +] + +[[package]] +name = "fluid-let" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "749cff877dc1af878a0b31a41dd221a753634401ea0ef2f87b62d3171522485a" + [[package]] name = "fnv" version = "1.0.7" @@ -818,12 +1491,53 @@ dependencies = [ "num-traits", ] +[[package]] +name = "fs-mistrust" +version = "0.7.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "daa843fc37db9fe16a248421fa36454f903dbc2ff722cc613a7e12932ee572c7" +dependencies = [ + "derive_builder_fork_arti", + "dirs", + "libc", + "once_cell", + "pwd-grp", + "serde", + "thiserror", + "walkdir", +] + +[[package]] +name = "fslock" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "04412b8935272e3a9bae6f48c7bfff74c2911f60525404edfdd28e49884c3bfb" +dependencies = [ + "libc", + "winapi", +] + [[package]] name = "funty" version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e6d5a32815ae3f33302d95fdcb2ce17862f8c65363dcfd29360480ba1001fc9c" +[[package]] +name = "futures" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "23342abe12aba583913b2e62f22225ff9c950774065e4bfb61a19cd9770fec40" +dependencies = [ + "futures-channel", + "futures-core", + "futures-executor", + "futures-io", + "futures-sink", + "futures-task", + "futures-util", +] + [[package]] name = "futures-channel" version = "0.3.30" @@ -831,6 +1545,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" dependencies = [ "futures-core", + "futures-sink", ] [[package]] @@ -840,10 +1555,27 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" [[package]] -name = "futures-macro" -version = "0.3.30" +name = "futures-executor" +version = "0.3.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" +checksum = "ccecee823288125bd88b4d7f565c9e58e41858e47ab72e8ea2d64e93624386e0" +dependencies = [ + "futures-core", + "futures-task", + "futures-util", +] + +[[package]] +name = "futures-io" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fff74096e71ed47f8e023204cfd0aa1289cd54ae5430a9523be060cdb849964" + +[[package]] +name = "futures-macro" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" dependencies = [ "proc-macro2", "quote", @@ -864,13 +1596,17 @@ checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" [[package]] name = "futures-util" -version = "0.3.30" +version = "0.3.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" +checksum = "26b01e40b772d54cf6c6d721c1d1abd0647a0106a12ecaa1c186273392a69533" dependencies = [ + "futures-channel", "futures-core", + "futures-io", "futures-macro", + "futures-sink", "futures-task", + "memchr", "pin-project-lite", "pin-utils", "slab", @@ -884,6 +1620,18 @@ checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a" dependencies = [ "typenum", "version_check", + "zeroize", +] + +[[package]] +name = "getrandom" +version = "0.1.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce" +dependencies = [ + "cfg-if", + "libc", + "wasi 0.9.0+wasi-snapshot-preview1", ] [[package]] @@ -893,8 +1641,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" dependencies = [ "cfg-if", + "js-sys", "libc", - "wasi", + "wasi 0.11.0+wasi-snapshot-preview1", + "wasm-bindgen", ] [[package]] @@ -903,6 +1653,12 @@ version = "0.28.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" +[[package]] +name = "glob-match" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9985c9503b412198aa4197559e9a318524ebc4519c229bfa05a535828c950b9d" + [[package]] name = "group" version = "0.13.0" @@ -911,7 +1667,7 @@ checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63" dependencies = [ "ff", "memuse", - "rand_core", + "rand_core 0.6.4", "subtle", ] @@ -946,7 +1702,7 @@ dependencies = [ "fnv", "futures-core", "futures-sink", - "http", + "http 1.1.0", "indexmap 2.2.6", "slab", "tokio", @@ -976,7 +1732,7 @@ dependencies = [ "halo2_proofs", "lazy_static", "pasta_curves", - "rand", + "rand 0.8.5", "subtle", "uint", ] @@ -999,7 +1755,7 @@ dependencies = [ "halo2_legacy_pdqsort", "maybe-rayon", "pasta_curves", - "rand_core", + "rand_core 0.6.4", "tracing", ] @@ -1046,13 +1802,22 @@ version = "0.4.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" +[[package]] +name = "hkdf" +version = "0.12.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b5f8eb2ad728638ea2c7d47a21db23b7b58a72ed6a38256b8a1849f15fbbdf7" +dependencies = [ + "hmac", +] + [[package]] name = "hmac" version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" dependencies = [ - "digest", + "digest 0.10.7", ] [[package]] @@ -1064,6 +1829,23 @@ dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "hostname-validator" +version = "1.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f558a64ac9af88b5ba400d99b579451af0d39c6d360980045b91aac966d705e2" + +[[package]] +name = "http" +version = "0.2.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" +dependencies = [ + "bytes", + "fnv", + "itoa", +] + [[package]] name = "http" version = "1.1.0" @@ -1082,7 +1864,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1cac85db508abc24a2e48553ba12a996e87244a0395ce011e62b37158745d643" dependencies = [ "bytes", - "http", + "http 1.1.0", ] [[package]] @@ -1093,7 +1875,7 @@ checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" dependencies = [ "bytes", "futures-util", - "http", + "http 1.1.0", "http-body", "pin-project-lite", ] @@ -1111,16 +1893,32 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" [[package]] -name = "hyper" -version = "1.4.1" +name = "humantime" +version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50dfd22e0e76d0f662d429a5f80fcaf3855009297eab6a0a9f8543834744ba05" +checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4" + +[[package]] +name = "humantime-serde" +version = "1.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "57a3db5ea5923d99402c94e9feb261dc5ee9b4efa158b0315f788cf549cc200c" +dependencies = [ + "humantime", + "serde", +] + +[[package]] +name = "hyper" +version = "1.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fe575dd17d0862a9a33781c8c4696a55c320909004a67a00fb286ba8b1bc496d" dependencies = [ "bytes", "futures-channel", "futures-util", "h2", - "http", + "http 1.1.0", "http-body", "httparse", "httpdate", @@ -1146,14 +1944,14 @@ dependencies = [ [[package]] name = "hyper-util" -version = "0.1.6" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3ab92f4f49ee4fb4f997c784b7a2e0fa70050211e0b6a287f898c3c9785ca956" +checksum = "7b875924a60b96e5d7b9ae7b066540b1dd1cbd90d1828f54c92e02a283351c56" dependencies = [ "bytes", "futures-channel", "futures-util", - "http", + "http 1.1.0", "http-body", "hyper", "pin-project-lite", @@ -1164,6 +1962,35 @@ dependencies = [ "tracing", ] +[[package]] +name = "iana-time-zone" +version = "0.1.60" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" +dependencies = [ + "android_system_properties", + "core-foundation-sys", + "iana-time-zone-haiku", + "js-sys", + "wasm-bindgen", + "windows-core", +] + +[[package]] +name = "iana-time-zone-haiku" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f31827a206f56af32e590ba56d5d2d085f558508192593743f16b2306495269f" +dependencies = [ + "cc", +] + +[[package]] +name = "ident_case" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" + [[package]] name = "incrementalmerkletree" version = "0.5.1" @@ -1171,8 +1998,8 @@ source = "git+https://github.com/zcash/incrementalmerkletree?rev=337f59179eda512 dependencies = [ "either", "proptest", - "rand", - "rand_core", + "rand 0.8.5", + "rand_core 0.6.4", ] [[package]] @@ -1183,6 +2010,7 @@ checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99" dependencies = [ "autocfg", "hashbrown 0.12.3", + "serde", ] [[package]] @@ -1193,6 +2021,7 @@ checksum = "168fb715dda47215e360912c096649d23d58bf392ac62f73919e831745e40f26" dependencies = [ "equivalent", "hashbrown 0.14.5", + "serde", ] [[package]] @@ -1242,12 +2071,39 @@ dependencies = [ "either", ] +[[package]] +name = "itertools" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b1c173a5686ce8bfa551b3563d0c2170bf24ca44da99c7ca4bfdab5418c3fe57" +dependencies = [ + "either", +] + +[[package]] +name = "itertools" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ba291022dbbd398a455acf126c1e341954079855bc60dfdda641363bd6922569" +dependencies = [ + "either", +] + [[package]] name = "itoa" version = "1.0.11" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" +[[package]] +name = "jobserver" +version = "0.1.31" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d2b099aaa34a9751c5bf0878add70444e1ed2dd73f347be99003d4577277de6e" +dependencies = [ + "libc", +] + [[package]] name = "js-sys" version = "0.3.69" @@ -1267,10 +2123,19 @@ dependencies = [ "bls12_381", "ff", "group", - "rand_core", + "rand_core 0.6.4", "subtle", ] +[[package]] +name = "keccak" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f6d5ed8676d904364de097082f4e7d240b571b67989ced0240f08b7f966f940" +dependencies = [ + "cpufeatures", +] + [[package]] name = "known-folders" version = "1.1.0" @@ -1301,6 +2166,16 @@ version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058" +[[package]] +name = "libredox" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c0ff37bd590ca25063e35af745c343cb7a0271906fb7b37e4813e8f79f00268d" +dependencies = [ + "bitflags 2.5.0", + "libc", +] + [[package]] name = "libsqlite3-sys" version = "0.26.0" @@ -1340,6 +2215,26 @@ version = "0.4.21" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" +[[package]] +name = "lzma-sys" +version = "0.1.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5fda04ab3764e6cde78b9974eec4f779acaba7c4e84b36eca3cf77c581b85d27" +dependencies = [ + "cc", + "libc", + "pkg-config", +] + +[[package]] +name = "matchers" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8263075bb86c5a1b1427b5ae862e8889656f126e9f77c484496e8b47cf5c5558" +dependencies = [ + "regex-automata 0.1.10", +] + [[package]] name = "matchit" version = "0.7.3" @@ -1380,6 +2275,18 @@ dependencies = [ "nonempty", ] +[[package]] +name = "merlin" +version = "2.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4e261cf0f8b3c42ded9f7d2bb59dea03aa52bc8a1cbc7482f9fc3fd1229d3b42" +dependencies = [ + "byteorder", + "keccak", + "rand_core 0.5.1", + "zeroize", +] + [[package]] name = "mime" version = "0.3.17" @@ -1421,7 +2328,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a4a650543ca06a924e8b371db273b2756685faae30f8487da1b56505a8f78b0c" dependencies = [ "libc", - "wasi", + "wasi 0.11.0+wasi-snapshot-preview1", "windows-sys 0.48.0", ] @@ -1458,6 +2365,16 @@ version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e9e591e719385e6ebaeb5ce5d3887f7d5676fceca6411d1925ccc95745f3d6f7" +[[package]] +name = "nu-ansi-term" +version = "0.46.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77a8165726e8236064dbb45459242600304b42a5ea24ee2948e18e023bf7ba84" +dependencies = [ + "overload", + "winapi", +] + [[package]] name = "num-bigint" version = "0.4.5" @@ -1468,6 +2385,23 @@ dependencies = [ "num-traits", ] +[[package]] +name = "num-bigint-dig" +version = "0.8.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc84195820f291c7697304f3cbdadd1cb7199c0efc917ff5eafd71225c136151" +dependencies = [ + "byteorder", + "lazy_static", + "libm", + "num-integer", + "num-iter", + "num-traits", + "rand 0.8.5", + "smallvec", + "zeroize", +] + [[package]] name = "num-conv" version = "0.1.0" @@ -1493,6 +2427,17 @@ dependencies = [ "num-traits", ] +[[package]] +name = "num-iter" +version = "0.1.45" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1429034a0490724d0075ebb2bc9e875d6503c3cf69e235a8941aa757d83ef5bf" +dependencies = [ + "autocfg", + "num-integer", + "num-traits", +] + [[package]] name = "num-traits" version = "0.2.19" @@ -1513,6 +2458,27 @@ dependencies = [ "libc", ] +[[package]] +name = "num_enum" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70bf6736f74634d299d00086f02986875b3c2d924781a6a2cb6c201e73da0ceb" +dependencies = [ + "num_enum_derive", +] + +[[package]] +name = "num_enum_derive" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "56ea360eafe1022f7cc56cd7b869ed57330fb2453d0c7831d99b74c65d2f5597" +dependencies = [ + "proc-macro-crate", + "proc-macro2", + "quote", + "syn 2.0.63", +] + [[package]] name = "object" version = "0.32.2" @@ -1540,6 +2506,12 @@ version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c08d65885ee38876c4f86fa503fb49d7b507c2b62552df7c70b2fce627e06381" +[[package]] +name = "option-ext" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "04744f49eae99ab78e0d5c0b603ab218f515ea8cfe5a456d7629ad883a3b6e7d" + [[package]] name = "orchard" version = "0.8.0" @@ -1561,7 +2533,7 @@ dependencies = [ "nonempty", "pasta_curves", "proptest", - "rand", + "rand 0.8.5", "reddsa", "serde", "subtle", @@ -1571,6 +2543,59 @@ dependencies = [ "zip32", ] +[[package]] +name = "ordered-float" +version = "2.10.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68f19d67e5a2795c94e73e0bb1cc1a7edeb2e28efd39e2e1c9b7a40c1108b11c" +dependencies = [ + "num-traits", +] + +[[package]] +name = "overload" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" + +[[package]] +name = "p256" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c9863ad85fa8f4460f9c48cb909d38a0d689dba1f6f6988a5e3e0d31071bcd4b" +dependencies = [ + "ecdsa", + "elliptic-curve", + "primeorder", + "sha2 0.10.8", +] + +[[package]] +name = "p384" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70786f51bcc69f6a4c0360e063a4cac5419ef7c5cd5b3c99ad70f3be5ba79209" +dependencies = [ + "ecdsa", + "elliptic-curve", + "primeorder", + "sha2 0.10.8", +] + +[[package]] +name = "p521" +version = "0.13.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0fc9e2161f1f215afdfce23677034ae137bbd45016a880c2eb3ba8eb95f085b2" +dependencies = [ + "base16ct", + "ecdsa", + "elliptic-curve", + "primeorder", + "rand_core 0.6.4", + "sha2 0.10.8", +] + [[package]] name = "pairing" version = "0.23.0" @@ -1580,6 +2605,12 @@ dependencies = [ "group", ] +[[package]] +name = "parking" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bb813b8af86854136c6922af0598d719255ecb2179515e6e7730d468f05c9cae" + [[package]] name = "parking_lot" version = "0.12.2" @@ -1613,11 +2644,32 @@ dependencies = [ "ff", "group", "lazy_static", - "rand", + "rand 0.8.5", "static_assertions", "subtle", ] +[[package]] +name = "paste" +version = "1.0.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "57c0d7b74b563b49d38dae00a0c37d4d6de9b432382b2892f0574ddcae73fd0a" + +[[package]] +name = "pathdiff" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8835116a5c179084a830efb3adc117ab007512b535bc1a21c991d3b32a6b44dd" + +[[package]] +name = "pem-rfc7468" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88b39c9bfcfc231068454382784bb460aae594343fb030d46e9f50a645418412" +dependencies = [ + "base64ct", +] + [[package]] name = "percent-encoding" version = "2.3.1" @@ -1634,6 +2686,48 @@ dependencies = [ "indexmap 2.2.6", ] +[[package]] +name = "phf" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ade2d8b8f33c7333b51bcf0428d37e217e9f32192ae4772156f65063b8ce03dc" +dependencies = [ + "phf_macros", + "phf_shared", +] + +[[package]] +name = "phf_generator" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "48e4cc64c2ad9ebe670cb8fd69dd50ae301650392e81c05f9bfcb2d5bdbc24b0" +dependencies = [ + "phf_shared", + "rand 0.8.5", +] + +[[package]] +name = "phf_macros" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3444646e286606587e49f3bcf1679b8cef1dc2c5ecc29ddacaffc305180d464b" +dependencies = [ + "phf_generator", + "phf_shared", + "proc-macro2", + "quote", + "syn 2.0.63", +] + +[[package]] +name = "phf_shared" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "90fcb95eef784c2ac79119d1dd819e162b5da872ce6f3c3abe1e8ca1c082f72b" +dependencies = [ + "siphasher", +] + [[package]] name = "pin-project" version = "1.1.5" @@ -1666,6 +2760,27 @@ version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" +[[package]] +name = "pkcs1" +version = "0.7.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c8ffb9f10fa047879315e6625af03c164b16962a5368d724ed16323b68ace47f" +dependencies = [ + "der", + "pkcs8", + "spki", +] + +[[package]] +name = "pkcs8" +version = "0.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7" +dependencies = [ + "der", + "spki", +] + [[package]] name = "pkg-config" version = "0.3.30" @@ -1711,6 +2826,21 @@ dependencies = [ "universal-hash", ] +[[package]] +name = "postage" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af3fb618632874fb76937c2361a7f22afd393c982a2165595407edc75b06d3c1" +dependencies = [ + "atomic", + "crossbeam-queue", + "futures", + "parking_lot", + "pin-project", + "static_assertions", + "thiserror", +] + [[package]] name = "powerfmt" version = "0.2.0" @@ -1755,6 +2885,15 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "primeorder" +version = "0.13.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "353e1ca18966c16d9deb1c69278edbc5f194139612772bd9537af60ac231e1e6" +dependencies = [ + "elliptic-curve", +] + [[package]] name = "primitive-types" version = "0.12.2" @@ -1765,6 +2904,26 @@ dependencies = [ "uint", ] +[[package]] +name = "priority-queue" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a0bda9164fe05bc9225752d54aae413343c36f684380005398a6a8fde95fe785" +dependencies = [ + "autocfg", + "indexmap 1.9.3", +] + +[[package]] +name = "proc-macro-crate" +version = "1.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f4c021e1093a56626774e81216a4ce732a735e5bad4868a03f3ed65ca0c3919" +dependencies = [ + "once_cell", + "toml_edit", +] + [[package]] name = "proc-macro2" version = "1.0.85" @@ -1785,10 +2944,10 @@ dependencies = [ "bitflags 2.5.0", "lazy_static", "num-traits", - "rand", - "rand_chacha", + "rand 0.8.5", + "rand_chacha 0.3.1", "rand_xorshift", - "regex-syntax", + "regex-syntax 0.8.3", "rusty-fork", "tempfile", "unarray", @@ -1812,7 +2971,7 @@ checksum = "5bb182580f71dd070f88d01ce3de9f4da5021db7115d2e1c3605a754153b77c1" dependencies = [ "bytes", "heck", - "itertools", + "itertools 0.11.0", "log", "multimap", "once_cell", @@ -1832,7 +2991,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "18bec9b0adc4eba778b33684b7ba3e7137789434769ee3ce3930463ef904cfca" dependencies = [ "anyhow", - "itertools", + "itertools 0.11.0", "proc-macro2", "quote", "syn 2.0.63", @@ -1847,6 +3006,18 @@ dependencies = [ "prost", ] +[[package]] +name = "pwd-grp" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6955c41fd7e4283bdf6ff3e7218b7e3f8ef24c4236b31d22be050f4cfd5e2a2c" +dependencies = [ + "derive-adhoc", + "libc", + "paste", + "thiserror", +] + [[package]] name = "quick-error" version = "1.2.3" @@ -1877,6 +3048,19 @@ version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dc33ff2d4973d518d823d61aa239014831e521c75da58e3df4840d3f47749d09" +[[package]] +name = "rand" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6a6b1679d49b24bbfe0c803429aa1874472f50d9b363131f0e89fc356b544d03" +dependencies = [ + "getrandom 0.1.16", + "libc", + "rand_chacha 0.2.2", + "rand_core 0.5.1", + "rand_hc", +] + [[package]] name = "rand" version = "0.8.5" @@ -1884,8 +3068,18 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404" dependencies = [ "libc", - "rand_chacha", - "rand_core", + "rand_chacha 0.3.1", + "rand_core 0.6.4", +] + +[[package]] +name = "rand_chacha" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f4c8ed856279c9737206bf725bf36935d8666ead7aa69b52be55af369d193402" +dependencies = [ + "ppv-lite86", + "rand_core 0.5.1", ] [[package]] @@ -1895,7 +3089,16 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" dependencies = [ "ppv-lite86", - "rand_core", + "rand_core 0.6.4", +] + +[[package]] +name = "rand_core" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "90bde5296fc891b0cef12a6d03ddccc162ce7b2aff54160af9338f8d40df6d19" +dependencies = [ + "getrandom 0.1.16", ] [[package]] @@ -1904,7 +3107,16 @@ version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" dependencies = [ - "getrandom", + "getrandom 0.2.15", +] + +[[package]] +name = "rand_hc" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca3129af7b92a17112d59ad498c6f81eaf463253766b90396d39ea7a39d6613c" +dependencies = [ + "rand_core 0.5.1", ] [[package]] @@ -1913,7 +3125,7 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d25bf25ec5ae4a3f1b92f929810509a2f53d7dca2f50b794ff57e3face536c8f" dependencies = [ - "rand_core", + "rand_core 0.6.4", ] [[package]] @@ -1948,7 +3160,7 @@ dependencies = [ "hex", "jubjub", "pasta_curves", - "rand_core", + "rand_core 0.6.4", "serde", "thiserror", "zeroize", @@ -1960,7 +3172,7 @@ version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7a60db2c3bc9c6fd1e8631fee75abc008841d27144be744951d6b9b75f9b569c" dependencies = [ - "rand_core", + "rand_core 0.6.4", "reddsa", "serde", "thiserror", @@ -1976,6 +3188,17 @@ dependencies = [ "bitflags 2.5.0", ] +[[package]] +name = "redox_users" +version = "0.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891" +dependencies = [ + "getrandom 0.2.15", + "libredox", + "thiserror", +] + [[package]] name = "regex" version = "1.10.4" @@ -1984,8 +3207,17 @@ checksum = "c117dbdfde9c8308975b6a18d71f3f385c89461f7b3fb054288ecf2a2058ba4c" dependencies = [ "aho-corasick", "memchr", - "regex-automata", - "regex-syntax", + "regex-automata 0.4.6", + "regex-syntax 0.8.3", +] + +[[package]] +name = "regex-automata" +version = "0.1.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c230d73fb8d8c1b9c0b3135c5142a8acee3a0558fb8db5cf1cb65f8d7862132" +dependencies = [ + "regex-syntax 0.6.29", ] [[package]] @@ -1996,15 +3228,43 @@ checksum = "86b83b8b9847f9bf95ef68afb0b8e6cdb80f498442f5179a29fad448fcc1eaea" dependencies = [ "aho-corasick", "memchr", - "regex-syntax", + "regex-syntax 0.8.3", ] +[[package]] +name = "regex-syntax" +version = "0.6.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f162c6dd7b008981e4d40210aca20b4bd0f9b60ca9271061b07f78537722f2e1" + [[package]] name = "regex-syntax" version = "0.8.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" +[[package]] +name = "retain_mut" +version = "0.1.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4389f1d5789befaf6029ebd9f7dac4af7f7e3d61b69d4f30e2ac02b57e7712b0" + +[[package]] +name = "retry-error" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b960f1dc847b9e4383ca73b4e8002f725b2f562addb9ade88a6ba109b305e96d" + +[[package]] +name = "rfc6979" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f8dd2a808d456c4a54e300a23e9f5a67e122c3024119acbfd73e3bf664491cb2" +dependencies = [ + "hmac", + "subtle", +] + [[package]] name = "rgb" version = "0.8.37" @@ -2014,6 +3274,21 @@ dependencies = [ "bytemuck", ] +[[package]] +name = "ring" +version = "0.16.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3053cf52e236a3ed746dfc745aa9cacf1b791d846bdaf412f60a8d7d6e17c8fc" +dependencies = [ + "cc", + "libc", + "once_cell", + "spin 0.5.2", + "untrusted 0.7.1", + "web-sys", + "winapi", +] + [[package]] name = "ring" version = "0.17.8" @@ -2022,10 +3297,10 @@ checksum = "c17fa4cb658e3583423e915b9f3acc01cceaee1860e33d59ebae66adc3a2dc0d" dependencies = [ "cc", "cfg-if", - "getrandom", + "getrandom 0.2.15", "libc", "spin 0.9.8", - "untrusted", + "untrusted 0.9.0", "windows-sys 0.52.0", ] @@ -2035,7 +3310,28 @@ version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bd124222d17ad93a644ed9d011a40f4fb64aa54275c08cc216524a9ea82fb09f" dependencies = [ - "digest", + "digest 0.10.7", +] + +[[package]] +name = "rsa" +version = "0.9.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5d0e5124fcb30e76a7e79bfee683a2746db83784b86289f6251b54b7950a0dfc" +dependencies = [ + "const-oid", + "digest 0.10.7", + "num-bigint-dig", + "num-integer", + "num-traits", + "pkcs1", + "pkcs8", + "rand_core 0.6.4", + "sha2 0.10.8", + "signature 2.2.0", + "spki", + "subtle", + "zeroize", ] [[package]] @@ -2053,12 +3349,32 @@ dependencies = [ "time", ] +[[package]] +name = "rust_decimal" +version = "1.35.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1790d1c4c0ca81211399e0e0af16333276f375209e71a37b67698a373db5b47a" +dependencies = [ + "arrayvec", + "num-traits", + "serde", +] + [[package]] name = "rustc-demangle" version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" +[[package]] +name = "rustc_version" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bfa0f585226d2e68097d4f95d113b15b83a82e819ab25717ec0590d9584ef366" +dependencies = [ + "semver", +] + [[package]] name = "rustix" version = "0.38.34" @@ -2079,7 +3395,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3f56a14d1f48b391359b22f731fd4bd7e43c97f3c50eee276f3aa09c94784d3e" dependencies = [ "log", - "ring", + "ring 0.17.8", "rustls-webpki", "sct", ] @@ -2090,8 +3406,8 @@ version = "0.101.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8b6275d1ee7a1cd780b64aca7726599a1dbc893b1e64144529e55c3c2f745765" dependencies = [ - "ring", - "untrusted", + "ring 0.17.8", + "untrusted 0.9.0", ] [[package]] @@ -2118,6 +3434,19 @@ version = "1.0.18" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" +[[package]] +name = "safelog" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4a1e9cd092ef5e122f1a34f3fe15de8e9685f8f610e31c4c0643976aa5e31737" +dependencies = [ + "derive_more", + "educe", + "either", + "fluid-let", + "thiserror", +] + [[package]] name = "same-file" version = "1.0.6" @@ -2127,6 +3456,16 @@ dependencies = [ "winapi-util", ] +[[package]] +name = "sanitize-filename" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2ed72fbaf78e6f2d41744923916966c4fbe3d7c74e3037a8ee482f1115572603" +dependencies = [ + "lazy_static", + "regex", +] + [[package]] name = "sapling-crypto" version = "0.1.3" @@ -2150,8 +3489,8 @@ dependencies = [ "lazy_static", "memuse", "proptest", - "rand", - "rand_core", + "rand 0.8.5", + "rand_core 0.6.4", "redjubjub", "subtle", "tracing", @@ -2195,8 +3534,22 @@ version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "da046153aa2352493d6cb7da4b6e5c0c057d8a1d0a9aa8560baffdd945acd414" dependencies = [ - "ring", - "untrusted", + "ring 0.17.8", + "untrusted 0.9.0", +] + +[[package]] +name = "sec1" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" +dependencies = [ + "base16ct", + "der", + "generic-array", + "pkcs8", + "subtle", + "zeroize", ] [[package]] @@ -2226,6 +3579,12 @@ dependencies = [ "zeroize", ] +[[package]] +name = "semver" +version = "1.0.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "92d43fe69e652f3df9bdc2b85b2854a0825b86e4fb76bc44d945137d053639ca" + [[package]] name = "serde" version = "1.0.202" @@ -2235,6 +3594,16 @@ dependencies = [ "serde_derive", ] +[[package]] +name = "serde-value" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f3a1a3341211875ef120e117ea7fd5228530ae7e7036a779fdc9117be6b3282c" +dependencies = [ + "ordered-float", + "serde", +] + [[package]] name = "serde_derive" version = "1.0.202" @@ -2246,6 +3615,15 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "serde_ignored" +version = "0.1.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a8e319a36d1b52126a0d608f24e93b2d81297091818cd70625fcf50a15d84ddf" +dependencies = [ + "serde", +] + [[package]] name = "serde_json" version = "1.0.117" @@ -2257,6 +3635,69 @@ dependencies = [ "serde", ] +[[package]] +name = "serde_spanned" +version = "0.6.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "79e674e01f999af37c49f70a6ede167a8a60b2503e56c5599532a65baa5969a0" +dependencies = [ + "serde", +] + +[[package]] +name = "serde_with" +version = "3.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0ad483d2ab0149d5a5ebcd9972a3852711e0153d863bf5a5d0391d28883c4a20" +dependencies = [ + "base64 0.22.1", + "chrono", + "hex", + "indexmap 1.9.3", + "indexmap 2.2.6", + "serde", + "serde_derive", + "serde_json", + "serde_with_macros", + "time", +] + +[[package]] +name = "serde_with_macros" +version = "3.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "65569b702f41443e8bc8bbb1c5779bd0450bbe723b56198980e80ec45780bce2" +dependencies = [ + "darling 0.20.9", + "proc-macro2", + "quote", + "syn 2.0.63", +] + +[[package]] +name = "sha1" +version = "0.10.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f04293dc80c3993519f2d7f6f511707ee7094fe0c6d3406feb330cdb3540eba3" +dependencies = [ + "cfg-if", + "cpufeatures", + "digest 0.10.7", +] + +[[package]] +name = "sha2" +version = "0.9.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4d58a1e1bf39749807d89cf2d98ac2dfa0ff1cb3faa38fbb64dd88ac8013d800" +dependencies = [ + "block-buffer 0.9.0", + "cfg-if", + "cpufeatures", + "digest 0.9.0", + "opaque-debug", +] + [[package]] name = "sha2" version = "0.10.8" @@ -2265,7 +3706,26 @@ checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8" dependencies = [ "cfg-if", "cpufeatures", - "digest", + "digest 0.10.7", +] + +[[package]] +name = "sha3" +version = "0.10.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75872d278a8f37ef87fa0ddbda7802605cb18344497949862c0d4dcb291eba60" +dependencies = [ + "digest 0.10.7", + "keccak", +] + +[[package]] +name = "sharded-slab" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" +dependencies = [ + "lazy_static", ] [[package]] @@ -2281,6 +3741,58 @@ dependencies = [ "tracing", ] +[[package]] +name = "shellexpand" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da03fa3b94cc19e3ebfc88c4229c49d8f08cdbd1228870a45f0ffdf84988e14b" +dependencies = [ + "dirs", +] + +[[package]] +name = "signal-hook-registry" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d8229b473baa5980ac72ef434c4415e70c4b5e71b423043adb4ba059f89c99a1" +dependencies = [ + "libc", +] + +[[package]] +name = "signature" +version = "1.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "74233d3b3b2f6d4b006dc19dee745e73e2a6bfb6f93607cd3b02bd5b00797d7c" + +[[package]] +name = "signature" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77549399552de45a898a580c1b41d445bf730df867cc44e6c0233bbc4b8329de" +dependencies = [ + "digest 0.10.7", + "rand_core 0.6.4", +] + +[[package]] +name = "simple_asn1" +version = "0.6.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "adc4e5204eb1910f40f9cfa375f6f05b68c3abac4b6fd879c8ff5e7ae8a0a085" +dependencies = [ + "num-bigint", + "num-traits", + "thiserror", + "time", +] + +[[package]] +name = "siphasher" +version = "0.3.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "38b58827f4464d87d377d175e90bf58eb00fd8716ff0a62f80356b5e61555d0d" + [[package]] name = "slab" version = "0.4.9" @@ -2290,6 +3802,15 @@ dependencies = [ "autocfg", ] +[[package]] +name = "slotmap" +version = "1.0.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dbff4acf519f630b3a3ddcfaea6c06b42174d9a44bc70c620e9ed1649d58b82a" +dependencies = [ + "version_check", +] + [[package]] name = "smallvec" version = "1.13.2" @@ -2318,6 +3839,57 @@ version = "0.9.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" +[[package]] +name = "spki" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d91ed6c858b01f942cd56b37a94b3e0a1798290327d1236e4d9cf4eaca44d29d" +dependencies = [ + "base64ct", + "der", +] + +[[package]] +name = "ssh-cipher" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "caac132742f0d33c3af65bfcde7f6aa8f62f0e991d80db99149eb9d44708784f" +dependencies = [ + "cipher", + "ssh-encoding", +] + +[[package]] +name = "ssh-encoding" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "eb9242b9ef4108a78e8cd1a2c98e193ef372437f8c22be363075233321dd4a15" +dependencies = [ + "base64ct", + "pem-rfc7468", + "sha2 0.10.8", +] + +[[package]] +name = "ssh-key" +version = "0.6.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca9b366a80cf18bb6406f4cf4d10aebfb46140a8c0c33f666a144c5c76ecbafc" +dependencies = [ + "p256", + "p384", + "p521", + "rand_core 0.6.4", + "rsa", + "sec1", + "sha2 0.10.8", + "signature 2.2.0", + "ssh-cipher", + "ssh-encoding", + "subtle", + "zeroize", +] + [[package]] name = "stable_deref_trait" version = "1.2.0" @@ -2342,6 +3914,34 @@ version = "0.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" +[[package]] +name = "strsim" +version = "0.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f" + +[[package]] +name = "strum" +version = "0.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "290d54ea6f91c969195bdbcd7442c8c2a2ba87da8bf60a7ee86a235d4bc1e125" +dependencies = [ + "strum_macros", +] + +[[package]] +name = "strum_macros" +version = "0.25.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "23dc1fa9ac9c169a78ba62f0b841814b7abae11bdd047b9c58f893439e309ea0" +dependencies = [ + "heck", + "proc-macro2", + "quote", + "rustversion", + "syn 2.0.63", +] + [[package]] name = "subtle" version = "2.5.0" @@ -2443,6 +4043,16 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "thread_local" +version = "1.1.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b9ef9bad013ada3808854ceac7b46812a6465ba368859a37e2100283d2d719c" +dependencies = [ + "cfg-if", + "once_cell", +] + [[package]] name = "time" version = "0.3.36" @@ -2474,6 +4084,15 @@ dependencies = [ "time-core", ] +[[package]] +name = "tinystr" +version = "0.7.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9117f5d4db391c1cf6927e7bea3db74b9a1c1add8f7eda9ffd5364f40f57b82f" +dependencies = [ + "displaydoc", +] + [[package]] name = "tinytemplate" version = "1.2.1" @@ -2511,6 +4130,7 @@ dependencies = [ "mio", "num_cpus", "pin-project-lite", + "signal-hook-registry", "socket2", "tokio-macros", "windows-sys 0.48.0", @@ -2527,6 +4147,16 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "tokio-rustls" +version = "0.24.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e0d409377ff5b1e3ca6437aa86c1eb7d40c134bfec254e44c830defa92669db5" +dependencies = [ + "rustls", + "tokio", +] + [[package]] name = "tokio-stream" version = "0.1.15" @@ -2546,11 +4176,55 @@ checksum = "9cf6b47b3771c49ac75ad09a6162f53ad4b8088b76ac60e8ec1455b31a189fe1" dependencies = [ "bytes", "futures-core", + "futures-io", "futures-sink", "pin-project-lite", "tokio", ] +[[package]] +name = "toml" +version = "0.5.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f4f7f0dd8d50a853a531c426359045b1998f04219d88799810762cd4ad314234" +dependencies = [ + "serde", +] + +[[package]] +name = "toml" +version = "0.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d6135d499e69981f9ff0ef2167955a5333c35e36f6937d382974566b3d5b94ec" +dependencies = [ + "serde", + "serde_spanned", + "toml_datetime", + "toml_edit", +] + +[[package]] +name = "toml_datetime" +version = "0.6.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7cda73e2f1397b1262d6dfdcef8aafae14d1de7748d66822d3bfeeb6d03e5e4b" +dependencies = [ + "serde", +] + +[[package]] +name = "toml_edit" +version = "0.19.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b5bb770da30e5cbfde35a2d7b9b8a2c4b8ef89548a7a6aeab5c9a576e3e7421" +dependencies = [ + "indexmap 2.2.6", + "serde", + "serde_spanned", + "toml_datetime", + "winnow", +] + [[package]] name = "tonic" version = "0.12.0" @@ -2563,7 +4237,7 @@ dependencies = [ "base64 0.22.1", "bytes", "h2", - "http", + "http 1.1.0", "http-body", "http-body-util", "hyper", @@ -2594,6 +4268,675 @@ dependencies = [ "syn 2.0.63", ] +[[package]] +name = "tor-async-utils" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "154dff0d035ea51ee67b491aca0d90875fae090cfea430527fcc343a0c59c0a3" +dependencies = [ + "futures", + "pin-project", + "postage", + "thiserror", + "void", +] + +[[package]] +name = "tor-basic-utils" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "11e82b6e151be1ba47f9aad40e02bb1dc8b2b174bc493b4a1d942ba8e405e3d3" +dependencies = [ + "hex", + "libc", + "paste", + "rand 0.8.5", + "rand_chacha 0.3.1", + "slab", + "thiserror", +] + +[[package]] +name = "tor-bytes" +version = "0.7.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69e6acef7dad3e9b3f2d12050ecc63195bbc643cdb75fca17f83d6d1bcef0760" +dependencies = [ + "bytes", + "digest 0.10.7", + "educe", + "getrandom 0.2.15", + "signature 1.6.4", + "thiserror", + "tor-error", + "tor-llcrypto", + "zeroize", +] + +[[package]] +name = "tor-cell" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8eb03a8c8ec5236564c2409bbbf7f6b37d2453abbe8847092468a37f195ec678" +dependencies = [ + "bitflags 2.5.0", + "bytes", + "caret", + "derive_more", + "educe", + "paste", + "rand 0.8.5", + "thiserror", + "tor-basic-utils", + "tor-bytes", + "tor-cert", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-units", +] + +[[package]] +name = "tor-cert" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a1dddfc048502c8d16292ff0f2f3559ca00140b4f4057ad53bd84063e589a33b" +dependencies = [ + "caret", + "derive_more", + "digest 0.10.7", + "signature 1.6.4", + "thiserror", + "tor-bytes", + "tor-checkable", + "tor-llcrypto", +] + +[[package]] +name = "tor-chanmgr" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9037f813b358df2d95efd8ec3c1b9003d884958c7169e1ca7c7044b99a4775c2" +dependencies = [ + "async-trait", + "derive_builder_fork_arti", + "derive_more", + "educe", + "futures", + "postage", + "rand 0.8.5", + "safelog", + "serde", + "thiserror", + "tor-async-utils", + "tor-basic-utils", + "tor-cell", + "tor-config", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-netdir", + "tor-proto", + "tor-rtcompat", + "tor-socksproto", + "tor-units", + "tracing", + "void", +] + +[[package]] +name = "tor-checkable" +version = "0.5.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "43f6eb12732d7f2faec544c20ac362dc85c37d3979e37da43a61f403917a9d1d" +dependencies = [ + "humantime", + "signature 1.6.4", + "thiserror", + "tor-llcrypto", +] + +[[package]] +name = "tor-circmgr" +version = "0.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "618fb3cd1a412fa3f36a70c08adc9f4f9d207cac2e8c092d57f6e9ffafedc87a" +dependencies = [ + "amplify", + "async-trait", + "bounded-vec-deque", + "derive_builder_fork_arti", + "derive_more", + "downcast-rs", + "dyn-clone", + "educe", + "futures", + "humantime-serde", + "itertools 0.11.0", + "once_cell", + "pin-project", + "rand 0.8.5", + "retry-error", + "safelog", + "serde", + "static_assertions", + "thiserror", + "tor-async-utils", + "tor-basic-utils", + "tor-chanmgr", + "tor-config", + "tor-error", + "tor-guardmgr", + "tor-linkspec", + "tor-netdir", + "tor-netdoc", + "tor-persist", + "tor-proto", + "tor-rtcompat", + "tracing", + "void", + "weak-table", +] + +[[package]] +name = "tor-config" +version = "0.9.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7269acd2a6216641ee7448bffade1f8270236a2cbecf37f7f9e2261fa284b46b" +dependencies = [ + "config", + "derive-adhoc", + "derive_builder_fork_arti", + "directories", + "educe", + "either", + "fs-mistrust", + "itertools 0.12.1", + "once_cell", + "paste", + "regex", + "serde", + "serde-value", + "serde_ignored", + "shellexpand", + "strum", + "thiserror", + "toml 0.7.4", + "tor-basic-utils", + "tor-error", + "tracing", + "void", +] + +[[package]] +name = "tor-consdiff" +version = "0.5.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a5f89dc260039f956ee4512420bfcf0b241777b9de15c0053ca82400eeadb63e" +dependencies = [ + "digest 0.10.7", + "hex", + "thiserror", + "tor-llcrypto", +] + +[[package]] +name = "tor-dirclient" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "99eda450363bbffdf0d07e549d71486474c036b26a7ece2a76bbd199150b11df" +dependencies = [ + "async-compression", + "base64ct", + "derive_more", + "futures", + "hex", + "http 0.2.12", + "httparse", + "httpdate", + "itertools 0.11.0", + "memchr", + "thiserror", + "tor-circmgr", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-netdoc", + "tor-proto", + "tor-rtcompat", + "tracing", +] + +[[package]] +name = "tor-dirmgr" +version = "0.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cc631aedfc5361d7127c6f6a74c125e9c5a417fd1b5a6f26cd1e216af5e2c649" +dependencies = [ + "async-trait", + "base64ct", + "derive_builder_fork_arti", + "derive_more", + "digest 0.10.7", + "educe", + "event-listener", + "fs-mistrust", + "fslock", + "futures", + "hex", + "humantime", + "humantime-serde", + "itertools 0.11.0", + "memmap2", + "once_cell", + "paste", + "postage", + "rand 0.8.5", + "retry-error", + "rusqlite", + "safelog", + "scopeguard", + "serde", + "signature 1.6.4", + "strum", + "thiserror", + "time", + "tor-async-utils", + "tor-basic-utils", + "tor-checkable", + "tor-circmgr", + "tor-config", + "tor-consdiff", + "tor-dirclient", + "tor-error", + "tor-guardmgr", + "tor-llcrypto", + "tor-netdir", + "tor-netdoc", + "tor-proto", + "tor-rtcompat", + "tracing", +] + +[[package]] +name = "tor-error" +version = "0.5.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fc4dec82bb91affde760c803e84efceaaca18c26e99fc7e5255038605546e106" +dependencies = [ + "backtrace", + "derive_more", + "futures", + "once_cell", + "paste", + "retry-error", + "static_assertions", + "strum", + "thiserror", + "tracing", +] + +[[package]] +name = "tor-guardmgr" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "41ecb3b00d12b67ecf7f1f8d2238d0df04223197322706222a6e610e2b10bd2b" +dependencies = [ + "base64ct", + "derive_builder_fork_arti", + "derive_more", + "dyn-clone", + "educe", + "futures", + "humantime", + "humantime-serde", + "itertools 0.11.0", + "num_enum", + "pin-project", + "postage", + "rand 0.8.5", + "retain_mut", + "safelog", + "serde", + "strum", + "thiserror", + "tor-async-utils", + "tor-basic-utils", + "tor-config", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-netdir", + "tor-netdoc", + "tor-persist", + "tor-proto", + "tor-rtcompat", + "tor-units", + "tracing", +] + +[[package]] +name = "tor-hscrypto" +version = "0.3.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1292e63d90a4e004d248b6f4ff95f727122f4b5c0f9b64d3e79268c2d76766b6" +dependencies = [ + "data-encoding", + "derive_more", + "digest 0.10.7", + "itertools 0.11.0", + "paste", + "rand 0.8.5", + "rand_core 0.6.4", + "safelog", + "serde", + "signature 1.6.4", + "subtle", + "thiserror", + "tor-basic-utils", + "tor-bytes", + "tor-error", + "tor-llcrypto", + "tor-units", +] + +[[package]] +name = "tor-keymgr" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d86bbc016d8f0f1c12ee95fb282c28ac027d9dc095d4e2326cdf01e4d38695c5" +dependencies = [ + "derive_builder_fork_arti", + "derive_more", + "downcast-rs", + "dyn-clone", + "fs-mistrust", + "glob-match", + "itertools 0.11.0", + "rand 0.8.5", + "serde", + "ssh-key", + "thiserror", + "tor-config", + "tor-error", + "tor-hscrypto", + "tor-llcrypto", + "walkdir", + "zeroize", +] + +[[package]] +name = "tor-linkspec" +version = "0.8.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8948c3648b1a1a450078b5733a53754e0e3aaa285385a72d0f8dfa074fed8ab2" +dependencies = [ + "base64ct", + "by_address", + "caret", + "cfg-if", + "derive_builder_fork_arti", + "derive_more", + "educe", + "hex", + "itertools 0.11.0", + "safelog", + "serde", + "serde_with", + "strum", + "thiserror", + "tor-basic-utils", + "tor-bytes", + "tor-config", + "tor-llcrypto", + "tor-protover", +] + +[[package]] +name = "tor-llcrypto" +version = "0.5.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ff0f97bb094ee676b3f00d8dce58c0b39faf21aab0f01658e22e7998cb5d8b1c" +dependencies = [ + "aes", + "base64ct", + "ctr", + "curve25519-dalek", + "derive_more", + "digest 0.10.7", + "ed25519-dalek", + "getrandom 0.2.15", + "hex", + "rand_core 0.5.1", + "rand_core 0.6.4", + "rsa", + "safelog", + "serde", + "sha1", + "sha2 0.10.8", + "sha3", + "signature 1.6.4", + "simple_asn1", + "subtle", + "thiserror", + "x25519-dalek", + "zeroize", +] + +[[package]] +name = "tor-netdir" +version = "0.9.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "33bff5a547d7caa33339c1c702bbfd6c13d957c8dd65095457fb547ba399ccd8" +dependencies = [ + "bitflags 2.5.0", + "derive_builder_fork_arti", + "derive_more", + "futures", + "humantime", + "itertools 0.11.0", + "num_enum", + "rand 0.8.5", + "serde", + "signature 1.6.4", + "static_assertions", + "strum", + "thiserror", + "tor-basic-utils", + "tor-checkable", + "tor-config", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-netdoc", + "tor-protover", + "tor-units", + "tracing", + "typed-index-collections", +] + +[[package]] +name = "tor-netdoc" +version = "0.9.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "467c8e98df87280219a3a12287ab5b82bd1b00d0a7b88d44ab002ba6383ffe31" +dependencies = [ + "amplify", + "base64ct", + "bitflags 2.5.0", + "cipher", + "derive_builder_fork_arti", + "derive_more", + "digest 0.10.7", + "educe", + "hex", + "humantime", + "itertools 0.11.0", + "once_cell", + "phf", + "serde", + "serde_with", + "signature 1.6.4", + "smallvec", + "subtle", + "thiserror", + "time", + "tinystr", + "tor-basic-utils", + "tor-bytes", + "tor-cell", + "tor-cert", + "tor-checkable", + "tor-error", + "tor-llcrypto", + "tor-protover", + "weak-table", + "zeroize", +] + +[[package]] +name = "tor-persist" +version = "0.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8acc41bbd75d29bd1552983221e6f88b710753e9bddeafb964e60cf59c75e8c4" +dependencies = [ + "derive_more", + "fs-mistrust", + "fslock", + "sanitize-filename", + "serde", + "serde_json", + "thiserror", + "tor-error", + "tracing", +] + +[[package]] +name = "tor-proto" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4a06c316e1fa8593cbe12664a1b15781bfd7d3817445f64cf7479ca96f969a59" +dependencies = [ + "asynchronous-codec", + "bitvec", + "bytes", + "cipher", + "coarsetime", + "derive_builder_fork_arti", + "derive_more", + "digest 0.10.7", + "educe", + "futures", + "hkdf", + "hmac", + "pin-project", + "rand 0.8.5", + "rand_core 0.6.4", + "safelog", + "subtle", + "thiserror", + "tokio", + "tokio-util", + "tor-async-utils", + "tor-basic-utils", + "tor-bytes", + "tor-cell", + "tor-cert", + "tor-checkable", + "tor-config", + "tor-error", + "tor-linkspec", + "tor-llcrypto", + "tor-protover", + "tor-rtcompat", + "tor-rtmock", + "tor-units", + "tracing", + "typenum", + "void", + "zeroize", +] + +[[package]] +name = "tor-protover" +version = "0.5.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "203fe1e2a4de305d285f8cf4edfe1d392e89c1e13cf69835dad43a0120a6ea83" +dependencies = [ + "caret", + "thiserror", +] + +[[package]] +name = "tor-rtcompat" +version = "0.9.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "be71f1a409ed38b64f11d4506407898daae2fab486a9cfc87d0d56fa783b22da" +dependencies = [ + "async-rustls", + "async-trait", + "async_executors", + "educe", + "futures", + "pin-project", + "rustls", + "thiserror", + "tokio", + "tokio-util", + "x509-signature", +] + +[[package]] +name = "tor-rtmock" +version = "0.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e54eab8e1436e94bc4777a865205809cf0fe8feddca56e44f754b087908583b" +dependencies = [ + "amplify", + "async-trait", + "backtrace", + "derive-adhoc", + "derive_more", + "educe", + "futures", + "humantime", + "itertools 0.12.1", + "pin-project", + "priority-queue", + "slotmap", + "strum", + "thiserror", + "tor-async-utils", + "tor-error", + "tor-rtcompat", + "tracing", + "tracing-test", + "void", +] + +[[package]] +name = "tor-socksproto" +version = "0.7.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "20ec6a2cc5847511ef53ccb452208019a1a1e8effc16ce615c8f7ec9e3c96f4e" +dependencies = [ + "caret", + "subtle", + "thiserror", + "tor-bytes", + "tor-error", +] + +[[package]] +name = "tor-units" +version = "0.6.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d59226676dc7633b813f92c781f7b637c5258234de27be4196740de2b4c946a" +dependencies = [ + "derive_more", + "thiserror", +] + [[package]] name = "tower" version = "0.4.13" @@ -2605,7 +4948,7 @@ dependencies = [ "indexmap 1.9.3", "pin-project", "pin-project-lite", - "rand", + "rand 0.8.5", "slab", "tokio", "tokio-util", @@ -2655,6 +4998,57 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" dependencies = [ "once_cell", + "valuable", +] + +[[package]] +name = "tracing-log" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee855f1f400bd0e5c02d150ae5de3840039a3f54b025156404e34c23c03f47c3" +dependencies = [ + "log", + "once_cell", + "tracing-core", +] + +[[package]] +name = "tracing-subscriber" +version = "0.3.18" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b" +dependencies = [ + "matchers", + "nu-ansi-term", + "once_cell", + "regex", + "sharded-slab", + "smallvec", + "thread_local", + "tracing", + "tracing-core", + "tracing-log", +] + +[[package]] +name = "tracing-test" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "557b891436fe0d5e0e363427fc7f217abf9ccd510d5136549847bdcbcd011d68" +dependencies = [ + "tracing-core", + "tracing-subscriber", + "tracing-test-macro", +] + +[[package]] +name = "tracing-test-macro" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "04659ddb06c87d233c566112c1c9c5b9e98256d9af50ec3bc9c8327f873a7568" +dependencies = [ + "quote", + "syn 2.0.63", ] [[package]] @@ -2663,6 +5057,12 @@ version = "0.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" +[[package]] +name = "typed-index-collections" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "183496e014253d15abbe6235677b1392dba2d40524c88938991226baa38ac7c4" + [[package]] name = "typenum" version = "1.17.0" @@ -2703,6 +5103,12 @@ dependencies = [ "subtle", ] +[[package]] +name = "untrusted" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" + [[package]] name = "untrusted" version = "0.9.0" @@ -2721,6 +5127,12 @@ version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a183cf7feeba97b4dd1c0d46788634f6221d87fa961b305bed08c851829efcc0" +[[package]] +name = "valuable" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" + [[package]] name = "vcpkg" version = "0.2.15" @@ -2733,6 +5145,12 @@ version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f" +[[package]] +name = "void" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6a02e4885ed3bc0f2de90ea6dd45ebcbb66dacffe03547fadbb0eeae2770887d" + [[package]] name = "wagyu-zcash-parameters" version = "0.2.0" @@ -2811,12 +5229,27 @@ dependencies = [ "try-lock", ] +[[package]] +name = "wasi" +version = "0.9.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cccddf32554fecc6acb585f82a32a72e28b48f8c4c1883ddfeeeaa96f7d8e519" + [[package]] name = "wasi" version = "0.11.0+wasi-snapshot-preview1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" +[[package]] +name = "wasix" +version = "0.12.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1fbb4ef9bbca0c1170e0b00dd28abc9e3b68669821600cad1caaed606583c6d" +dependencies = [ + "wasi 0.11.0+wasi-snapshot-preview1", +] + [[package]] name = "wasm-bindgen" version = "0.2.92" @@ -2871,6 +5304,12 @@ version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" +[[package]] +name = "weak-table" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "323f4da9523e9a669e1eaf9c6e763892769b1d38c623913647bfdc1532fe4549" + [[package]] name = "web-sys" version = "0.3.69" @@ -2930,6 +5369,15 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" +[[package]] +name = "windows-core" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" +dependencies = [ + "windows-targets 0.52.5", +] + [[package]] name = "windows-sys" version = "0.48.0" @@ -3069,6 +5517,15 @@ version = "0.52.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bec47e5bfd1bff0eeaf6d8b485cc1074891a197ab4225d504cb7a1ab88b02bf0" +[[package]] +name = "winnow" +version = "0.5.40" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f593a95398737aeed53e489c785df13f3618e41dbcd6718c6addbf1395aa6876" +dependencies = [ + "memchr", +] + [[package]] name = "wyz" version = "0.5.1" @@ -3078,12 +5535,42 @@ dependencies = [ "tap", ] +[[package]] +name = "x25519-dalek" +version = "2.0.0-pre.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5da623d8af10a62342bcbbb230e33e58a63255a58012f8653c578e54bab48df" +dependencies = [ + "curve25519-dalek", + "rand_core 0.6.4", + "zeroize", +] + +[[package]] +name = "x509-signature" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9fb2bc2a902d992cd5f471ee3ab0ffd6603047a4207384562755b9d6de977518" +dependencies = [ + "ring 0.16.20", + "untrusted 0.7.1", +] + [[package]] name = "xdg" version = "2.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "213b7324336b53d2414b2db8537e56544d981803139155afa84f76eeebb7a546" +[[package]] +name = "xz2" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "388c44dc09d76f1536602ead6d325eb532f5c122f17782bd57fb47baeeb767e2" +dependencies = [ + "lzma-sys", +] + [[package]] name = "zcash" version = "0.1.0" @@ -3109,6 +5596,7 @@ dependencies = [ name = "zcash_client_backend" version = "0.12.1" dependencies = [ + "arti-client", "assert_matches", "async-trait", "base64 0.21.7", @@ -3123,6 +5611,9 @@ dependencies = [ "group", "gumdrop", "hex", + "http-body-util", + "hyper", + "hyper-util", "incrementalmerkletree", "jubjub", "memuse", @@ -3132,17 +5623,24 @@ dependencies = [ "percent-encoding", "proptest", "prost", - "rand_core", + "rand 0.8.5", + "rand_core 0.6.4", "rayon", + "rust_decimal", "sapling-crypto", "secrecy", + "serde", + "serde_json", "shardtree", "subtle", "time", "tokio", + "tokio-rustls", "tonic", "tonic-build", + "tor-rtcompat", "tracing", + "webpki-roots", "which", "zcash_address", "zcash_encoding", @@ -3174,8 +5672,8 @@ dependencies = [ "pasta_curves", "proptest", "prost", - "rand_chacha", - "rand_core", + "rand_chacha 0.3.1", + "rand_core 0.6.4", "regex", "rusqlite", "sapling-crypto", @@ -3217,7 +5715,7 @@ dependencies = [ "ff", "jubjub", "orchard", - "rand_core", + "rand_core 0.6.4", "sapling-crypto", "zcash_address", "zcash_primitives", @@ -3253,7 +5751,7 @@ dependencies = [ "nonempty", "orchard", "proptest", - "rand_core", + "rand_core 0.6.4", "sapling-crypto", "secrecy", "subtle", @@ -3274,7 +5772,7 @@ dependencies = [ "chacha20", "chacha20poly1305", "cipher", - "rand_core", + "rand_core 0.6.4", "subtle", ] @@ -3304,14 +5802,14 @@ dependencies = [ "orchard", "pprof", "proptest", - "rand", - "rand_core", + "rand 0.8.5", + "rand_core 0.6.4", "rand_xorshift", "redjubjub", "ripemd", "sapling-crypto", "secp256k1", - "sha2", + "sha2 0.10.8", "subtle", "tracing", "zcash_address", @@ -3337,7 +5835,7 @@ dependencies = [ "known-folders", "lazy_static", "minreq", - "rand_core", + "rand_core 0.6.4", "redjubjub", "sapling-crypto", "tracing", @@ -3427,3 +5925,31 @@ dependencies = [ "zcash_address", "zcash_protocol", ] + +[[package]] +name = "zstd" +version = "0.13.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2d789b1514203a1120ad2429eae43a7bd32b90976a7bb8a05f7ec02fa88cc23a" +dependencies = [ + "zstd-safe", +] + +[[package]] +name = "zstd-safe" +version = "7.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1cd99b45c6bc03a018c8b8a86025678c87e55526064e38f9df301989dce7ec0a" +dependencies = [ + "zstd-sys", +] + +[[package]] +name = "zstd-sys" +version = "2.0.10+zstd.1.5.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c253a4914af5bafc8fa8c86ee400827e83cf6ec01195ec1f1ed8441bf00d65aa" +dependencies = [ + "cc", + "pkg-config", +] diff --git a/Cargo.toml b/Cargo.toml index 1ba2dc6be..fc050ad30 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -71,6 +71,9 @@ secp256k1 = "0.27" rand = "0.8" rand_core = "0.6" +# Currency conversions +rust_decimal = { version = "1.35", default-features = false, features = ["serde"] } + # Digests blake2b_simd = "1" sha2 = "0.10" @@ -85,6 +88,15 @@ bs58 = { version = "0.5", features = ["check"] } byteorder = "1" hex = "0.4" percent-encoding = "2.1.0" +serde = { version = "1", features = ["derive"] } +serde_json = "1" + +# HTTP +hyper = "1" +http-body-util = "0.1" +hyper-util = { version = "0.1.1", features = ["tokio"] } +tokio-rustls = "0.24" +webpki-roots = "0.25" # Logging and metrics memuse = "0.2.1" @@ -104,6 +116,16 @@ tonic-build = { version = "0.12", default-features = false } secrecy = "0.8" subtle = "2.2.3" +# SQLite databases +# - Warning: One of the downstream consumers requires that SQLite be available through +# CocoaPods, due to being bound to React Native. We need to ensure that the SQLite +# version required for `rusqlite` is a version that is available through CocoaPods. +rusqlite = { version = "0.29.0", features = ["bundled"] } +schemer = "0.2" +schemer-rusqlite = "0.2.2" +time = "0.3.22" +uuid = "1.1" + # Static constants and assertions lazy_static = "1" static_assertions = "1" @@ -115,6 +137,13 @@ proptest = "1" rand_chacha = "0.3" rand_xorshift = "0.3" +# Tor +# - `arti-client` depends on `rusqlite`, and a version mismatch there causes a compilation +# failure due to incompatible `libsqlite3-sys` versions. +arti-client = { version = "0.11", default-features = false, features = ["compression", "rustls", "tokio"] } +tokio = "1" +tor-rtcompat = "0.9" + # ZIP 32 aes = "0.8" fpe = "0.6" diff --git a/deny.toml b/deny.toml index 79248160d..146dbd8f7 100644 --- a/deny.toml +++ b/deny.toml @@ -31,16 +31,27 @@ allow = [ ] exceptions = [ { name = "arrayref", allow = ["BSD-2-Clause"] }, + { name = "async_executors", allow = ["Unlicense"] }, + { name = "bounded-vec-deque", allow = ["BSD-3-Clause"] }, + { name = "coarsetime", allow = ["ISC"] }, + { name = "curve25519-dalek", allow = ["BSD-3-Clause"] }, + { name = "ed25519-dalek", allow = ["BSD-3-Clause"] }, { name = "matchit", allow = ["BSD-3-Clause"] }, { name = "minreq", allow = ["ISC"] }, + { name = "option-ext", allow = ["MPL-2.0"] }, + { name = "priority-queue", allow = ["MPL-2.0"] }, { name = "ring", allow = ["LicenseRef-ring"] }, { name = "rustls-webpki", allow = ["ISC"] }, { name = "secp256k1", allow = ["CC0-1.0"] }, { name = "secp256k1-sys", allow = ["CC0-1.0"] }, + { name = "simple_asn1", allow = ["ISC"] }, + { name = "slotmap", allow = ["Zlib"] }, { name = "subtle", allow = ["BSD-3-Clause"] }, + { name = "tinystr", allow = ["Unicode-3.0"] }, { name = "unicode-ident", allow = ["Unicode-DFS-2016"] }, { name = "untrusted", allow = ["ISC"] }, { name = "webpki-roots", allow = ["MPL-2.0"] }, + { name = "x25519-dalek", allow = ["BSD-3-Clause"] }, ] [[licenses.clarify]] diff --git a/supply-chain/config.toml b/supply-chain/config.toml index 74279c6b3..9311656c0 100644 --- a/supply-chain/config.toml +++ b/supply-chain/config.toml @@ -88,6 +88,26 @@ criteria = "safe-to-deploy" version = "0.2.16" criteria = "safe-to-deploy" +[[exemptions.amplify]] +version = "4.6.0" +criteria = "safe-to-deploy" + +[[exemptions.amplify_derive]] +version = "4.0.0" +criteria = "safe-to-deploy" + +[[exemptions.amplify_num]] +version = "0.5.2" +criteria = "safe-to-deploy" + +[[exemptions.amplify_syn]] +version = "2.0.1" +criteria = "safe-to-deploy" + +[[exemptions.android-tzdata]] +version = "0.1.1" +criteria = "safe-to-deploy" + [[exemptions.anstyle-wincon]] version = "3.0.3" criteria = "safe-to-run" @@ -96,14 +116,42 @@ criteria = "safe-to-run" version = "0.7.4" criteria = "safe-to-deploy" +[[exemptions.arti-client]] +version = "0.11.0" +criteria = "safe-to-deploy" + +[[exemptions.ascii]] +version = "1.1.0" +criteria = "safe-to-deploy" + [[exemptions.assert_matches]] version = "1.5.0" criteria = "safe-to-deploy" +[[exemptions.async-compression]] +version = "0.4.11" +criteria = "safe-to-deploy" + +[[exemptions.async-rustls]] +version = "0.4.2" +criteria = "safe-to-deploy" + [[exemptions.async-trait]] version = "0.1.78" criteria = "safe-to-deploy" +[[exemptions.async_executors]] +version = "0.7.0" +criteria = "safe-to-deploy" + +[[exemptions.asynchronous-codec]] +version = "0.7.0" +criteria = "safe-to-deploy" + +[[exemptions.atomic]] +version = "0.5.3" +criteria = "safe-to-deploy" + [[exemptions.atomic-waker]] version = "1.1.2" criteria = "safe-to-deploy" @@ -120,10 +168,18 @@ criteria = "safe-to-deploy" version = "0.3.69" criteria = "safe-to-deploy" +[[exemptions.base16ct]] +version = "0.2.0" +criteria = "safe-to-deploy" + [[exemptions.base64]] version = "0.22.1" criteria = "safe-to-deploy" +[[exemptions.base64ct]] +version = "1.6.0" +criteria = "safe-to-deploy" + [[exemptions.bech32]] version = "0.9.1" criteria = "safe-to-deploy" @@ -148,14 +204,26 @@ criteria = "safe-to-deploy" version = "1.0.1" criteria = "safe-to-deploy" +[[exemptions.blanket]] +version = "0.3.0" +criteria = "safe-to-deploy" + [[exemptions.bls12_381]] version = "0.8.0" criteria = "safe-to-deploy" +[[exemptions.bounded-vec-deque]] +version = "0.1.1" +criteria = "safe-to-deploy" + [[exemptions.bs58]] version = "0.5.0" criteria = "safe-to-deploy" +[[exemptions.by_address]] +version = "1.2.1" +criteria = "safe-to-deploy" + [[exemptions.byteorder]] version = "1.5.0" criteria = "safe-to-deploy" @@ -164,6 +232,10 @@ criteria = "safe-to-deploy" version = "1.5.0" criteria = "safe-to-deploy" +[[exemptions.caret]] +version = "0.4.6" +criteria = "safe-to-deploy" + [[exemptions.cbc]] version = "0.1.2" criteria = "safe-to-deploy" @@ -176,6 +248,10 @@ criteria = "safe-to-deploy" version = "0.10.1" criteria = "safe-to-deploy" +[[exemptions.chrono]] +version = "0.4.38" +criteria = "safe-to-deploy" + [[exemptions.ciborium]] version = "0.2.1" criteria = "safe-to-run" @@ -192,6 +268,22 @@ criteria = "safe-to-run" version = "0.4.4" criteria = "safe-to-deploy" +[[exemptions.coarsetime]] +version = "0.1.34" +criteria = "safe-to-deploy" + +[[exemptions.concurrent-queue]] +version = "2.5.0" +criteria = "safe-to-deploy" + +[[exemptions.config]] +version = "0.13.4" +criteria = "safe-to-deploy" + +[[exemptions.const-oid]] +version = "0.9.6" +criteria = "safe-to-deploy" + [[exemptions.cpp_demangle]] version = "0.4.3" criteria = "safe-to-run" @@ -200,6 +292,10 @@ criteria = "safe-to-run" version = "0.2.11" criteria = "safe-to-deploy" +[[exemptions.crc32fast]] +version = "1.4.2" +criteria = "safe-to-deploy" + [[exemptions.criterion]] version = "0.4.0" criteria = "safe-to-run" @@ -224,12 +320,124 @@ criteria = "safe-to-deploy" version = "0.8.19" criteria = "safe-to-deploy" +[[exemptions.crypto-bigint]] +version = "0.5.5" +criteria = "safe-to-deploy" + +[[exemptions.ctr]] +version = "0.9.2" +criteria = "safe-to-deploy" + +[[exemptions.curve25519-dalek]] +version = "3.2.0" +criteria = "safe-to-deploy" + [[exemptions.daggy]] version = "0.8.0" criteria = "safe-to-deploy" +[[exemptions.darling]] +version = "0.14.4" +criteria = "safe-to-deploy" + +[[exemptions.darling]] +version = "0.20.9" +criteria = "safe-to-deploy" + +[[exemptions.darling_core]] +version = "0.14.4" +criteria = "safe-to-deploy" + +[[exemptions.darling_core]] +version = "0.20.9" +criteria = "safe-to-deploy" + +[[exemptions.darling_macro]] +version = "0.14.4" +criteria = "safe-to-deploy" + +[[exemptions.darling_macro]] +version = "0.20.9" +criteria = "safe-to-deploy" + +[[exemptions.data-encoding]] +version = "2.6.0" +criteria = "safe-to-deploy" + +[[exemptions.der]] +version = "0.7.8" +criteria = "safe-to-deploy" + +[[exemptions.derive-adhoc]] +version = "0.7.3" +criteria = "safe-to-deploy" + +[[exemptions.derive-adhoc-macros]] +version = "0.7.3" +criteria = "safe-to-deploy" + +[[exemptions.derive_builder_core_fork_arti]] +version = "0.11.2" +criteria = "safe-to-deploy" + +[[exemptions.derive_builder_fork_arti]] +version = "0.11.2" +criteria = "safe-to-deploy" + +[[exemptions.derive_builder_macro_fork_arti]] +version = "0.11.2" +criteria = "safe-to-deploy" + [[exemptions.digest]] -version = "0.10.7" +version = "0.9.0" +criteria = "safe-to-deploy" + +[[exemptions.directories]] +version = "5.0.1" +criteria = "safe-to-deploy" + +[[exemptions.dirs]] +version = "5.0.1" +criteria = "safe-to-deploy" + +[[exemptions.dirs-sys]] +version = "0.4.1" +criteria = "safe-to-deploy" + +[[exemptions.downcast-rs]] +version = "1.2.1" +criteria = "safe-to-deploy" + +[[exemptions.dyn-clone]] +version = "1.0.17" +criteria = "safe-to-deploy" + +[[exemptions.ecdsa]] +version = "0.16.9" +criteria = "safe-to-deploy" + +[[exemptions.ed25519]] +version = "1.4.1" +criteria = "safe-to-deploy" + +[[exemptions.ed25519-dalek]] +version = "1.0.1" +criteria = "safe-to-deploy" + +[[exemptions.educe]] +version = "0.4.23" +criteria = "safe-to-deploy" + +[[exemptions.elliptic-curve]] +version = "0.13.8" +criteria = "safe-to-deploy" + +[[exemptions.enum-ordinalize]] +version = "3.1.15" +criteria = "safe-to-deploy" + +[[exemptions.event-listener]] +version = "3.1.0" criteria = "safe-to-deploy" [[exemptions.fallible-iterator]] @@ -256,16 +464,32 @@ criteria = "safe-to-deploy" version = "0.4.2" criteria = "safe-to-deploy" +[[exemptions.flate2]] +version = "1.0.30" +criteria = "safe-to-deploy" + +[[exemptions.fluid-let]] +version = "1.0.0" +criteria = "safe-to-deploy" + [[exemptions.fpe]] version = "0.6.1" criteria = "safe-to-deploy" +[[exemptions.fs-mistrust]] +version = "0.7.11" +criteria = "safe-to-deploy" + +[[exemptions.fslock]] +version = "0.2.1" +criteria = "safe-to-deploy" + [[exemptions.funty]] version = "2.0.0" criteria = "safe-to-deploy" [[exemptions.futures-macro]] -version = "0.3.29" +version = "0.3.21" criteria = "safe-to-deploy" [[exemptions.futures-sink]] @@ -277,13 +501,17 @@ version = "0.3.29" criteria = "safe-to-deploy" [[exemptions.futures-util]] -version = "0.3.29" +version = "0.3.21" criteria = "safe-to-deploy" [[exemptions.generic-array]] version = "0.14.7" criteria = "safe-to-deploy" +[[exemptions.getrandom]] +version = "0.1.16" +criteria = "safe-to-deploy" + [[exemptions.getrandom]] version = "0.2.11" criteria = "safe-to-deploy" @@ -292,6 +520,10 @@ criteria = "safe-to-deploy" version = "0.28.1" criteria = "safe-to-deploy" +[[exemptions.glob-match]] +version = "0.2.1" +criteria = "safe-to-deploy" + [[exemptions.group]] version = "0.13.0" criteria = "safe-to-deploy" @@ -320,10 +552,22 @@ criteria = "safe-to-deploy" version = "0.3.3" criteria = "safe-to-deploy" +[[exemptions.hkdf]] +version = "0.12.4" +criteria = "safe-to-deploy" + [[exemptions.home]] version = "0.5.5" criteria = "safe-to-deploy" +[[exemptions.hostname-validator]] +version = "1.1.1" +criteria = "safe-to-deploy" + +[[exemptions.http]] +version = "0.2.8" +criteria = "safe-to-deploy" + [[exemptions.http]] version = "1.1.0" criteria = "safe-to-deploy" @@ -332,8 +576,16 @@ criteria = "safe-to-deploy" version = "1.8.0" criteria = "safe-to-deploy" +[[exemptions.humantime]] +version = "2.1.0" +criteria = "safe-to-deploy" + +[[exemptions.humantime-serde]] +version = "1.1.1" +criteria = "safe-to-deploy" + [[exemptions.hyper]] -version = "1.4.1" +version = "1.3.1" criteria = "safe-to-deploy" [[exemptions.hyper-timeout]] @@ -341,7 +593,11 @@ version = "0.4.1" criteria = "safe-to-deploy" [[exemptions.hyper-util]] -version = "0.1.6" +version = "0.1.5" +criteria = "safe-to-deploy" + +[[exemptions.iana-time-zone]] +version = "0.1.60" criteria = "safe-to-deploy" [[exemptions.indexmap]] @@ -360,9 +616,17 @@ criteria = "safe-to-run" version = "0.10.5" criteria = "safe-to-deploy" +[[exemptions.itertools]] +version = "0.11.0" +criteria = "safe-to-deploy" + +[[exemptions.jobserver]] +version = "0.1.31" +criteria = "safe-to-deploy" + [[exemptions.js-sys]] version = "0.3.65" -criteria = "safe-to-run" +criteria = "safe-to-deploy" [[exemptions.jubjub]] version = "0.10.0" @@ -376,6 +640,10 @@ criteria = "safe-to-deploy" version = "0.2.2" criteria = "safe-to-deploy" +[[exemptions.libredox]] +version = "0.0.1" +criteria = "safe-to-deploy" + [[exemptions.libsqlite3-sys]] version = "0.26.0" criteria = "safe-to-deploy" @@ -385,8 +653,12 @@ version = "0.4.12" criteria = "safe-to-deploy" [[exemptions.lock_api]] -version = "0.4.11" -criteria = "safe-to-run" +version = "0.4.12" +criteria = "safe-to-deploy" + +[[exemptions.lzma-sys]] +version = "0.1.20" +criteria = "safe-to-deploy" [[exemptions.matchit]] version = "0.7.3" @@ -396,10 +668,18 @@ criteria = "safe-to-deploy" version = "2.6.4" criteria = "safe-to-deploy" +[[exemptions.memmap2]] +version = "0.5.4" +criteria = "safe-to-deploy" + [[exemptions.memuse]] version = "0.2.1" criteria = "safe-to-deploy" +[[exemptions.merlin]] +version = "2.0.1" +criteria = "safe-to-deploy" + [[exemptions.mime]] version = "0.3.17" criteria = "safe-to-deploy" @@ -424,6 +704,10 @@ criteria = "safe-to-deploy" version = "0.7.0" criteria = "safe-to-deploy" +[[exemptions.num-bigint-dig]] +version = "0.8.4" +criteria = "safe-to-deploy" + [[exemptions.num-format]] version = "0.4.4" criteria = "safe-to-run" @@ -440,22 +724,78 @@ criteria = "safe-to-deploy" version = "1.18.0" criteria = "safe-to-deploy" +[[exemptions.option-ext]] +version = "0.2.0" +criteria = "safe-to-deploy" + +[[exemptions.ordered-float]] +version = "2.10.1" +criteria = "safe-to-deploy" + +[[exemptions.p256]] +version = "0.13.2" +criteria = "safe-to-deploy" + +[[exemptions.p384]] +version = "0.13.0" +criteria = "safe-to-deploy" + +[[exemptions.p521]] +version = "0.13.3" +criteria = "safe-to-deploy" + [[exemptions.pairing]] version = "0.23.0" criteria = "safe-to-deploy" +[[exemptions.parking]] +version = "2.2.0" +criteria = "safe-to-deploy" + +[[exemptions.parking_lot]] +version = "0.12.2" +criteria = "safe-to-deploy" + [[exemptions.parking_lot_core]] -version = "0.9.9" -criteria = "safe-to-run" +version = "0.9.10" +criteria = "safe-to-deploy" [[exemptions.pasta_curves]] version = "0.5.1" criteria = "safe-to-deploy" +[[exemptions.paste]] +version = "1.0.15" +criteria = "safe-to-deploy" + +[[exemptions.pathdiff]] +version = "0.2.1" +criteria = "safe-to-deploy" + +[[exemptions.pem-rfc7468]] +version = "0.7.0" +criteria = "safe-to-deploy" + [[exemptions.petgraph]] version = "0.6.5" criteria = "safe-to-deploy" +[[exemptions.phf]] +version = "0.8.0" +criteria = "safe-to-deploy" + +[[exemptions.phf_generator]] +version = "0.8.0" +criteria = "safe-to-deploy" + +[[exemptions.phf_macros]] +version = "0.10.0" +criteria = "safe-to-deploy" + +[[exemptions.phf_shared]] +version = "0.8.0" +criteria = "safe-to-deploy" + [[exemptions.pin-project]] version = "1.1.5" criteria = "safe-to-deploy" @@ -464,6 +804,14 @@ criteria = "safe-to-deploy" version = "1.1.3" criteria = "safe-to-deploy" +[[exemptions.pkcs1]] +version = "0.7.5" +criteria = "safe-to-deploy" + +[[exemptions.pkcs8]] +version = "0.10.2" +criteria = "safe-to-deploy" + [[exemptions.plotters]] version = "0.3.5" criteria = "safe-to-run" @@ -480,6 +828,10 @@ criteria = "safe-to-run" version = "0.8.0" criteria = "safe-to-deploy" +[[exemptions.postage]] +version = "0.5.0" +criteria = "safe-to-deploy" + [[exemptions.pprof]] version = "0.13.0" criteria = "safe-to-run" @@ -492,10 +844,22 @@ criteria = "safe-to-deploy" version = "0.2.15" criteria = "safe-to-deploy" +[[exemptions.primeorder]] +version = "0.13.6" +criteria = "safe-to-deploy" + [[exemptions.primitive-types]] version = "0.12.2" criteria = "safe-to-deploy" +[[exemptions.priority-queue]] +version = "1.4.0" +criteria = "safe-to-deploy" + +[[exemptions.proc-macro-crate]] +version = "1.2.1" +criteria = "safe-to-deploy" + [[exemptions.proptest]] version = "1.3.1" criteria = "safe-to-deploy" @@ -516,6 +880,10 @@ criteria = "safe-to-deploy" version = "0.13.1" criteria = "safe-to-deploy" +[[exemptions.pwd-grp]] +version = "0.1.1" +criteria = "safe-to-deploy" + [[exemptions.quick-error]] version = "1.2.3" criteria = "safe-to-deploy" @@ -528,34 +896,78 @@ criteria = "safe-to-run" version = "0.7.0" criteria = "safe-to-deploy" +[[exemptions.rand]] +version = "0.7.3" +criteria = "safe-to-deploy" + [[exemptions.rand]] version = "0.8.5" criteria = "safe-to-deploy" +[[exemptions.rand_chacha]] +version = "0.2.2" +criteria = "safe-to-deploy" + +[[exemptions.rand_core]] +version = "0.5.1" +criteria = "safe-to-deploy" + +[[exemptions.rand_hc]] +version = "0.2.0" +criteria = "safe-to-deploy" + [[exemptions.reddsa]] version = "0.5.1" criteria = "safe-to-deploy" [[exemptions.redox_syscall]] -version = "0.4.1" -criteria = "safe-to-run" +version = "0.5.1" +criteria = "safe-to-deploy" + +[[exemptions.redox_users]] +version = "0.4.3" +criteria = "safe-to-deploy" [[exemptions.regex]] version = "1.10.2" criteria = "safe-to-deploy" +[[exemptions.regex-automata]] +version = "0.1.10" +criteria = "safe-to-deploy" + [[exemptions.regex-automata]] version = "0.4.3" criteria = "safe-to-deploy" +[[exemptions.regex-syntax]] +version = "0.6.26" +criteria = "safe-to-deploy" + [[exemptions.regex-syntax]] version = "0.7.5" criteria = "safe-to-deploy" +[[exemptions.retain_mut]] +version = "0.1.9" +criteria = "safe-to-deploy" + +[[exemptions.retry-error]] +version = "0.5.3" +criteria = "safe-to-deploy" + +[[exemptions.rfc6979]] +version = "0.4.0" +criteria = "safe-to-deploy" + [[exemptions.rgb]] version = "0.8.37" criteria = "safe-to-run" +[[exemptions.ring]] +version = "0.16.12" +criteria = "safe-to-deploy" + [[exemptions.ring]] version = "0.17.8" criteria = "safe-to-deploy" @@ -564,10 +976,18 @@ criteria = "safe-to-deploy" version = "0.1.3" criteria = "safe-to-deploy" +[[exemptions.rsa]] +version = "0.9.6" +criteria = "safe-to-deploy" + [[exemptions.rusqlite]] version = "0.29.0" criteria = "safe-to-deploy" +[[exemptions.rust_decimal]] +version = "1.35.0" +criteria = "safe-to-deploy" + [[exemptions.rustix]] version = "0.38.34" criteria = "safe-to-deploy" @@ -585,8 +1005,20 @@ version = "0.3.0" criteria = "safe-to-deploy" [[exemptions.ryu]] -version = "1.0.15" -criteria = "safe-to-run" +version = "1.0.18" +criteria = "safe-to-deploy" + +[[exemptions.safelog]] +version = "0.3.7" +criteria = "safe-to-deploy" + +[[exemptions.same-file]] +version = "1.0.6" +criteria = "safe-to-deploy" + +[[exemptions.sanitize-filename]] +version = "0.5.0" +criteria = "safe-to-deploy" [[exemptions.schemer]] version = "0.2.1" @@ -596,10 +1028,18 @@ criteria = "safe-to-deploy" version = "0.2.2" criteria = "safe-to-deploy" +[[exemptions.scopeguard]] +version = "1.1.0" +criteria = "safe-to-deploy" + [[exemptions.sct]] version = "0.7.1" criteria = "safe-to-deploy" +[[exemptions.sec1]] +version = "0.7.3" +criteria = "safe-to-deploy" + [[exemptions.secp256k1]] version = "0.26.0" criteria = "safe-to-deploy" @@ -612,14 +1052,62 @@ criteria = "safe-to-deploy" version = "0.8.0" criteria = "safe-to-deploy" +[[exemptions.serde-value]] +version = "0.7.0" +criteria = "safe-to-deploy" + +[[exemptions.serde_ignored]] +version = "0.1.10" +criteria = "safe-to-deploy" + +[[exemptions.serde_json]] +version = "1.0.117" +criteria = "safe-to-deploy" + +[[exemptions.serde_spanned]] +version = "0.6.6" +criteria = "safe-to-deploy" + +[[exemptions.serde_with]] +version = "3.8.1" +criteria = "safe-to-deploy" + +[[exemptions.serde_with_macros]] +version = "3.8.1" +criteria = "safe-to-deploy" + +[[exemptions.sha2]] +version = "0.9.9" +criteria = "safe-to-deploy" + [[exemptions.sha2]] version = "0.10.8" criteria = "safe-to-deploy" +[[exemptions.shellexpand]] +version = "3.1.0" +criteria = "safe-to-deploy" + +[[exemptions.signature]] +version = "1.6.4" +criteria = "safe-to-deploy" + +[[exemptions.simple_asn1]] +version = "0.6.2" +criteria = "safe-to-deploy" + +[[exemptions.siphasher]] +version = "0.3.10" +criteria = "safe-to-deploy" + [[exemptions.slab]] version = "0.4.9" criteria = "safe-to-deploy" +[[exemptions.slotmap]] +version = "1.0.7" +criteria = "safe-to-deploy" + [[exemptions.smallvec]] version = "1.11.1" criteria = "safe-to-deploy" @@ -636,10 +1124,30 @@ criteria = "safe-to-deploy" version = "0.9.8" criteria = "safe-to-deploy" +[[exemptions.spki]] +version = "0.7.3" +criteria = "safe-to-deploy" + +[[exemptions.ssh-cipher]] +version = "0.2.0" +criteria = "safe-to-deploy" + +[[exemptions.ssh-encoding]] +version = "0.2.0" +criteria = "safe-to-deploy" + +[[exemptions.ssh-key]] +version = "0.6.6" +criteria = "safe-to-deploy" + [[exemptions.str_stack]] version = "0.1.0" criteria = "safe-to-run" +[[exemptions.strsim]] +version = "0.11.1" +criteria = "safe-to-deploy" + [[exemptions.symbolic-common]] version = "12.9.2" criteria = "safe-to-run" @@ -648,6 +1156,10 @@ criteria = "safe-to-run" version = "12.9.2" criteria = "safe-to-run" +[[exemptions.syn]] +version = "1.0.96" +criteria = "safe-to-deploy" + [[exemptions.syn]] version = "2.0.53" criteria = "safe-to-deploy" @@ -676,6 +1188,14 @@ criteria = "safe-to-deploy" version = "0.7.10" criteria = "safe-to-deploy" +[[exemptions.toml]] +version = "0.5.7" +criteria = "safe-to-deploy" + +[[exemptions.toml_edit]] +version = "0.19.15" +criteria = "safe-to-deploy" + [[exemptions.tonic]] version = "0.12.0" criteria = "safe-to-deploy" @@ -684,6 +1204,114 @@ criteria = "safe-to-deploy" version = "0.10.2" criteria = "safe-to-deploy" +[[exemptions.tor-async-utils]] +version = "0.1.5" +criteria = "safe-to-deploy" + +[[exemptions.tor-basic-utils]] +version = "0.8.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-bytes]] +version = "0.7.5" +criteria = "safe-to-deploy" + +[[exemptions.tor-cell]] +version = "0.13.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-cert]] +version = "0.8.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-chanmgr]] +version = "0.11.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-checkable]] +version = "0.5.5" +criteria = "safe-to-deploy" + +[[exemptions.tor-circmgr]] +version = "0.12.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-config]] +version = "0.9.7" +criteria = "safe-to-deploy" + +[[exemptions.tor-consdiff]] +version = "0.5.6" +criteria = "safe-to-deploy" + +[[exemptions.tor-dirclient]] +version = "0.10.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-dirmgr]] +version = "0.12.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-error]] +version = "0.5.5" +criteria = "safe-to-deploy" + +[[exemptions.tor-guardmgr]] +version = "0.11.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-hscrypto]] +version = "0.3.4" +criteria = "safe-to-deploy" + +[[exemptions.tor-keymgr]] +version = "0.4.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-linkspec]] +version = "0.8.4" +criteria = "safe-to-deploy" + +[[exemptions.tor-llcrypto]] +version = "0.5.6" +criteria = "safe-to-deploy" + +[[exemptions.tor-netdir]] +version = "0.9.6" +criteria = "safe-to-deploy" + +[[exemptions.tor-netdoc]] +version = "0.9.1" +criteria = "safe-to-deploy" + +[[exemptions.tor-persist]] +version = "0.7.4" +criteria = "safe-to-deploy" + +[[exemptions.tor-proto]] +version = "0.13.0" +criteria = "safe-to-deploy" + +[[exemptions.tor-protover]] +version = "0.5.4" +criteria = "safe-to-deploy" + +[[exemptions.tor-rtcompat]] +version = "0.9.7" +criteria = "safe-to-deploy" + +[[exemptions.tor-rtmock]] +version = "0.11.1" +criteria = "safe-to-deploy" + +[[exemptions.tor-socksproto]] +version = "0.7.5" +criteria = "safe-to-deploy" + +[[exemptions.tor-units]] +version = "0.6.5" +criteria = "safe-to-deploy" + [[exemptions.tower]] version = "0.4.13" criteria = "safe-to-deploy" @@ -708,6 +1336,22 @@ criteria = "safe-to-deploy" version = "0.1.32" criteria = "safe-to-deploy" +[[exemptions.tracing-log]] +version = "0.2.0" +criteria = "safe-to-deploy" + +[[exemptions.tracing-test]] +version = "0.2.5" +criteria = "safe-to-deploy" + +[[exemptions.tracing-test-macro]] +version = "0.2.5" +criteria = "safe-to-deploy" + +[[exemptions.typed-index-collections]] +version = "3.1.0" +criteria = "safe-to-deploy" + [[exemptions.typenum]] version = "1.17.0" criteria = "safe-to-deploy" @@ -733,49 +1377,89 @@ version = "0.2.0" criteria = "safe-to-deploy" [[exemptions.walkdir]] -version = "2.4.0" -criteria = "safe-to-run" +version = "2.5.0" +criteria = "safe-to-deploy" + +[[exemptions.wasi]] +version = "0.9.0+wasi-snapshot-preview1" +criteria = "safe-to-deploy" [[exemptions.wasi]] version = "0.11.0+wasi-snapshot-preview1" criteria = "safe-to-deploy" +[[exemptions.wasix]] +version = "0.12.21" +criteria = "safe-to-deploy" + [[exemptions.wasm-bindgen]] version = "0.2.92" -criteria = "safe-to-run" +criteria = "safe-to-deploy" [[exemptions.wasm-bindgen-backend]] version = "0.2.88" -criteria = "safe-to-run" +criteria = "safe-to-deploy" [[exemptions.wasm-bindgen-macro]] version = "0.2.88" -criteria = "safe-to-run" +criteria = "safe-to-deploy" + +[[exemptions.weak-table]] +version = "0.3.2" +criteria = "safe-to-deploy" [[exemptions.web-sys]] version = "0.3.65" -criteria = "safe-to-run" +criteria = "safe-to-deploy" [[exemptions.which]] version = "4.4.2" criteria = "safe-to-deploy" +[[exemptions.winapi]] +version = "0.3.9" +criteria = "safe-to-deploy" + [[exemptions.winapi-i686-pc-windows-gnu]] version = "0.4.0" -criteria = "safe-to-run" +criteria = "safe-to-deploy" + +[[exemptions.winapi-util]] +version = "0.1.8" +criteria = "safe-to-deploy" [[exemptions.winapi-x86_64-pc-windows-gnu]] version = "0.4.0" -criteria = "safe-to-run" +criteria = "safe-to-deploy" + +[[exemptions.windows-core]] +version = "0.52.0" +criteria = "safe-to-deploy" + +[[exemptions.winnow]] +version = "0.5.40" +criteria = "safe-to-deploy" [[exemptions.wyz]] version = "0.5.1" criteria = "safe-to-deploy" +[[exemptions.x25519-dalek]] +version = "2.0.0-pre.1" +criteria = "safe-to-deploy" + +[[exemptions.x509-signature]] +version = "0.5.0" +criteria = "safe-to-deploy" + [[exemptions.xdg]] version = "2.5.2" criteria = "safe-to-deploy" +[[exemptions.xz2]] +version = "0.1.7" +criteria = "safe-to-deploy" + [[exemptions.zeroize]] version = "1.6.0" criteria = "safe-to-deploy" @@ -783,3 +1467,15 @@ criteria = "safe-to-deploy" [[exemptions.zeroize_derive]] version = "1.4.2" criteria = "safe-to-deploy" + +[[exemptions.zstd]] +version = "0.13.1" +criteria = "safe-to-deploy" + +[[exemptions.zstd-safe]] +version = "7.1.0" +criteria = "safe-to-deploy" + +[[exemptions.zstd-sys]] +version = "2.0.10+zstd.1.5.6" +criteria = "safe-to-deploy" diff --git a/supply-chain/imports.lock b/supply-chain/imports.lock index aca7af703..c5a1a15fa 100644 --- a/supply-chain/imports.lock +++ b/supply-chain/imports.lock @@ -8,6 +8,13 @@ user-id = 696 user-login = "fitzgen" user-name = "Nick Fitzgerald" +[[publisher.core-foundation-sys]] +version = "0.8.4" +when = "2023-04-03" +user-id = 5946 +user-login = "jrmuizel" +user-name = "Jeff Muizelaar" + [[publisher.equihash]] version = "0.2.0" when = "2022-06-24" @@ -344,11 +351,34 @@ criteria = "safe-to-deploy" version = "0.2.4" notes = "A few tiny blocks of `unsafe` but each of them is very obviously correct." +[[audits.bytecode-alliance.audits.core-foundation-sys]] +who = "Dan Gohman " +criteria = "safe-to-deploy" +delta = "0.8.4 -> 0.8.6" +notes = """ +The changes here are all typical bindings updates: new functions, types, and +constants. I have not audited all the bindings for ABI conformance. +""" + [[audits.bytecode-alliance.audits.crypto-common]] who = "Benjamin Bouvier " criteria = "safe-to-deploy" version = "0.1.3" +[[audits.bytecode-alliance.audits.digest]] +who = "Benjamin Bouvier " +criteria = "safe-to-deploy" +delta = "0.9.0 -> 0.10.3" + +[[audits.bytecode-alliance.audits.ed25519]] +who = "Alex Crichton " +criteria = "safe-to-deploy" +delta = "1.4.1 -> 1.5.3" +notes = """ +This diff brings in a number of minor updates of which none are related to +`unsafe` code or anything system-related like filesystems. +""" + [[audits.bytecode-alliance.audits.errno]] who = "Dan Gohman " criteria = "safe-to-deploy" @@ -382,6 +412,23 @@ criteria = "safe-to-deploy" version = "0.3.27" notes = "Unsafe used to implement a concurrency primitive AtomicWaker. Well-commented and not obviously incorrect. Like my other audits of these concurrency primitives inside the futures family, I couldn't certify that it is correct without formal methods, but that is out of scope for this vetting." +[[audits.bytecode-alliance.audits.futures-executor]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.3.27" +notes = "Unsafe used to implement the unpark mutex, which is well commented and not obviously incorrect. Like with futures-channel I wouldn't be able to certify it as correct without formal methods." + +[[audits.bytecode-alliance.audits.futures-io]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.3.27" + +[[audits.bytecode-alliance.audits.http]] +who = "Alex Crichton " +criteria = "safe-to-deploy" +delta = "0.2.9 -> 1.0.0" +notes = "Minor changes leading up to the 1.0.0 release and nothing fundamentally new here." + [[audits.bytecode-alliance.audits.http-body]] who = "Pat Hickey " criteria = "safe-to-deploy" @@ -405,6 +452,20 @@ criteria = "safe-to-deploy" delta = "0.1.0-rc.2 -> 0.1.0" notes = "Minor documentation updates an additions, nothing major." +[[audits.bytecode-alliance.audits.iana-time-zone-haiku]] +who = "Dan Gohman " +criteria = "safe-to-deploy" +version = "0.1.2" + +[[audits.bytecode-alliance.audits.itertools]] +who = "Nick Fitzgerald " +criteria = "safe-to-deploy" +delta = "0.10.5 -> 0.12.1" +notes = """ +Minimal `unsafe` usage. Few blocks that existed looked reasonable. Does what it +says on the tin: lots of iterators. +""" + [[audits.bytecode-alliance.audits.libm]] who = "Alex Crichton " criteria = "safe-to-deploy" @@ -424,6 +485,11 @@ This is a minor update which has some testing affordances as well as some updated math algorithms. """ +[[audits.bytecode-alliance.audits.matchers]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.1.0" + [[audits.bytecode-alliance.audits.miniz_oxide]] who = "Alex Crichton " criteria = "safe-to-deploy" @@ -438,6 +504,18 @@ its own longevity should be relatively hardened against some of the more common compression-related issues. """ +[[audits.bytecode-alliance.audits.nu-ansi-term]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.46.0" +notes = "one use of unsafe to call windows specific api to get console handle." + +[[audits.bytecode-alliance.audits.overload]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.1.1" +notes = "small crate, only defines macro-rules!, nicely documented as well" + [[audits.bytecode-alliance.audits.percent-encoding]] who = "Alex Crichton " criteria = "safe-to-deploy" @@ -474,6 +552,40 @@ criteria = "safe-to-deploy" version = "0.1.21" notes = "I am the author of this crate." +[[audits.bytecode-alliance.audits.semver]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "1.0.17" +notes = "plenty of unsafe pointer and vec tricks, but in well-structured and commented code that appears to be correct" + +[[audits.bytecode-alliance.audits.sharded-slab]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.1.4" +notes = "I always really enjoy reading eliza's code, she left perfect comments at every use of unsafe." + +[[audits.bytecode-alliance.audits.signal-hook-registry]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "1.4.1" + +[[audits.bytecode-alliance.audits.thread_local]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "1.1.4" +notes = "uses unsafe to implement thread local storage of objects" + +[[audits.bytecode-alliance.audits.tokio-rustls]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.24.0" +notes = "no unsafe, no build, no ambient capabilities" + +[[audits.bytecode-alliance.audits.tracing-subscriber]] +who = "Pat Hickey " +criteria = "safe-to-deploy" +version = "0.3.17" + [[audits.bytecode-alliance.audits.try-lock]] who = "Pat Hickey " criteria = "safe-to-deploy" @@ -512,6 +624,58 @@ criteria = "safe-to-deploy" version = "1.0.0" notes = "No unsafe usage or ambient capabilities" +[[audits.embark-studios.audits.convert_case]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.4.0" +notes = "No unsafe usage or ambient capabilities" + +[[audits.embark-studios.audits.derive_more]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.99.17" +notes = "No unsafe usage or ambient capabilities" + +[[audits.embark-studios.audits.ident_case]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "1.0.1" +notes = "No unsafe usage or ambient capabilities" + +[[audits.embark-studios.audits.num_enum]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.5.11" +notes = "No unsafe usage or ambient capabilities" + +[[audits.embark-studios.audits.num_enum]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +delta = "0.5.11 -> 0.6.1" +notes = "Minor changes" + +[[audits.embark-studios.audits.num_enum]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +delta = "0.6.1 -> 0.7.0" + +[[audits.embark-studios.audits.num_enum_derive]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.5.11" +notes = "Proc macro that generates some unsafe code for conversion but looks sound, no ambient capabilities" + +[[audits.embark-studios.audits.num_enum_derive]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +delta = "0.5.11 -> 0.6.1" +notes = "Minor changes" + +[[audits.embark-studios.audits.num_enum_derive]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +delta = "0.6.1 -> 0.7.0" + [[audits.embark-studios.audits.tap]] who = "Johan Andersson " criteria = "safe-to-deploy" @@ -530,12 +694,30 @@ criteria = "safe-to-deploy" version = "1.0.40" notes = "Found no unsafe or ambient capabilities used" +[[audits.embark-studios.audits.toml]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.7.4" +notes = "No unsafe usage or ambient capabilities" + +[[audits.embark-studios.audits.toml_datetime]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +delta = "0.6.1 -> 0.6.2" +notes = "No notable changes" + [[audits.embark-studios.audits.utf8parse]] who = "Johan Andersson " criteria = "safe-to-deploy" version = "0.2.1" notes = "Single unsafe usage that looks sound, no ambient capabilities" +[[audits.embark-studios.audits.valuable]] +who = "Johan Andersson " +criteria = "safe-to-deploy" +version = "0.1.0" +notes = "No unsafe usage or ambient capabilities, sane build script" + [[audits.embark-studios.audits.webpki-roots]] who = "Johan Andersson " criteria = "safe-to-deploy" @@ -746,6 +928,16 @@ that the RNG here is not cryptographically secure. """ aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" +[[audits.google.audits.futures]] +who = "George Burgess IV " +criteria = "safe-to-deploy" +version = "0.3.28" +notes = """ +`futures` has no logic other than tests - it simply `pub use`s things from +other crates. +""" +aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" + [[audits.google.audits.heck]] who = "Lukasz Anforowicz " criteria = "safe-to-deploy" @@ -777,6 +969,12 @@ criteria = "safe-to-run" delta = "0.4.2 -> 0.4.9" aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" +[[audits.google.audits.itertools]] +who = "ChromeOS" +criteria = "safe-to-run" +version = "0.10.5" +aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" + [[audits.google.audits.itoa]] who = "Lukasz Anforowicz " criteria = "safe-to-deploy" @@ -806,12 +1004,6 @@ Straightforward diff between 1.0.10 and 1.0.11 - only 3 commits: """ aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" -[[audits.google.audits.memmap2]] -who = "Ying Hsu " -criteria = "safe-to-run" -version = "0.8.0" -aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" - [[audits.google.audits.nix]] who = "David Koloski " criteria = "safe-to-run" @@ -841,16 +1033,10 @@ Reviewed in https://chromium-review.googlesource.com/c/chromium/src/+/5046153 """ aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" -[[audits.google.audits.parking_lot]] +[[audits.google.audits.num-iter]] who = "George Burgess IV " -criteria = "safe-to-run" -version = "0.11.2" -aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" - -[[audits.google.audits.parking_lot]] -who = "George Burgess IV " -criteria = "safe-to-run" -delta = "0.11.2 -> 0.12.1" +criteria = "safe-to-deploy" +version = "0.1.43" aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" [[audits.google.audits.pin-project-lite]] @@ -935,6 +1121,16 @@ criteria = "safe-to-deploy" delta = "1.0.35 -> 1.0.36" aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" +[[audits.google.audits.ring]] +who = "Laura Peskin " +criteria = "safe-to-deploy" +delta = "0.16.12 -> 0.16.20" +notes = """ +Reviewed on: https://fxrev.dev/923001 (0.16.13 -> 0.16.20) +Reviewed on: https://fxrev.dev/716624 (0.16.12 -> 0.16.13) +""" +aggregated-from = "https://fuchsia.googlesource.com/fuchsia/+/refs/heads/main/third_party/rust_crates/supply-chain/audits.toml?format=TEXT" + [[audits.google.audits.rustversion]] who = "Lukasz Anforowicz " criteria = "safe-to-deploy" @@ -970,18 +1166,6 @@ criteria = "safe-to-deploy" delta = "1.0.14 -> 1.0.15" aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" -[[audits.google.audits.same-file]] -who = "Android Legacy" -criteria = "safe-to-run" -version = "1.0.6" -aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" - -[[audits.google.audits.scopeguard]] -who = "Android Legacy" -criteria = "safe-to-run" -version = "1.1.0" -aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" - [[audits.google.audits.serde]] who = "Lukasz Anforowicz " criteria = "safe-to-deploy" @@ -1024,16 +1208,12 @@ criteria = "safe-to-deploy" delta = "1.0.197 -> 1.0.201" aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" -[[audits.google.audits.serde_json]] -who = "danakj@chromium.org" -criteria = "safe-to-run" -version = "1.0.108" -notes = """ -Reviewed in https://crrev.com/c/5171063 - -Previously reviewed during security review and the audit is grandparented in. -""" -aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" +[[audits.google.audits.sha1]] +who = "David Koloski " +criteria = "safe-to-deploy" +version = "0.10.5" +notes = "Reviewed on https://fxrev.dev/712371." +aggregated-from = "https://fuchsia.googlesource.com/fuchsia/+/refs/heads/main/third_party/rust_crates/supply-chain/audits.toml?format=TEXT" [[audits.google.audits.stable_deref_trait]] who = "George Burgess IV " @@ -1059,15 +1239,31 @@ description contains a link to a document with an additional security review. aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" [[audits.google.audits.strsim]] -who = "George Burgess IV " -criteria = "safe-to-run" -version = "0.10.0" -aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" - -[[audits.google.audits.syn]] who = "danakj@chromium.org" -criteria = "safe-to-run" -version = "1.0.109" +criteria = "safe-to-deploy" +version = "0.10.0" +notes = """ +Reviewed in https://crrev.com/c/5171063 + +Previously reviewed during security review and the audit is grandparented in. +""" +aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" + +[[audits.google.audits.strum]] +who = "danakj@chromium.org" +criteria = "safe-to-deploy" +version = "0.25.0" +notes = """ +Reviewed in https://crrev.com/c/5171063 + +Previously reviewed during security review and the audit is grandparented in. +""" +aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" + +[[audits.google.audits.strum_macros]] +who = "danakj@chromium.org" +criteria = "safe-to-deploy" +version = "0.25.3" notes = """ Reviewed in https://crrev.com/c/5171063 @@ -1144,27 +1340,11 @@ criteria = "safe-to-deploy" version = "0.9.4" aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" -[[audits.google.audits.winapi]] -who = "danakj@chromium.org" -criteria = "safe-to-run" -version = "0.3.9" -notes = """ -Reviewed in https://crrev.com/c/5171063 - -Previously reviewed during security review and the audit is grandparented in. -""" -aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" - -[[audits.google.audits.winapi-util]] -who = "danakj@chromium.org" -criteria = "safe-to-run" -version = "0.1.6" -notes = """ -Reviewed in https://crrev.com/c/5171063 - -Previously reviewed during security review and the audit is grandparented in. -""" -aggregated-from = "https://chromium.googlesource.com/chromium/src/+/main/third_party/rust/chromium_crates_io/supply-chain/audits.toml?format=TEXT" +[[audits.google.audits.void]] +who = "George Burgess IV " +criteria = "safe-to-deploy" +version = "1.0.2" +aggregated-from = "https://chromium.googlesource.com/chromiumos/third_party/rust_crates/+/refs/heads/main/cargo-vet/audits.toml?format=TEXT" [[audits.isrg.audits.aes]] who = "Tim Geoghegan " @@ -1206,6 +1386,11 @@ who = "David Cook " criteria = "safe-to-deploy" version = "0.2.2" +[[audits.isrg.audits.digest]] +who = "David Cook " +criteria = "safe-to-deploy" +delta = "0.10.6 -> 0.10.7" + [[audits.isrg.audits.either]] who = "David Cook " criteria = "safe-to-deploy" @@ -1231,6 +1416,21 @@ who = "David Cook " criteria = "safe-to-deploy" version = "0.12.1" +[[audits.isrg.audits.keccak]] +who = "David Cook " +criteria = "safe-to-deploy" +version = "0.1.2" + +[[audits.isrg.audits.keccak]] +who = "Brandon Pitman " +criteria = "safe-to-deploy" +delta = "0.1.2 -> 0.1.3" + +[[audits.isrg.audits.keccak]] +who = "Brandon Pitman " +criteria = "safe-to-deploy" +delta = "0.1.3 -> 0.1.4" + [[audits.isrg.audits.num-bigint]] who = "David Cook " criteria = "safe-to-deploy" @@ -1241,6 +1441,16 @@ who = "David Cook " criteria = "safe-to-deploy" delta = "0.1.45 -> 0.1.46" +[[audits.isrg.audits.num-iter]] +who = "David Cook " +criteria = "safe-to-deploy" +delta = "0.1.43 -> 0.1.44" + +[[audits.isrg.audits.num-iter]] +who = "David Cook " +criteria = "safe-to-deploy" +delta = "0.1.44 -> 0.1.45" + [[audits.isrg.audits.num-traits]] who = "David Cook " criteria = "safe-to-deploy" @@ -1311,6 +1521,21 @@ who = "Ameer Ghani " criteria = "safe-to-deploy" version = "1.12.1" +[[audits.isrg.audits.sha3]] +who = "David Cook " +criteria = "safe-to-deploy" +version = "0.10.6" + +[[audits.isrg.audits.sha3]] +who = "Brandon Pitman " +criteria = "safe-to-deploy" +delta = "0.10.6 -> 0.10.7" + +[[audits.isrg.audits.sha3]] +who = "Brandon Pitman " +criteria = "safe-to-deploy" +delta = "0.10.7 -> 0.10.8" + [[audits.isrg.audits.thiserror]] who = "Brandon Pitman " criteria = "safe-to-deploy" @@ -1331,17 +1556,51 @@ who = "David Cook " criteria = "safe-to-deploy" delta = "0.5.0 -> 0.5.1" +[[audits.isrg.audits.untrusted]] +who = "David Cook " +criteria = "safe-to-deploy" +version = "0.7.1" + [[audits.isrg.audits.wasm-bindgen-shared]] who = "David Cook " criteria = "safe-to-deploy" version = "0.2.83" +[[audits.mozilla.wildcard-audits.core-foundation-sys]] +who = "Bobby Holley " +criteria = "safe-to-deploy" +user-id = 5946 # Jeff Muizelaar (jrmuizel) +start = "2020-10-14" +end = "2023-05-04" +renew = false +notes = "I've reviewed every source contribution that was neither authored nor reviewed by Mozilla." +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.ahash]] who = "Erich Gubler " criteria = "safe-to-deploy" delta = "0.8.7 -> 0.8.11" aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.android_system_properties]] +who = "Nicolas Silva " +criteria = "safe-to-deploy" +version = "0.1.2" +notes = "I wrote this crate, reviewed by jimb. It is mostly a Rust port of some C++ code we already ship." +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.android_system_properties]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.1.2 -> 0.1.4" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.android_system_properties]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.1.4 -> 0.1.5" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.anyhow]] who = "Mike Hommey " criteria = "safe-to-deploy" @@ -1424,6 +1683,12 @@ delta = "0.5.11 -> 0.5.12" notes = "Minimal change fixing a memory leak." aggregated-from = "https://raw.githubusercontent.com/mozilla/glean/main/supply-chain/audits.toml" +[[audits.mozilla.audits.crossbeam-queue]] +who = "Matthew Gregan " +criteria = "safe-to-deploy" +version = "0.3.8" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.crypto-common]] who = "Mike Hommey " criteria = "safe-to-deploy" @@ -1448,6 +1713,29 @@ otherwise the unsafety is documented and left to the caller to verify. """ aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.digest]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.10.3 -> 0.10.6" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.displaydoc]] +who = "Makoto Kato " +criteria = "safe-to-deploy" +version = "0.2.3" +notes = """ +This crate is convenient macros to implement core::fmt::Display trait. +Although `unsafe` is used for test code to call `libc::abort()`, it has no `unsafe` code in this crate. And there is no file access. +It meets the criteria for safe-to-deploy. +""" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.displaydoc]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.2.3 -> 0.2.4" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.document-features]] who = "Erich Gubler " criteria = "safe-to-deploy" @@ -1503,6 +1791,66 @@ criteria = "safe-to-deploy" delta = "0.3.27 -> 0.3.28" aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.futures-executor]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.27 -> 0.3.28" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-io]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.27 -> 0.3.28" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-macro]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.21 -> 0.3.23" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-macro]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.23 -> 0.3.25" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-macro]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.25 -> 0.3.26" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-macro]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.26 -> 0.3.28" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-util]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.21 -> 0.3.23" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-util]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.23 -> 0.3.25" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-util]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.25 -> 0.3.26" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.futures-util]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.3.26 -> 0.3.28" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.half]] who = "John M. Schanck " criteria = "safe-to-deploy" @@ -1560,6 +1908,30 @@ delta = "0.4.18 -> 0.4.20" notes = "Only cfg attribute and internal macro changes and module refactorings" aggregated-from = "https://raw.githubusercontent.com/mozilla/glean/main/supply-chain/audits.toml" +[[audits.mozilla.audits.memmap2]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.5.4 -> 0.5.7" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.memmap2]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.5.7 -> 0.5.8" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.memmap2]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.5.8 -> 0.5.9" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.memmap2]] +who = "Gabriele Svelto " +criteria = "safe-to-deploy" +delta = "0.5.9 -> 0.8.0" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.memmap2]] who = "Mike Hommey " criteria = "safe-to-deploy" @@ -1609,6 +1981,12 @@ criteria = "safe-to-deploy" delta = "2.3.0 -> 2.3.1" aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.phf_macros]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.10.0 -> 0.11.2" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.pkg-config]] who = "Mike Hommey " criteria = "safe-to-deploy" @@ -1644,6 +2022,18 @@ criteria = "safe-to-deploy" delta = "1.5.3 -> 1.6.1" aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.regex-syntax]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.6.26 -> 0.6.27" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.regex-syntax]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.6.27 -> 0.6.28" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.serde]] who = "Erich Gubler " criteria = "safe-to-deploy" @@ -1657,6 +2047,18 @@ version = "2.5.0" notes = "The goal is to provide some constant-time correctness for cryptographic implementations. The approach is reasonable, it is known to be insufficient but this is pointed out in the documentation." aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.syn]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "1.0.96 -> 1.0.99" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.syn]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "1.0.99 -> 1.0.107" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.time]] who = "Alex Franchuk " criteria = "safe-to-deploy" @@ -1704,6 +2106,49 @@ criteria = "safe-to-deploy" delta = "0.2.10 -> 0.2.18" aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" +[[audits.mozilla.audits.tinystr]] +who = "Makoto Kato " +criteria = "safe-to-deploy" +version = "0.7.0" +notes = "One of original auther was Zibi Braniecki who worked at Mozilla and maintained by ICU4X developers (Google and Mozilla). I've vetted the one instance of unsafe code." +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.tinystr]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.7.0 -> 0.7.1" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.tinystr]] +who = "Makoto Kato " +criteria = "safe-to-deploy" +delta = "0.7.1 -> 0.7.4" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.tinystr]] +who = "Makoto Kato " +criteria = "safe-to-deploy" +delta = "0.7.4 -> 0.7.6" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.toml]] +who = "Bobby Holley " +criteria = "safe-to-deploy" +delta = "0.5.7 -> 0.5.9" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.toml]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.5.9 -> 0.5.10" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + +[[audits.mozilla.audits.toml]] +who = "Mike Hommey " +criteria = "safe-to-deploy" +delta = "0.5.10 -> 0.5.11" +aggregated-from = "https://hg.mozilla.org/mozilla-central/raw-file/tip/supply-chain/audits.toml" + [[audits.mozilla.audits.zerocopy]] who = "Alex Franchuk " criteria = "safe-to-deploy" @@ -1937,6 +2382,13 @@ criteria = "safe-to-deploy" delta = "0.9.17 -> 0.9.18" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.der]] +who = "Daira-Emma Hopwood " +criteria = "safe-to-deploy" +delta = "0.7.8 -> 0.7.9" +notes = "The change to ignore RUSTSEC-2023-0071 is correct for this crate." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.either]] who = "Jack Grigg " criteria = "safe-to-deploy" @@ -1994,27 +2446,30 @@ delta = "0.3.29 -> 0.3.30" notes = "Removes `build.rs` now that it can rely on the `target_has_atomic` attribute." aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" -[[audits.zcash.audits.futures-util]] -who = "Jack Grigg " -criteria = "safe-to-deploy" -delta = "0.3.29 -> 0.3.30" -notes = """ -- Removes `build.rs` now that it can rely on the `target_has_atomic` attribute. -- Almost all changes to `unsafe` blocks are to either move them around, or - replace them with safe method calls. -- One new `unsafe` block is added for a slice lifetime transmutation. The slice - reconstruction is obviously correct. AFAICT the lifetime transmutation is also - correct; the slice's lifetime logically comes from the `AsyncBufRead` reader - inside `FillBuf`, rather than the `Context`. -""" -aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" - [[audits.zcash.audits.hermit-abi]] who = "Daira-Emma Hopwood " criteria = "safe-to-deploy" delta = "0.3.3 -> 0.3.9" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.http]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.2.8 -> 0.2.9" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.http]] +who = "Daira-Emma Hopwood " +criteria = "safe-to-deploy" +delta = "0.2.11 -> 0.2.12" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.http]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.0.0 -> 0.2.11" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.inout]] who = "Daira Hopwood " criteria = "safe-to-deploy" @@ -2065,6 +2520,12 @@ delta = "0.2.7 -> 0.2.8" notes = "Forces some intermediate values to not have too much precision on the x87 FPU." aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.libredox]] +who = "Daira-Emma Hopwood " +criteria = "safe-to-deploy" +delta = "0.0.1 -> 0.1.3" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.linux-raw-sys]] who = "Daira-Emma Hopwood " criteria = "safe-to-deploy" @@ -2139,12 +2600,72 @@ criteria = "safe-to-deploy" delta = "0.3.0 -> 0.3.1" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.phf]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.8.0 -> 0.11.1" +notes = """ +Mostly modernisation, migrating to `PhfBorrow`, and making more things `&'static`. +No unsafe code in the new `OrderedMap` and `OrderedSet` types. +""" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.phf]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.11.1 -> 0.11.2" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.phf_generator]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.8.0 -> 0.11.1" +notes = "Just dependency and edition bumps and code formatting." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.phf_generator]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.11.1 -> 0.11.2" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.phf_shared]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.8.0 -> 0.11.1" +notes = """ +Adds `uncased` dependency, and newly generates unsafe code to transmute `&'static str` +into `&'static UncasedStr`. I verified that `UncasedStr` is a `#[repr(transparent)]` +newtype around `str`. +""" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.phf_shared]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.11.1 -> 0.11.2" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.pin-project-lite]] who = "Daira-Emma Hopwood " criteria = "safe-to-deploy" delta = "0.2.13 -> 0.2.14" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.proc-macro-crate]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.2.1 -> 1.3.0" +notes = "Migrates from `toml` to `toml_edit`." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.proc-macro-crate]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.3.0 -> 1.3.1" +notes = "Bumps MSRV to 1.60." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.rand_xorshift]] who = "Sean Bowe " criteria = "safe-to-deploy" @@ -2169,6 +2690,19 @@ https://research.nccgroup.com/wp-content/uploads/2020/07/NCC_Group_Zcash2018_Pub """ aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.redox_users]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.4.3 -> 0.4.4" +notes = "Switches from `redox_syscall` crate to `libredox` crate for syscalls." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.redox_users]] +who = "Daira-Emma Hopwood " +criteria = "safe-to-deploy" +delta = "0.4.4 -> 0.4.5" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.regex]] who = "Daira-Emma Hopwood " criteria = "safe-to-deploy" @@ -2181,6 +2715,12 @@ criteria = "safe-to-deploy" delta = "0.4.3 -> 0.4.6" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.regex-syntax]] +who = "Sean Bowe " +criteria = "safe-to-deploy" +delta = "0.6.28 -> 0.6.29" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.regex-syntax]] who = "Jack Grigg " criteria = "safe-to-deploy" @@ -2205,16 +2745,19 @@ criteria = "safe-to-deploy" delta = "0.1.22 -> 0.1.23" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" -[[audits.zcash.audits.ryu]] +[[audits.zcash.audits.rustc_version]] who = "Jack Grigg " criteria = "safe-to-deploy" -delta = "1.0.15 -> 1.0.16" -aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +version = "0.4.0" +notes = """ +Most of the crate is code to parse and validate the output of `rustc -vV`. The caller can +choose which `rustc` to use, or can use `rustc_version::{version, version_meta}` which will +try `$RUSTC` followed by `rustc`. -[[audits.zcash.audits.ryu]] -who = "Daira-Emma Hopwood " -criteria = "safe-to-deploy" -delta = "1.0.16 -> 1.0.17" +If an adversary can arbitrarily set the `$RUSTC` environment variable then this crate will +execute arbitrary code. But when this crate is used within a build script, `$RUSTC` should +be set correctly by `cargo`. +""" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" [[audits.zcash.audits.scopeguard]] @@ -2224,16 +2767,57 @@ delta = "1.1.0 -> 1.2.0" notes = "Only change to an `unsafe` block is to replace a `mem::forget` with `ManuallyDrop`." aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" -[[audits.zcash.audits.serde_json]] +[[audits.zcash.audits.semver]] who = "Jack Grigg " criteria = "safe-to-deploy" -delta = "1.0.108 -> 1.0.110" +delta = "1.0.17 -> 1.0.18" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" -[[audits.zcash.audits.serde_json]] +[[audits.zcash.audits.semver]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.0.18 -> 1.0.19" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.semver]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.0.19 -> 1.0.20" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.semver]] who = "Daira-Emma Hopwood " criteria = "safe-to-deploy" -delta = "1.0.110 -> 1.0.116" +delta = "1.0.20 -> 1.0.22" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.sharded-slab]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.1.4 -> 0.1.7" +notes = "Only change to an `unsafe` block is to fix a clippy lint." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.signature]] +who = "Daira Emma Hopwood " +criteria = "safe-to-deploy" +version = "2.1.0" +notes = """ +This crate uses `#![forbid(unsafe_code)]`, has no build script, and only provides traits with some trivial default implementations. +I did not review whether implementing these APIs would present any undocumented cryptographic hazards. +""" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.signature]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "2.1.0 -> 2.2.0" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.siphasher]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.3.10 -> 0.3.11" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" [[audits.zcash.audits.socket2]] @@ -2242,6 +2826,13 @@ criteria = "safe-to-deploy" delta = "0.5.5 -> 0.5.6" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.syn]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.0.107 -> 1.0.109" +notes = "Fixes string literal parsing to only skip specified whitespace characters." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.tempfile]] who = "Jack Grigg " criteria = "safe-to-deploy" @@ -2320,6 +2911,27 @@ criteria = "safe-to-deploy" delta = "1.0.56 -> 1.0.58" aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.thread_local]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "1.1.4 -> 1.1.7" +notes = """ +New `unsafe` usage: +- An extra `deallocate_bucket`, to replace a `Mutex::lock` with a `compare_exchange`. +- Setting and getting a `#[thread_local] static mut Option` on nightly. +""" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.thread_local]] +who = "Daira-Emma Hopwood " +criteria = "safe-to-deploy" +delta = "1.1.7 -> 1.1.8" +notes = """ +Adds `unsafe` code that makes an assumption that `ptr::null_mut::>()` is a valid representation +of an `AtomicPtr>`, but this is likely a correct assumption. +""" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.tinyvec_macros]] who = "Jack Grigg " criteria = "safe-to-deploy" @@ -2334,6 +2946,32 @@ delta = "1.35.1 -> 1.37.0" notes = "Cursory review, but new and changed uses of `unsafe` code look fine, as far as I can see." aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" +[[audits.zcash.audits.toml_datetime]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +version = "0.5.1" +notes = "Crate has `#![forbid(unsafe_code)]`, no `unwrap / expect / panic`, no ambient capabilities." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.toml_datetime]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.5.1 -> 0.6.1" +notes = "Fixes a bug in parsing negative minutes in datetime string offsets." +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.toml_datetime]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.6.2 -> 0.6.3" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + +[[audits.zcash.audits.tracing-subscriber]] +who = "Jack Grigg " +criteria = "safe-to-deploy" +delta = "0.3.17 -> 0.3.18" +aggregated-from = "https://raw.githubusercontent.com/zcash/zcash/master/qa/supply-chain/audits.toml" + [[audits.zcash.audits.try-lock]] who = "Jack Grigg " criteria = "safe-to-deploy" diff --git a/zcash_client_backend/CHANGELOG.md b/zcash_client_backend/CHANGELOG.md index 492169ace..607207685 100644 --- a/zcash_client_backend/CHANGELOG.md +++ b/zcash_client_backend/CHANGELOG.md @@ -38,6 +38,7 @@ funds to those addresses. See [ZIP 320](https://zips.z.cash/zip-0320) for detail - `zcash_client_backend::scanning`: - `testing` module - `zcash_client_backend::sync` module, behind the `sync` feature flag. +- `zcash_client_backend::tor` module, behind the `tor` feature flag. - `zcash_client_backend::wallet::Recipient::map_ephemeral_transparent_outpoint` ### Changed diff --git a/zcash_client_backend/Cargo.toml b/zcash_client_backend/Cargo.toml index 1ddc7bfb5..593d2d76c 100644 --- a/zcash_client_backend/Cargo.toml +++ b/zcash_client_backend/Cargo.toml @@ -27,6 +27,7 @@ features = [ "lightwalletd-tonic", "transparent-inputs", "test-dependencies", + "tor", "unstable", "unstable-serialization", "unstable-spanning-tree", @@ -94,6 +95,17 @@ jubjub = { workspace = true, optional = true } # - ZIP 321 nom = "7" +# - Tor +# -- Exposed error types: `arti_client::Error`, `arti_client::config::ConfigBuildError`, +# `hyper::Error`, `hyper::http::Error`, `serde_json::Error`. We could avoid this with +# changes to error handling. +arti-client = { workspace = true, optional = true } +hyper = { workspace = true, optional = true, features = ["client", "http1"] } +serde_json = { workspace = true, optional = true } + +# - Currency conversion +rust_decimal = { workspace = true, optional = true } + # Dependencies used internally: # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.) # - Documentation @@ -107,6 +119,18 @@ percent-encoding.workspace = true crossbeam-channel.workspace = true rayon.workspace = true +# - Tor +tokio = { workspace = true, optional = true, features = ["fs"] } +tor-rtcompat = { workspace = true, optional = true } + +# - HTTP through Tor +http-body-util = { workspace = true, optional = true } +hyper-util = { workspace = true, optional = true } +rand = { workspace = true, optional = true } +serde = { workspace = true, optional = true } +tokio-rustls = { workspace = true, optional = true } +webpki-roots = { workspace = true, optional = true } + [build-dependencies] tonic-build = { workspace = true, features = ["prost"] } which = "4" @@ -148,6 +172,25 @@ sync = [ "dep:futures-util", ] +## Exposes a Tor client for hiding a wallet's IP address while performing certain wallet +## operations. +tor = [ + "dep:arti-client", + "dep:async-trait", + "dep:futures-util", + "dep:http-body-util", + "dep:hyper", + "dep:hyper-util", + "dep:rand", + "dep:rust_decimal", + "dep:serde", + "dep:serde_json", + "dep:tokio", + "dep:tokio-rustls", + "dep:tor-rtcompat", + "dep:webpki-roots", +] + ## Exposes APIs that are useful for testing, such as `proptest` strategies. test-dependencies = [ "dep:proptest", diff --git a/zcash_client_backend/src/lib.rs b/zcash_client_backend/src/lib.rs index b13434b21..2dfd59956 100644 --- a/zcash_client_backend/src/lib.rs +++ b/zcash_client_backend/src/lib.rs @@ -80,6 +80,9 @@ pub mod sync; #[cfg(feature = "unstable-serialization")] pub mod serialization; +#[cfg(feature = "tor")] +pub mod tor; + pub use decrypt::{decrypt_transaction, DecryptedOutput, TransferType}; pub use zcash_protocol::{PoolType, ShieldedProtocol}; diff --git a/zcash_client_backend/src/tor.rs b/zcash_client_backend/src/tor.rs new file mode 100644 index 000000000..bab418a66 --- /dev/null +++ b/zcash_client_backend/src/tor.rs @@ -0,0 +1,99 @@ +//! Tor support for Zcash wallets. + +use std::{fmt, io, path::Path}; + +use arti_client::{config::TorClientConfigBuilder, TorClient}; +use tor_rtcompat::PreferredRuntime; +use tracing::debug; + +pub mod http; + +/// A Tor client that exposes capabilities designed for Zcash wallets. +pub struct Client { + inner: TorClient, +} + +impl Client { + /// Creates and bootstraps a Tor client. + /// + /// The client's persistent data and cache are both stored in the given directory. + /// Preserving the contents of this directory will speed up subsequent calls to + /// `Client::create`. + /// + /// Returns an error if `tor_dir` does not exist, or if bootstrapping fails. + pub async fn create(tor_dir: &Path) -> Result { + let runtime = PreferredRuntime::current()?; + + if !tokio::fs::try_exists(tor_dir).await? { + return Err(Error::MissingTorDirectory); + } + + let config = TorClientConfigBuilder::from_directories( + tor_dir.join("arti-data"), + tor_dir.join("arti-cache"), + ) + .build() + .expect("all required fields initialized"); + + let client_builder = TorClient::with_runtime(runtime).config(config); + + debug!("Bootstrapping Tor"); + let inner = client_builder.create_bootstrapped().await?; + debug!("Tor bootstrapped"); + + Ok(Self { inner }) + } +} + +/// Errors that can occur while creating or using a Tor [`Client`]. +#[derive(Debug)] +pub enum Error { + /// The directory passed to [`Client::create`] does not exist. + MissingTorDirectory, + /// An error occurred while using HTTP-over-Tor. + Http(self::http::HttpError), + /// An IO error occurred while interacting with the filesystem. + Io(io::Error), + /// A Tor-specific error. + Tor(arti_client::Error), +} + +impl fmt::Display for Error { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + match self { + Error::MissingTorDirectory => write!(f, "Tor directory is missing"), + Error::Http(e) => write!(f, "HTTP-over-Tor error: {}", e), + Error::Io(e) => write!(f, "IO error: {}", e), + Error::Tor(e) => write!(f, "Tor error: {}", e), + } + } +} + +impl std::error::Error for Error { + fn source(&self) -> Option<&(dyn std::error::Error + 'static)> { + match self { + Error::MissingTorDirectory => None, + Error::Http(e) => Some(e), + Error::Io(e) => Some(e), + Error::Tor(e) => Some(e), + } + } +} + +impl From for Error { + fn from(e: self::http::HttpError) -> Self { + Error::Http(e) + } +} + +impl From for Error { + fn from(e: io::Error) -> Self { + Error::Io(e) + } +} + +impl From for Error { + fn from(e: arti_client::Error) -> Self { + Error::Tor(e) + } +} diff --git a/zcash_client_backend/src/tor/http.rs b/zcash_client_backend/src/tor/http.rs new file mode 100644 index 000000000..c1aa62bfc --- /dev/null +++ b/zcash_client_backend/src/tor/http.rs @@ -0,0 +1,209 @@ +//! HTTP requests over Tor. + +use std::{fmt, future::Future, io, sync::Arc}; + +use futures_util::task::SpawnExt; +use http_body_util::{BodyExt, Empty}; +use hyper::{ + body::{Buf, Bytes, Incoming}, + client::conn, + http::{request::Builder, uri::Scheme}, + Request, Response, Uri, +}; +use hyper_util::rt::TokioIo; +use serde::de::DeserializeOwned; +use tokio::io::{AsyncRead, AsyncWrite}; +use tokio_rustls::{ + rustls::{ClientConfig, OwnedTrustAnchor, RootCertStore, ServerName}, + TlsConnector, +}; +use tor_rtcompat::PreferredRuntime; +use tracing::{debug, error}; + +use super::{Client, Error}; + +pub mod cryptex; + +impl Client { + #[tracing::instrument(skip(self, h, f))] + async fn get>>( + &self, + url: Uri, + h: impl FnOnce(Builder) -> Builder, + f: impl FnOnce(Incoming) -> F, + ) -> Result, Error> { + let is_https = url.scheme().ok_or_else(|| HttpError::NonHttpUrl)? == &Scheme::HTTPS; + + let host = url.host().ok_or_else(|| HttpError::NonHttpUrl)?.to_string(); + + let port = match url.port_u16() { + Some(port) => port, + None if is_https => 443, + None => 80, + }; + + // Connect to the server. + debug!("Connecting through Tor to {}:{}", host, port); + let stream = self.inner.connect((host.as_str(), port)).await?; + + if is_https { + // On apple-darwin targets there's an issue with the native TLS implementation + // when used over Tor circuits. We use Rustls instead. + // + // https://gitlab.torproject.org/tpo/core/arti/-/issues/715 + let mut root_store = RootCertStore::empty(); + root_store.add_trust_anchors(webpki_roots::TLS_SERVER_ROOTS.iter().map(|root| { + OwnedTrustAnchor::from_subject_spki_name_constraints( + root.subject, + root.spki, + root.name_constraints, + ) + })); + let config = ClientConfig::builder() + .with_safe_defaults() + .with_root_certificates(root_store) + .with_no_client_auth(); + let connector = TlsConnector::from(Arc::new(config)); + let dnsname = ServerName::try_from(host.as_str()).expect("Already checked"); + let stream = connector + .connect(dnsname, stream) + .await + .map_err(HttpError::Tls)?; + make_http_request(stream, url, h, f).await + } else { + make_http_request(stream, url, h, f).await + } + } + + async fn get_json(&self, url: Uri) -> Result, Error> { + self.get( + url, + |builder| builder.header(hyper::header::ACCEPT, "application/json"), + |body| async { + Ok(serde_json::from_reader( + body.collect() + .await + .map_err(HttpError::from)? + .aggregate() + .reader(), + ) + .map_err(HttpError::from)?) + }, + ) + .await + } +} + +async fn make_http_request>>( + stream: impl AsyncRead + AsyncWrite + Unpin + Send + 'static, + url: Uri, + h: impl FnOnce(Builder) -> Builder, + f: impl FnOnce(Incoming) -> F, +) -> Result, Error> { + debug!("Making request"); + let (mut sender, connection) = conn::http1::handshake(TokioIo::new(stream)) + .await + .map_err(HttpError::from)?; + + // Spawn a task to poll the connection and drive the HTTP state. + PreferredRuntime::current()? + .spawn(async move { + if let Err(e) = connection.await { + error!("Connection failed: {}", e); + } + }) + .map_err(HttpError::from)?; + + let req = h(Request::builder() + .header( + hyper::header::HOST, + url.authority().expect("Already checked").as_str(), + ) + .uri(url)) + .body(Empty::::new()) + .map_err(HttpError::from)?; + let (parts, body) = sender + .send_request(req) + .await + .map_err(HttpError::from)? + .into_parts(); + debug!("Response status code: {}", parts.status); + + if parts.status.is_success() { + Ok(Response::from_parts(parts, f(body).await?)) + } else { + Err(Error::Http(HttpError::Unsuccessful(parts.status))) + } +} + +/// Errors that can occurr while using HTTP-over-Tor. +#[derive(Debug)] +pub enum HttpError { + /// A non-HTTP URL was encountered. + NonHttpUrl, + /// An HTTP error. + Http(hyper::http::Error), + /// A [`hyper`] error. + Hyper(hyper::Error), + /// A JSON parsing error. + Json(serde_json::Error), + /// An error occurred while spawning a background worker task for driving the HTTP + /// connection. + Spawn(futures_util::task::SpawnError), + /// A TLS-specific IO error. + Tls(io::Error), + /// The status code indicated that the request was unsuccessful. + Unsuccessful(hyper::http::StatusCode), +} + +impl fmt::Display for HttpError { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + match self { + HttpError::NonHttpUrl => write!(f, "Only HTTP or HTTPS URLs are supported"), + HttpError::Http(e) => write!(f, "HTTP error: {}", e), + HttpError::Hyper(e) => write!(f, "Hyper error: {}", e), + HttpError::Json(e) => write!(f, "Failed to parse JSON: {}", e), + HttpError::Spawn(e) => write!(f, "Failed to spawn task: {}", e), + HttpError::Tls(e) => write!(f, "TLS error: {}", e), + HttpError::Unsuccessful(status) => write!(f, "Request was unsuccessful ({:?})", status), + } + } +} + +impl std::error::Error for HttpError { + fn source(&self) -> Option<&(dyn std::error::Error + 'static)> { + match self { + HttpError::NonHttpUrl => None, + HttpError::Http(e) => Some(e), + HttpError::Hyper(e) => Some(e), + HttpError::Json(e) => Some(e), + HttpError::Spawn(e) => Some(e), + HttpError::Tls(e) => Some(e), + HttpError::Unsuccessful(_) => None, + } + } +} + +impl From for HttpError { + fn from(e: hyper::http::Error) -> Self { + HttpError::Http(e) + } +} + +impl From for HttpError { + fn from(e: hyper::Error) -> Self { + HttpError::Hyper(e) + } +} + +impl From for HttpError { + fn from(e: serde_json::Error) -> Self { + HttpError::Json(e) + } +} + +impl From for HttpError { + fn from(e: futures_util::task::SpawnError) -> Self { + HttpError::Spawn(e) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex.rs b/zcash_client_backend/src/tor/http/cryptex.rs new file mode 100644 index 000000000..933a71357 --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex.rs @@ -0,0 +1,197 @@ +//! Cryptocurrency exchange rate APIs. + +use async_trait::async_trait; +use futures_util::{future::join_all, join}; +use rand::{seq::IteratorRandom, thread_rng}; +use rust_decimal::Decimal; +use tracing::{error, trace}; + +use crate::tor::{Client, Error}; + +mod binance; +mod coinbase; +mod gate_io; +mod gemini; +mod ku_coin; +mod mexc; + +/// Exchanges for which we know how to query data over Tor. +pub mod exchanges { + pub use super::binance::Binance; + pub use super::coinbase::Coinbase; + pub use super::gate_io::GateIo; + pub use super::gemini::Gemini; + pub use super::ku_coin::KuCoin; + pub use super::mexc::Mexc; +} + +/// An exchange that can be queried for ZEC data. +#[async_trait] +pub trait Exchange: 'static { + /// Queries data about the USD/ZEC pair. + /// + /// The returned bid and ask data must be denominated in USD, i.e. the latest bid and + /// ask for 1 ZEC. + async fn query_zec_to_usd(&self, client: &Client) -> Result; +} + +/// Data queried from an [`Exchange`]. +#[derive(Debug)] +pub struct ExchangeData { + /// The highest current bid. + pub bid: Decimal, + + /// The lowest current ask. + pub ask: Decimal, +} + +impl ExchangeData { + /// Returns the mid-point between current best bid and current best ask, to avoid + /// manipulation by targeted trade fulfilment. + fn exchange_rate(&self) -> Decimal { + (self.bid + self.ask) / Decimal::TWO + } +} + +/// A set of [`Exchange`]s that can be queried for ZEC data. +pub struct Exchanges { + trusted: Box, + others: Vec>, +} + +impl Exchanges { + /// Unauthenticated connections to all known exchanges with USD/ZEC pairs. + /// + /// Gemini is treated as a "trusted" data source due to being a NYDFS-regulated + /// exchange. + pub fn unauthenticated_known_with_gemini_trusted() -> Self { + Self::builder(exchanges::Gemini::unauthenticated()) + .with(exchanges::Binance::unauthenticated()) + .with(exchanges::Coinbase::unauthenticated()) + .with(exchanges::GateIo::unauthenticated()) + .with(exchanges::KuCoin::unauthenticated()) + .with(exchanges::Mexc::unauthenticated()) + .build() + } + + /// Returns an `Exchanges` builder. + /// + /// The `trusted` exchange will always have its data used, _if_ data is successfully + /// obtained via Tor (i.e. no transient failures). + pub fn builder(trusted: impl Exchange) -> ExchangesBuilder { + ExchangesBuilder::new(trusted) + } +} + +/// Builder type for [`Exchanges`]. +/// +/// Every [`Exchanges`] is configured with a "trusted" [`Exchange`] that will always have +/// its data used, if data is successfully obtained via Tor (i.e. no transient failures). +/// Additional data sources can be provided to [`ExchangesBuilder::with`] for resiliency +/// against transient network failures or adversarial market manipulation on individual +/// sources. +/// +/// The number of times [`ExchangesBuilder::with`] is called will affect the behaviour of +/// the final [`Exchanges`]: +/// - With no additional sources, the trusted [`Exchange`] is used on its own. +/// - With one additional source, the trusted [`Exchange`] is used preferentially, +/// with the additional source as a backup if the trusted source cannot be queried. +/// - With two or more additional sources, a minimum of three successful responses are +/// required from any of the sources. +pub struct ExchangesBuilder(Exchanges); + +impl ExchangesBuilder { + /// Constructs a new [`Exchanges`] builder. + /// + /// The `trusted` exchange will always have its data used, _if_ data is successfully + /// obtained via Tor (i.e. no transient failures). + pub fn new(trusted: impl Exchange) -> Self { + Self(Exchanges { + trusted: Box::new(trusted), + others: vec![], + }) + } + + /// Adds another [`Exchange`] as a data source. + pub fn with(mut self, other: impl Exchange) -> Self { + self.0.others.push(Box::new(other)); + self + } + + /// Builds the [`Exchanges`]. + pub fn build(self) -> Exchanges { + self.0 + } +} + +impl Client { + /// Fetches the latest USD/ZEC exchange rate, derived from the given exchanges. + /// + /// Returns: + /// - `Ok(rate)` if at least one exchange request succeeds. + /// - `Err(_)` if none of the exchange queries succeed. + pub async fn get_latest_zec_to_usd_rate( + &self, + exchanges: &Exchanges, + ) -> Result { + // Fetch the data in parallel. + let res = join!( + exchanges.trusted.query_zec_to_usd(self), + join_all(exchanges.others.iter().map(|e| e.query_zec_to_usd(self))) + ); + trace!(?res, "Data results"); + let (trusted_res, other_res) = res; + + // Split into successful queries and errors. + let mut rates: Vec = vec![]; + let mut errors = vec![]; + for res in other_res { + match res { + Ok(d) => rates.push(d.exchange_rate()), + Err(e) => errors.push(e), + } + } + + // "Never go to sea with two chronometers; take one or three." + // Randomly drop one rate if necessary to have an odd number of rates, as long as + // we have either at least three rates, or fewer than three sources. + if exchanges.others.len() >= 2 && rates.len() + usize::from(trusted_res.is_ok()) < 3 { + error!("Too many exchange requests failed"); + return Err(errors + .into_iter() + .next() + .expect("At least one request failed")); + } + let evict_random = |s: &mut Vec| { + if let Some(index) = (0..s.len()).choose(&mut thread_rng()) { + s.remove(index); + } + }; + match trusted_res { + Ok(trusted) => { + if rates.len() % 2 != 0 { + evict_random(&mut rates); + } + rates.push(trusted.exchange_rate()); + } + Err(e) => { + if rates.len() % 2 == 0 { + evict_random(&mut rates); + } + errors.push(e); + } + } + + // If all of the requests failed, log all errors and return one of them. + if rates.is_empty() { + error!("All exchange requests failed"); + Err(errors.into_iter().next().expect("All requests failed")) + } else { + // We have an odd number of rates; take the median. + assert!(rates.len() % 2 != 0); + rates.sort(); + let median = rates.len() / 2; + Ok(rates[median]) + } + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/binance.rs b/zcash_client_backend/src/tor/http/cryptex/binance.rs new file mode 100644 index 000000000..49f3001d6 --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/binance.rs @@ -0,0 +1,65 @@ +use async_trait::async_trait; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the Binance exchange. +pub struct Binance { + _private: (), +} + +impl Binance { + /// Prepares for unauthenticated connections to Binance. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Clone, Debug, Deserialize)] +#[allow(dead_code)] +#[allow(non_snake_case)] +struct BinanceData { + symbol: String, + priceChange: Decimal, + priceChangePercent: Decimal, + weightedAvgPrice: Decimal, + prevClosePrice: Decimal, + lastPrice: Decimal, + lastQty: Decimal, + bidPrice: Decimal, + bidQty: Decimal, + askPrice: Decimal, + askQty: Decimal, + openPrice: Decimal, + highPrice: Decimal, + lowPrice: Decimal, + volume: Decimal, + quoteVolume: Decimal, + openTime: u64, + closeTime: u64, + firstId: u32, + lastId: u32, + count: u32, +} + +#[async_trait] +impl Exchange for Binance { + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://binance-docs.github.io/apidocs/spot/en/#24hr-ticker-price-change-statistics + let res = client + .get_json::( + "https://api.binance.com/api/v3/ticker/24hr?symbol=ZECUSDT" + .parse() + .unwrap(), + ) + .await?; + let data = res.into_body(); + Ok(ExchangeData { + bid: data.bidPrice, + ask: data.askPrice, + }) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/coinbase.rs b/zcash_client_backend/src/tor/http/cryptex/coinbase.rs new file mode 100644 index 000000000..61a355f26 --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/coinbase.rs @@ -0,0 +1,53 @@ +use async_trait::async_trait; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the Coinbase exchange. +pub struct Coinbase { + _private: (), +} + +impl Coinbase { + /// Prepares for unauthenticated connections to Coinbase. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +struct CoinbaseData { + ask: Decimal, + bid: Decimal, + volume: Decimal, + trade_id: u32, + price: Decimal, + size: Decimal, + time: String, + rfq_volume: Option, + conversions_volume: Option, +} + +#[async_trait] +impl Exchange for Coinbase { + #[allow(dead_code)] + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://docs.cdp.coinbase.com/exchange/reference/exchangerestapi_getproductticker + let res = client + .get_json::( + "https://api.exchange.coinbase.com/products/ZEC-USD/ticker" + .parse() + .unwrap(), + ) + .await?; + let data = res.into_body(); + Ok(ExchangeData { + bid: data.bid, + ask: data.ask, + }) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/gate_io.rs b/zcash_client_backend/src/tor/http/cryptex/gate_io.rs new file mode 100644 index 000000000..80a81b7dc --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/gate_io.rs @@ -0,0 +1,56 @@ +use async_trait::async_trait; +use hyper::StatusCode; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the Gate.io exchange. +pub struct GateIo { + _private: (), +} + +impl GateIo { + /// Prepares for unauthenticated connections to Gate.io. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +struct GateIoData { + currency_pair: String, + last: Decimal, + lowest_ask: Decimal, + highest_bid: Decimal, + change_percentage: Decimal, + base_volume: Decimal, + quote_volume: Decimal, + high_24h: Decimal, + low_24h: Decimal, +} + +#[async_trait] +impl Exchange for GateIo { + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://www.gate.io/docs/developers/apiv4/#retrieve-ticker-information + let res = client + .get_json::>( + "https://api.gateio.ws/api/v4/spot/tickers?currency_pair=ZEC_USDT" + .parse() + .unwrap(), + ) + .await?; + let data = res.into_body().into_iter().next().ok_or(Error::Http( + super::super::HttpError::Unsuccessful(StatusCode::GONE), + ))?; + + Ok(ExchangeData { + bid: data.highest_bid, + ask: data.lowest_ask, + }) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/gemini.rs b/zcash_client_backend/src/tor/http/cryptex/gemini.rs new file mode 100644 index 000000000..dbb596e24 --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/gemini.rs @@ -0,0 +1,47 @@ +use async_trait::async_trait; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the Gemini exchange. +pub struct Gemini { + _private: (), +} + +impl Gemini { + /// Prepares for unauthenticated connections to Gemini. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +struct GeminiData { + symbol: String, + open: Decimal, + high: Decimal, + low: Decimal, + close: Decimal, + changes: Vec, + bid: Decimal, + ask: Decimal, +} + +#[async_trait] +impl Exchange for Gemini { + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://docs.gemini.com/rest-api/#ticker-v2 + let res = client + .get_json::("https://api.gemini.com/v2/ticker/zecusd".parse().unwrap()) + .await?; + let data = res.into_body(); + Ok(ExchangeData { + bid: data.bid, + ask: data.ask, + }) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/ku_coin.rs b/zcash_client_backend/src/tor/http/cryptex/ku_coin.rs new file mode 100644 index 000000000..30b4ac629 --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/ku_coin.rs @@ -0,0 +1,67 @@ +use async_trait::async_trait; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the KuCoin exchange. +pub struct KuCoin { + _private: (), +} + +impl KuCoin { + /// Prepares for unauthenticated connections to KuCoin. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +#[allow(non_snake_case)] +struct KuCoinData { + time: u64, + symbol: String, + buy: Decimal, + sell: Decimal, + changeRate: Decimal, + changePrice: Decimal, + high: Decimal, + low: Decimal, + vol: Decimal, + volValue: Decimal, + last: Decimal, + averagePrice: Decimal, + takerFeeRate: Decimal, + makerFeeRate: Decimal, + takerCoefficient: Decimal, + makerCoefficient: Decimal, +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +struct KuCoinResponse { + code: String, + data: KuCoinData, +} + +#[async_trait] +impl Exchange for KuCoin { + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://www.kucoin.com/docs/rest/spot-trading/market-data/get-24hr-stats + let res = client + .get_json::( + "https://api.kucoin.com/api/v1/market/stats?symbol=ZEC-USDT" + .parse() + .unwrap(), + ) + .await?; + let data = res.into_body().data; + Ok(ExchangeData { + bid: data.buy, + ask: data.sell, + }) + } +} diff --git a/zcash_client_backend/src/tor/http/cryptex/mexc.rs b/zcash_client_backend/src/tor/http/cryptex/mexc.rs new file mode 100644 index 000000000..7dcb46d7b --- /dev/null +++ b/zcash_client_backend/src/tor/http/cryptex/mexc.rs @@ -0,0 +1,60 @@ +use async_trait::async_trait; +use rust_decimal::Decimal; +use serde::Deserialize; + +use super::{Exchange, ExchangeData}; +use crate::tor::{Client, Error}; + +/// Querier for the MEXC exchange. +pub struct Mexc { + _private: (), +} + +impl Mexc { + /// Prepares for unauthenticated connections to MEXC. + pub fn unauthenticated() -> Self { + Self { _private: () } + } +} + +#[derive(Debug, Deserialize)] +#[allow(dead_code)] +#[allow(non_snake_case)] +struct MexcData { + symbol: String, + priceChange: Decimal, + priceChangePercent: Decimal, + prevClosePrice: Decimal, + lastPrice: Decimal, + bidPrice: Decimal, + bidQty: Decimal, + askPrice: Decimal, + askQty: Decimal, + openPrice: Decimal, + highPrice: Decimal, + lowPrice: Decimal, + volume: Decimal, + quoteVolume: Decimal, + openTime: u64, + closeTime: u64, +} + +#[async_trait] +impl Exchange for Mexc { + async fn query_zec_to_usd(&self, client: &Client) -> Result { + // API documentation: + // https://mexcdevelop.github.io/apidocs/spot_v3_en/#24hr-ticker-price-change-statistics + let res = client + .get_json::( + "https://api.mexc.com/api/v3/ticker/24hr?symbol=ZECUSDT" + .parse() + .unwrap(), + ) + .await?; + let data = res.into_body(); + Ok(ExchangeData { + bid: data.bidPrice, + ask: data.askPrice, + }) + } +} diff --git a/zcash_client_sqlite/Cargo.toml b/zcash_client_sqlite/Cargo.toml index 1521d3a0e..939dfcc1c 100644 --- a/zcash_client_sqlite/Cargo.toml +++ b/zcash_client_sqlite/Cargo.toml @@ -66,14 +66,11 @@ incrementalmerkletree.workspace = true shardtree = { workspace = true, features = ["legacy-api"] } # - SQLite databases -# Warning: One of the downstream consumers requires that SQLite be available through -# CocoaPods, due to being bound to React Native. We need to ensure that the SQLite -# version required for `rusqlite` is a version that is available through CocoaPods. -rusqlite = { version = "0.29.0", features = ["bundled", "time", "array"] } -schemer = "0.2" -schemer-rusqlite = "0.2.2" -time = "0.3.22" -uuid = "1.1" +rusqlite = { workspace = true, features = ["time", "array"] } +schemer.workspace = true +schemer-rusqlite.workspace = true +time.workspace = true +uuid.workspace = true # Dependencies used internally: # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.)