From c8b537181aecbbf3db4a34a837b2ad955aa3eb0b Mon Sep 17 00:00:00 2001 From: hmqgg Date: Thu, 26 Sep 2024 20:48:47 +0800 Subject: [PATCH] feat!: make http client pooling --- Cargo.lock | 613 +++++++++++++---------------- Cargo.toml | 1 + src/tigergraph/mod.rs | 2 +- src/upstream/aggregation/mod.rs | 2 +- src/upstream/clusters/mod.rs | 4 +- src/upstream/dotbit/mod.rs | 14 +- src/upstream/ens_reverse/mod.rs | 2 +- src/upstream/farcaster/warpcast.rs | 6 +- src/upstream/firefly/mod.rs | 2 +- src/upstream/genome/mod.rs | 4 +- src/upstream/keybase/mod.rs | 2 +- src/upstream/opensea/mod.rs | 2 +- src/upstream/proof_client/mod.rs | 4 +- src/upstream/rss3/mod.rs | 2 +- src/upstream/space_id/mod.rs | 4 +- src/upstream/sybil_list/mod.rs | 2 +- src/upstream/unstoppable/mod.rs | 12 +- src/util/mod.rs | 47 ++- 18 files changed, 348 insertions(+), 377 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 46a0907..2b04fd9 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -14,18 +14,18 @@ dependencies = [ [[package]] name = "addr2line" -version = "0.22.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e4503c46a5c0c7844e948c9a4d6acd9f50cccb4de1c48eb9e291ea17470c678" +checksum = "f5fb1d8e4442bd405fdfd1dacb42792696b0cf9cb15882e5d097b742a676d375" dependencies = [ "gimli", ] [[package]] -name = "adler" -version = "1.0.2" +name = "adler2" +version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" +checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627" [[package]] name = "aead" @@ -184,9 +184,9 @@ dependencies = [ [[package]] name = "anyhow" -version = "1.0.86" +version = "1.0.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b3d1d046238990b9cf5bcde22a3fb3584ee5cf65fb2765f454ed428c7a0063da" +checksum = "86fdf8605db99b54d3cd748a44c6d04df638eb5dafb219b135d0149bd0db01f6" [[package]] name = "array_tool" @@ -196,15 +196,15 @@ checksum = "8f8cb5d814eb646a863c4f24978cff2880c4be96ad8cde2c0f0678732902e271" [[package]] name = "arrayref" -version = "0.3.8" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d151e35f61089500b617991b791fc8bfd237ae50cd5950803758a179b41e67a" +checksum = "76a2e8124351fda1ef8aaaa3bbd7ebbcb486bbcd4225aca0aa0d84bb2db8fecb" [[package]] name = "arrayvec" -version = "0.7.4" +version = "0.7.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" +checksum = "7c02d123df017efcdfbd739ef81735b36c5ba83ec3c59c80a9d7ecc718f92e50" [[package]] name = "ascii_utils" @@ -235,7 +235,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "726535892e8eae7e70657b4c8ea93d26b8553afb1ce617caee529ef96d7dee6c" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", "synstructure", ] @@ -247,7 +247,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2777730b2039ac0f95f093556e61b6d26cebed5393ca6f152717777cec3a42ed" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -296,13 +296,13 @@ dependencies = [ [[package]] name = "async-executor" -version = "1.13.0" +version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d7ebdfa2ebdab6b1760375fa7d6f382b9f486eac35fc994625a00e89280bdbb7" +checksum = "30ca9a001c1e8ba5149f91a74362376cc6bc5b919d92d988668657bd570bdcec" dependencies = [ "async-task", "concurrent-queue", - "fastrand 2.1.0", + "fastrand 2.1.1", "futures-lite 2.3.0", "slab", ] @@ -315,8 +315,8 @@ checksum = "05b1b633a2115cd122d73b955eadd9916c18c8f510ec9cd1686404c60ad1c29c" dependencies = [ "async-channel 2.3.1", "async-executor", - "async-io 2.3.4", - "async-lock 3.4.0", + "async-io", + "async-lock", "blocking", "futures-lite 2.3.0", "once_cell", @@ -334,14 +334,14 @@ dependencies = [ "async-stream", "async-trait", "base64 0.21.7", - "bytes 1.7.1", + "bytes 1.7.2", "chrono", "fast_chemail", "fnv", "futures-util", "handlebars", "http 1.1.0", - "indexmap 2.4.0", + "indexmap 2.5.0", "mime", "multer 3.1.0", "num-traits", @@ -368,17 +368,17 @@ dependencies = [ "darling", "proc-macro-crate 1.3.1", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "strum", - "syn 2.0.74", + "syn 2.0.77", "thiserror", ] [[package]] name = "async-graphql-parser" -version = "7.0.7" +version = "7.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f801451484b4977d6fe67b29030f81353cabdcbb754e5a064f39493582dac0cf" +checksum = "2e94b202e404d18429c8482d61f64cb0a8639fd1e7c2caf2b258f035e0b7caff" dependencies = [ "async-graphql-value", "pest", @@ -388,12 +388,12 @@ dependencies = [ [[package]] name = "async-graphql-value" -version = "7.0.7" +version = "7.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "69117c43c01d81a69890a9f5dd6235f2f027ca8d1ec62d6d3c5e01ca0edb4f2b" +checksum = "a43a7bbb0ddea47c6f51913eba6e17a093b34e000588a93bb80a978ad129f3e9" dependencies = [ - "bytes 1.7.1", - "indexmap 2.4.0", + "bytes 1.7.2", + "indexmap 2.5.0", "serde", "serde_json", ] @@ -411,54 +411,25 @@ dependencies = [ "warp", ] -[[package]] -name = "async-io" -version = "1.13.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fc5b45d93ef0529756f812ca52e44c221b35341892d3dcc34132ac02f3dd2af" -dependencies = [ - "async-lock 2.8.0", - "autocfg", - "cfg-if", - "concurrent-queue", - "futures-lite 1.13.0", - "log", - "parking", - "polling 2.8.0", - "rustix 0.37.27", - "slab", - "socket2 0.4.10", - "waker-fn", -] - [[package]] name = "async-io" version = "2.3.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "444b0228950ee6501b3568d3c93bf1176a1fdbc3b758dcd9475046d30f4dc7e8" dependencies = [ - "async-lock 3.4.0", + "async-lock", "cfg-if", "concurrent-queue", "futures-io", "futures-lite 2.3.0", "parking", "polling 3.7.3", - "rustix 0.38.34", + "rustix", "slab", "tracing", "windows-sys 0.59.0", ] -[[package]] -name = "async-lock" -version = "2.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "287272293e9d8c41773cec55e365490fe034813a2f172f502d6ddcf75b2f582b" -dependencies = [ - "event-listener 2.5.3", -] - [[package]] name = "async-lock" version = "3.4.0" @@ -486,25 +457,25 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3b43422f69d8ff38f95f1b2bb76517c91589a924d1559a0e935d7c8ce0274c11" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] name = "async-std" -version = "1.12.0" +version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62565bb4402e926b29953c785397c6dc0391b7b446e45008b0049eb43cec6f5d" +checksum = "c634475f29802fde2b8f0b505b1bd00dfe4df7d4a000f0b36f7671197d5c3615" dependencies = [ "async-channel 1.9.0", "async-global-executor", - "async-io 1.13.0", - "async-lock 2.8.0", + "async-io", + "async-lock", "crossbeam-utils", "futures-channel", "futures-core", "futures-io", - "futures-lite 1.13.0", + "futures-lite 2.3.0", "gloo-timers", "kv-log-macro", "log", @@ -534,8 +505,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "16e62a023e7c117e27523144c5d2459f4397fcc3cab0085af8e2224f643a0193" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -546,13 +517,13 @@ checksum = "8b75356056920673b02621b35afd0f7dda9306d03c79a30f5c56c44cf256e3de" [[package]] name = "async-trait" -version = "0.1.81" +version = "0.1.83" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e0c28dcc82d7c8ead5cb13beb15405b57b8546e93215673ff8ca0349a028107" +checksum = "721cae7de5c34fbb2acd27e21e6d2cf7b886dce0c27388d46c4e6c47ea4318dd" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -594,7 +565,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "03611508dd1e514e311caec235b581c99a4cb66fa1771bd502819eed69894f12" dependencies = [ "base64 0.21.7", - "bytes 1.7.1", + "bytes 1.7.2", "http 0.2.12", "http-body", "http-serde", @@ -605,17 +576,17 @@ dependencies = [ [[package]] name = "backtrace" -version = "0.3.73" +version = "0.3.74" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5cc23269a4f8976d0a4d2e7109211a419fe30e8d88d677cd60b6bc79c5732e0a" +checksum = "8d82cb332cdfaed17ae235a638438ac4d4839913cc2af585c3c6746e8f8bee1a" dependencies = [ "addr2line", - "cc", "cfg-if", "libc", "miniz_oxide", "object", "rustc-demangle", + "windows-targets 0.52.6", ] [[package]] @@ -755,7 +726,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec81c59258e8ae2f9a98771ed6bca2769ffdc2e1e2a7ac509023bed4211821d9" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "solana-program", "spl-name-service", "syn 1.0.109", @@ -805,7 +776,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5449c28a7b352f2d1e592a8a28bf139bc71afb0764a14f3c02500935d8c44065" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -816,7 +787,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cdbd5696d8bfa21d53d9fe39a714a18538bad11492a42d066dbbc395fb1951c0" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -865,22 +836,22 @@ dependencies = [ [[package]] name = "bytemuck" -version = "1.16.3" +version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "102087e286b4677862ea56cf8fc58bb2cdfa8725c40ffb80fe3a008eb7f2fc83" +checksum = "94bbb0ad554ad961ddc5da507a12a29b14e4ae5bda06b19f575a3e6079d2e2ae" dependencies = [ "bytemuck_derive", ] [[package]] name = "bytemuck_derive" -version = "1.7.0" +version = "1.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1ee891b04274a59bd38b412188e24b849617b2e45a0fd8d057deb63e7403761b" +checksum = "0cc8b54b395f2fcfbb3d90c47b01c7f444d94d05bdeb775811dec868ac3bbc26" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -897,9 +868,9 @@ checksum = "0e4cec68f03f32e44924783795810fa50a7035d8c8ebe78580ad7e6c703fba38" [[package]] name = "bytes" -version = "1.7.1" +version = "1.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8318a53db07bb3f8dca91a600466bdb3f2eaadeedfdbcf02e1accbad9271ba50" +checksum = "428d9aa8fbc0670b7b8d6030a7fadd0f86151cae55e4dbbece15f3780a3dfaf3" dependencies = [ "serde", ] @@ -922,9 +893,9 @@ checksum = "a2698f953def977c68f935bb0dfa959375ad4638570e969e2f1e9f433cbf1af6" [[package]] name = "cc" -version = "1.1.12" +version = "1.1.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68064e60dbf1f17005c2fde4d07c16d8baa506fd7ffed8ccab702d93617975c7" +checksum = "07b1695e2c7e8fc85310cde85aeaab7e3097f593c91d209d3f9df76c928100f0" dependencies = [ "jobserver", "libc", @@ -1149,9 +1120,9 @@ dependencies = [ [[package]] name = "cpufeatures" -version = "0.2.13" +version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "51e852e6dc9a5bed1fae92dd2375037bf2b768725bf3be87811edee3249d09ad" +checksum = "608697df725056feaccfa42cffdaeeec3fccc4ffc38358ecd19b243e716a78e0" dependencies = [ "libc", ] @@ -1247,8 +1218,8 @@ version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "edb49164822f3ee45b17acd4a208cfc1251410cf0cad9a833234c9890774dd9f" dependencies = [ - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1286,9 +1257,9 @@ dependencies = [ [[package]] name = "curl-sys" -version = "0.4.74+curl-8.9.0" +version = "0.4.76+curl-8.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8af10b986114528fcdc4b63b6f5f021b7057618411046a4de2ba0f0149a097bf" +checksum = "00462dbe9cbb9344e1b2be34d9094d74e3b8aac59a883495b335eafd02e25120" dependencies = [ "cc", "libc", @@ -1316,9 +1287,9 @@ dependencies = [ [[package]] name = "cynic" -version = "3.7.3" +version = "3.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "478c02b53607e3f21c374f024c2cfc2154e554905bba478e8e09409f10ce3726" +checksum = "394a4797bda697d5e028f3bc3fcb8c8c374a2b72cf8d22e0efc0e127c95fd11f" dependencies = [ "cynic-proc-macros", "ref-cast", @@ -1331,9 +1302,9 @@ dependencies = [ [[package]] name = "cynic-codegen" -version = "3.7.3" +version = "3.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7c0ec86f960a00ce087e96ff6f073f6ff28b6876d69ce8caa06c03fb4143981c" +checksum = "408ad3d9c8d729e4d89e1aaed76eab918f76169f1bb3aa017c9fc1b39dac3066" dependencies = [ "counter", "cynic-parser", @@ -1341,9 +1312,9 @@ dependencies = [ "once_cell", "ouroboros", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "strsim 0.10.0", - "syn 2.0.74", + "syn 2.0.77", "thiserror", ] @@ -1353,21 +1324,21 @@ version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "718f6cd8c54ae5249fd42b0c86639df0100b8a86eea2e5f1b915cde2e1481453" dependencies = [ - "indexmap 2.4.0", + "indexmap 2.5.0", "lalrpop-util", "logos", ] [[package]] name = "cynic-proc-macros" -version = "3.7.3" +version = "3.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25a69ecdf4aa110fed1c0c8de290bc8ccb2835388733cf2f418f0abdf6ff3899" +checksum = "7f72af69ebf914a975468c4f7e3f81ddc5482e140dd98032d90e7602c535681d" dependencies = [ "cynic-codegen", "darling", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1389,9 +1360,9 @@ dependencies = [ "fnv", "ident_case", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "strsim 0.11.1", - "syn 2.0.74", + "syn 2.0.77", ] [[package]] @@ -1401,8 +1372,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d336a2a514f6ccccaa3e09b02d41d35330c07ddf03a62165fcec10bb561c7806" dependencies = [ "darling_core", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1486,9 +1457,9 @@ checksum = "5f33878137e4dafd7fa914ad4e259e18a4e8e532b9617a2d0150262bf53abfce" dependencies = [ "convert_case", "proc-macro2 1.0.86", - "quote 1.0.36", - "rustc_version 0.4.0", - "syn 2.0.74", + "quote 1.0.37", + "rustc_version 0.4.1", + "syn 2.0.77", ] [[package]] @@ -1563,8 +1534,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1680,7 +1651,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8958699f9359f0b04e691a13850d48b7de329138023876d07cbd024c2c820598" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -1692,8 +1663,8 @@ checksum = "aa18ce2bc66555b3218614519ac839ddb759a7d6720732f979ef8d13be147ecd" dependencies = [ "once_cell", "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1712,8 +1683,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "de0d48a183585823424a4ce1aa132d174a6a81bd540895822eb4c8373a8e49e8" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -1784,9 +1755,9 @@ dependencies = [ [[package]] name = "fake" -version = "2.9.2" +version = "2.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1c25829bde82205da46e1823b2259db6273379f626fc211f126f65654a2669be" +checksum = "2d391ba4af7f1d93f01fcf7b2f29e2bc9348e109dfdbf4dcbdc51dfa38dab0b6" dependencies = [ "chrono", "deunicode", @@ -1814,9 +1785,9 @@ dependencies = [ [[package]] name = "fastrand" -version = "2.1.0" +version = "2.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9fc0510504f03c51ada170672ac806f1f105a88aa97a5281117e1ddc3368e51a" +checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6" [[package]] name = "feature-probe" @@ -1826,9 +1797,9 @@ checksum = "835a3dc7d1ec9e75e2b5fb4ba75396837112d2060b03f7d43bc1897c7f7211da" [[package]] name = "flate2" -version = "1.0.31" +version = "1.0.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f211bbe8e69bbd0cfdea405084f128ae8b4aaa6b0b522fc8f2b009084797920" +checksum = "324a1be68054ef05ad64b861cc9eaf1d623d2d8cb25b4bf2cb9cdd902b4bf253" dependencies = [ "crc32fast", "miniz_oxide", @@ -1944,7 +1915,7 @@ version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "52527eb5074e35e9339c6b4e8d12600c7128b68fb25dcb9fa9dec18f7c25f3a5" dependencies = [ - "fastrand 2.1.0", + "fastrand 2.1.1", "futures-core", "futures-io", "parking", @@ -1958,8 +1929,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -2060,15 +2031,15 @@ dependencies = [ [[package]] name = "gimli" -version = "0.29.0" +version = "0.31.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "40ecd4077b5ae9fd2e9e169b102c6c330d0605168eb0e8bf79952b256dbefffd" +checksum = "32085ea23f3234fc7846555e85283ba4de91e21016dc0455a16286d87a292d64" [[package]] name = "gloo-timers" -version = "0.2.6" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b995a66bb87bebce9a0f4a95aed01daca4872c050bfcb21653361c03bc35e5c" +checksum = "bbb143cf96099802033e0d4f4963b19fd2e0b728bcf076cd9cf7f6634f092994" dependencies = [ "futures-channel", "futures-core", @@ -2094,13 +2065,13 @@ version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "81fe527a889e1532da5c525686d96d4c2e74cdd345badf8dfef9f6b39dd5f5e8" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "fnv", "futures-core", "futures-sink", "futures-util", "http 0.2.12", - "indexmap 2.4.0", + "indexmap 2.5.0", "slab", "tokio", "tokio-util", @@ -2152,7 +2123,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "06683b93020a07e3dbcf5f8c0f6d40080d725bea7936fc01ad345c01b97dc270" dependencies = [ "base64 0.21.7", - "bytes 1.7.1", + "bytes 1.7.2", "headers-core", "http 0.2.12", "httpdate", @@ -2273,7 +2244,7 @@ version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "fnv", "itoa", ] @@ -2284,7 +2255,7 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "fnv", "itoa", ] @@ -2295,7 +2266,7 @@ version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "http 0.2.12", "pin-project-lite", ] @@ -2370,7 +2341,7 @@ version = "0.14.30" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a152ddd61dfaec7273fe8419ab357f33aee0d914c5f4efbf0d96fa749eea5ec9" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "futures-channel", "futures-core", "futures-util", @@ -2408,7 +2379,7 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "hyper", "native-tls", "tokio", @@ -2417,9 +2388,9 @@ dependencies = [ [[package]] name = "iana-time-zone" -version = "0.1.60" +version = "0.1.61" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" +checksum = "235e081f3925a06703c2d0117ea8b91f042756fd6e7a6e5d901e8ca1a996b220" dependencies = [ "android_system_properties", "core-foundation-sys", @@ -2482,9 +2453,9 @@ dependencies = [ [[package]] name = "indexmap" -version = "2.4.0" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93ead53efc7ea8ed3cfb0c79fc8023fbb782a5432b52830b6518941cebe6505c" +checksum = "68b900aa2f7301e21c36462b170ee99994de34dff39a4a6a528e80e7376d07e5" dependencies = [ "equivalent", "hashbrown 0.14.5", @@ -2520,9 +2491,9 @@ dependencies = [ [[package]] name = "insta" -version = "1.39.0" +version = "1.40.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "810ae6042d48e2c9e9215043563a58a80b877bc863228a74cf10c49d4620a6f5" +checksum = "6593a41c7a73841868772495db7dc1e8ecab43bb5c0b6da2059246c4b506ab60" dependencies = [ "console", "lazy_static", @@ -2545,22 +2516,11 @@ version = "0.3.15" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f958d3d68f4167080a18141e10381e7634563984a537f2a49a30fd8e53ac5767" -[[package]] -name = "io-lifetimes" -version = "1.0.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eae7b9aee968036d54dce06cebaefd919e4472e753296daccd6d344e3e2df0c2" -dependencies = [ - "hermit-abi 0.3.9", - "libc", - "windows-sys 0.48.0", -] - [[package]] name = "ipnet" -version = "2.9.0" +version = "2.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f518f335dce6725a761382244631d86cf0ccb2863413590b31338feb467f9c3" +checksum = "187674a687eed5fe42285b40c6291f9a01517d415fad1c3cbc6a9f778af7fcd4" [[package]] name = "isahc" @@ -2715,7 +2675,7 @@ checksum = "2505c4a24f5a8d8ac66a87691215ec1f79736c5bc6e62bb921788dca9753f650" dependencies = [ "aws_lambda_events", "base64 0.21.7", - "bytes 1.7.1", + "bytes 1.7.2", "encoding_rs", "futures", "http 0.2.12", @@ -2739,7 +2699,7 @@ checksum = "deca8f65d7ce9a8bfddebb49d7d91b22e788a59ca0c5190f26794ab80ed7a702" dependencies = [ "async-stream", "base64 0.20.0", - "bytes 1.7.1", + "bytes 1.7.2", "futures", "http 0.2.12", "http-body", @@ -2775,9 +2735,9 @@ checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe" [[package]] name = "libc" -version = "0.2.156" +version = "0.2.159" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5f43f184355eefb8d17fc948dbecf6c13be3c141f20d834ae842193a448c72a" +checksum = "561d97a539a36e26a9a5fad1ea11a3039a67714694aaa379433e580854bc3dc5" [[package]] name = "libloading" @@ -2859,9 +2819,9 @@ dependencies = [ [[package]] name = "libz-sys" -version = "1.1.19" +version = "1.1.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fdc53a7799a7496ebc9fd29f31f7df80e83c9bda5299768af5f9e59eeea74647" +checksum = "d2d16453e800a8cf6dd2fc3eb4bc99b786a9b90c663b8559a5b1a041bf89e472" dependencies = [ "cc", "libc", @@ -2875,12 +2835,6 @@ version = "0.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0717cef1bc8b636c6e1c1bbdefc09e6322da8a9321966e8928ef80d20f7f770f" -[[package]] -name = "linux-raw-sys" -version = "0.3.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ef53942eb7bf7ff43a617b3e2c1c4a5ecf5944a7c1bc12d7ee39bbb15e5c1519" - [[package]] name = "linux-raw-sys" version = "0.4.14" @@ -2908,33 +2862,33 @@ dependencies = [ [[package]] name = "logos" -version = "0.14.1" +version = "0.14.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ff1ceb190eb9bdeecdd8f1ad6a71d6d632a50905948771718741b5461fb01e13" +checksum = "1c6b6e02facda28ca5fb8dbe4b152496ba3b1bd5a4b40bb2b1b2d8ad74e0f39b" dependencies = [ "logos-derive", ] [[package]] name = "logos-codegen" -version = "0.14.1" +version = "0.14.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90be66cb7bd40cb5cc2e9cfaf2d1133b04a3d93b72344267715010a466e0915a" +checksum = "b32eb6b5f26efacd015b000bfc562186472cd9b34bdba3f6b264e2a052676d10" dependencies = [ "beef", "fnv", "lazy_static", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "regex-syntax 0.8.4", - "syn 2.0.74", + "syn 2.0.77", ] [[package]] name = "logos-derive" -version = "0.14.1" +version = "0.14.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "45154231e8e96586b39494029e58f12f8ffcb5ecf80333a603a13aa205ea8cbd" +checksum = "3e5d0c5463c911ef55624739fc353238b4e310f0144be1f875dc42fec6bfd5ec" dependencies = [ "logos-codegen", ] @@ -2955,8 +2909,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5cf92c10c7e361d6b99666ec1c6f9805b0bea2c3bd8c78dc6fe98ac5bd78db11" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -3029,11 +2983,11 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" [[package]] name = "miniz_oxide" -version = "0.7.4" +version = "0.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b8a240ddb74feaf34a79a7add65a741f3167852fba007066dcac1ca548d89c08" +checksum = "e2d80299ef12ff69b16a84bb182e3b9df68b5a91574d3d4fa6e41b65deec4df1" dependencies = [ - "adler", + "adler2", ] [[package]] @@ -3093,7 +3047,7 @@ version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "12989bc45715b0ee91944855130131479f9c772e198a910c3eb0ea327d5bffc3" dependencies = [ - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -3103,7 +3057,7 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b5a739019e11d93661a64ef5fe108ab17c79b35961e944442ff6efdd460ad01a" dependencies = [ - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -3124,7 +3078,7 @@ version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "01acbdc23469fd8fe07ab135923371d5f5a422fbf9c522158677c8eb15bc51c2" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "encoding_rs", "futures-util", "http 0.2.12", @@ -3142,7 +3096,7 @@ version = "3.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "83e87776546dc87511aa5ee218730c92b666d7264ab6ed41f9d215af9cd5224b" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "encoding_rs", "futures-util", "http 1.1.0", @@ -3282,7 +3236,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "876a53fff98e03a936a674b29568b0e605f06b29372c2489ff4de23f1949743d" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -3293,8 +3247,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed3955f1a9c7c0c15e092f9c887db08b1fc683305fdf6eb6684f22555355e202" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -3365,7 +3319,7 @@ checksum = "dcbff9bc912032c62bf65ef1d5aea88983b420f4f839db1e9b0c281a25c9c799" dependencies = [ "proc-macro-crate 1.3.1", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", ] @@ -3377,9 +3331,9 @@ checksum = "830b246a0e5f20af87141b25c173cd1b609bd7779a4617d6ec582abaf90870f3" [[package]] name = "object" -version = "0.36.3" +version = "0.36.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "27b64972346851a39438c60b341ebc01bba47464ae329e55cf343eb93964efd9" +checksum = "084f1a5821ac4c651660a94a7153d27ac9d8a53736203f58b31945ded098070a" dependencies = [ "memchr", ] @@ -3427,8 +3381,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -3486,8 +3440,8 @@ dependencies = [ "itertools 0.12.1", "proc-macro2 1.0.86", "proc-macro2-diagnostics", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -3498,9 +3452,9 @@ checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" [[package]] name = "parking" -version = "2.2.0" +version = "2.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bb813b8af86854136c6922af0598d719255ecb2179515e6e7730d468f05c9cae" +checksum = "f38d5652c16fde515bb1ecef450ab0f6a219d619a7274976324d5e377f7dceba" [[package]] name = "parking_lot" @@ -3581,9 +3535,9 @@ dependencies = [ [[package]] name = "pest" -version = "2.7.11" +version = "2.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cd53dff83f26735fdc1ca837098ccf133605d794cdae66acfc2bfac3ec809d95" +checksum = "fdbef9d1d47087a895abd220ed25eb4ad973a5e26f6a4367b038c25e28dfc2d9" dependencies = [ "memchr", "thiserror", @@ -3592,9 +3546,9 @@ dependencies = [ [[package]] name = "pest_derive" -version = "2.7.11" +version = "2.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2a548d2beca6773b1c244554d36fcf8548a8a58e74156968211567250e48e49a" +checksum = "4d3a6e3394ec80feb3b6393c725571754c6188490265c61aaf260810d6b95aa0" dependencies = [ "pest", "pest_generator", @@ -3602,22 +3556,22 @@ dependencies = [ [[package]] name = "pest_generator" -version = "2.7.11" +version = "2.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c93a82e8d145725dcbaf44e5ea887c8a869efdcc28706df2d08c69e17077183" +checksum = "94429506bde1ca69d1b5601962c73f4172ab4726571a59ea95931218cb0e930e" dependencies = [ "pest", "pest_meta", "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] name = "pest_meta" -version = "2.7.11" +version = "2.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a941429fea7e08bedec25e4f6785b6ffaacc6b755da98df5ef3e7dcf4a124c4f" +checksum = "ac8a071862e93690b6e34e9a5fb8e33ff3734473ac0245b27232222c4906a33f" dependencies = [ "once_cell", "pest", @@ -3640,8 +3594,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2f38a4412a78282e09a2cf38d195ea5420d15ba0602cb375210efbc877243965" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -3663,7 +3617,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "96c8c490f422ef9a4efd2cb5b42b76c8613d7e7dfc1caf667b8a3350a5acc066" dependencies = [ "atomic-waker", - "fastrand 2.1.0", + "fastrand 2.1.1", "futures-io", ] @@ -3680,9 +3634,9 @@ dependencies = [ [[package]] name = "pkg-config" -version = "0.3.30" +version = "0.3.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" +checksum = "953ec861398dccce10c670dfeaf3ec4911ca479e9c02154b3a215178c5f566f2" [[package]] name = "polling" @@ -3710,7 +3664,7 @@ dependencies = [ "concurrent-queue", "hermit-abi 0.4.0", "pin-project-lite", - "rustix 0.38.34", + "rustix", "tracing", "windows-sys 0.59.0", ] @@ -3803,8 +3757,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "af066a9c399a26e020ada66a034357a868728e72cd426f3adcd35f80d88d88c8" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", "version_check", "yansi", ] @@ -3871,7 +3825,7 @@ version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5b435e71d9bfa0d8889927231970c51fb89c58fa63bffcab117c9c7a41e5ef8f" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "futures-channel", "futures-util", "fxhash", @@ -3890,7 +3844,7 @@ version = "0.8.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3fce546b9688f767a57530652488420d419a8b1f44a478b451c3d1ab6d992a55" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "fxhash", "rand 0.8.5", "ring 0.16.20", @@ -3929,9 +3883,9 @@ dependencies = [ [[package]] name = "quote" -version = "1.0.36" +version = "1.0.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" +checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af" dependencies = [ "proc-macro2 1.0.86", ] @@ -4050,18 +4004,18 @@ dependencies = [ [[package]] name = "redox_syscall" -version = "0.5.3" +version = "0.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2a908a6e00f1fdd0dfd9c0eb08ce85126f6d8bbda50017e74bc4a4b7d4a926a4" +checksum = "355ae415ccd3a04315d3f8246e86d67689ea74d88d915576e1589a351062a13b" dependencies = [ "bitflags 2.6.0", ] [[package]] name = "redox_users" -version = "0.4.5" +version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd283d9651eeda4b2a83a43c1c91b266c40fd76ecd39a50a8c630ae69dc72891" +checksum = "ba009ff324d1fc1b900bd1fdb31564febe58a8ccc8a6fdbb93b543d33b13ca43" dependencies = [ "getrandom 0.2.15", "libredox", @@ -4084,8 +4038,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bcc303e793d3734489387d205e9b186fac9c6cfacedd98cbb2e8a5943595f3e6" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -4161,6 +4115,7 @@ dependencies = [ "lazy_static", "maybe-async", "num_cpus", + "once_cell", "rand 0.8.5", "rand_chacha 0.3.1", "regex", @@ -4198,7 +4153,7 @@ checksum = "dd67538700a17451e7cba03ac727fb961abb7607553461627b97de0b89cf4a62" dependencies = [ "async-compression", "base64 0.21.7", - "bytes 1.7.1", + "bytes 1.7.2", "encoding_rs", "futures-core", "futures-util", @@ -4350,9 +4305,9 @@ dependencies = [ [[package]] name = "rustc_version" -version = "0.4.0" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfa0f585226d2e68097d4f95d113b15b83a82e819ab25717ec0590d9584ef366" +checksum = "cfcb3a22ef46e85b45de6ee7e79d063319ebb6594faafcf1c225ea92ab6e9b92" dependencies = [ "semver 1.0.23", ] @@ -4368,28 +4323,14 @@ dependencies = [ [[package]] name = "rustix" -version = "0.37.27" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fea8ca367a3a01fe35e6943c400addf443c0f57670e6ec51196f71a4b8762dd2" -dependencies = [ - "bitflags 1.3.2", - "errno", - "io-lifetimes", - "libc", - "linux-raw-sys 0.3.8", - "windows-sys 0.48.0", -] - -[[package]] -name = "rustix" -version = "0.38.34" +version = "0.38.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70dc5ec042f7a43c4a73241207cecc9873a06d45debb38b329f8541d85c2730f" +checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811" dependencies = [ "bitflags 2.6.0", "errno", "libc", - "linux-raw-sys 0.4.14", + "linux-raw-sys", "windows-sys 0.52.0", ] @@ -4471,11 +4412,11 @@ checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" [[package]] name = "schannel" -version = "0.1.23" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fbc91545643bcf3a0bbb6569265615222618bdf33ce4ffbbd13c4bbd4c093534" +checksum = "e9aaafd5a2b6e3d657ff009d82fbd630b6bd54dd4eb06f21693925cdf80f9b8b" dependencies = [ - "windows-sys 0.52.0", + "windows-sys 0.59.0", ] [[package]] @@ -4497,9 +4438,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b1eee588578aff73f856ab961cd2f79e36bc45d7ded33a7562adba4667aecc0e" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "serde_derive_internals", - "syn 2.0.74", + "syn 2.0.77", ] [[package]] @@ -4539,9 +4480,9 @@ dependencies = [ [[package]] name = "security-framework-sys" -version = "2.11.1" +version = "2.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "75da29fe9b9b08fe9d6b22b5b4bcbc75d8db3aa31e639aa56bb62e9d46bfceaf" +checksum = "ea4a292869320c0272d7bc55a5a6aafaff59b4f63404a003887b679a2e05b4b6" dependencies = [ "core-foundation-sys", "libc", @@ -4570,9 +4511,9 @@ checksum = "388a1df253eca08550bef6c72392cfe7c30914bf41df5269b68cbd6ff8f570a3" [[package]] name = "serde" -version = "1.0.208" +version = "1.0.210" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cff085d2cb684faa248efb494c39b68e522822ac0de72ccf08109abde717cfb2" +checksum = "c8e3592472072e6e22e0a54d5904d9febf8508f65fb8552499a1abc7d1078c3a" dependencies = [ "serde_derive", ] @@ -4588,13 +4529,13 @@ dependencies = [ [[package]] name = "serde_derive" -version = "1.0.208" +version = "1.0.210" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24008e81ff7613ed8e5ba0cfaf24e2c2f1e5b8a0495711e44fcd4882fca62bcf" +checksum = "243902eda00fad750862fc144cea25caca5e20d615af0a81bee94ca738f1df1f" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -4604,15 +4545,15 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "18d26a20a969b9e3fdf2fc2d9f21eda6c40e2de84c9408bb5d3b05d499aae711" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] name = "serde_json" -version = "1.0.125" +version = "1.0.128" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "83c8e735a073ccf5be70aa8066aa984eaf2fa000db6c8d0100ae605b366d31ed" +checksum = "6ff5456707a1de34e7e37f2a6fd3d3f808c318259cbd01ab6377795054b483d8" dependencies = [ "itoa", "memchr", @@ -4648,8 +4589,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6c64451ba24fc7a6a2d60fc75dd9c83c90903b19028d4eff35e88fc1e86564e9" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -4775,7 +4716,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "63927d22a1e8b74bda98cc6e151fcdf178b7abb0dc6c4f81e0bbf5ffe2fc4ec8" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "shank_macro_impl", "syn 1.0.109", ] @@ -4788,7 +4729,7 @@ checksum = "40ce03403df682f80f4dc1efafa87a4d0cb89b03726d0565e6364bdca5b9a441" dependencies = [ "anyhow", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "serde", "syn 1.0.109", ] @@ -4954,7 +4895,7 @@ dependencies = [ "log", "num-derive 0.3.3", "num-traits", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "serde", "solana-frozen-abi", "solana-frozen-abi-macro", @@ -5009,7 +4950,7 @@ dependencies = [ "base64 0.13.1", "bincode", "bs58", - "bytes 1.7.1", + "bytes 1.7.2", "clap 2.34.0", "crossbeam-channel", "enum_dispatch", @@ -5113,7 +5054,7 @@ dependencies = [ "memmap2", "once_cell", "rand_core 0.6.4", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "serde", "serde_bytes", "serde_derive", @@ -5131,8 +5072,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c9eca469f181dcc35c81fb9e0c31c37d0d9abd13805e7cd82446b843a0232246" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "rustc_version 0.4.0", + "quote 1.0.37", + "rustc_version 0.4.1", "syn 1.0.109", ] @@ -5252,7 +5193,7 @@ dependencies = [ "parking_lot", "rand 0.7.3", "rand_chacha 0.2.2", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "rustversion", "serde", "serde_bytes", @@ -5286,7 +5227,7 @@ dependencies = [ "num-derive 0.3.3", "num-traits", "rand 0.7.3", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "serde", "solana-frozen-abi", "solana-frozen-abi-macro", @@ -5358,7 +5299,7 @@ dependencies = [ "qstring", "rand 0.7.3", "rand_chacha 0.2.2", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "rustversion", "serde", "serde_bytes", @@ -5384,7 +5325,7 @@ checksum = "a9a86d529a78915940dcbdfd46d07fa7d64ac0e57a2688d7201fff5a55318653" dependencies = [ "bs58", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "rustversion", "syn 1.0.109", ] @@ -5454,7 +5395,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9252ad2a1ff40cf7b09285af6b6f5922267b04eab8cae0290f8caf29c281b12e" dependencies = [ "log", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "semver 1.0.23", "serde", "serde_derive", @@ -5473,7 +5414,7 @@ dependencies = [ "log", "num-derive 0.3.3", "num-traits", - "rustc_version 0.4.0", + "rustc_version 0.4.1", "serde", "serde_derive", "solana-frozen-abi", @@ -5659,7 +5600,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c87a60a40fccc84bef0652345bbbbbe20a605bf5d0ce81719fc476f5c03b50ef" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "serde", "serde_derive", "syn 1.0.109", @@ -5673,7 +5614,7 @@ checksum = "58fa5ff6ad0d98d1ffa8cb115892b6e69d67799f6763e162a1c9db421dc22e11" dependencies = [ "base-x", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "serde", "serde_derive", "serde_json", @@ -5722,9 +5663,9 @@ checksum = "4c6bee85a5a24955dc440386795aa378cd9cf82acd5f764469152d2270e581be" dependencies = [ "heck 0.5.0", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "rustversion", - "syn 2.0.74", + "syn 2.0.77", ] [[package]] @@ -5774,18 +5715,18 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "unicode-ident", ] [[package]] name = "syn" -version = "2.0.74" +version = "2.0.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1fceb41e3d546d0bd83421d3409b1460cc7444cd389341a4c880fe7a042cb3d7" +checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "unicode-ident", ] @@ -5802,9 +5743,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f36bdaa60a83aca3921b5259d5400cbf5e90fc51931376a9bd4a0eb79aa7210f" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "syn 1.0.109", - "unicode-xid 0.2.4", + "unicode-xid 0.2.6", ] [[package]] @@ -5835,9 +5776,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "04cbcdd0c794ebb0d4cf35e88edd2f7d2c4c3e9a5a6dab322839b321c6a87a64" dependencies = [ "cfg-if", - "fastrand 2.1.0", + "fastrand 2.1.1", "once_cell", - "rustix 0.38.34", + "rustix", "windows-sys 0.59.0", ] @@ -5867,22 +5808,22 @@ checksum = "23d434d3f8967a09480fb04132ebe0a3e088c173e6d0ee7897abbdf4eab0f8b9" [[package]] name = "thiserror" -version = "1.0.63" +version = "1.0.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c0342370b38b6a11b6cc11d6a805569958d54cfa061a29969c3b5ce2ea405724" +checksum = "d50af8abc119fb8bb6dbabcfa89656f46f84aa0ac7688088608076ad2b459a84" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.63" +version = "1.0.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261" +checksum = "08904e7672f5eb876eaaf87e0ce17857500934f4981c4a0ab2b4aa98baac7fc3" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -5959,7 +5900,7 @@ checksum = "fd3c141a1b43194f3f56a1411225df8646c55781d5f26db825b3d98507eb482f" dependencies = [ "proc-macro-hack", "proc-macro2 1.0.86", - "quote 1.0.36", + "quote 1.0.37", "standback", "syn 1.0.109", ] @@ -6000,12 +5941,12 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.39.2" +version = "1.40.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "daa4fb1bc778bd6f04cbfc4bb2d06a7396a8f299dc33ea1900cedaa316f467b1" +checksum = "e2b070231665d27ad9ec9b8df639893f46727666c6767db40317fbe920a5d998" dependencies = [ "backtrace", - "bytes 1.7.1", + "bytes 1.7.2", "libc", "mio", "parking_lot", @@ -6023,8 +5964,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "693d596312e88961bc67d7f1f97af8a70227d9f90c31bba5806eec004978d752" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -6060,9 +6001,9 @@ dependencies = [ [[package]] name = "tokio-stream" -version = "0.1.15" +version = "0.1.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "267ac89e0bec6e691e5813911606935d77c476ff49024f98abcea3e7b15e37af" +checksum = "4f4e6ce100d0eb49a2734f8c0812bcd324cf357d21810932c5df6b96ef2b86f1" dependencies = [ "futures-core", "pin-project-lite", @@ -6099,11 +6040,11 @@ dependencies = [ [[package]] name = "tokio-util" -version = "0.7.11" +version = "0.7.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9cf6b47b3771c49ac75ad09a6162f53ad4b8088b76ac60e8ec1455b31a189fe1" +checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "futures-core", "futures-sink", "pin-project-lite", @@ -6182,8 +6123,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -6249,7 +6190,7 @@ checksum = "e27992fd6a8c29ee7eef28fc78349aa244134e10ad447ce3b9f0ac0ed0fa4ce0" dependencies = [ "base64 0.13.1", "byteorder", - "bytes 1.7.1", + "bytes 1.7.2", "http 0.2.12", "httparse", "log", @@ -6270,7 +6211,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9ef1a641ea34f399a848dea702823bbecfb4c486f911735368f1f137cb8257e1" dependencies = [ "byteorder", - "bytes 1.7.1", + "bytes 1.7.2", "data-encoding", "http 1.1.0", "httparse", @@ -6284,9 +6225,9 @@ dependencies = [ [[package]] name = "typeid" -version = "1.0.0" +version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "059d83cc991e7a42fc37bd50941885db0888e34209f8cfd9aab07ddec03bc9cf" +checksum = "0e13db2e0ccd5e14a544e8a246ba2312cd25223f616442d7f2cb0e3db614236e" [[package]] name = "typenum" @@ -6314,8 +6255,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "70b20a22c42c8f1cd23ce5e34f165d4d37038f5b663ad20fb6adbdf029172483" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -6341,24 +6282,24 @@ checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" [[package]] name = "unicode-ident" -version = "1.0.12" +version = "1.0.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" +checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" [[package]] name = "unicode-normalization" -version = "0.1.23" +version = "0.1.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a56d1686db2308d901306f92a263857ef59ea39678a5458e7cb17f01415101f5" +checksum = "5033c97c4262335cded6d6fc3e5c18ab755e1a3dc96376350f3d8e9f009ad956" dependencies = [ "tinyvec", ] [[package]] name = "unicode-width" -version = "0.1.13" +version = "0.1.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0336d538f7abc86d282a4189614dfaa90810dfc2c6f6427eaf88e16311dd225d" +checksum = "7dd6e30e90baa6f72411720665d41d89b9a3d039dc45b8faea1ddd07f617f6af" [[package]] name = "unicode-xid" @@ -6368,9 +6309,9 @@ checksum = "fc72304796d0818e357ead4e000d19c9c174ab23dc11093ac919054d20a6a7fc" [[package]] name = "unicode-xid" -version = "0.2.4" +version = "0.2.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c" +checksum = "ebc1c04c71510c7f702b52b7c350734c9ff1295c464a03335b00bb84fc54f853" [[package]] name = "universal-hash" @@ -6492,7 +6433,7 @@ version = "0.3.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4378d202ff965b011c64817db11d5829506d3404edeadb61f190d111da3f231c" dependencies = [ - "bytes 1.7.1", + "bytes 1.7.2", "futures-channel", "futures-util", "headers", @@ -6548,8 +6489,8 @@ dependencies = [ "log", "once_cell", "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", "wasm-bindgen-shared", ] @@ -6571,7 +6512,7 @@ version = "0.2.93" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "585c4c91a46b072c92e908d99cb1dcdf95c5218eeb6f3bf1efa991ee7a68cccf" dependencies = [ - "quote 1.0.36", + "quote 1.0.37", "wasm-bindgen-macro-support", ] @@ -6582,8 +6523,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "afc340c74d9005395cf9dd098506f7f44e38f2b4a21c6aaacf9a105ea5e1e836" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", "wasm-bindgen-backend", "wasm-bindgen-shared", ] @@ -6895,8 +6836,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] @@ -6915,8 +6856,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69" dependencies = [ "proc-macro2 1.0.86", - "quote 1.0.36", - "syn 2.0.74", + "quote 1.0.37", + "syn 2.0.77", ] [[package]] diff --git a/Cargo.toml b/Cargo.toml index 193296c..1f0433a 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -79,6 +79,7 @@ reqwest = { version = "^0.11", features = ["json", "blocking"] } isahc = "1.7.2" async-recursion = "1.0.4" regex = "1.10.2" +once_cell = "1.19.0" [dev-dependencies] fake = { version = "2.4", features = ["uuid", "chrono"] } diff --git a/src/tigergraph/mod.rs b/src/tigergraph/mod.rs index 526d284..7c388fb 100644 --- a/src/tigergraph/mod.rs +++ b/src/tigergraph/mod.rs @@ -139,7 +139,7 @@ pub struct IdAllocationResult { } pub async fn id_allocation(payload: &IdAllocation) -> Result { - let http_client = make_client(); + let http_client = make_client().await.unwrap(); let id_allocation_url = format!("{}:{}", C.tdb.host.trim_end_matches(":9000"), "9002"); let uri: http::Uri = format!("{}/id_allocation/allocation", id_allocation_url,) .parse() diff --git a/src/upstream/aggregation/mod.rs b/src/upstream/aggregation/mod.rs index 1a59d97..fcd6e68 100644 --- a/src/upstream/aggregation/mod.rs +++ b/src/upstream/aggregation/mod.rs @@ -79,7 +79,7 @@ async fn fetch_connections_by_platform_identity( platform: &Platform, identity: &str, ) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let mut page = 1; let mut next_targets: TargetProcessedList = Vec::new(); diff --git a/src/upstream/clusters/mod.rs b/src/upstream/clusters/mod.rs index 51d84a4..58e6d2b 100644 --- a/src/upstream/clusters/mod.rs +++ b/src/upstream/clusters/mod.rs @@ -476,7 +476,7 @@ pub struct Metadata { } async fn get_clusters_by_address(address: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/get_name?address={}", C.upstream.clusters_api.url.clone(), @@ -535,7 +535,7 @@ async fn get_clusters_by_address(address: &str) -> Result, Error> } async fn get_address_by_clusters(name: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/get_address?name={}", C.upstream.clusters_api.url.clone(), diff --git a/src/upstream/dotbit/mod.rs b/src/upstream/dotbit/mod.rs index a591788..657721b 100644 --- a/src/upstream/dotbit/mod.rs +++ b/src/upstream/dotbit/mod.rs @@ -204,7 +204,7 @@ async fn query_by_handle( }; let json_params = serde_json::to_vec(¶ms)?; - let client = make_client(); + let client = make_client().await.unwrap(); let req = Request::builder() .method(Method::POST) .uri(C.upstream.dotbit_service.url.clone()) @@ -268,7 +268,7 @@ async fn query_by_wallet(platform: &Platform, address: &str) -> Result Result Result, Erro }; let json_params = serde_json::to_string(¶ms).map_err(|err| Error::JSONParseError(err))?; - let client = make_client(); + let client = make_client().await.unwrap(); let req = Request::builder() .method(Method::POST) .uri(C.upstream.dotbit_service.register_api.clone()) diff --git a/src/upstream/ens_reverse/mod.rs b/src/upstream/ens_reverse/mod.rs index 8e78378..12a249b 100644 --- a/src/upstream/ens_reverse/mod.rs +++ b/src/upstream/ens_reverse/mod.rs @@ -190,7 +190,7 @@ impl Fetcher for ENSReverseLookup { } pub async fn fetch_record(wallet: &str) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let url: http::Uri = format!("{}{}", C.upstream.ens_reverse.url, wallet) .parse() .map_err(|err: http::uri::InvalidUri| { diff --git a/src/upstream/farcaster/warpcast.rs b/src/upstream/farcaster/warpcast.rs index 6ec59f3..6e05ed3 100644 --- a/src/upstream/farcaster/warpcast.rs +++ b/src/upstream/farcaster/warpcast.rs @@ -446,7 +446,7 @@ pub struct Verification { } async fn user_by_username(username: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v2/user-by-username?username={}", C.upstream.warpcast_api.url, username @@ -523,7 +523,7 @@ async fn user_by_verification(address: &str) -> Result, Error> { return Ok(None); } - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v2/user-by-verification?address={}", C.upstream.warpcast_api.url, address @@ -587,7 +587,7 @@ async fn user_by_verification(address: &str) -> Result, Error> { } async fn get_verifications(fid: i64) -> Result>, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v2/verifications?fid={}", C.upstream.warpcast_api.url, fid diff --git a/src/upstream/firefly/mod.rs b/src/upstream/firefly/mod.rs index 4cb6fe6..37bec9b 100644 --- a/src/upstream/firefly/mod.rs +++ b/src/upstream/firefly/mod.rs @@ -185,7 +185,7 @@ async fn search_records( platform: &Platform, identity: &str, ) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/aggregation/search?platform={}&identity={}", C.upstream.aggregation_service.url.clone(), diff --git a/src/upstream/genome/mod.rs b/src/upstream/genome/mod.rs index d6e6ba4..4e54ca6 100644 --- a/src/upstream/genome/mod.rs +++ b/src/upstream/genome/mod.rs @@ -565,7 +565,7 @@ async fn fetch_address_by_domain( } async fn get_name(address: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/get_name?tld=gno&address={}", C.upstream.genome_api.url.clone(), @@ -622,7 +622,7 @@ async fn get_name(address: &str) -> Result, Error> { } async fn get_address(domain: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/get_address?tld=gno&domain={}", C.upstream.genome_api.url.clone(), diff --git a/src/upstream/keybase/mod.rs b/src/upstream/keybase/mod.rs index 1c1f7ab..acaadde 100644 --- a/src/upstream/keybase/mod.rs +++ b/src/upstream/keybase/mod.rs @@ -516,7 +516,7 @@ async fn fetch_connections_by_platform_identity( platform: &Platform, identity: &str, ) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = match format!( "{}?{}={}&fields=proofs_summary", C.upstream.keybase_service.url, platform, identity diff --git a/src/upstream/opensea/mod.rs b/src/upstream/opensea/mod.rs index 936a1f1..44c30e5 100644 --- a/src/upstream/opensea/mod.rs +++ b/src/upstream/opensea/mod.rs @@ -176,7 +176,7 @@ async fn search_opensea_account( platform: &Platform, identity: &str, ) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/aggregation/opensea_account?platform={}&identity={}", C.upstream.aggregation_service.url.clone(), diff --git a/src/upstream/proof_client/mod.rs b/src/upstream/proof_client/mod.rs index 701c057..e9d422e 100644 --- a/src/upstream/proof_client/mod.rs +++ b/src/upstream/proof_client/mod.rs @@ -107,7 +107,7 @@ async fn batch_fetch_connections( platform: &Platform, identity: &str, ) -> Result<(TargetProcessedList, EdgeList), Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v1/proof?exact=true&platform={}&identity={}", @@ -259,7 +259,7 @@ async fn fetch_connections_by_platform_identity( platform: &Platform, identity: &str, ) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v1/proof?exact=true&platform={}&identity={}", diff --git a/src/upstream/rss3/mod.rs b/src/upstream/rss3/mod.rs index 263ffbe..49de6c7 100644 --- a/src/upstream/rss3/mod.rs +++ b/src/upstream/rss3/mod.rs @@ -139,7 +139,7 @@ impl Fetcher for Rss3 { } async fn batch_fetch_nfts(target: &Target) -> Result<(TargetProcessedList, EdgeList), Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let address = target.identity()?.to_lowercase(); let mut current_cursor = String::from(""); diff --git a/src/upstream/space_id/mod.rs b/src/upstream/space_id/mod.rs index 12c77ef..5f1a90e 100644 --- a/src/upstream/space_id/mod.rs +++ b/src/upstream/space_id/mod.rs @@ -437,7 +437,7 @@ async fn fetch_address_by_domain( /// Resolve Names: https://docs.space.id/developer-guide/web3-name-sdk/sid-api#resolve-names async fn get_address(domain: &str) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v1/getAddress?tld=bnb&domain={}", C.upstream.spaceid_api.url.clone(), @@ -490,7 +490,7 @@ async fn get_address(domain: &str) -> Result { /// Reverse Resolve Names: https://docs.space.id/developer-guide/web3-name-sdk/sid-api#reverse-resolve-names async fn get_name(address: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/v1/getName?tld=bnb&address={}", C.upstream.spaceid_api.url.clone(), diff --git a/src/upstream/sybil_list/mod.rs b/src/upstream/sybil_list/mod.rs index 2b81af2..46702bc 100644 --- a/src/upstream/sybil_list/mod.rs +++ b/src/upstream/sybil_list/mod.rs @@ -119,7 +119,7 @@ async fn save_item( /// Trigger a refetch from github. pub async fn prefetch() -> Result<(), Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = (C.upstream.sybil_service.url).parse().unwrap(); let req = hyper::Request::builder() diff --git a/src/upstream/unstoppable/mod.rs b/src/upstream/unstoppable/mod.rs index fed0abc..795c4dd 100644 --- a/src/upstream/unstoppable/mod.rs +++ b/src/upstream/unstoppable/mod.rs @@ -381,7 +381,7 @@ async fn fetch_domain_by_owner( owners: &str, next: Option, ) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); // curl --request GET "https://api.unstoppabledomains.com/resolve/owners/0x50b6a9ba0b1ca77ce67c22b30afc0a5bbbdb5a18/domains" let uri: http::Uri = if next.is_none() { format!( @@ -444,7 +444,7 @@ async fn fetch_domain_by_owner( } async fn fetch_owner_by_domain(domains: &str) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!( "{}/resolve/domains/{}", C.upstream.unstoppable_api.url, domains @@ -491,7 +491,7 @@ async fn fetch_owner_by_domain(domains: &str) -> Result { /// Do not use `fetch_domain` query #[allow(dead_code)] async fn fetch_domain(owners: &str, page: &str) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = if page.is_empty() { format!( "{}/domains?owners={}", @@ -551,7 +551,7 @@ async fn fetch_domain(owners: &str, page: &str) -> Result Result { - let client = make_client(); + let client = make_client().await.unwrap(); // https://api.unstoppabledomains.com/resolve/reverse/{owner} let reverse_uri: http::Uri = format!( "{}/resolve/reverse/{}", @@ -715,7 +715,7 @@ async fn fetch_domains_by_account( } async fn fetch_owner(domains: &str) -> Result { - let client = make_client(); + let client = make_client().await.unwrap(); let uri: http::Uri = format!("{}/domains/{}", C.upstream.unstoppable_api.url, domains) .parse() .map_err(|_err: InvalidUri| Error::ParamError(format!("Uri format Error {}", _err)))?; @@ -1040,7 +1040,7 @@ struct DomainInfo { // https://api.unstoppabledomains.com/api/domain/search/internal?q=0xbillys async fn domain_search(name: &str) -> Result, Error> { - let client = make_client(); + let client = make_client().await.unwrap(); let encoded_name = urlencoding::encode(name); let uri: http::Uri = format!( "{}/api/domain/search/internal?q={}", diff --git a/src/util/mod.rs b/src/util/mod.rs index fd693b7..9a97fd6 100644 --- a/src/util/mod.rs +++ b/src/util/mod.rs @@ -1,17 +1,27 @@ #[cfg(test)] mod tests; -use std::{collections::HashSet, hash::Hash}; +use std::{collections::HashSet, hash::Hash, sync::Arc}; use crate::error::Error; use chrono::{DateTime, NaiveDateTime}; -use http::Response; +use deadpool::managed::{Manager, Object, Pool, RecycleResult}; +use http::{Response, StatusCode}; use hyper::{body::HttpBody as _, client::HttpConnector, Body, Client, Request}; use hyper_tls::HttpsConnector; +use once_cell::sync::Lazy; use serde::{Deserialize, Deserializer, Serialize, Serializer}; const DEFAULT_TIMEOUT: std::time::Duration = std::time::Duration::from_secs(5); +static CLIENT_POOL: Lazy> = Lazy::new(|| { + let manager = ClientManager{}; + let pool = Pool::builder(manager) + .build() + .unwrap(); + Arc::new(pool) +}); + /// Returns current UNIX timestamp (unit: second). pub fn timestamp() -> i64 { naive_now().and_utc().timestamp() @@ -58,13 +68,32 @@ pub fn utc_to_naive(s: String) -> Result { Ok(dt.naive_utc()) } -pub fn make_client() -> Client> { - let https = HttpsConnector::new(); - // let mut http = HttpConnector::new(); - // http.set_connect_timeout(Some(std::time::Duration::from_secs(5))); - // let https = HttpsConnector::new_with_connector(http); +pub struct ClientManager; + +#[async_trait::async_trait] +impl Manager for ClientManager { + type Type = Client>; + type Error = Error; + + // make_client() implementation moved here + async fn create(&self) -> Result>, Error> { + let https = HttpsConnector::new(); + Ok(Client::builder().build::<_, hyper::Body>(https)) + } + + async fn recycle(&self, _: &mut Client>) -> RecycleResult { + Ok(()) + } +} + +type ClientPool = Pool; - Client::builder().build::<_, hyper::Body>(https) +pub async fn make_client() -> Result, Error> { + let pool = CLIENT_POOL.clone(); + let client = pool.get().await.map_err(|_| { + Error::General("Failed to acquire client from pool".to_string(), StatusCode::INTERNAL_SERVER_ERROR) + })?; + Ok(client) } pub fn make_http_client() -> Client { @@ -76,7 +105,7 @@ pub fn make_http_client() -> Client { /// If timeout is None, default timeout is 5 seconds. pub async fn request_with_timeout( - client: &Client>, + client: &Object, req: Request, timeout: Option, ) -> Result, Error> {