From f64c51ce6525bc34c60c6e1a80fbe72d75c3b005 Mon Sep 17 00:00:00 2001 From: Rain Jiang Date: Wed, 22 Nov 2023 01:15:33 +0000 Subject: [PATCH] use async fn in trait to replace TAIT --- Cargo.lock | 1243 +++++++++-------- Cargo.toml | 16 +- examples/config.toml | 14 +- monolake-core/Cargo.toml | 13 +- monolake-core/src/http/mod.rs | 21 +- monolake-core/src/lib.rs | 3 - monolake-core/src/listener.rs | 124 +- monolake-core/src/util/mod.rs | 1 + monolake-core/src/util/uri_serde.rs | 17 + monolake-services/Cargo.toml | 25 +- monolake-services/src/common/context.rs | 10 +- monolake-services/src/common/delay.rs | 15 +- monolake-services/src/common/erase.rs | 11 +- monolake-services/src/common/timeout.rs | 20 +- monolake-services/src/http/core.rs | 25 +- monolake-services/src/http/detect.rs | 71 +- .../src/http/handlers/conn_reuse.rs | 108 +- .../src/http/handlers/content_handler.rs | 106 +- monolake-services/src/http/handlers/proxy.rs | 23 +- .../src/http/handlers/rewrite.rs | 59 +- monolake-services/src/lib.rs | 1 - monolake-services/src/tcp/echo.rs | 30 +- monolake-services/src/tls/mod.rs | 43 +- monolake-services/src/tls/nativetls.rs | 16 +- monolake-services/src/tls/rustls.rs | 16 +- monolake/Cargo.toml | 10 +- monolake/src/main.rs | 3 - 27 files changed, 1014 insertions(+), 1030 deletions(-) create mode 100644 monolake-core/src/util/uri_serde.rs diff --git a/Cargo.lock b/Cargo.lock index c043b01..58096ad 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2,12 +2,30 @@ # It is not intended for manual editing. version = 3 +[[package]] +name = "addr2line" +version = "0.21.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a30b2e23b9e17a9f90641c7ab1549cd9b44f296d3ccbf309d2863cfe398a0cb" +dependencies = [ + "gimli", +] + [[package]] name = "adler" version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" +[[package]] +name = "aho-corasick" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b2969dcb958b36655471fc61f7e416fa76033bdd4bfed0678d8fee1e2d07a1f0" +dependencies = [ + "memchr", +] + [[package]] name = "alloc-no-stdlib" version = "2.0.4" @@ -40,30 +58,29 @@ dependencies = [ [[package]] name = "anstream" -version = "0.3.2" +version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ca84f3628370c59db74ee214b3263d58f9aadd9b4fe7e711fd87dc452b7f163" +checksum = "2ab91ebe16eb252986481c5b62f6098f3b698a45e34b5b98200cf20dd2484a44" dependencies = [ "anstyle", "anstyle-parse", "anstyle-query", "anstyle-wincon", "colorchoice", - "is-terminal", "utf8parse", ] [[package]] name = "anstyle" -version = "1.0.1" +version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3a30da5c5f2d5e72842e00bcb57657162cdabef0931f40e2deb9b4140440cecd" +checksum = "7079075b41f533b8c61d2a4d073c4676e1f8b249ff94a393b0595db304e0dd87" [[package]] name = "anstyle-parse" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "938874ff5980b03a87c5524b3ae5b59cf99b1d6bc836848df7bc5ada9643c333" +checksum = "317b9a89c1868f5ea6ff1d9539a69f45dffc21ce321ac1fd1160dfa48c8e2140" dependencies = [ "utf8parse", ] @@ -74,30 +91,30 @@ version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5ca11d4be1bab0c8bc8734a9aa7bf4ee8316d462a08c6ac5052f888fef5b494b" dependencies = [ - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "anstyle-wincon" -version = "1.0.1" +version = "3.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "180abfa45703aebe0093f79badacc01b8fd4ea2e35118747e5811127f926e188" +checksum = "f0699d10d2f4d628a98ee7b57b289abbc98ff3bad977cb3152709d4bf2330628" dependencies = [ "anstyle", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "anyhow" -version = "1.0.71" +version = "1.0.75" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c7d0618f0e0b7e8ff11427422b64564d5fb0be1940354bfe2e0529b18a9d9b8" +checksum = "a4668cab20f66d8d020e1fbc0ebe47217433c1b6c8f2040faf858554e394ace6" [[package]] name = "async-channel" -version = "1.8.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cf46fee83e5ccffc220104713af3292ff9bc7c64c7de289f66dae8e38d826833" +checksum = "81953c529336010edd6d8e358f886d9581267795c61b19475b71314bffa46d35" dependencies = [ "concurrent-queue", "event-listener", @@ -106,13 +123,13 @@ dependencies = [ [[package]] name = "auto-const-array" -version = "0.2.0" +version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "336c4771be12bbacae182a5ad2a788bfa27d2c21c5837731480ab5cf161c0e04" +checksum = "62f7df18977a1ee03650ee4b31b4aefed6d56bac188760b6e37610400fe8d4bb" dependencies = [ "proc-macro2", "quote", - "syn 1.0.109", + "syn 2.0.39", ] [[package]] @@ -121,11 +138,26 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" +[[package]] +name = "backtrace" +version = "0.3.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2089b7e3f35b9dd2d0ed921ead4f6d318c27680d4a5bd167b3ee120edb105837" +dependencies = [ + "addr2line", + "cc", + "cfg-if", + "libc", + "miniz_oxide", + "object", + "rustc-demangle", +] + [[package]] name = "base16ct" -version = "0.1.1" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "349a06037c7bf932dd7e7d1f653678b2038b9ad46a74102f1fc7bd7872678cce" +checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" [[package]] name = "base64" @@ -135,9 +167,9 @@ checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8" [[package]] name = "base64" -version = "0.21.2" +version = "0.21.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "604178f6c5c21f02dc555784810edfb88d34ac2c73b2eae109655649ee73ce3d" +checksum = "35636a1494ede3b646cc98f74f8e62c773a38a659ebc777a2cf26b9b74171df9" [[package]] name = "base64ct" @@ -151,6 +183,12 @@ version = "1.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" +[[package]] +name = "bitflags" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" + [[package]] name = "block-buffer" version = "0.10.4" @@ -162,9 +200,9 @@ dependencies = [ [[package]] name = "brotli" -version = "3.3.4" +version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a1a0b1dbcc8ae29329621f8d4f0d835787c1c38bb1401979b49d13b0b305ff68" +checksum = "516074a47ef4bce09577a3b379392300159ce5b1ba2e501ff1c819950066100f" dependencies = [ "alloc-no-stdlib", "alloc-stdlib", @@ -173,9 +211,9 @@ dependencies = [ [[package]] name = "brotli-decompressor" -version = "2.3.4" +version = "2.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b6561fd3f895a11e8f72af2cb7d22e08366bebc2b6b57f7744c4bda27034744" +checksum = "4e2e4afe60d7dd600fdd3de8d0f08c2b7ec039712e3b6137ff98b7004e82de4f" dependencies = [ "alloc-no-stdlib", "alloc-stdlib", @@ -183,27 +221,30 @@ dependencies = [ [[package]] name = "bumpalo" -version = "3.13.0" +version = "3.14.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a3e2c3daef883ecc1b5d58c15adae93470a91d425f3532ba1695849656af3fc1" +checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" [[package]] name = "byteorder" -version = "1.4.3" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "14c189c53d098945499cdfa7ecc63567cf3886b3332b312a5b4585d8d3a6a610" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" [[package]] name = "bytes" -version = "1.4.0" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89b2fd2a0dcf38d7971e2194b6b6eebab45ae01067456a7fd93d5547a61b70be" +checksum = "a2bd12c1caf447e69cd4528f47f94d203fd2582878ecb9e9465484c4148a8223" [[package]] name = "cc" -version = "1.0.79" +version = "1.0.83" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50d30906286121d95be3d479533b458f87493b30a4b5f79a607db8f5d11aa91f" +checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" +dependencies = [ + "libc", +] [[package]] name = "certain-map" @@ -223,7 +264,7 @@ checksum = "87e8e7991daf33cd9aae128c7a1eaff7678d20b310f0f19ae19a1e407b1be02c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] @@ -234,58 +275,58 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chrono" -version = "0.4.26" +version = "0.4.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ec837a71355b28f6556dbd569b37b3f363091c0bd4b2e735674521b4c5fd9bc5" +checksum = "7f2c685bad3eb3d45a01354cedb7d5faa66194d1d58ba6e267a8de788f79db38" dependencies = [ "android-tzdata", "iana-time-zone", + "js-sys", "num-traits", "serde", - "winapi", + "wasm-bindgen", + "windows-targets", ] [[package]] name = "clap" -version = "4.3.8" +version = "4.4.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d9394150f5b4273a1763355bd1c2ec54cc5a2593f790587bcd6b2c947cfa9211" +checksum = "2275f18819641850fa26c89acc84d465c1bf91ce57bc2748b28c420473352f64" dependencies = [ "clap_builder", "clap_derive", - "once_cell", ] [[package]] name = "clap_builder" -version = "4.3.8" +version = "4.4.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a78fbdd3cc2914ddf37ba444114bc7765bbdcb55ec9cbe6fa054f0137400717" +checksum = "07cdf1b148b25c1e1f7a42225e30a0d99a615cd4637eae7365548dd4529b95bc" dependencies = [ "anstream", "anstyle", - "bitflags", "clap_lex", "strsim", ] [[package]] name = "clap_derive" -version = "4.3.2" +version = "4.4.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b8cd2b2a819ad6eec39e8f1d6b53001af1e5469f8c177579cdaeb313115b825f" +checksum = "cf9804afaaf59a91e75b022a30fb7229a7901f60c755489cc61c9b423b836442" dependencies = [ "heck", "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "clap_lex" -version = "0.5.0" +version = "0.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2da6da31387c7e4ef160ffab6d5e7f00c42626fe39aea70a7b0f1773f7dd6c1b" +checksum = "702fc72eb24e5a1e48ce58027a675bc24edd52096d5397d4aea7c6dd9eca0bd1" [[package]] name = "colorchoice" @@ -295,18 +336,18 @@ checksum = "acbf1af155f9b9ef647e42cdc158db4b64a1b61f743629225fde6f3e0be2a7c7" [[package]] name = "concurrent-queue" -version = "2.2.0" +version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62ec6771ecfa0762d24683ee5a32ad78487a3d3afdc0fb8cae19d2c5deb50b7c" +checksum = "f057a694a54f12365049b0958a1685bb52d567f5593b355fbf685838e873d400" dependencies = [ "crossbeam-utils", ] [[package]] name = "const-oid" -version = "0.9.2" +version = "0.9.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "520fbf3c07483f94e3e3ca9d0cfd913d7718ef2483d2cfd91c0d9e91474ab913" +checksum = "28c122c3980598d243d63d9a704629a2d748d101f278052ff068be5a4423ab6f" [[package]] name = "convert_case" @@ -342,9 +383,9 @@ checksum = "e496a50fda8aacccc86d7529e2c1e0892dbd0f898a6b5645b5561b89c3210efa" [[package]] name = "cpufeatures" -version = "0.2.8" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "03e69e28e9f7f77debdedbaafa2866e1de9ba56df55a8bd7cfc724c25a09987c" +checksum = "ce420fe07aecd3e67c5f910618fe65e94158f6dcc0adf44e00d69ce2bdfe0fd0" dependencies = [ "libc", ] @@ -369,9 +410,9 @@ dependencies = [ [[package]] name = "crypto-bigint" -version = "0.4.9" +version = "0.5.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ef2b4b23cddf68b89b8f8069890e8c270d54e2d5fe1b143820234805e4cb17ef" +checksum = "28f85c3514d2a6e64160359b45a3918c3b4178bcbf4ae5d03ab2d02e521c479a" dependencies = [ "generic-array", "rand_core", @@ -389,11 +430,39 @@ dependencies = [ "typenum", ] +[[package]] +name = "curve25519-dalek" +version = "4.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e89b8c6a2e4b1f45971ad09761aafb85514a84744b67a95e32c3cc1352d1f65c" +dependencies = [ + "cfg-if", + "cpufeatures", + "curve25519-dalek-derive", + "digest", + "fiat-crypto", + "platforms", + "rustc_version", + "subtle", + "zeroize", +] + +[[package]] +name = "curve25519-dalek-derive" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f46882e17999c6cc590af592290432be3bce0428cb0d5f8b6715e4dc7b383eb3" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.39", +] + [[package]] name = "darling" -version = "0.13.4" +version = "0.20.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a01d95850c592940db9b8194bc39f4bc0e89dee5c4265e4b1807c34a9aba453c" +checksum = "0209d94da627ab5605dcccf08bb18afa5009cfbef48d8a8b7d7bdbc79be25c5e" dependencies = [ "darling_core", "darling_macro", @@ -401,40 +470,50 @@ dependencies = [ [[package]] name = "darling_core" -version = "0.13.4" +version = "0.20.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "859d65a907b6852c9361e3185c862aae7fafd2887876799fa55f5f99dc40d610" +checksum = "177e3443818124b357d8e76f53be906d60937f0d3a90773a664fa63fa253e621" dependencies = [ "fnv", "ident_case", "proc-macro2", "quote", "strsim", - "syn 1.0.109", + "syn 2.0.39", ] [[package]] name = "darling_macro" -version = "0.13.4" +version = "0.20.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c972679f83bdf9c42bd905396b6c3588a843a17f0f16dfcfa3e2c5d57441835" +checksum = "836a9bbc7ad63342d6d6e7b815ccab164bc77a2d95d84bc3117a8c0d5c98e2d5" dependencies = [ "darling_core", "quote", - "syn 1.0.109", + "syn 2.0.39", ] [[package]] name = "der" -version = "0.6.1" +version = "0.7.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1a467a65c5e759bce6e65eaf91cc29f466cdc57cb65777bd646872a8a1fd4de" +checksum = "fffa369a668c8af7dbf8b5e56c9f744fbd399949ed171606040001947de40b1c" dependencies = [ "const-oid", "pem-rfc7468", "zeroize", ] +[[package]] +name = "deranged" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0f32d04922c60427da6f9fef14d042d9edddef64cb9d4ce0d64d0685fbeb1fd3" +dependencies = [ + "powerfmt", + "serde", +] + [[package]] name = "derive_more" version = "0.99.17" @@ -468,37 +547,62 @@ checksum = "fea41bba32d969b513997752735605054bc0dfa92b4c56bf1189f2e174be7a10" [[package]] name = "dyn-clone" -version = "1.0.11" +version = "1.0.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68b0cf012f1230e43cd00ebb729c6bb58707ecfa8ad08b52ef3a4ccd2697fc30" +checksum = "545b22097d44f8a9581187cdf93de7a71e4722bf51200cfaba810865b49a495d" [[package]] name = "ecdsa" -version = "0.14.8" +version = "0.16.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "413301934810f597c1d19ca71c8710e99a3f1ba28a0d2ebc01551a2daeea3c5c" +checksum = "ee27f32b5c5292967d2d4a9d7f1e0b0aed2c15daded5a60300e4abb9d8020bca" dependencies = [ "der", + "digest", "elliptic-curve", "rfc6979", "signature", + "spki", +] + +[[package]] +name = "ed25519" +version = "2.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "115531babc129696a58c64a4fef0a8bf9e9698629fb97e9e40767d235cfbcd53" +dependencies = [ + "pkcs8", + "signature", +] + +[[package]] +name = "ed25519-dalek" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f628eaec48bfd21b865dc2950cfa014450c01d2fa2b69a86c2fd5844ec523c0" +dependencies = [ + "curve25519-dalek", + "ed25519", + "serde", + "sha2", + "subtle", + "zeroize", ] [[package]] name = "either" -version = "1.8.1" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7fcaabb2fef8c910e7f4c7ce9f67a1283a1715879a7c230ca9d6d1ae31f16d91" +checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" [[package]] name = "elliptic-curve" -version = "0.12.3" +version = "0.13.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7bb888ab5300a19b8e5bceef25ac745ad065f3c9f7efc6de1b91958110891d3" +checksum = "e9775b22bc152ad86a0cf23f0f348b884b26add12bf741e7ffc4d4ab2ab4d205" dependencies = [ "base16ct", "crypto-bigint", - "der", "digest", "ff", "generic-array", @@ -514,32 +618,27 @@ dependencies = [ [[package]] name = "encoding_rs" -version = "0.8.32" +version = "0.8.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "071a31f4ee85403370b58aca746f01041ede6f0da2730960ad001edc2b71b394" +checksum = "7268b386296a025e474d5140678f75d6de9493ae55a5d709eeb9dd08149945e1" dependencies = [ "cfg-if", ] [[package]] -name = "errno" -version = "0.3.1" +name = "equivalent" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4bcfec3a70f97c962c307b2d2c56e358cf1d00b558d74262b5f929ee8cc7e73a" -dependencies = [ - "errno-dragonfly", - "libc", - "windows-sys 0.48.0", -] +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" [[package]] -name = "errno-dragonfly" -version = "0.1.2" +name = "errno" +version = "0.3.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aa68f1b12764fab894d2755d2518754e71b4fd80ecfb822714a1206c2aab39bf" +checksum = "f258a7194e7f7c2a7837a8913aeab7fd8c383457034fa20ce4dd3dcb813e8eb8" dependencies = [ - "cc", "libc", + "windows-sys", ] [[package]] @@ -550,28 +649,31 @@ checksum = "0206175f82b8d6bf6652ff7d71a1e27fd2e4efde587fd368662814d6ec1d9ce0" [[package]] name = "fastrand" -version = "1.9.0" +version = "2.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e51093e27b0797c359783294ca4f0a911c270184cb10f85783b118614a1501be" -dependencies = [ - "instant", -] +checksum = "25cbce373ec4653f1a01a31e8a5e5ec0c622dc27ff9c4e6606eefef5cbbed4a5" [[package]] name = "ff" -version = "0.12.1" +version = "0.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d013fc25338cc558c5c2cfbad646908fb23591e2404481826742b651c9af7160" +checksum = "ded41244b729663b1e574f1b4fb731469f69f79c17667b5d776b16cda0479449" dependencies = [ "rand_core", "subtle", ] +[[package]] +name = "fiat-crypto" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "53a56f0780318174bad1c127063fd0c5fdfb35398e3cd79ffaab931a6c79df80" + [[package]] name = "flate2" -version = "1.0.27" +version = "1.0.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c6c98ee8095e9d1dcbf2fcc6d95acccb90d1c81db1e44725c6a984b1dbdfb010" +checksum = "46303f565772937ffe1d394a4fac6f411c6013172fadde9dcdb1e147a086940e" dependencies = [ "crc32fast", "miniz_oxide", @@ -622,9 +724,9 @@ dependencies = [ [[package]] name = "futures" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23342abe12aba583913b2e62f22225ff9c950774065e4bfb61a19cd9770fec40" +checksum = "da0290714b38af9b4a7b094b8a37086d1b4e61f2df9122c3cad2577669145335" dependencies = [ "futures-channel", "futures-core", @@ -637,9 +739,9 @@ dependencies = [ [[package]] name = "futures-channel" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "955518d47e09b25bbebc7a18df10b81f0c766eaf4c4f1cccef2fca5f2a4fb5f2" +checksum = "ff4dd66668b557604244583e3e1e1eada8c5c2e96a6d0d6653ede395b78bbacb" dependencies = [ "futures-core", "futures-sink", @@ -647,15 +749,15 @@ dependencies = [ [[package]] name = "futures-core" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4bca583b7e26f571124fe5b7561d49cb2868d79116cfa0eefce955557c6fee8c" +checksum = "eb1d22c66e66d9d72e1758f0bd7d4fd0bee04cad842ee34587d68c07e45d088c" [[package]] name = "futures-executor" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccecee823288125bd88b4d7f565c9e58e41858e47ab72e8ea2d64e93624386e0" +checksum = "0f4fb8693db0cf099eadcca0efe2a5a22e4550f98ed16aba6c48700da29597bc" dependencies = [ "futures-core", "futures-task", @@ -664,38 +766,38 @@ dependencies = [ [[package]] name = "futures-io" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fff74096e71ed47f8e023204cfd0aa1289cd54ae5430a9523be060cdb849964" +checksum = "8bf34a163b5c4c52d0478a4d757da8fb65cabef42ba90515efee0f6f9fa45aaa" [[package]] name = "futures-macro" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" +checksum = "53b153fd91e4b0147f4aced87be237c98248656bb01050b96bf3ee89220a8ddb" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "futures-sink" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f43be4fe21a13b9781a69afa4985b0f6ee0e1afab2c6f454a8cf30e2b2237b6e" +checksum = "e36d3378ee38c2a36ad710c5d30c2911d752cb941c00c72dbabfb786a7970817" [[package]] name = "futures-task" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76d3d132be6c0e6aa1534069c705a74a5997a356c0dc2f86a47765e5617c5b65" +checksum = "efd193069b0ddadc69c46389b740bbccdd97203899b48d09c5f7969591d6bae2" [[package]] name = "futures-util" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26b01e40b772d54cf6c6d721c1d1abd0647a0106a12ecaa1c186273392a69533" +checksum = "a19526d624e703a3179b3d322efec918b6246ea0fa51d41124525f00f1cc8104" dependencies = [ "futures-channel", "futures-core", @@ -726,13 +828,14 @@ checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a" dependencies = [ "typenum", "version_check", + "zeroize", ] [[package]] name = "getrandom" -version = "0.2.10" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "be4136b2a15dd319360be1c07d9933517ccf0be8f16bf62a3bee4f0d618df427" +checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f" dependencies = [ "cfg-if", "js-sys", @@ -741,11 +844,17 @@ dependencies = [ "wasm-bindgen", ] +[[package]] +name = "gimli" +version = "0.28.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6fb8d784f27acf97159b40fc4db5ecd8aa23b9ad5ef69cdd136d3bc80665f0c0" + [[package]] name = "group" -version = "0.12.1" +version = "0.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5dfbfb3a6cfbd390d5c9564ab283a0349b9b9fcd46a706c1eb10e0db70bfbac7" +checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63" dependencies = [ "ff", "rand_core", @@ -754,17 +863,17 @@ dependencies = [ [[package]] name = "h2" -version = "0.3.19" +version = "0.3.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d357c7ae988e7d2182f7d7871d0b963962420b0678b0997ce7de72001aeab782" +checksum = "4d6250322ef6e60f93f9a2162799302cd6f68f79f6e5d85c8c16f14d1d958178" dependencies = [ "bytes", "fnv", "futures-core", "futures-sink", "futures-util", - "http", - "indexmap", + "http 0.2.11", + "indexmap 2.1.0", "slab", "tokio", "tokio-util", @@ -778,25 +887,22 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" [[package]] -name = "heck" -version = "0.4.1" +name = "hashbrown" +version = "0.14.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" +checksum = "f93e7192158dbcda357bdec5fb5788eebf8bbac027f3f33e719d29135ae84156" [[package]] -name = "hermit-abi" -version = "0.2.6" +name = "heck" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7" -dependencies = [ - "libc", -] +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" [[package]] name = "hermit-abi" -version = "0.3.1" +version = "0.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fed44880c466736ef9a5c5b5facefb5ed0785676d0c02d612db14e54f0d84286" +checksum = "d77f7ec81a6d05a3abb01ab6eb7590f6083d08449fe5a1c8b1e620283546ccb7" [[package]] name = "hex" @@ -824,9 +930,9 @@ dependencies = [ [[package]] name = "http" -version = "0.2.9" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd6effc99afb63425aff9b05836f029929e345a6148a14b7ecd5ab67af944482" +checksum = "8947b1a6fad4393052c7ba1f4cd97bed3e953a95c79c92ad9b051a04611d9fbb" dependencies = [ "bytes", "fnv", @@ -834,24 +940,25 @@ dependencies = [ ] [[package]] -name = "http-body" -version = "0.4.5" +name = "http" +version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d5f38f16d184e36f2408a55281cd658ecbd3ca05cce6d6510a176eca393e26d1" +checksum = "b32afd38673a8016f7c9ae69e5af41a58f81b1d31689040f2f1959594ce194ea" dependencies = [ "bytes", - "http", - "pin-project-lite", + "fnv", + "itoa", ] [[package]] -name = "http-serde" -version = "1.1.2" +name = "http-body" +version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0e272971f774ba29341db2f686255ff8a979365a26fb9e4277f6b6d9ec0cdd5e" +checksum = "d5f38f16d184e36f2408a55281cd658ecbd3ca05cce6d6510a176eca393e26d1" dependencies = [ - "http", - "serde", + "bytes", + "http 0.2.11", + "pin-project-lite", ] [[package]] @@ -862,28 +969,28 @@ checksum = "d897f394bad6a705d5f4104762e116a75639e470d80901eed05a860a95cb1904" [[package]] name = "httpdate" -version = "1.0.2" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4a1e36c821dbe04574f602848a19f742f4fb3c98d40449f11bcad18d6b17421" +checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" [[package]] name = "hyper" -version = "0.14.26" +version = "0.14.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab302d72a6f11a3b910431ff93aae7e773078c769f0a3ef15fb9ec692ed147d4" +checksum = "ffb1cfd654a8219eaef89881fdb3bb3b1cdc5fa75ded05d6933b2b382e395468" dependencies = [ "bytes", "futures-channel", "futures-core", "futures-util", "h2", - "http", + "http 0.2.11", "http-body", "httparse", "httpdate", "itoa", "pin-project-lite", - "socket2 0.4.9", + "socket2 0.4.10", "tokio", "tower-service", "tracing", @@ -892,11 +999,12 @@ dependencies = [ [[package]] name = "hyper-rustls" -version = "0.24.0" +version = "0.24.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0646026eb1b3eea4cd9ba47912ea5ce9cc07713d105b1a14698f4e6433d348b7" +checksum = "ec3efd23720e2049821a693cbc7e65ea87c72f1c58ff2f9522ff332b1491e590" dependencies = [ - "http", + "futures-util", + "http 0.2.11", "hyper", "rustls", "tokio", @@ -905,16 +1013,16 @@ dependencies = [ [[package]] name = "iana-time-zone" -version = "0.1.57" +version = "0.1.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2fad5b825842d2b38bd206f3e81d6957625fd7f0a361e345c30e01a0ae2dd613" +checksum = "8326b86b6cff230b97d0d312a6c40a60726df3332e721f72a1b035f451663b20" dependencies = [ "android_system_properties", "core-foundation-sys", "iana-time-zone-haiku", "js-sys", "wasm-bindgen", - "windows", + "windows-core", ] [[package]] @@ -949,56 +1057,36 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99" dependencies = [ "autocfg", - "hashbrown", -] - -[[package]] -name = "instant" -version = "0.1.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7a5bbe824c507c5da5956355e86a746d82e0e1464f65d862cc5e71da70e94b2c" -dependencies = [ - "cfg-if", + "hashbrown 0.12.3", + "serde", ] [[package]] -name = "io-lifetimes" -version = "1.0.11" +name = "indexmap" +version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eae7b9aee968036d54dce06cebaefd919e4472e753296daccd6d344e3e2df0c2" +checksum = "d530e1a18b1cb4c484e6e34556a0d948706958449fca0cab753d649f2bce3d1f" dependencies = [ - "hermit-abi 0.3.1", - "libc", - "windows-sys 0.48.0", + "equivalent", + "hashbrown 0.14.2", + "serde", ] [[package]] name = "io-uring" -version = "0.6.0" +version = "0.6.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8b7b36074613a723279637061b40db993208908a94f10ccb14436ce735bc0f57" +checksum = "460648e47a07a43110fbfa2e0b14afb2be920093c31e5dccc50e49568e099762" dependencies = [ - "bitflags", + "bitflags 1.3.2", "libc", ] [[package]] name = "ipnet" -version = "2.7.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "12b6ee2129af8d4fb011108c73d99a1b83a85977f23b82460c0ae2e25bb4b57f" - -[[package]] -name = "is-terminal" -version = "0.4.7" +version = "2.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adcf93614601c8129ddf72e2d5633df827ba6551541c6d8c59520a371475be1f" -dependencies = [ - "hermit-abi 0.3.1", - "io-lifetimes", - "rustix", - "windows-sys 0.48.0", -] +checksum = "8f518f335dce6725a761382244631d86cf0ccb2863413590b31338feb467f9c3" [[package]] name = "itertools" @@ -1011,15 +1099,15 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.6" +version = "1.0.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "453ad9f582a441959e5f0d088b02ce04cfe8d51a8eaf077f12ac6d3e94164ca6" +checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" [[package]] name = "js-sys" -version = "0.3.64" +version = "0.3.65" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c5f195fe497f702db0f318b07fdd68edb16955aed830df8363d837542f8f935a" +checksum = "54c0c35952f67de54bb584e9fd912b3023117cbafc0a77d8f3dee1fb5f572fe8" dependencies = [ "wasm-bindgen", ] @@ -1035,27 +1123,27 @@ dependencies = [ [[package]] name = "libc" -version = "0.2.146" +version = "0.2.150" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f92be4933c13fd498862a9e02a3055f8a8d9c039ce33db97306fd5a6caa7f29b" +checksum = "89d92a4743f9a61002fae18374ed11e7973f530cb3a3255fb354818118b2203c" [[package]] name = "libm" -version = "0.2.7" +version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f7012b1bbb0719e1097c47611d3898568c546d597c2e74d66f6087edd5233ff4" +checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058" [[package]] name = "linux-raw-sys" -version = "0.3.8" +version = "0.4.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ef53942eb7bf7ff43a617b3e2c1c4a5ecf5944a7c1bc12d7ee39bbb15e5c1519" +checksum = "969488b55f8ac402214f3f5fd243ebb7206cf82de60d3172994707a4bcc2b829" [[package]] name = "local-sync" -version = "0.1.0" +version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5271fc029f75f74ab28194c9bd8580a1b953a8c3896e70b2a61b8dceb3667e79" +checksum = "3865cc3ed16dd99f3b89098478647a558a5a2f6dc5f0b45d7867d75da80050ef" dependencies = [ "futures-core", "futures-sink", @@ -1064,9 +1152,9 @@ dependencies = [ [[package]] name = "lock_api" -version = "0.4.10" +version = "0.4.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c1cc9717a20b1bb222f333e6a92fd32f7d8a18ddc5a3191a11af45dcbf4dcd16" +checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" dependencies = [ "autocfg", "scopeguard", @@ -1074,9 +1162,9 @@ dependencies = [ [[package]] name = "log" -version = "0.4.19" +version = "0.4.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b06a4cde4c0f271a446782e3eff8de789548ce57dbc8eca9292c27f4a42004b4" +checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" [[package]] name = "matchers" @@ -1084,20 +1172,20 @@ version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8263075bb86c5a1b1427b5ae862e8889656f126e9f77c484496e8b47cf5c5558" dependencies = [ - "regex-automata", + "regex-automata 0.1.10", ] [[package]] name = "matchit" -version = "0.7.0" +version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b87248edafb776e59e6ee64a79086f65890d3510f2c656c000bf2a7e8a0aea40" +checksum = "0e7465ac9959cc2b1404e8e2367b43684a6d13790fe23056cc8c6c5a6b7bcb94" [[package]] name = "memchr" -version = "2.5.0" +version = "2.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" +checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" [[package]] name = "memoffset" @@ -1125,21 +1213,21 @@ dependencies = [ [[package]] name = "mio" -version = "0.8.8" +version = "0.8.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2" +checksum = "3dce281c5e46beae905d4de1870d8b1509a9142b62eedf18b443b011ca8343d0" dependencies = [ "libc", "log", "wasi", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "monoio" -version = "0.1.8" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68e0b5faffe5004c52893010eb3bd50a04b236efdebdfb27337a083487c64720" +checksum = "c91a9bcc2622991bc92f3b6d7dc495329c4863e4dc530d1748529b009bb2170a" dependencies = [ "auto-const-array", "bytes", @@ -1151,16 +1239,16 @@ dependencies = [ "monoio-macros", "nix", "pin-project-lite", - "socket2 0.5.3", + "socket2 0.5.5", "threadpool", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "monoio-codec" -version = "0.1.0" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e926de38a488d3867f3702a82b9820c9a99bf60e92183105686409389ab7111" +checksum = "e27eed408f0e927a9ad28d334a76f8878253aaf61bcc4f0e209623104415974d" dependencies = [ "bytes", "monoio", @@ -1169,9 +1257,9 @@ dependencies = [ [[package]] name = "monoio-compat" -version = "0.1.1" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cc7b456f37f985b3602e5263a011fa10f8e8df0004db21794e752c7ca61c30d1" +checksum = "216043fca04ac7042ec501a9d32c625df6e4b50731ec2295367e70eab7699f33" dependencies = [ "monoio", "reusable-box-future", @@ -1180,23 +1268,24 @@ dependencies = [ [[package]] name = "monoio-http" -version = "0.2.4" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5adcf99e4445c72e982e7aae54ecfa88df08ff1ff084bf4276de1cbda661d040" +checksum = "2ebd005afc1553dbb2ca0f13ec0a28ac826378850420e8b003d8eb6ad52a347b" dependencies = [ "brotli", "bytes", "flate2", "fnv", "futures-core", - "http", + "http 1.0.0", "httparse", - "indexmap", + "indexmap 1.9.3", "local-sync", "memchr", "monoio", "monoio-codec", "monoio-compat", + "monoio-rustls", "service-async", "slab", "smallvec", @@ -1206,12 +1295,12 @@ dependencies = [ [[package]] name = "monoio-http-client" -version = "0.2.5" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ee71ad3731c899398e735e042c7eb3a868b17988470623fa0f2858362a0b1e0" +checksum = "35501d02c689997ac8aff8bc0005ff7b2b8ce8b65ddb11930539ddeae0465f51" dependencies = [ "bytes", - "http", + "http 1.0.0", "local-sync", "monoio", "monoio-http", @@ -1223,14 +1312,14 @@ dependencies = [ "smol_str", "thiserror", "tracing", - "webpki-roots 0.23.1", + "webpki-roots", ] [[package]] name = "monoio-io-wrapper" -version = "0.1.0" +version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "553fa5f587e4dfcb661ef7b1a79750555c6eace117fa19351bfa904eed51eb05" +checksum = "4bcfaa76e5daf87cc4d31b4d1b6bc93c12db59c19df50b9200afdbde42077655" dependencies = [ "monoio", ] @@ -1243,14 +1332,14 @@ checksum = "176a5f5e69613d9e88337cf2a65e11135332b4efbcc628404a7c555e4452084c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "monoio-native-tls" -version = "0.1.0" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "987b149f205ba60f16b725c65058abd400204fe1dae7b6f06464d2fa22490875" +checksum = "56512b1d2ed1a875ffdb80f0f5180766c2bff2366de15a5b60440f81e022f698" dependencies = [ "bytes", "monoio", @@ -1261,9 +1350,9 @@ dependencies = [ [[package]] name = "monoio-rustls" -version = "0.1.5" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4db41fb084cc1f69b8a77e696ed022f4b566e54873ae000c130f25c3f36b508d" +checksum = "2cf89f9d9a47ee9e2d93c2bc4aeeb40240b19c0575f8f784a45bcf7e2d98aded" dependencies = [ "bytes", "monoio", @@ -1274,7 +1363,7 @@ dependencies = [ [[package]] name = "monolake" -version = "0.2.0" +version = "0.3.0" dependencies = [ "anyhow", "certain-map", @@ -1294,15 +1383,14 @@ dependencies = [ [[package]] name = "monolake-core" -version = "0.2.0" +version = "0.3.0" dependencies = [ "anyhow", "derive_more", "futures-channel", "futures-util", "hex", - "http", - "http-serde", + "http 1.0.0", "io-uring", "monoio", "monoio-http", @@ -1314,15 +1402,14 @@ dependencies = [ [[package]] name = "monolake-services" -version = "0.1.1" +version = "0.3.0" dependencies = [ "anyhow", "async-channel", "bytes", "cookie", "futures", - "http", - "http-serde", + "http 1.0.0", "lazy_static", "local-sync", "matchit", @@ -1344,7 +1431,7 @@ dependencies = [ "thiserror", "tracing", "url", - "webpki-roots 0.23.1", + "webpki-roots", ] [[package]] @@ -1376,16 +1463,15 @@ dependencies = [ [[package]] name = "nix" -version = "0.26.2" +version = "0.26.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfdda3d196821d6af13126e40375cdf7da646a96114af134d5f417a9a1dc8e1a" +checksum = "598beaf3cc6fdd9a5dfb1630c2800c7acd31df7aaf0f565796fba2b53ca1af1b" dependencies = [ - "bitflags", + "bitflags 1.3.2", "cfg-if", "libc", "memoffset", "pin-utils", - "static_assertions", ] [[package]] @@ -1400,9 +1486,9 @@ dependencies = [ [[package]] name = "num-bigint-dig" -version = "0.8.2" +version = "0.8.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2399c9463abc5f909349d8aa9ba080e0b88b3ce2885389b60b993f39b1a56905" +checksum = "dc84195820f291c7697304f3cbdadd1cb7199c0efc917ff5eafd71225c136151" dependencies = [ "byteorder", "lazy_static", @@ -1438,9 +1524,9 @@ dependencies = [ [[package]] name = "num-traits" -version = "0.2.15" +version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "578ede34cf02f8924ab9447f50c28075b4d3e5b269972345e7e0372b38c6cdcd" +checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" dependencies = [ "autocfg", "libm", @@ -1448,24 +1534,24 @@ dependencies = [ [[package]] name = "num_cpus" -version = "1.15.0" +version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fac9e2da13b5eb447a6ce3d392f23a29d8694bff781bf03a16cd9ac8697593b" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" dependencies = [ - "hermit-abi 0.2.6", + "hermit-abi", "libc", ] [[package]] name = "oauth2" -version = "4.4.1" +version = "4.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09a6e2a2b13a56ebeabba9142f911745be6456163fd6c3d361274ebcd891a80c" +checksum = "c38841cdd844847e3e7c8d29cef9dcfed8877f8f56f9071f77843ecf3baf937f" dependencies = [ "base64 0.13.1", "chrono", "getrandom", - "http", + "http 0.2.11", "rand", "reqwest", "serde", @@ -1476,6 +1562,15 @@ dependencies = [ "url", ] +[[package]] +name = "object" +version = "0.32.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9cf5f9dd3933bd50a9e1f149ec995f39ae2c496d31fd772c1fd45ebc27e902b0" +dependencies = [ + "memchr", +] + [[package]] name = "once_cell" version = "1.18.0" @@ -1484,15 +1579,16 @@ checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" [[package]] name = "openidconnect" -version = "3.2.0" +version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05a5d6209b4c67f07ec48ca5329cc68eb229ba1b856152d5688962110de7e286" +checksum = "62d6050f6a84b81f23c569f5607ad883293e57491036e318fafe6fc4895fadb1" dependencies = [ "base64 0.13.1", "chrono", "dyn-clone", + "ed25519-dalek", "hmac", - "http", + "http 0.2.11", "itertools", "log", "oauth2", @@ -1515,11 +1611,11 @@ dependencies = [ [[package]] name = "openssl" -version = "0.10.55" +version = "0.10.59" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "345df152bc43501c5eb9e4654ff05f794effb78d4efe3d53abc158baddc0703d" +checksum = "7a257ad03cd8fb16ad4172fedf8094451e1af1c4b70097636ef2eac9a5f0cc33" dependencies = [ - "bitflags", + "bitflags 2.4.1", "cfg-if", "foreign-types", "libc", @@ -1536,7 +1632,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] @@ -1547,18 +1643,18 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" [[package]] name = "openssl-src" -version = "111.26.0+1.1.1u" +version = "300.1.6+3.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "efc62c9f12b22b8f5208c23a7200a442b2e5999f8bdf80233852122b5a4f6f37" +checksum = "439fac53e092cd7442a3660c85dde4643ab3b5bd39040912388dcdabf6b88085" dependencies = [ "cc", ] [[package]] name = "openssl-sys" -version = "0.9.90" +version = "0.9.95" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "374533b0e45f3a7ced10fcaeccca020e66656bc03dac384f852e4e5a7a8104a6" +checksum = "40a4130519a360279579c2053038317e40eff64d13fd3f004f9e1b72b8a6aaf9" dependencies = [ "cc", "libc", @@ -1569,9 +1665,9 @@ dependencies = [ [[package]] name = "ordered-float" -version = "2.10.0" +version = "2.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7940cf2ca942593318d07fcf2596cdca60a85c9e7fab408a5e21a4f9dcd40d87" +checksum = "68f19d67e5a2795c94e73e0bb1cc1a7edeb2e28efd39e2e1c9b7a40c1108b11c" dependencies = [ "num-traits", ] @@ -1584,23 +1680,25 @@ checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" [[package]] name = "p256" -version = "0.11.1" +version = "0.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "51f44edd08f51e2ade572f141051021c5af22677e42b7dd28a88155151c33594" +checksum = "c9863ad85fa8f4460f9c48cb909d38a0d689dba1f6f6988a5e3e0d31071bcd4b" dependencies = [ "ecdsa", "elliptic-curve", + "primeorder", "sha2", ] [[package]] name = "p384" -version = "0.11.2" +version = "0.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfc8c5bf642dde52bb9e87c0ecd8ca5a76faac2eeed98dedb7c717997e1080aa" +checksum = "70786f51bcc69f6a4c0360e063a4cac5419ef7c5cd5b3c99ad70f3be5ba79209" dependencies = [ "ecdsa", "elliptic-curve", + "primeorder", "sha2", ] @@ -1612,9 +1710,9 @@ checksum = "2da24af13fd75465e54b0040b7303173dc90d5f53a82ead2041f8ad453678247" [[package]] name = "pem-rfc7468" -version = "0.6.0" +version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24d159833a9105500e0398934e205e0773f0b27529557134ecfc51c27646adac" +checksum = "88b39c9bfcfc231068454382784bb460aae594343fb030d46e9f50a645418412" dependencies = [ "base64ct", ] @@ -1627,29 +1725,29 @@ checksum = "9b2a4787296e9989611394c33f193f676704af1686e70b8f8033ab5ba9a35a94" [[package]] name = "pin-project" -version = "1.1.0" +version = "1.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c95a7476719eab1e366eaf73d0260af3021184f18177925b07f54b30089ceead" +checksum = "fda4ed1c6c173e3fc7a83629421152e01d7b1f9b7f65fb301e490e8cfc656422" dependencies = [ "pin-project-internal", ] [[package]] name = "pin-project-internal" -version = "1.1.0" +version = "1.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39407670928234ebc5e6e580247dd567ad73a3578460c5990f9503df207e8f07" +checksum = "4359fd9c9171ec6e8c62926d6faaf553a8dc3f64e1507e76da7911b4f6a04405" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "pin-project-lite" -version = "0.2.9" +version = "0.2.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0a7ae3ac2f1173085d398531c705756c94a4c56843785df85a60c1a0afac116" +checksum = "8afb450f006bf6385ca15ef45d71d2288452bc3683ce2e2cacc0d18e4be60b58" [[package]] name = "pin-utils" @@ -1659,21 +1757,20 @@ checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" [[package]] name = "pkcs1" -version = "0.4.1" +version = "0.7.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eff33bdbdfc54cc98a2eca766ebdec3e1b8fb7387523d5c9c9a2891da856f719" +checksum = "c8ffb9f10fa047879315e6625af03c164b16962a5368d724ed16323b68ace47f" dependencies = [ "der", "pkcs8", "spki", - "zeroize", ] [[package]] name = "pkcs8" -version = "0.9.0" +version = "0.10.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9eca2c590a5f85da82668fa685c09ce2888b9430e83299debf1f34b65fd4a4ba" +checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7" dependencies = [ "der", "spki", @@ -1685,17 +1782,38 @@ version = "0.3.27" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "26072860ba924cbfa98ea39c8c19b4dd6a4a25423dbdf219c1eca91aa0cf6964" +[[package]] +name = "platforms" +version = "3.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "14e6ab3f592e6fb464fc9712d8d6e6912de6473954635fd76a589d832cffcbb0" + +[[package]] +name = "powerfmt" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" + [[package]] name = "ppv-lite86" version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" +[[package]] +name = "primeorder" +version = "0.13.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "353e1ca18966c16d9deb1c69278edbc5f194139612772bd9537af60ac231e1e6" +dependencies = [ + "elliptic-curve", +] + [[package]] name = "proc-macro2" -version = "1.0.60" +version = "1.0.69" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dec2b086b7a862cf4de201096214fa870344cf922b2b30c167badb3af3195406" +checksum = "134c189feb4956b20f6f547d2cf727d4c0fe06722b20a0eec87ed445a97f92da" dependencies = [ "unicode-ident", ] @@ -1712,9 +1830,9 @@ dependencies = [ [[package]] name = "quote" -version = "1.0.28" +version = "1.0.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1b9ab9c7eadfd8df19006f1cf1a4aed13540ed5cbc047010ece5826e10825488" +checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" dependencies = [ "proc-macro2", ] @@ -1751,20 +1869,23 @@ dependencies = [ [[package]] name = "redox_syscall" -version = "0.3.5" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "567664f262709473930a4bf9e51bf2ebf3348f2e748ccc50dea20646858f8f29" +checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" dependencies = [ - "bitflags", + "bitflags 1.3.2", ] [[package]] name = "regex" -version = "1.8.4" +version = "1.10.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d0ab3ca65655bb1e41f2a8c8cd662eb4fb035e67c3f78da1d61dffe89d07300f" +checksum = "380b951a9c5e80ddfd6136919eef32310721aa4aacd4889a8d39124b026ab343" dependencies = [ - "regex-syntax 0.7.2", + "aho-corasick", + "memchr", + "regex-automata 0.4.3", + "regex-syntax 0.8.2", ] [[package]] @@ -1776,6 +1897,17 @@ dependencies = [ "regex-syntax 0.6.29", ] +[[package]] +name = "regex-automata" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5f804c7828047e88b2d32e2d7fe5a105da8ee3264f01902f796c8e067dc2483f" +dependencies = [ + "aho-corasick", + "memchr", + "regex-syntax 0.8.2", +] + [[package]] name = "regex-syntax" version = "0.6.29" @@ -1784,23 +1916,23 @@ checksum = "f162c6dd7b008981e4d40210aca20b4bd0f9b60ca9271061b07f78537722f2e1" [[package]] name = "regex-syntax" -version = "0.7.2" +version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "436b050e76ed2903236f032a59761c1eb99e1b0aead2c257922771dab1fc8c78" +checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f" [[package]] name = "reqwest" -version = "0.11.18" +version = "0.11.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cde824a14b7c14f85caff81225f411faacc04a2013f41670f41443742b1c1c55" +checksum = "046cd98826c46c2ac8ddecae268eb5c2e58628688a5fc7a2643704a73faba95b" dependencies = [ - "base64 0.21.2", + "base64 0.21.5", "bytes", "encoding_rs", "futures-core", "futures-util", "h2", - "http", + "http 0.2.11", "http-body", "hyper", "hyper-rustls", @@ -1816,6 +1948,7 @@ dependencies = [ "serde", "serde_json", "serde_urlencoded", + "system-configuration", "tokio", "tokio-rustls", "tower-service", @@ -1823,7 +1956,7 @@ dependencies = [ "wasm-bindgen", "wasm-bindgen-futures", "web-sys", - "webpki-roots 0.22.6", + "webpki-roots", "winreg", ] @@ -1835,51 +1968,54 @@ checksum = "1e0e61cd21fbddd85fbd9367b775660a01d388c08a61c6d2824af480b0309bb9" [[package]] name = "rfc6979" -version = "0.3.1" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7743f17af12fa0b03b803ba12cd6a8d9483a587e89c69445e3909655c0b9fabb" +checksum = "f8dd2a808d456c4a54e300a23e9f5a67e122c3024119acbfd73e3bf664491cb2" dependencies = [ - "crypto-bigint", "hmac", - "zeroize", + "subtle", ] [[package]] name = "ring" -version = "0.16.20" +version = "0.17.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3053cf52e236a3ed746dfc745aa9cacf1b791d846bdaf412f60a8d7d6e17c8fc" +checksum = "fb0205304757e5d899b9c2e448b867ffd03ae7f988002e47cd24954391394d0b" dependencies = [ "cc", + "getrandom", "libc", - "once_cell", - "spin 0.5.2", + "spin 0.9.8", "untrusted", - "web-sys", - "winapi", + "windows-sys", ] [[package]] name = "rsa" -version = "0.7.2" +version = "0.9.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "094052d5470cbcef561cb848a7209968c9f12dfa6d668f4bca048ac5de51099c" +checksum = "86ef35bf3e7fe15a53c4ab08a998e42271eab13eb0db224126bc7bc4c4bad96d" dependencies = [ - "byteorder", + "const-oid", "digest", "num-bigint-dig", "num-integer", - "num-iter", "num-traits", "pkcs1", "pkcs8", "rand_core", "signature", - "smallvec", + "spki", "subtle", "zeroize", ] +[[package]] +name = "rustc-demangle" +version = "0.1.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d626bb9dae77e28219937af045c257c28bfd3f69333c512553507f5f9798cb76" + [[package]] name = "rustc_version" version = "0.4.0" @@ -1891,23 +2027,22 @@ dependencies = [ [[package]] name = "rustix" -version = "0.37.20" +version = "0.38.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b96e891d04aa506a6d1f318d2771bcb1c7dfda84e126660ace067c9b474bb2c0" +checksum = "9ad981d6c340a49cdc40a1028d9c6084ec7e9fa33fcb839cab656a267071e234" dependencies = [ - "bitflags", + "bitflags 2.4.1", "errno", - "io-lifetimes", "libc", "linux-raw-sys", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "rustls" -version = "0.21.2" +version = "0.21.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e32ca28af694bc1bbf399c33a516dbdf1c90090b8ab23c2bc24f834aa2247f5f" +checksum = "629648aced5775d558af50b2b4c7b02983a04b312126d45eeead26e7caa498b9" dependencies = [ "log", "ring", @@ -1917,18 +2052,18 @@ dependencies = [ [[package]] name = "rustls-pemfile" -version = "1.0.2" +version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d194b56d58803a43635bdc398cd17e383d6f71f9182b9a192c127ca42494a59b" +checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c" dependencies = [ - "base64 0.21.2", + "base64 0.21.5", ] [[package]] name = "rustls-webpki" -version = "0.100.1" +version = "0.101.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6207cd5ed3d8dca7816f8f3725513a34609c0c765bf652b8c3cb4cfd87db46b" +checksum = "8b6275d1ee7a1cd780b64aca7726599a1dbc893b1e64144529e55c3c2f745765" dependencies = [ "ring", "untrusted", @@ -1936,30 +2071,30 @@ dependencies = [ [[package]] name = "ryu" -version = "1.0.13" +version = "1.0.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f91339c0467de62360649f8d3e185ca8de4224ff281f66000de5eb2a77a79041" +checksum = "1ad4cc8da4ef723ed60bced201181d83791ad433213d8c24efffda1eec85d741" [[package]] name = "schannel" -version = "0.1.21" +version = "0.1.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "713cfb06c7059f3588fb8044c0fad1d09e3c01d225e25b9220dbfdcf16dbb1b3" +checksum = "0c3733bf4cf7ea0880754e19cb5a462007c4a8c1914bff372ccc95b464f1df88" dependencies = [ - "windows-sys 0.42.0", + "windows-sys", ] [[package]] name = "scopeguard" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d29ab0c6d3fc0ee92fe66e2d99f700eab17a8d57d1c1d3b748380fb20baa78cd" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "sct" -version = "0.7.0" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d53dcdb7c9f8158937a7981b48accfd39a43af418591a5d008c7b22b5e1b7ca4" +checksum = "da046153aa2352493d6cb7da4b6e5c0c057d8a1d0a9aa8560baffdd945acd414" dependencies = [ "ring", "untrusted", @@ -1967,9 +2102,9 @@ dependencies = [ [[package]] name = "sec1" -version = "0.3.0" +version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3be24c1842290c45df0a7bf069e0c268a747ad05a192f2fd7dcfdbc1cba40928" +checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" dependencies = [ "base16ct", "der", @@ -1981,11 +2116,11 @@ dependencies = [ [[package]] name = "security-framework" -version = "2.9.1" +version = "2.9.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1fc758eb7bffce5b308734e9b0c1468893cae9ff70ebf13e7090be8dcbcc83a8" +checksum = "05b64fb303737d99b81884b2c63433e9ae28abebe5eb5045dcdd175dc2ecf4de" dependencies = [ - "bitflags", + "bitflags 1.3.2", "core-foundation", "core-foundation-sys", "libc", @@ -1994,9 +2129,9 @@ dependencies = [ [[package]] name = "security-framework-sys" -version = "2.9.0" +version = "2.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f51d0c0d83bec45f16480d0ce0058397a69e48fcdc52d1dc8855fb68acbd31a7" +checksum = "e932934257d3b408ed8f30db49d85ea163bfe74961f017f405b025af298f0c7a" dependencies = [ "core-foundation-sys", "libc", @@ -2004,15 +2139,15 @@ dependencies = [ [[package]] name = "semver" -version = "1.0.17" +version = "1.0.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bebd363326d05ec3e2f532ab7660680f3b02130d780c299bca73469d521bc0ed" +checksum = "836fa6a3e1e547f9a2c4040802ec865b5d85f4014efe00555d7090a3dcaa1090" [[package]] name = "serde" -version = "1.0.164" +version = "1.0.192" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9e8c8cf938e98f769bc164923b06dce91cea1751522f46f8466461af04c9027d" +checksum = "bca2a08484b285dcb282d0f67b26cadc0df8b19f8c12502c13d966bf9482f001" dependencies = [ "serde_derive", ] @@ -2029,20 +2164,20 @@ dependencies = [ [[package]] name = "serde_derive" -version = "1.0.164" +version = "1.0.192" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d9735b638ccc51c28bf6914d90a2e9725b377144fc612c49a611fddd1b631d68" +checksum = "d6c7207fbec9faa48073f3e3074cbe553af6ea512d7c21ba46e434e70ea9fbc1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "serde_json" -version = "1.0.97" +version = "1.0.108" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bdf3bf93142acad5821c99197022e170842cdbc1c30482b98750c688c640842a" +checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b" dependencies = [ "itoa", "ryu", @@ -2051,27 +2186,28 @@ dependencies = [ [[package]] name = "serde_path_to_error" -version = "0.1.11" +version = "0.1.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f7f05c1d5476066defcdfacce1f52fc3cae3af1d3089727100c02ae92e5abbe0" +checksum = "4beec8bce849d58d06238cb50db2e1c417cfeafa4c63f692b15c82b7c80f8335" dependencies = [ + "itoa", "serde", ] [[package]] name = "serde_plain" -version = "1.0.1" +version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6018081315db179d0ce57b1fe4b62a12a0028c9cf9bbef868c9cf477b3c34ae" +checksum = "9ce1fc6db65a611022b23a0dec6975d63fb80a302cb3388835ff02c097258d50" dependencies = [ "serde", ] [[package]] name = "serde_spanned" -version = "0.6.2" +version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93107647184f6027e3b7dcb2e11034cf95ffa1e3a682c67951963ac69c1c007d" +checksum = "12022b835073e5b11e90a14f86838ceb1c8fb0325b72416845c487ac0fa95e80" dependencies = [ "serde", ] @@ -2090,41 +2226,47 @@ dependencies = [ [[package]] name = "serde_with" -version = "1.14.0" +version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "678b5a069e50bf00ecd22d0cd8ddf7c236f68581b03db652061ed5eb13a312ff" +checksum = "64cd236ccc1b7a29e7e2739f27c0b2dd199804abc4290e32f59f3b68d6405c23" dependencies = [ + "base64 0.21.5", + "chrono", + "hex", + "indexmap 1.9.3", + "indexmap 2.1.0", "serde", + "serde_json", "serde_with_macros", + "time", ] [[package]] name = "serde_with_macros" -version = "1.5.2" +version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e182d6ec6f05393cc0e5ed1bf81ad6db3a8feedf8ee515ecdd369809bcce8082" +checksum = "93634eb5f75a2323b16de4748022ac4297f9e76b6dced2be287a099f41b5e788" dependencies = [ "darling", "proc-macro2", "quote", - "syn 1.0.109", + "syn 2.0.39", ] [[package]] name = "service-async" -version = "0.1.13" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fbef7f6e6da968ca53e8da538bf74dc1fb923778fc1976176fab39c1fc78da79" +checksum = "8223e2f6a34d48241701c94c991defd6191ed8f2558f89568b764be990e8e347" dependencies = [ - "futures-util", "param", ] [[package]] name = "sha2" -version = "0.10.7" +version = "0.10.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "479fb9d862239e610720565ca91403019f2f00410f1864c5aa7479b950a76ed8" +checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8" dependencies = [ "cfg-if", "cpufeatures", @@ -2133,18 +2275,18 @@ dependencies = [ [[package]] name = "sharded-slab" -version = "0.1.4" +version = "0.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "900fba806f70c630b0a382d0d825e17a0f19fcd059a2ade1ff237bcddf446b31" +checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" dependencies = [ "lazy_static", ] [[package]] name = "signature" -version = "1.6.4" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "74233d3b3b2f6d4b006dc19dee745e73e2a6bfb6f93607cd3b02bd5b00797d7c" +checksum = "77549399552de45a898a580c1b41d445bf730df867cc44e6c0233bbc4b8329de" dependencies = [ "digest", "rand_core", @@ -2152,18 +2294,18 @@ dependencies = [ [[package]] name = "slab" -version = "0.4.8" +version = "0.4.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6528351c9bc8ab22353f9d776db39a20288e8d6c37ef8cfe3317cf875eecfc2d" +checksum = "8f92a496fb766b417c996b9c5e57daf2f7ad3b0bebe1ccfca4856390e3d3bb67" dependencies = [ "autocfg", ] [[package]] name = "smallvec" -version = "1.10.0" +version = "1.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a507befe795404456341dfab10cef66ead4c041f62b8b11bbb92bffe5d0953e0" +checksum = "4dccd0940a2dcdf68d092b8cbab7dc0ad8fa938bf95787e1b916b0e3d0e8e970" [[package]] name = "smol_str" @@ -2197,9 +2339,9 @@ dependencies = [ [[package]] name = "socket2" -version = "0.4.9" +version = "0.4.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "64a4a911eed85daf18834cfaa86a79b7d266ff93ff5ba14005426219480ed662" +checksum = "9f7916fc008ca5542385b89a3d3ce689953c143e9304a9bf8beec1de48994c0d" dependencies = [ "libc", "winapi", @@ -2207,12 +2349,12 @@ dependencies = [ [[package]] name = "socket2" -version = "0.5.3" +version = "0.5.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2538b18701741680e0322a2302176d3253a35388e2e62f172f64f4f16605f877" +checksum = "7b5fac59a5cb5dd637972e5fca70daf0523c9067fcdc4842f053dae04a18f8e9" dependencies = [ "libc", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] @@ -2232,20 +2374,14 @@ dependencies = [ [[package]] name = "spki" -version = "0.6.0" +version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "67cf02bbac7a337dc36e4f5a693db6c21e7863f45070f7064577eb4367a3212b" +checksum = "9d1e996ef02c474957d681f1b05213dfb0abab947b446a62d37770b23500184a" dependencies = [ "base64ct", "der", ] -[[package]] -name = "static_assertions" -version = "1.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f" - [[package]] name = "strsim" version = "0.10.0" @@ -2271,47 +2407,67 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.18" +version = "2.0.39" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "32d41677bcbe24c20c52e7c70b0d8db04134c5d1066bf98662e2871ad200ea3e" +checksum = "23e78b90f2fcf45d3e842032ce32e3f2d1545ba6636271dcbf24fa306d87be7a" dependencies = [ "proc-macro2", "quote", "unicode-ident", ] +[[package]] +name = "system-configuration" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ba3a3adc5c275d719af8cb4272ea1c4a6d668a777f37e115f6d11ddbc1c8e0e7" +dependencies = [ + "bitflags 1.3.2", + "core-foundation", + "system-configuration-sys", +] + +[[package]] +name = "system-configuration-sys" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75fb188eb626b924683e3b95e3a48e63551fcfb51949de2f06a9d91dbee93c9" +dependencies = [ + "core-foundation-sys", + "libc", +] + [[package]] name = "tempfile" -version = "3.6.0" +version = "3.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "31c0432476357e58790aaa47a8efb0c5138f137343f3b5f23bd36a27e3b0a6d6" +checksum = "7ef1adac450ad7f4b3c28589471ade84f25f731a7a0fe30d71dfa9f60fd808e5" dependencies = [ - "autocfg", "cfg-if", "fastrand", "redox_syscall", "rustix", - "windows-sys 0.48.0", + "windows-sys", ] [[package]] name = "thiserror" -version = "1.0.40" +version = "1.0.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "978c9a314bd8dc99be594bc3c175faaa9794be04a5a5e153caba6915336cebac" +checksum = "f9a7210f5c9a7156bb50aa36aed4c95afb51df0df00713949448cf9e97d382d2" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.40" +version = "1.0.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f9456a42c5b0d803c8cd86e73dd7cc9edd429499f37a3550d286d5e86720569f" +checksum = "266b2e40bc00e5a6c09c3584011e08b06f123c00362c92b975ba9843aaaa14b8" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] @@ -2335,11 +2491,13 @@ dependencies = [ [[package]] name = "time" -version = "0.3.22" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ea9e1b3cf1243ae005d9e74085d4d542f3125458f3a81af210d901dcd7411efd" +checksum = "c4a34ab300f2dee6e562c10a046fc05e358b29f9bf92277f30c3c8d82275f6f5" dependencies = [ + "deranged", "itoa", + "powerfmt", "serde", "time-core", "time-macros", @@ -2347,15 +2505,15 @@ dependencies = [ [[package]] name = "time-core" -version = "0.1.1" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7300fbefb4dadc1af235a9cef3737cea692a9d97e1b9cbcd4ebdae6f8868e6fb" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" [[package]] name = "time-macros" -version = "0.2.9" +version = "0.2.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "372950940a5f07bf38dbe211d7283c9e6d7327df53794992d293e534c733d09b" +checksum = "4ad70d68dba9e1f8aceda7aa6711965dfec1cac869f311a51bd08b3a2ccbce20" dependencies = [ "time-core", ] @@ -2377,18 +2535,18 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.28.2" +version = "1.34.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94d7b1cfd2aa4011f2de74c2c4c63665e27a71006b0a192dcd2710272e73dfa2" +checksum = "d0c014766411e834f7af5b8f4cf46257aab4036ca95e9d2c144a10f59ad6f5b9" dependencies = [ - "autocfg", + "backtrace", "bytes", "libc", "mio", "num_cpus", "pin-project-lite", - "socket2 0.4.9", - "windows-sys 0.48.0", + "socket2 0.5.5", + "windows-sys", ] [[package]] @@ -2403,9 +2561,9 @@ dependencies = [ [[package]] name = "tokio-util" -version = "0.7.8" +version = "0.7.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "806fe8c2c87eccc8b3267cbae29ed3ab2d0bd37fca70ab622e46aaa9375ddb7d" +checksum = "5419f34732d9eb6ee4c3578b7989078579b7f039cbbb9ca2c4da015749371e15" dependencies = [ "bytes", "futures-core", @@ -2417,9 +2575,9 @@ dependencies = [ [[package]] name = "toml" -version = "0.7.4" +version = "0.8.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6135d499e69981f9ff0ef2167955a5333c35e36f6937d382974566b3d5b94ec" +checksum = "a1a195ec8c9da26928f773888e0742ca3ca1040c6cd859c919c9f59c1954ab35" dependencies = [ "serde", "serde_spanned", @@ -2429,20 +2587,20 @@ dependencies = [ [[package]] name = "toml_datetime" -version = "0.6.2" +version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a76a9312f5ba4c2dec6b9161fdf25d87ad8a09256ccea5a556fef03c706a10f" +checksum = "3550f4e9685620ac18a50ed434eb3aec30db8ba93b0287467bca5826ea25baf1" dependencies = [ "serde", ] [[package]] name = "toml_edit" -version = "0.19.10" +version = "0.21.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2380d56e8670370eee6566b0bfd4265f65b3f432e8c6d85623f728d4fa31f739" +checksum = "d34d383cd00a163b4a5b85053df514d45bc330f6de7737edfe0a93311d1eaa03" dependencies = [ - "indexmap", + "indexmap 2.1.0", "serde", "serde_spanned", "toml_datetime", @@ -2457,11 +2615,10 @@ checksum = "b6bc1c9ce2b5135ac7f93c72918fc37feb872bdc6a5533a8b85eb4b86bfdae52" [[package]] name = "tracing" -version = "0.1.37" +version = "0.1.40" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ce8c33a8d48bd45d624a6e523445fd21ec13d3653cd51f681abf67418f54eb8" +checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" dependencies = [ - "cfg-if", "pin-project-lite", "tracing-attributes", "tracing-core", @@ -2469,20 +2626,20 @@ dependencies = [ [[package]] name = "tracing-attributes" -version = "0.1.26" +version = "0.1.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f4f31f56159e98206da9efd823404b79b6ef3143b4a7ab76e67b1751b25a4ab" +checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", ] [[package]] name = "tracing-core" -version = "0.1.31" +version = "0.1.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0955b8137a1df6f1a2e9a37d8a6656291ff0297c1a97c24e0d8425fe2312f79a" +checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" dependencies = [ "once_cell", "valuable", @@ -2490,20 +2647,20 @@ dependencies = [ [[package]] name = "tracing-log" -version = "0.1.3" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "78ddad33d2d10b1ed7eb9d1f518a5674713876e97e5bb9b7345a7984fbb4f922" +checksum = "ee855f1f400bd0e5c02d150ae5de3840039a3f54b025156404e34c23c03f47c3" dependencies = [ - "lazy_static", "log", + "once_cell", "tracing-core", ] [[package]] name = "tracing-subscriber" -version = "0.3.17" +version = "0.3.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "30a651bc37f915e81f087d86e62a18eec5f79550c7faff886f7090b4ea757c77" +checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b" dependencies = [ "matchers", "nu-ansi-term", @@ -2525,9 +2682,9 @@ checksum = "3528ecfd12c466c6f163363caf2d02a71161dd5e1cc6ae7b34207ea2d42d81ed" [[package]] name = "typenum" -version = "1.16.0" +version = "1.17.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "497961ef93d974e23eb6f433eb5fe1b7930b659f06d12dec6fc44a8f554c0bba" +checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825" [[package]] name = "unicode-bidi" @@ -2537,9 +2694,9 @@ checksum = "92888ba5573ff080736b3648696b70cafad7d250551175acbaa4e0385b3e1460" [[package]] name = "unicode-ident" -version = "1.0.9" +version = "1.0.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b15811caf2415fb889178633e7724bad2509101cde276048e013b9def5e51fa0" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" [[package]] name = "unicode-normalization" @@ -2552,15 +2709,15 @@ dependencies = [ [[package]] name = "untrusted" -version = "0.7.1" +version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" +checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" [[package]] name = "url" -version = "2.4.0" +version = "2.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50bff7831e19200a85b17131d085c25d7811bc4e186efdaf54bbd132994a88cb" +checksum = "143b538f18257fac9cad154828a57c6bf5157e1aa604d4816b5995bf6de87ae5" dependencies = [ "form_urlencoded", "idna", @@ -2609,9 +2766,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.87" +version = "0.2.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7706a72ab36d8cb1f80ffbf0e071533974a60d0a308d01a5d0375bf60499a342" +checksum = "7daec296f25a1bae309c0cd5c29c4b260e510e6d813c286b19eaadf409d40fce" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -2619,24 +2776,24 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.87" +version = "0.2.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ef2b6d3c510e9625e5fe6f509ab07d66a760f0885d858736483c32ed7809abd" +checksum = "e397f4664c0e4e428e8313a469aaa58310d302159845980fd23b0f22a847f217" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.37" +version = "0.4.38" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c02dbc21516f9f1f04f187958890d7e6026df8d16540b7ad9492bc34a67cea03" +checksum = "9afec9963e3d0994cac82455b2b3502b81a7f40f9a0d32181f7528d9f4b43e02" dependencies = [ "cfg-if", "js-sys", @@ -2646,9 +2803,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.87" +version = "0.2.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dee495e55982a3bd48105a7b947fd2a9b4a8ae3010041b9e0faab3f9cd028f1d" +checksum = "5961017b3b08ad5f3fe39f1e79877f8ee7c23c5e5fd5eb80de95abc41f1f16b2" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -2656,60 +2813,38 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.87" +version = "0.2.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54681b18a46765f095758388f2d0cf16eb8d4169b639ab575a8f5693af210c7b" +checksum = "c5353b8dab669f5e10f5bd76df26a9360c748f054f862ff5f3f8aae0c7fb3907" dependencies = [ "proc-macro2", "quote", - "syn 2.0.18", + "syn 2.0.39", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.87" +version = "0.2.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca6ad05a4870b2bf5fe995117d3728437bd27d7cd5f06f13c17443ef369775a1" +checksum = "0d046c5d029ba91a1ed14da14dca44b68bf2f124cfbaf741c54151fdb3e0750b" [[package]] name = "web-sys" -version = "0.3.64" +version = "0.3.65" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b85cbef8c220a6abc02aefd892dfc0fc23afb1c6a426316ec33253a3877249b" +checksum = "5db499c5f66323272151db0e666cd34f78617522fb0c1604d31a27c50c206a85" dependencies = [ "js-sys", "wasm-bindgen", ] -[[package]] -name = "webpki" -version = "0.22.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f095d78192e208183081cc07bc5515ef55216397af48b873e5edcd72637fa1bd" -dependencies = [ - "ring", - "untrusted", -] - -[[package]] -name = "webpki-roots" -version = "0.22.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b6c71e40d7d2c34a5106301fb632274ca37242cd0c9d3e64dbece371a40a2d87" -dependencies = [ - "webpki", -] - [[package]] name = "webpki-roots" -version = "0.23.1" +version = "0.25.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b03058f88386e5ff5310d9111d53f48b17d732b401aeb83a8d5190f2ac459338" -dependencies = [ - "rustls-webpki", -] +checksum = "14247bb57be4f377dfb94c72830b8ce8fc6beac03cf4bf7b9732eadd414123fc" [[package]] name = "winapi" @@ -2734,29 +2869,14 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" [[package]] -name = "windows" -version = "0.48.0" +name = "windows-core" +version = "0.51.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f" +checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" dependencies = [ "windows-targets", ] -[[package]] -name = "windows-sys" -version = "0.42.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a3e1820f08b8513f676f7ab6c1f99ff312fb97b553d30ff4dd86f9f15728aa7" -dependencies = [ - "windows_aarch64_gnullvm 0.42.2", - "windows_aarch64_msvc 0.42.2", - "windows_i686_gnu 0.42.2", - "windows_i686_msvc 0.42.2", - "windows_x86_64_gnu 0.42.2", - "windows_x86_64_gnullvm 0.42.2", - "windows_x86_64_msvc 0.42.2", -] - [[package]] name = "windows-sys" version = "0.48.0" @@ -2768,123 +2888,82 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b1eb6f0cd7c80c79759c929114ef071b87354ce476d9d94271031c0497adfd5" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm 0.48.0", - "windows_aarch64_msvc 0.48.0", - "windows_i686_gnu 0.48.0", - "windows_i686_msvc 0.48.0", - "windows_x86_64_gnu 0.48.0", - "windows_x86_64_gnullvm 0.48.0", - "windows_x86_64_msvc 0.48.0", + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", ] [[package]] name = "windows_aarch64_gnullvm" -version = "0.42.2" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "597a5118570b68bc08d8d59125332c54f1ba9d9adeedeef5b99b02ba2b0698f8" - -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.48.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" - -[[package]] -name = "windows_aarch64_msvc" -version = "0.42.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e08e8864a60f06ef0d0ff4ba04124db8b0fb3be5776a5cd47641e942e58c4d43" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_msvc" -version = "0.48.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" - -[[package]] -name = "windows_i686_gnu" -version = "0.42.2" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c61d927d8da41da96a81f029489353e68739737d3beca43145c8afec9a31a84f" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_i686_gnu" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_msvc" -version = "0.42.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "44d840b6ec649f480a41c8d80f9c65108b92d89345dd94027bfe06ac444d1060" - -[[package]] -name = "windows_i686_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_x86_64_gnu" -version = "0.42.2" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8de912b8b8feb55c064867cf047dda097f92d51efad5b491dfb98f6bbb70cb36" - -[[package]] -name = "windows_x86_64_gnu" -version = "0.48.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnullvm" -version = "0.42.2" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26d41b46a36d453748aedef1486d5c7a85db22e56aff34643984ea85514e94a3" - -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.48.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" - -[[package]] -name = "windows_x86_64_msvc" -version = "0.42.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9aec5da331524158c6d1a4ac0ab1541149c0b9505fde06423b02f5ef0106b9f0" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "winnow" -version = "0.4.7" +version = "0.5.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca0ace3845f0d96209f0375e6d367e3eb87eb65d27d445bdc9f1843a26f39448" +checksum = "829846f3e3db426d4cee4510841b71a8e58aa2a76b1132579487ae430ccd9c7b" dependencies = [ "memchr", ] [[package]] name = "winreg" -version = "0.10.1" +version = "0.50.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80d0f4e272c85def139476380b12f9ac60926689dd2e01d4923222f40580869d" +checksum = "524e57b2c537c0f9b1e69f1965311ec12182b4122e45035b1508cd24d2adadb1" dependencies = [ - "winapi", + "cfg-if", + "windows-sys", ] [[package]] name = "zeroize" -version = "1.6.0" +version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2a0956f1ba7c7909bfb66c2e9e4124ab6f6482560f6628b5aaeba39207c9aad9" +checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d" diff --git a/Cargo.toml b/Cargo.toml index 89d5a05..7b04e1b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -3,15 +3,19 @@ members = ["monolake", "monolake-core", "monolake-services"] resolver = "2" [workspace.dependencies] -monoio = "0.1.8" -monoio-http = "0.2.4" -monoio-http-client = "0.2.5" -monoio-native-tls = "0.1.0" -monoio-rustls = "0.1.5" +monoio = "0.2.0" +monoio-http = "0.3.0" +monoio-http-client = "0.3.0" +monoio-native-tls = "0.3.0" +monoio-rustls = "0.3.0" native-tls = "0.2" -service-async = "0.1.13" +service-async = "0.2.0" certain-map = "0.2.4" local-sync = "0.1" +http = "1.0" +anyhow = "1" +serde = "1" +tracing = "0.1" [profile.release-lto] inherits = "release" diff --git a/examples/config.toml b/examples/config.toml index 42826bd..5530dcd 100644 --- a/examples/config.toml +++ b/examples/config.toml @@ -1,20 +1,22 @@ [runtime] # runtime_type = "legacy" workers = 1 -entries = 8192 +entries = 1024 [servers.server_basic] name = "proxy.monolake.rs" -listener = { type = "socket", value = "0.0.0.0:9081" } +listener = { type = "socket", value = "0.0.0.0:8080" } [[servers.server_basic.routes]] path = '/' -upstreams = [{ endpoint = { type = "uri", value = "http://127.0.0.1:8080" }, version = "HTTP2" }] +upstreams = [ + { endpoint = { type = "uri", value = "http://127.0.0.1:9080" }, version = "HTTP2" }, +] [[servers.server_basic.routes]] path = '/*p' -upstreams = [{ endpoint = { type = "uri", value = "http://127.0.0.1:8080" } }] +upstreams = [{ endpoint = { type = "uri", value = "http://127.0.0.1:9080" } }] [servers.server_tls] @@ -58,7 +60,9 @@ listener = { type = "socket", value = "0.0.0.0:8082" } [[servers.server3.routes]] path = '/' -upstreams = [{ endpoint = { type = "uri", value = "https://rsproxy.cn" } }] +upstreams = [ + { endpoint = { type = "uri", value = "https://www.wikipedia.org" } }, +] [servers.server4] diff --git a/monolake-core/Cargo.toml b/monolake-core/Cargo.toml index f8fe41f..fb3d423 100644 --- a/monolake-core/Cargo.toml +++ b/monolake-core/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "monolake-core" -version = "0.2.0" +version = "0.3.0" edition = "2021" [features] @@ -11,18 +11,15 @@ proxy-protocol = [] monoio = { workspace = true, features = ["splice", "sync"] } monoio-http = { workspace = true } service-async = { workspace = true } - -anyhow = "1" -tracing = "0.1" +http = { workspace = true } +anyhow = { workspace = true } +serde = { workspace = true, features = ["derive"] } +tracing = { workspace = true } # futures futures-util = { version = "0.3", features = ["sink"] } futures-channel = { version = "0.3", features = ["sink"] } -http = "0.2" -http-serde = "1" -serde = "1" - sha2 = "0" hex = "0" derive_more = "0.99.0" diff --git a/monolake-core/src/http/mod.rs b/monolake-core/src/http/mod.rs index d0a3c73..72fff52 100644 --- a/monolake-core/src/http/mod.rs +++ b/monolake-core/src/http/mod.rs @@ -15,12 +15,12 @@ pub type HttpAccept = (bool, Stream, CX); pub trait HttpHandler: SealedT { type Error; - type Future<'a>: Future> - where - Self: 'a, - CX: 'a; - fn handle(&self, request: Request, ctx: CX) -> Self::Future<'_>; + fn handle( + &self, + request: Request, + ctx: CX, + ) -> impl Future>; } impl SealedT for T where @@ -33,11 +33,12 @@ where T: Service<(Request, CX), Response = ResponseWithContinue>, { type Error = T::Error; - type Future<'a> = impl Future> + 'a - where - Self: 'a, CX: 'a; - fn handle(&self, req: Request, ctx: CX) -> Self::Future<'_> { - self.call((req, ctx)) + async fn handle( + &self, + req: Request, + ctx: CX, + ) -> Result { + self.call((req, ctx)).await } } diff --git a/monolake-core/src/lib.rs b/monolake-core/src/lib.rs index 8cfe4d5..22b2a0c 100644 --- a/monolake-core/src/lib.rs +++ b/monolake-core/src/lib.rs @@ -1,6 +1,3 @@ -#![feature(impl_trait_in_assoc_type)] -#![feature(type_alias_impl_trait)] - #[macro_use] mod error; pub use error::{AnyError, AnyResult}; diff --git a/monolake-core/src/listener.rs b/monolake-core/src/listener.rs index 160a3d2..e96e676 100644 --- a/monolake-core/src/listener.rs +++ b/monolake-core/src/listener.rs @@ -1,4 +1,4 @@ -use std::{future::Future, io, net::SocketAddr, path::Path}; +use std::{io, net::SocketAddr, path::Path}; use monoio::{ buf::{IoBuf, IoBufMut, IoVecBuf, IoVecBufMut}, @@ -65,31 +65,25 @@ pub enum Listener { impl Stream for Listener { type Item = io::Result<(AcceptedStream, AcceptedAddr)>; - type NextFuture<'a> = impl std::future::Future> + 'a - where - Self: 'a; - - fn next(&mut self) -> Self::NextFuture<'_> { - async move { - match self { - Listener::Tcp(l) => match l.next().await { - Some(Ok(accepted)) => Some(Ok(( - AcceptedStream::Tcp(accepted.0), - AcceptedAddr::Tcp(accepted.1), - ))), - Some(Err(e)) => Some(Err(e)), - None => None, - }, - #[cfg(unix)] - Listener::Unix(l) => match l.next().await { - Some(Ok(accepted)) => Some(Ok(( - AcceptedStream::Unix(accepted.0), - AcceptedAddr::Unix(accepted.1), - ))), - Some(Err(e)) => Some(Err(e)), - None => None, - }, - } + async fn next(&mut self) -> Option { + match self { + Listener::Tcp(l) => match l.next().await { + Some(Ok(accepted)) => Some(Ok(( + AcceptedStream::Tcp(accepted.0), + AcceptedAddr::Tcp(accepted.1), + ))), + Some(Err(e)) => Some(Err(e)), + None => None, + }, + #[cfg(unix)] + Listener::Unix(l) => match l.next().await { + Some(Ok(accepted)) => Some(Ok(( + AcceptedStream::Unix(accepted.0), + AcceptedAddr::Unix(accepted.1), + ))), + Some(Err(e)) => Some(Err(e)), + None => None, + }, } } } @@ -123,81 +117,51 @@ impl From for AcceptedAddr { } impl AsyncReadRent for AcceptedStream { - type ReadFuture<'a, B> = impl Future> +'a - where - B: IoBufMut + 'a, Self: 'a; - type ReadvFuture<'a, B> = impl Future> + 'a - where - B: IoVecBufMut + 'a, Self: 'a; - - fn read(&mut self, buf: T) -> Self::ReadFuture<'_, T> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.read(buf).await, - AcceptedStream::Unix(inner) => inner.read(buf).await, - } + async fn read(&mut self, buf: T) -> BufResult { + match self { + AcceptedStream::Tcp(inner) => inner.read(buf).await, + AcceptedStream::Unix(inner) => inner.read(buf).await, } } - fn readv(&mut self, buf: T) -> Self::ReadvFuture<'_, T> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.readv(buf).await, - AcceptedStream::Unix(inner) => inner.readv(buf).await, - } + async fn readv(&mut self, buf: T) -> BufResult { + match self { + AcceptedStream::Tcp(inner) => inner.readv(buf).await, + AcceptedStream::Unix(inner) => inner.readv(buf).await, } } } impl AsyncWriteRent for AcceptedStream { - type WriteFuture<'a, T> = impl Future> + 'a - where - T: IoBuf + 'a, Self: 'a; - - type WritevFuture<'a, T>= impl Future> + 'a where - T: IoVecBuf + 'a, Self: 'a; - - type FlushFuture<'a> = impl Future> + 'a where Self: 'a; - - type ShutdownFuture<'a> = impl Future> + 'a where Self: 'a; - #[inline] - fn write(&mut self, buf: T) -> Self::WriteFuture<'_, T> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.write(buf).await, - AcceptedStream::Unix(inner) => inner.write(buf).await, - } + async fn write(&mut self, buf: T) -> BufResult { + match self { + AcceptedStream::Tcp(inner) => inner.write(buf).await, + AcceptedStream::Unix(inner) => inner.write(buf).await, } } #[inline] - fn writev(&mut self, buf_vec: T) -> Self::WritevFuture<'_, T> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.writev(buf_vec).await, - AcceptedStream::Unix(inner) => inner.writev(buf_vec).await, - } + async fn writev(&mut self, buf_vec: T) -> BufResult { + match self { + AcceptedStream::Tcp(inner) => inner.writev(buf_vec).await, + AcceptedStream::Unix(inner) => inner.writev(buf_vec).await, } } #[inline] - fn flush(&mut self) -> Self::FlushFuture<'_> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.flush().await, - AcceptedStream::Unix(inner) => inner.flush().await, - } + async fn flush(&mut self) -> io::Result<()> { + match self { + AcceptedStream::Tcp(inner) => inner.flush().await, + AcceptedStream::Unix(inner) => inner.flush().await, } } #[inline] - fn shutdown(&mut self) -> Self::ShutdownFuture<'_> { - async move { - match self { - AcceptedStream::Tcp(inner) => inner.shutdown().await, - AcceptedStream::Unix(inner) => inner.shutdown().await, - } + async fn shutdown(&mut self) -> io::Result<()> { + match self { + AcceptedStream::Tcp(inner) => inner.shutdown().await, + AcceptedStream::Unix(inner) => inner.shutdown().await, } } } diff --git a/monolake-core/src/util/mod.rs b/monolake-core/src/util/mod.rs index 4ce0689..0e56d7e 100644 --- a/monolake-core/src/util/mod.rs +++ b/monolake-core/src/util/mod.rs @@ -3,6 +3,7 @@ use std::path::Path; use monoio::buf::IoBufMut; pub mod hash; +pub mod uri_serde; pub async fn file_read(path: impl AsRef) -> std::io::Result> { // since monoio has not support statx, we have to use std diff --git a/monolake-core/src/util/uri_serde.rs b/monolake-core/src/util/uri_serde.rs new file mode 100644 index 0000000..e3a4195 --- /dev/null +++ b/monolake-core/src/util/uri_serde.rs @@ -0,0 +1,17 @@ +use http::Uri; +use serde::{de, Deserialize, Deserializer, Serializer}; + +pub fn deserialize<'de, D>(deserializer: D) -> Result +where + D: Deserializer<'de>, +{ + let s = String::deserialize(deserializer)?; + s.parse().map_err(de::Error::custom) +} + +pub fn serialize(uri: &Uri, serializer: S) -> Result +where + S: Serializer, +{ + serializer.serialize_str(&uri.to_string()) +} diff --git a/monolake-services/Cargo.toml b/monolake-services/Cargo.toml index edafd70..68ab666 100644 --- a/monolake-services/Cargo.toml +++ b/monolake-services/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "monolake-services" -version = "0.1.1" +version = "0.3.0" edition = "2021" [features] @@ -26,27 +26,28 @@ vendored = ["native-tls?/vendored"] monoio = { workspace = true, features = ['splice'] } monolake-core = { path = "../monolake-core" } monoio-http = { workspace = true } -monoio-http-client = { workspace = true, features = ["logging", "rustls-unsafe-io"] } +monoio-http-client = { workspace = true, features = [ + "logging", + "rustls-unsafe-io", +] } local-sync = { workspace = true } service-async = { workspace = true } +http = { workspace = true } +anyhow = { workspace = true } +serde = { workspace = true } +tracing = { workspace = true } # tls monoio-rustls = { workspace = true, optional = true } -rustls = { version = "0.21", optional = true } -rustls-pemfile = { version = "1", optional = true } -webpki-roots = { version = "0.23", optional = true } monoio-native-tls = { workspace = true, optional = true } native-tls = { workspace = true, optional = true } +rustls = { version = "0.21", optional = true, default-features = false } +rustls-pemfile = { version = "1", optional = true } +webpki-roots = { version = "0.25.2", optional = true } + # common -anyhow = "1" -tracing = "0.1" -http = "0.2" bytes = "1" - -http-serde = "1" -serde = "1" - async-channel = "1" rand = "0.8" matchit = "0.7" diff --git a/monolake-services/src/common/context.rs b/monolake-services/src/common/context.rs index 3310057..92a40b2 100644 --- a/monolake-services/src/common/context.rs +++ b/monolake-services/src/common/context.rs @@ -1,5 +1,3 @@ -use std::future::Future; - use monolake_core::{context::PeerAddr, listener::AcceptedAddr}; use service_async::{ layer::{layer_fn, FactoryLayer}, @@ -21,14 +19,10 @@ where { type Response = T::Response; type Error = T::Error; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - R: 'cx; - fn call(&self, (req, addr): (R, AcceptedAddr)) -> Self::Future<'_> { + async fn call(&self, (req, addr): (R, AcceptedAddr)) -> Result { let ctx = self.ctx.clone().param_set(PeerAddr(addr)); - self.inner.call((req, ctx)) + self.inner.call((req, ctx)).await } } diff --git a/monolake-services/src/common/delay.rs b/monolake-services/src/common/delay.rs index 2d59892..405bffe 100644 --- a/monolake-services/src/common/delay.rs +++ b/monolake-services/src/common/delay.rs @@ -1,4 +1,4 @@ -use std::{future::Future, time::Duration}; +use std::time::Duration; use service_async::{ layer::{layer_fn, FactoryLayer}, @@ -19,16 +19,9 @@ where type Error = T::Error; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - R: 'cx; - - fn call(&self, req: R) -> Self::Future<'_> { - async { - monoio::time::sleep(self.delay).await; - self.inner.call(req).await - } + async fn call(&self, req: R) -> Result { + monoio::time::sleep(self.delay).await; + self.inner.call(req).await } } diff --git a/monolake-services/src/common/erase.rs b/monolake-services/src/common/erase.rs index 18a8f29..ea415bd 100644 --- a/monolake-services/src/common/erase.rs +++ b/monolake-services/src/common/erase.rs @@ -1,4 +1,3 @@ -use futures::Future; use service_async::{ layer::{layer_fn, FactoryLayer}, MakeService, Service, @@ -26,17 +25,11 @@ impl MakeService for EraseResp { impl, Req> Service for EraseResp { type Response = (); - type Error = T::Error; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - Req: 'cx; - #[inline] - fn call(&self, req: Req) -> Self::Future<'_> { - async move { self.svc.call(req).await.map(|_| ()) } + async fn call(&self, req: Req) -> Result { + self.svc.call(req).await.map(|_| ()) } } diff --git a/monolake-services/src/common/timeout.rs b/monolake-services/src/common/timeout.rs index 571cfc4..6dfa0ad 100644 --- a/monolake-services/src/common/timeout.rs +++ b/monolake-services/src/common/timeout.rs @@ -1,4 +1,4 @@ -use std::{future::Future, time::Duration}; +use std::time::Duration; use monoio::time::timeout; use monolake_core::AnyError; @@ -19,21 +19,13 @@ where T::Error: Into, { type Response = T::Response; - type Error = AnyError; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - R: 'cx; - - fn call(&self, req: R) -> Self::Future<'_> { - async { - match timeout(self.timeout, self.inner.call(req)).await { - Ok(Ok(resp)) => Ok(resp), - Ok(Err(err)) => Err(err.into()), - Err(e) => Err(e.into()), - } + async fn call(&self, req: R) -> Result { + match timeout(self.timeout, self.inner.call(req)).await { + Ok(Ok(resp)) => Ok(resp), + Ok(Err(err)) => Err(err.into()), + Err(e) => Err(e.into()), } } } diff --git a/monolake-services/src/http/core.rs b/monolake-services/src/http/core.rs index 625f29b..1074309 100644 --- a/monolake-services/src/http/core.rs +++ b/monolake-services/src/http/core.rs @@ -1,4 +1,4 @@ -use std::{convert::Infallible, fmt::Debug, future::Future, pin::Pin, time::Duration}; +use std::{convert::Infallible, fmt::Debug, pin::Pin, time::Duration}; use bytes::Bytes; use futures::{stream::FuturesUnordered, FutureExt, StreamExt}; @@ -27,7 +27,6 @@ use service_async::{ use tracing::{error, info, warn}; use super::{generate_response, util::AccompanyPair}; -use crate::tcp::Accept; #[derive(Clone)] pub struct HttpCoreService { @@ -257,20 +256,18 @@ where { type Response = (); type Error = Infallible; - type Future<'a> = impl Future> + 'a - where - Self: 'a, Accept: 'a; - fn call(&self, incoming_stream: HttpAccept) -> Self::Future<'_> { - async move { - let (use_h2, stream, ctx) = incoming_stream; - if use_h2 { - self.h2_svc(stream, ctx).await - } else { - self.h1_svc(stream, ctx).await - } - Ok(()) + async fn call( + &self, + incoming_stream: HttpAccept, + ) -> Result { + let (use_h2, stream, ctx) = incoming_stream; + if use_h2 { + self.h2_svc(stream, ctx).await + } else { + self.h1_svc(stream, ctx).await } + Ok(()) } } diff --git a/monolake-services/src/http/detect.rs b/monolake-services/src/http/detect.rs index 5ab6f1a..62eae18 100644 --- a/monolake-services/src/http/detect.rs +++ b/monolake-services/src/http/detect.rs @@ -1,4 +1,4 @@ -use std::{future::Future, io::Cursor}; +use std::io::Cursor; use monoio::{ buf::IoBufMut, @@ -47,50 +47,47 @@ where { type Response = T::Response; type Error = AnyError; - type Future<'a> = impl Future> + 'a - where - Self: 'a, - Accept: 'a; - fn call(&self, incoming_stream: Accept) -> Self::Future<'_> { - async move { - let (mut stream, addr) = incoming_stream; - let mut buf = vec![0; PREFACE.len()]; - let mut pos = 0; - let mut h2_detect = false; + async fn call( + &self, + incoming_stream: Accept, + ) -> Result { + let (mut stream, addr) = incoming_stream; + let mut buf = vec![0; PREFACE.len()]; + let mut pos = 0; + let mut h2_detect = false; - loop { - let buf_slice = unsafe { buf.slice_mut_unchecked(pos..PREFACE.len()) }; - let (result, buf_slice) = stream.read(buf_slice).await; - buf = buf_slice.into_inner(); - match result { - Ok(0) => { + loop { + let buf_slice = unsafe { buf.slice_mut_unchecked(pos..PREFACE.len()) }; + let (result, buf_slice) = stream.read(buf_slice).await; + buf = buf_slice.into_inner(); + match result { + Ok(0) => { + break; + } + Ok(n) => { + if PREFACE[pos..pos + n] != buf[pos..pos + n] { break; } - Ok(n) => { - if PREFACE[pos..pos + n] != buf[pos..pos + n] { - break; - } - pos += n; - } - Err(e) => { - return Err(e.into()); - } + pos += n; } - - if pos == PREFACE.len() { - h2_detect = true; - break; + Err(e) => { + return Err(e.into()); } } - let preface_buf = std::io::Cursor::new(buf); - let rewind_io = monoio::io::PrefixedReadIo::new(stream, preface_buf); - - self.inner - .call((h2_detect, rewind_io, addr)) - .await - .map_err(Into::into) + if pos == PREFACE.len() { + h2_detect = true; + break; + } } + + let preface_buf = std::io::Cursor::new(buf); + let rewind_io = monoio::io::PrefixedReadIo::new(stream, preface_buf); + + self.inner + .call((h2_detect, rewind_io, addr)) + .await + .map_err(Into::into) } } diff --git a/monolake-services/src/http/handlers/conn_reuse.rs b/monolake-services/src/http/handlers/conn_reuse.rs index 56fdfc6..3e058d1 100644 --- a/monolake-services/src/http/handlers/conn_reuse.rs +++ b/monolake-services/src/http/handlers/conn_reuse.rs @@ -1,5 +1,3 @@ -use std::future::Future; - use http::{Request, Version}; use monoio_http::common::body::HttpBody; use monolake_core::http::{HttpHandler, ResponseWithContinue}; @@ -24,68 +22,66 @@ where { type Response = ResponseWithContinue; type Error = H::Error; - type Future<'a> = impl Future> + 'a - where - Self: 'a, Request: 'a, CX: 'a; - - fn call(&self, (mut request, ctx): (Request, CX)) -> Self::Future<'_> { - async move { - let version = request.version(); - let keepalive = is_conn_keepalive(request.headers(), version); - debug!("frontend keepalive {:?}", keepalive); - match version { - // for http 1.0, hack it to 1.1 like setting nginx `proxy_http_version` to 1.1 - Version::HTTP_10 => { - // modify to 1.1 and remove connection header - *request.version_mut() = Version::HTTP_11; - let _ = request.headers_mut().remove(http::header::CONNECTION); + async fn call( + &self, + (mut request, ctx): (Request, CX), + ) -> Result { + let version = request.version(); + let keepalive = is_conn_keepalive(request.headers(), version); + debug!("frontend keepalive {:?}", keepalive); - // send - let (mut response, mut cont) = self.inner.handle(request, ctx).await?; - cont &= keepalive; + match version { + // for http 1.0, hack it to 1.1 like setting nginx `proxy_http_version` to 1.1 + Version::HTTP_10 => { + // modify to 1.1 and remove connection header + *request.version_mut() = Version::HTTP_11; + let _ = request.headers_mut().remove(http::header::CONNECTION); - // modify back and make sure reply keepalive if client want it and server - // support it. - let _ = response.headers_mut().remove(http::header::CONNECTION); - if cont { - // insert keepalive header - response - .headers_mut() - .insert(http::header::CONNECTION, KEEPALIVE_VALUE); - } - *response.version_mut() = version; + // send + let (mut response, mut cont) = self.inner.handle(request, ctx).await?; + cont &= keepalive; - Ok((response, cont)) + // modify back and make sure reply keepalive if client want it and server + // support it. + let _ = response.headers_mut().remove(http::header::CONNECTION); + if cont { + // insert keepalive header + response + .headers_mut() + .insert(http::header::CONNECTION, KEEPALIVE_VALUE); } - Version::HTTP_11 => { - // remove connection header - let _ = request.headers_mut().remove(http::header::CONNECTION); + *response.version_mut() = version; - // send - let (mut response, mut cont) = self.inner.handle(request, ctx).await?; - cont &= keepalive; + Ok((response, cont)) + } + Version::HTTP_11 => { + // remove connection header + let _ = request.headers_mut().remove(http::header::CONNECTION); - // modify back and make sure reply keepalive if client want it and server - // support it. - let _ = response.headers_mut().remove(http::header::CONNECTION); - if !cont { - // insert close header - response - .headers_mut() - .insert(http::header::CONNECTION, CLOSE_VALUE); - } - Ok((response, cont)) - } - Version::HTTP_2 => { - let (response, _) = self.inner.handle(request, ctx).await?; - Ok((response, true)) - } - // for http 0.9 and other versions, just relay it - _ => { - let (response, _) = self.inner.handle(request, ctx).await?; - Ok((response, false)) + // send + let (mut response, mut cont) = self.inner.handle(request, ctx).await?; + cont &= keepalive; + + // modify back and make sure reply keepalive if client want it and server + // support it. + let _ = response.headers_mut().remove(http::header::CONNECTION); + if !cont { + // insert close header + response + .headers_mut() + .insert(http::header::CONNECTION, CLOSE_VALUE); } + Ok((response, cont)) + } + Version::HTTP_2 => { + let (response, _) = self.inner.handle(request, ctx).await?; + Ok((response, true)) + } + // for http 0.9 and other versions, just relay it + _ => { + let (response, _) = self.inner.handle(request, ctx).await?; + Ok((response, false)) } } } diff --git a/monolake-services/src/http/handlers/content_handler.rs b/monolake-services/src/http/handlers/content_handler.rs index 6eec9b6..5d1a866 100644 --- a/monolake-services/src/http/handlers/content_handler.rs +++ b/monolake-services/src/http/handlers/content_handler.rs @@ -1,5 +1,3 @@ -use std::future::Future; - use http::{Request, StatusCode}; use monoio_http::common::{ body::{BodyExt, FixedBody, HttpBody}, @@ -24,67 +22,65 @@ where { type Response = ResponseWithContinue; type Error = H::Error; - type Future<'a> = impl Future> + 'a - where - Self: 'a, Request: 'a, CX: 'a; - fn call(&self, (request, ctx): (Request, CX)) -> Self::Future<'_> { - async move { - let content_encoding = request - .headers() - .get(http::header::CONTENT_ENCODING) - .and_then(|value: &http::HeaderValue| value.to_str().ok()) - .unwrap_or("identity") - .to_string(); + async fn call( + &self, + (request, ctx): (Request, CX), + ) -> Result { + let content_encoding = request + .headers() + .get(http::header::CONTENT_ENCODING) + .and_then(|value: &http::HeaderValue| value.to_str().ok()) + .unwrap_or("identity") + .to_string(); - let accept_encoding = request - .headers() - .get(http::header::ACCEPT_ENCODING) - .and_then(|value| value.to_str().ok()) - .unwrap_or("identity") - .to_string(); + let accept_encoding = request + .headers() + .get(http::header::ACCEPT_ENCODING) + .and_then(|value| value.to_str().ok()) + .unwrap_or("identity") + .to_string(); - let content_length = request - .headers() - .get(http::header::CONTENT_LENGTH) - .and_then(|value| value.to_str().ok()) - .map(|value| value.parse::().unwrap_or_default()) - .unwrap_or_default(); + let content_length = request + .headers() + .get(http::header::CONTENT_LENGTH) + .and_then(|value| value.to_str().ok()) + .map(|value| value.parse::().unwrap_or_default()) + .unwrap_or_default(); - if content_length == 0 || content_encoding == "identity" { - let (response, _) = self.inner.handle(request, ctx).await?; - return Ok((response, true)); - } + if content_length == 0 || content_encoding == "identity" { + let (response, _) = self.inner.handle(request, ctx).await?; + return Ok((response, true)); + } - let (parts, body) = request.into_parts(); - match body.decode_content(content_encoding).await { - Ok(decodec_data) => { - let req = Request::from_parts(parts, HttpBody::fixed_body(Some(decodec_data))); - let (mut response, _) = self.inner.handle(req, ctx).await?; - if accept_encoding != "identity" { - let (parts, body) = response.into_parts(); - match body.encode_content(accept_encoding).await { - Ok(encoded_data) => { - response = Response::from_parts( - parts, - HttpBody::fixed_body(Some(encoded_data)), - ) - } - Err(e) => { - tracing::error!("Response content encoding failed {}", e); - return Ok(( - generate_response(StatusCode::INTERNAL_SERVER_ERROR, false), - true, - )); - } + let (parts, body) = request.into_parts(); + match body.decode_content(content_encoding).await { + Ok(decodec_data) => { + let req = Request::from_parts(parts, HttpBody::fixed_body(Some(decodec_data))); + let (mut response, _) = self.inner.handle(req, ctx).await?; + if accept_encoding != "identity" { + let (parts, body) = response.into_parts(); + match body.encode_content(accept_encoding).await { + Ok(encoded_data) => { + response = Response::from_parts( + parts, + HttpBody::fixed_body(Some(encoded_data)), + ) + } + Err(e) => { + tracing::error!("Response content encoding failed {}", e); + return Ok(( + generate_response(StatusCode::INTERNAL_SERVER_ERROR, false), + true, + )); } } - Ok((response, true)) - } - Err(e) => { - tracing::error!("Request content decode failed {}", e); - Ok((generate_response(StatusCode::BAD_REQUEST, false), true)) } + Ok((response, true)) + } + Err(e) => { + tracing::error!("Request content decode failed {}", e); + Ok((generate_response(StatusCode::BAD_REQUEST, false), true)) } } } diff --git a/monolake-services/src/http/handlers/proxy.rs b/monolake-services/src/http/handlers/proxy.rs index d4f2791..d74b3b4 100644 --- a/monolake-services/src/http/handlers/proxy.rs +++ b/monolake-services/src/http/handlers/proxy.rs @@ -1,4 +1,4 @@ -use std::{convert::Infallible, future::Future}; +use std::convert::Infallible; use bytes::Bytes; use http::{header, HeaderMap, HeaderValue, Request, StatusCode}; @@ -34,19 +34,18 @@ where { type Response = ResponseWithContinue; type Error = Infallible; - type Future<'a> = impl Future> + 'a - where - Self: 'a, CX: 'a; - fn call(&self, (mut req, ctx): (Request, CX)) -> Self::Future<'_> { + async fn call( + &self, + (mut req, ctx): (Request, CX), + ) -> Result { add_xff_header(req.headers_mut(), &ctx); - async move { - match self.client.send_request(req).await { - Ok(resp) => Ok((resp, true)), - // Bad gateway should not affect inbound connection. - // It should still be keepalive. - Err(_e) => Ok((generate_response(StatusCode::BAD_GATEWAY, false), true)), - } + + match self.client.send_request(req).await { + Ok(resp) => Ok((resp, true)), + // Bad gateway should not affect inbound connection. + // It should still be keepalive. + Err(_e) => Ok((generate_response(StatusCode::BAD_GATEWAY, false), true)), } } } diff --git a/monolake-services/src/http/handlers/rewrite.rs b/monolake-services/src/http/handlers/rewrite.rs index e55637c..4172190 100644 --- a/monolake-services/src/http/handlers/rewrite.rs +++ b/monolake-services/src/http/handlers/rewrite.rs @@ -1,9 +1,10 @@ -use std::future::Future; - use http::{uri::Scheme, HeaderValue, Request, StatusCode, Version}; use matchit::Router; use monoio_http::common::body::HttpBody; -use monolake_core::http::{HttpHandler, ResponseWithContinue}; +use monolake_core::{ + http::{HttpHandler, ResponseWithContinue}, + util::uri_serde, +}; use rand::RngCore; use serde::{Deserialize, Serialize}; use service_async::{ @@ -26,32 +27,30 @@ where { type Response = ResponseWithContinue; type Error = H::Error; - type Future<'a> = impl Future> + 'a - where - Self: 'a, CX: 'a; - - fn call(&self, (mut request, ctx): (Request, CX)) -> Self::Future<'_> { - async move { - let req_path = request.uri().path(); - tracing::info!("request path: {req_path}"); - - match self.router.at(req_path) { - Ok(route) => { - let route = route.value; - tracing::info!("the route id: {}", route.id); - let upstreams = &route.upstreams; - let mut rng = rand::thread_rng(); - let next = rng.next_u32() as usize % upstreams.len(); - let upstream: &Upstream = &upstreams[next]; - - rewrite_request(&mut request, upstream); - - self.inner.handle(request, ctx).await - } - Err(e) => { - debug!("match request uri: {} with error: {e}", request.uri()); - Ok((generate_response(StatusCode::NOT_FOUND, false), true)) - } + + async fn call( + &self, + (mut request, ctx): (Request, CX), + ) -> Result { + let req_path = request.uri().path(); + tracing::info!("request path: {req_path}"); + + match self.router.at(req_path) { + Ok(route) => { + let route = route.value; + tracing::info!("the route id: {}", route.id); + let upstreams = &route.upstreams; + let mut rng = rand::thread_rng(); + let next = rng.next_u32() as usize % upstreams.len(); + let upstream: &Upstream = &upstreams[next]; + + rewrite_request(&mut request, upstream); + + self.inner.handle(request, ctx).await + } + Err(e) => { + debug!("match request uri: {} with error: {e}", request.uri()); + Ok((generate_response(StatusCode::NOT_FOUND, false), true)) } } } @@ -115,7 +114,7 @@ pub struct Upstream { #[derive(Debug, Clone, Serialize, Deserialize, PartialEq, Eq)] #[serde(tag = "type", content = "value", rename_all = "snake_case")] pub enum Endpoint { - #[serde(with = "http_serde::uri")] + #[serde(with = "uri_serde")] Uri(http::Uri), Socket(std::net::SocketAddr), Unix(std::path::PathBuf), diff --git a/monolake-services/src/lib.rs b/monolake-services/src/lib.rs index c3d6de2..502dbe3 100644 --- a/monolake-services/src/lib.rs +++ b/monolake-services/src/lib.rs @@ -1,4 +1,3 @@ -#![feature(impl_trait_in_assoc_type)] #![feature(let_chains)] pub mod common; diff --git a/monolake-services/src/tcp/echo.rs b/monolake-services/src/tcp/echo.rs index f7da20a..4b71c2e 100644 --- a/monolake-services/src/tcp/echo.rs +++ b/monolake-services/src/tcp/echo.rs @@ -1,4 +1,4 @@ -use std::{convert::Infallible, future::Future, io}; +use std::{convert::Infallible, io}; use monoio::io::{AsyncReadRent, AsyncWriteRent, AsyncWriteRentExt}; use service_async::{ @@ -15,28 +15,20 @@ where S: AsyncReadRent + AsyncWriteRent, { type Response = (); - type Error = io::Error; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - S: 'cx; - - fn call(&self, mut io: S) -> Self::Future<'_> { - async move { - let mut buffer = Vec::with_capacity(self.buffer_size); - loop { - let (mut r, buf) = io.read(buffer).await; - if r? == 0 { - break; - } - (r, buffer) = io.write_all(buf).await; - r?; + async fn call(&self, mut io: S) -> Result { + let mut buffer = Vec::with_capacity(self.buffer_size); + loop { + let (mut r, buf) = io.read(buffer).await; + if r? == 0 { + break; } - tracing::info!("tcp relay finished successfully"); - Ok(()) + (r, buffer) = io.write_all(buf).await; + r?; } + tracing::info!("tcp relay finished successfully"); + Ok(()) } } diff --git a/monolake-services/src/tls/mod.rs b/monolake-services/src/tls/mod.rs index 6c38d03..507030d 100644 --- a/monolake-services/src/tls/mod.rs +++ b/monolake-services/src/tls/mod.rs @@ -1,4 +1,4 @@ -use std::{future::Future, io::Cursor}; +use std::io::Cursor; use monolake_core::AnyError; use native_tls::Identity; @@ -78,30 +78,23 @@ where type Error = AnyError; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - Accept: 'cx; - - fn call(&self, req: Accept) -> Self::Future<'_> { - async move { - match self { - UnifiedTlsService::Rustls(inner) => inner - .call(req) - .await - .map(UnifiedResponse::Rustls) - .map_err(Into::into), - UnifiedTlsService::Native(inner) => inner - .call(req) - .await - .map(UnifiedResponse::Native) - .map_err(Into::into), - UnifiedTlsService::None(inner) => inner - .call(req) - .await - .map(UnifiedResponse::None) - .map_err(Into::into), - } + async fn call(&self, req: Accept) -> Result { + match self { + UnifiedTlsService::Rustls(inner) => inner + .call(req) + .await + .map(UnifiedResponse::Rustls) + .map_err(Into::into), + UnifiedTlsService::Native(inner) => inner + .call(req) + .await + .map(UnifiedResponse::Native) + .map_err(Into::into), + UnifiedTlsService::None(inner) => inner + .call(req) + .await + .map(UnifiedResponse::None) + .map_err(Into::into), } } } diff --git a/monolake-services/src/tls/nativetls.rs b/monolake-services/src/tls/nativetls.rs index da5ebda..c6b394c 100644 --- a/monolake-services/src/tls/nativetls.rs +++ b/monolake-services/src/tls/nativetls.rs @@ -1,4 +1,4 @@ -use std::{fmt::Display, future::Future}; +use std::fmt::Display; use monoio::io::{AsyncReadRent, AsyncWriteRent}; use monoio_native_tls::{TlsAcceptor, TlsStream}; @@ -26,19 +26,11 @@ where S: AsyncReadRent + AsyncWriteRent, { type Response = T::Response; - type Error = AnyError; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - Accept: 'cx; - - fn call(&self, (stream, addr): Accept) -> Self::Future<'_> { - async move { - let stream = self.acceptor.accept(stream).await?; - self.inner.call((stream, addr)).await.map_err(Into::into) - } + async fn call(&self, (stream, addr): Accept) -> Result { + let stream = self.acceptor.accept(stream).await?; + self.inner.call((stream, addr)).await.map_err(Into::into) } } diff --git a/monolake-services/src/tls/rustls.rs b/monolake-services/src/tls/rustls.rs index 3d84c1f..0756b32 100644 --- a/monolake-services/src/tls/rustls.rs +++ b/monolake-services/src/tls/rustls.rs @@ -1,4 +1,4 @@ -use std::{fmt::Display, future::Future, sync::Arc}; +use std::{fmt::Display, sync::Arc}; use monoio::io::{AsyncReadRent, AsyncWriteRent}; use monoio_rustls::{ServerTlsStream, TlsAcceptor}; @@ -25,19 +25,11 @@ where S: AsyncReadRent + AsyncWriteRent, { type Response = T::Response; - type Error = AnyError; - type Future<'cx> = impl Future> + 'cx - where - Self: 'cx, - Accept: 'cx; - - fn call(&self, (stream, cx): Accept) -> Self::Future<'_> { - async move { - let stream = self.acceptor.accept(stream).await?; - self.inner.call((stream, cx)).await.map_err(Into::into) - } + async fn call(&self, (stream, cx): Accept) -> Result { + let stream = self.acceptor.accept(stream).await?; + self.inner.call((stream, cx)).await.map_err(Into::into) } } diff --git a/monolake/Cargo.toml b/monolake/Cargo.toml index 42caf5e..4970f7c 100644 --- a/monolake/Cargo.toml +++ b/monolake/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "monolake" -version = "0.2.0" +version = "0.3.0" edition = "2021" keywords = ["monoio", "http", "async"] description = "High Performance Proxy base on Monoio" @@ -19,6 +19,9 @@ vendored = ["monolake-services/vendored"] monoio = { workspace = true, features = ["sync", "async-cancel"] } service-async = { workspace = true } certain-map = { workspace = true } +anyhow = { workspace = true } +serde = { workspace = true } +tracing = { workspace = true } monolake-core = { path = "../monolake-core" } monolake-services = { path = "../monolake-services" } @@ -27,15 +30,10 @@ monolake-services = { path = "../monolake-services" } native-tls = { workspace = true, optional = true } monoio-native-tls = { workspace = true, optional = true } -# error -anyhow = "1" - # log -tracing = "0.1" tracing-subscriber = { version = "0.3", features = ["env-filter"] } # parse clap = { version = "4", features = ['derive'] } -serde = "1" serde_json = "1" toml = "0" diff --git a/monolake/src/main.rs b/monolake/src/main.rs index efe5acb..f5e2dd1 100644 --- a/monolake/src/main.rs +++ b/monolake/src/main.rs @@ -1,6 +1,3 @@ -#![feature(impl_trait_in_assoc_type)] -#![feature(type_alias_impl_trait)] - use std::sync::Arc; use anyhow::Result;