diff --git a/Cargo.lock b/Cargo.lock new file mode 100644 index 0000000..92b419d --- /dev/null +++ b/Cargo.lock @@ -0,0 +1,1666 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "anyhow" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "224afbd727c3d6e4b90103ece64b8d1b67fbb1973b1046c2281eed3f3803f800" + +[[package]] +name = "atty" +version = "0.2.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d9b39be18770d11421cdb1b9947a45dd3f37e93092cbf377614828a319d5fee8" +dependencies = [ + "hermit-abi 0.1.19", + "libc", + "winapi", +] + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "base64" +version = "0.13.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8" + +[[package]] +name = "base64" +version = "0.21.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4a4ddaa51a5bc52a6948f74c06d20aaaddb71924eab79b8c97a8c556e942d6a" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "bumpalo" +version = "3.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d261e256854913907f67ed06efbc3338dfe6179796deefc1ff763fc1aee5535" + +[[package]] +name = "bytes" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "89b2fd2a0dcf38d7971e2194b6b6eebab45ae01067456a7fd93d5547a61b70be" + +[[package]] +name = "cc" +version = "1.0.79" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "50d30906286121d95be3d479533b458f87493b30a4b5f79a607db8f5d11aa91f" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "cherrybomb" +version = "1.0.0" +dependencies = [ + "anyhow", + "cherrybomb-engine", + "clap", + "comfy-table", + "const_format", + "dirs", + "reqwest", + "serde", + "serde_derive", + "serde_json", + "serde_yaml", + "thiserror", + "tokio", + "uuid 1.3.0", +] + +[[package]] +name = "cherrybomb-engine" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8dbae9f28b8112520b2f6b8d89094ab685a558c6b508504825adf42b8ccf2c74" +dependencies = [ + "anyhow", + "base64 0.13.1", + "cherrybomb-oas", + "clap", + "reqwest", + "serde", + "serde_json", + "strum 0.23.0", + "strum_macros 0.23.1", + "thiserror", + "url", +] + +[[package]] +name = "cherrybomb-oas" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69dec5274a0a239037855a6e6753a093e9690522c6883f2a8bc9288a70b86a68" +dependencies = [ + "colored", + "serde", + "serde_json", + "uuid 0.8.2", +] + +[[package]] +name = "clap" +version = "4.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f13b9c79b5d1dd500d20ef541215a6423c75829ef43117e1b4d17fd8af0b5d76" +dependencies = [ + "bitflags", + "clap_derive", + "clap_lex", + "is-terminal", + "once_cell", + "strsim", + "termcolor", +] + +[[package]] +name = "clap_derive" +version = "4.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "684a277d672e91966334af371f1a7b5833f9aa00b07c84e92fbce95e00208ce8" +dependencies = [ + "heck 0.4.1", + "proc-macro-error", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "clap_lex" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "783fe232adfca04f90f56201b26d79682d4cd2625e0bc7290b95123afe558ade" +dependencies = [ + "os_str_bytes", +] + +[[package]] +name = "colored" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b3616f750b84d8f0de8a58bda93e08e2a81ad3f523089b05f1dffecab48c6cbd" +dependencies = [ + "atty", + "lazy_static", + "winapi", +] + +[[package]] +name = "comfy-table" +version = "6.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6e7b787b0dc42e8111badfdbe4c3059158ccb2db8780352fa1b01e8ccf45cc4d" +dependencies = [ + "crossterm", + "strum 0.24.1", + "strum_macros 0.24.3", + "unicode-width", +] + +[[package]] +name = "const_format" +version = "0.2.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7309d9b4d3d2c0641e018d449232f2e28f1b22933c137f157d3dbc14228b8c0e" +dependencies = [ + "const_format_proc_macros", +] + +[[package]] +name = "const_format_proc_macros" +version = "0.2.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d897f47bf7270cf70d370f8f98c1abb6d2d4cf60a6845d30e05bfb90c6568650" +dependencies = [ + "proc-macro2", + "quote", + "unicode-xid", +] + +[[package]] +name = "core-foundation" +version = "0.9.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "194a7a9e6de53fa55116934067c844d9d749312f75c6f6d0980e8c252f8c2146" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "core-foundation-sys" +version = "0.8.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5827cebf4670468b8772dd191856768aedcb1b0278a04f989f7766351917b9dc" + +[[package]] +name = "crossterm" +version = "0.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e64e6c0fbe2c17357405f7c758c1ef960fce08bdfb2c03d88d2a18d7e09c4b67" +dependencies = [ + "bitflags", + "crossterm_winapi", + "libc", + "mio", + "parking_lot", + "signal-hook", + "signal-hook-mio", + "winapi", +] + +[[package]] +name = "crossterm_winapi" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2ae1b35a484aa10e07fe0638d02301c5ad24de82d310ccbd2f3693da5f09bf1c" +dependencies = [ + "winapi", +] + +[[package]] +name = "dirs" +version = "4.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca3aa72a6f96ea37bbc5aa912f6788242832f75369bdfdadcb0e38423f100059" +dependencies = [ + "dirs-sys", +] + +[[package]] +name = "dirs-sys" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b1d1d91c932ef41c0f2663aa8b0ca0342d444d842c06914aa0a7e352d0bada6" +dependencies = [ + "libc", + "redox_users", + "winapi", +] + +[[package]] +name = "encoding_rs" +version = "0.8.32" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "071a31f4ee85403370b58aca746f01041ede6f0da2730960ad001edc2b71b394" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "errno" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f639046355ee4f37944e44f60642c6f3a7efa3cf6b78c78a0d989a8ce6c396a1" +dependencies = [ + "errno-dragonfly", + "libc", + "winapi", +] + +[[package]] +name = "errno-dragonfly" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aa68f1b12764fab894d2755d2518754e71b4fd80ecfb822714a1206c2aab39bf" +dependencies = [ + "cc", + "libc", +] + +[[package]] +name = "fastrand" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a7a407cfaa3385c4ae6b23e84623d48c2798d06e3e6a1878f7f59f17b3f86499" +dependencies = [ + "instant", +] + +[[package]] +name = "fnv" +version = "1.0.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" + +[[package]] +name = "foreign-types" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" +dependencies = [ + "foreign-types-shared", +] + +[[package]] +name = "foreign-types-shared" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" + +[[package]] +name = "form_urlencoded" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a9c384f161156f5260c24a097c56119f9be8c798586aecc13afbcbe7b7e26bf8" +dependencies = [ + "percent-encoding", +] + +[[package]] +name = "futures-channel" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2e5317663a9089767a1ec00a487df42e0ca174b61b4483213ac24448e4664df5" +dependencies = [ + "futures-core", +] + +[[package]] +name = "futures-core" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ec90ff4d0fe1f57d600049061dc6bb68ed03c7d2fbd697274c41805dcb3f8608" + +[[package]] +name = "futures-sink" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f310820bb3e8cfd46c80db4d7fb8353e15dfff853a127158425f31e0be6c8364" + +[[package]] +name = "futures-task" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dcf79a1bf610b10f42aea489289c5a2c478a786509693b80cd39c44ccd936366" + +[[package]] +name = "futures-util" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c1d6de3acfef38d2be4b1f543f553131788603495be83da675e180c8d6b7bd1" +dependencies = [ + "futures-core", + "futures-task", + "pin-project-lite", + "pin-utils", +] + +[[package]] +name = "getrandom" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c05aeb6a22b8f62540c194aac980f2115af067bfe15a0734d7277a768d396b31" +dependencies = [ + "cfg-if", + "libc", + "wasi", +] + +[[package]] +name = "h2" +version = "0.3.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5f9f29bc9dda355256b2916cf526ab02ce0aeaaaf2bad60d65ef3f12f11dd0f4" +dependencies = [ + "bytes", + "fnv", + "futures-core", + "futures-sink", + "futures-util", + "http", + "indexmap", + "slab", + "tokio", + "tokio-util", + "tracing", +] + +[[package]] +name = "hashbrown" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" + +[[package]] +name = "heck" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6d621efb26863f0e9924c6ac577e8275e5e6b77455db64ffa6c65c904e9e132c" +dependencies = [ + "unicode-segmentation", +] + +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + +[[package]] +name = "hermit-abi" +version = "0.1.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62b467343b94ba476dcb2500d242dadbb39557df889310ac77c5d99100aaac33" +dependencies = [ + "libc", +] + +[[package]] +name = "hermit-abi" +version = "0.2.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7" +dependencies = [ + "libc", +] + +[[package]] +name = "hermit-abi" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "856b5cb0902c2b6d65d5fd97dfa30f9b70c7538e770b98eab5ed52d8db923e01" + +[[package]] +name = "http" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75f43d41e26995c17e71ee126451dd3941010b0514a81a9d11f3b341debc2399" +dependencies = [ + "bytes", + "fnv", + "itoa", +] + +[[package]] +name = "http-body" +version = "0.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d5f38f16d184e36f2408a55281cd658ecbd3ca05cce6d6510a176eca393e26d1" +dependencies = [ + "bytes", + "http", + "pin-project-lite", +] + +[[package]] +name = "httparse" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d897f394bad6a705d5f4104762e116a75639e470d80901eed05a860a95cb1904" + +[[package]] +name = "httpdate" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4a1e36c821dbe04574f602848a19f742f4fb3c98d40449f11bcad18d6b17421" + +[[package]] +name = "hyper" +version = "0.14.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5e011372fa0b68db8350aa7a248930ecc7839bf46d8485577d69f117a75f164c" +dependencies = [ + "bytes", + "futures-channel", + "futures-core", + "futures-util", + "h2", + "http", + "http-body", + "httparse", + "httpdate", + "itoa", + "pin-project-lite", + "socket2", + "tokio", + "tower-service", + "tracing", + "want", +] + +[[package]] +name = "hyper-rustls" +version = "0.23.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1788965e61b367cd03a62950836d5cd41560c3577d90e40e0819373194d1661c" +dependencies = [ + "http", + "hyper", + "rustls", + "tokio", + "tokio-rustls", +] + +[[package]] +name = "hyper-tls" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" +dependencies = [ + "bytes", + "hyper", + "native-tls", + "tokio", + "tokio-native-tls", +] + +[[package]] +name = "idna" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e14ddfc70884202db2244c223200c204c2bda1bc6e0998d11b5e024d657209e6" +dependencies = [ + "unicode-bidi", + "unicode-normalization", +] + +[[package]] +name = "indexmap" +version = "1.9.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1885e79c1fc4b10f0e172c475f458b7f7b93061064d98c3293e98c5ba0c8b399" +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", +] + +[[package]] +name = "io-lifetimes" +version = "1.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1abeb7a0dd0f8181267ff8adc397075586500b81b28a73e8a0208b00fc170fb3" +dependencies = [ + "libc", + "windows-sys 0.45.0", +] + +[[package]] +name = "ipnet" +version = "2.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "30e22bd8629359895450b59ea7a776c850561b96a3b1d31321c1949d9e6c9146" + +[[package]] +name = "is-terminal" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "22e18b0a45d56fe973d6db23972bf5bc46f988a4a2385deac9cc29572f09daef" +dependencies = [ + "hermit-abi 0.3.0", + "io-lifetimes", + "rustix", + "windows-sys 0.45.0", +] + +[[package]] +name = "itoa" +version = "1.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fad582f4b9e86b6caa621cabeb0963332d92eea04729ab12892c2533951e6440" + +[[package]] +name = "js-sys" +version = "0.3.61" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "445dde2150c55e483f3d8416706b97ec8e8237c307e5b7b4b8dd15e6af2a0730" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "lazy_static" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" + +[[package]] +name = "libc" +version = "0.2.139" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "201de327520df007757c1f0adce6e827fe8562fbc28bfd9c15571c66ca1f5f79" + +[[package]] +name = "linux-raw-sys" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f051f77a7c8e6957c0696eac88f26b0117e54f52d3fc682ab19397a8812846a4" + +[[package]] +name = "lock_api" +version = "0.4.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "435011366fe56583b16cf956f9df0095b405b82d76425bc8981c0e22e60ec4df" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "log" +version = "0.4.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "abb12e687cfb44aa40f41fc3978ef76448f9b6038cad6aef4259d3c095a2382e" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "memchr" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" + +[[package]] +name = "mime" +version = "0.3.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2a60c7ce501c71e03a9c9c0d35b861413ae925bd979cc7a4e30d060069aaac8d" + +[[package]] +name = "mio" +version = "0.8.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5d732bc30207a6423068df043e3d02e0735b155ad7ce1a6f76fe2baa5b158de" +dependencies = [ + "libc", + "log", + "wasi", + "windows-sys 0.42.0", +] + +[[package]] +name = "native-tls" +version = "0.2.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07226173c32f2926027b63cce4bcd8076c3552846cbe7925f3aaffeac0a3b92e" +dependencies = [ + "lazy_static", + "libc", + "log", + "openssl", + "openssl-probe", + "openssl-sys", + "schannel", + "security-framework", + "security-framework-sys", + "tempfile", +] + +[[package]] +name = "num_cpus" +version = "1.15.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0fac9e2da13b5eb447a6ce3d392f23a29d8694bff781bf03a16cd9ac8697593b" +dependencies = [ + "hermit-abi 0.2.6", + "libc", +] + +[[package]] +name = "once_cell" +version = "1.17.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6f61fba1741ea2b3d6a1e3178721804bb716a68a6aeba1149b5d52e3d464ea66" + +[[package]] +name = "openssl" +version = "0.10.45" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b102428fd03bc5edf97f62620f7298614c45cedf287c271e7ed450bbaf83f2e1" +dependencies = [ + "bitflags", + "cfg-if", + "foreign-types", + "libc", + "once_cell", + "openssl-macros", + "openssl-sys", +] + +[[package]] +name = "openssl-macros" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b501e44f11665960c7e7fcf062c7d96a14ade4aa98116c004b2e37b5be7d736c" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "openssl-probe" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" + +[[package]] +name = "openssl-sys" +version = "0.9.80" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "23bbbf7854cd45b83958ebe919f0e8e516793727652e27fda10a8384cfc790b7" +dependencies = [ + "autocfg", + "cc", + "libc", + "pkg-config", + "vcpkg", +] + +[[package]] +name = "os_str_bytes" +version = "6.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b7820b9daea5457c9f21c69448905d723fbd21136ccf521748f23fd49e723ee" + +[[package]] +name = "parking_lot" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9069cbb9f99e3a5083476ccb29ceb1de18b9118cafa53e90c9551235de2b9521" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-sys 0.45.0", +] + +[[package]] +name = "percent-encoding" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "478c572c3d73181ff3c2539045f6eb99e5491218eae919370993b890cdbdd98e" + +[[package]] +name = "pin-project-lite" +version = "0.2.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e0a7ae3ac2f1173085d398531c705756c94a4c56843785df85a60c1a0afac116" + +[[package]] +name = "pin-utils" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" + +[[package]] +name = "pkg-config" +version = "0.3.26" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6ac9a59f73473f1b8d852421e59e64809f025994837ef743615c6d0c5b305160" + +[[package]] +name = "proc-macro-error" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da25490ff9892aab3fcf7c36f08cfb902dd3e71ca0f9f9517bea02a73a5ce38c" +dependencies = [ + "proc-macro-error-attr", + "proc-macro2", + "quote", + "syn", + "version_check", +] + +[[package]] +name = "proc-macro-error-attr" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a1be40180e52ecc98ad80b184934baf3d0d29f979574e439af5a55274b35f869" +dependencies = [ + "proc-macro2", + "quote", + "version_check", +] + +[[package]] +name = "proc-macro2" +version = "1.0.51" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5d727cae5b39d21da60fa540906919ad737832fe0b1c165da3a34d6548c849d6" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "quote" +version = "1.0.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8856d8364d252a14d474036ea1358d63c9e6965c8e5c1885c18f73d70bff9c7b" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "redox_syscall" +version = "0.2.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fb5a58c1855b4b6819d59012155603f0b22ad30cad752600aadfcb695265519a" +dependencies = [ + "bitflags", +] + +[[package]] +name = "redox_users" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b033d837a7cf162d7993aded9304e30a83213c648b6e389db233191f891e5c2b" +dependencies = [ + "getrandom", + "redox_syscall", + "thiserror", +] + +[[package]] +name = "remove_dir_all" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3acd125665422973a33ac9d3dd2df85edad0f4ae9b00dafb1a05e43a9f5ef8e7" +dependencies = [ + "winapi", +] + +[[package]] +name = "reqwest" +version = "0.11.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "21eed90ec8570952d53b772ecf8f206aa1ec9a3d76b2521c56c42973f2d91ee9" +dependencies = [ + "base64 0.21.0", + "bytes", + "encoding_rs", + "futures-core", + "futures-util", + "h2", + "http", + "http-body", + "hyper", + "hyper-rustls", + "hyper-tls", + "ipnet", + "js-sys", + "log", + "mime", + "native-tls", + "once_cell", + "percent-encoding", + "pin-project-lite", + "rustls", + "rustls-pemfile", + "serde", + "serde_json", + "serde_urlencoded", + "tokio", + "tokio-native-tls", + "tokio-rustls", + "tower-service", + "url", + "wasm-bindgen", + "wasm-bindgen-futures", + "web-sys", + "webpki-roots", + "winreg", +] + +[[package]] +name = "ring" +version = "0.16.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3053cf52e236a3ed746dfc745aa9cacf1b791d846bdaf412f60a8d7d6e17c8fc" +dependencies = [ + "cc", + "libc", + "once_cell", + "spin", + "untrusted", + "web-sys", + "winapi", +] + +[[package]] +name = "rustix" +version = "0.36.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f43abb88211988493c1abb44a70efa56ff0ce98f233b7b276146f1f3f7ba9644" +dependencies = [ + "bitflags", + "errno", + "io-lifetimes", + "libc", + "linux-raw-sys", + "windows-sys 0.45.0", +] + +[[package]] +name = "rustls" +version = "0.20.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fff78fc74d175294f4e83b28343315ffcfb114b156f0185e9741cb5570f50e2f" +dependencies = [ + "log", + "ring", + "sct", + "webpki", +] + +[[package]] +name = "rustls-pemfile" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d194b56d58803a43635bdc398cd17e383d6f71f9182b9a192c127ca42494a59b" +dependencies = [ + "base64 0.21.0", +] + +[[package]] +name = "rustversion" +version = "1.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5583e89e108996506031660fe09baa5011b9dd0341b89029313006d1fb508d70" + +[[package]] +name = "ryu" +version = "1.0.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b4b9743ed687d4b4bcedf9ff5eaa7398495ae14e61cba0a295704edbc7decde" + +[[package]] +name = "schannel" +version = "0.1.21" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "713cfb06c7059f3588fb8044c0fad1d09e3c01d225e25b9220dbfdcf16dbb1b3" +dependencies = [ + "windows-sys 0.42.0", +] + +[[package]] +name = "scopeguard" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d29ab0c6d3fc0ee92fe66e2d99f700eab17a8d57d1c1d3b748380fb20baa78cd" + +[[package]] +name = "sct" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d53dcdb7c9f8158937a7981b48accfd39a43af418591a5d008c7b22b5e1b7ca4" +dependencies = [ + "ring", + "untrusted", +] + +[[package]] +name = "security-framework" +version = "2.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a332be01508d814fed64bf28f798a146d73792121129962fdf335bb3c49a4254" +dependencies = [ + "bitflags", + "core-foundation", + "core-foundation-sys", + "libc", + "security-framework-sys", +] + +[[package]] +name = "security-framework-sys" +version = "2.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31c9bb296072e961fcbd8853511dd39c2d8be2deb1e17c6860b1d30732b323b4" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "serde" +version = "1.0.152" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bb7d1f0d3021d347a83e556fc4683dea2ea09d87bccdf88ff5c12545d89d5efb" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde_derive" +version = "1.0.152" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af487d118eecd09402d70a5d72551860e788df87b464af30e5ea6a38c75c541e" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "serde_json" +version = "1.0.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7434af0dc1cbd59268aa98b4c22c131c0584d2232f6fb166efb993e2832e896a" +dependencies = [ + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "serde_urlencoded" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3491c14715ca2294c4d6a88f15e84739788c1d030eed8c110436aafdaa2f3fd" +dependencies = [ + "form_urlencoded", + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "serde_yaml" +version = "0.9.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8fb06d4b6cdaef0e0c51fa881acb721bed3c924cfaa71d9c94a3b771dfdf6567" +dependencies = [ + "indexmap", + "itoa", + "ryu", + "serde", + "unsafe-libyaml", +] + +[[package]] +name = "signal-hook" +version = "0.3.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a253b5e89e2698464fc26b545c9edceb338e18a89effeeecfea192c3025be29d" +dependencies = [ + "libc", + "signal-hook-registry", +] + +[[package]] +name = "signal-hook-mio" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29ad2e15f37ec9a6cc544097b78a1ec90001e9f71b81338ca39f430adaca99af" +dependencies = [ + "libc", + "mio", + "signal-hook", +] + +[[package]] +name = "signal-hook-registry" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e51e73328dc4ac0c7ccbda3a494dfa03df1de2f46018127f60c693f2648455b0" +dependencies = [ + "libc", +] + +[[package]] +name = "slab" +version = "0.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4614a76b2a8be0058caa9dbbaf66d988527d86d003c11a94fbd335d7661edcef" +dependencies = [ + "autocfg", +] + +[[package]] +name = "smallvec" +version = "1.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a507befe795404456341dfab10cef66ead4c041f62b8b11bbb92bffe5d0953e0" + +[[package]] +name = "socket2" +version = "0.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "02e2d2db9033d13a1567121ddd7a095ee144db4e1ca1b1bda3419bc0da294ebd" +dependencies = [ + "libc", + "winapi", +] + +[[package]] +name = "spin" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6e63cff320ae2c57904679ba7cb63280a3dc4613885beafb148ee7bf9aa9042d" + +[[package]] +name = "strsim" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" + +[[package]] +name = "strum" +version = "0.23.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cae14b91c7d11c9a851d3fbc80a963198998c2a64eec840477fa92d8ce9b70bb" + +[[package]] +name = "strum" +version = "0.24.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "063e6045c0e62079840579a7e47a355ae92f60eb74daaf156fb1e84ba164e63f" + +[[package]] +name = "strum_macros" +version = "0.23.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5bb0dc7ee9c15cea6199cde9a127fa16a4c5819af85395457ad72d68edc85a38" +dependencies = [ + "heck 0.3.3", + "proc-macro2", + "quote", + "rustversion", + "syn", +] + +[[package]] +name = "strum_macros" +version = "0.24.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e385be0d24f186b4ce2f9982191e7101bb737312ad61c1f2f984f34bcf85d59" +dependencies = [ + "heck 0.4.1", + "proc-macro2", + "quote", + "rustversion", + "syn", +] + +[[package]] +name = "syn" +version = "1.0.107" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f4064b5b16e03ae50984a5a8ed5d4f8803e6bc1fd170a3cda91a1be4b18e3f5" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "tempfile" +version = "3.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5cdb1ef4eaeeaddc8fbd371e5017057064af0911902ef36b39801f67cc6d79e4" +dependencies = [ + "cfg-if", + "fastrand", + "libc", + "redox_syscall", + "remove_dir_all", + "winapi", +] + +[[package]] +name = "termcolor" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "be55cf8942feac5c765c2c993422806843c9a9a45d4d5c407ad6dd2ea95eb9b6" +dependencies = [ + "winapi-util", +] + +[[package]] +name = "thiserror" +version = "1.0.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6a9cd18aa97d5c45c6603caea1da6628790b37f7a34b6ca89522331c5180fed0" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fb327af4685e4d03fa8cbcf1716380da910eeb2bb8be417e7f9fd3fb164f36f" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tinyvec" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87cc5ceb3875bb20c2890005a4e226a4651264a5c75edb2421b52861a0a0cb50" +dependencies = [ + "tinyvec_macros", +] + +[[package]] +name = "tinyvec_macros" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" + +[[package]] +name = "tokio" +version = "1.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c8e00990ebabbe4c14c08aca901caed183ecd5c09562a12c824bb53d3c3fd3af" +dependencies = [ + "autocfg", + "bytes", + "libc", + "memchr", + "mio", + "num_cpus", + "pin-project-lite", + "socket2", + "tokio-macros", + "windows-sys 0.42.0", +] + +[[package]] +name = "tokio-macros" +version = "1.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d266c00fde287f55d3f1c3e96c500c362a2b8c695076ec180f27918820bc6df8" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tokio-native-tls" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f7d995660bd2b7f8c1568414c1126076c13fbb725c40112dc0120b78eb9b717b" +dependencies = [ + "native-tls", + "tokio", +] + +[[package]] +name = "tokio-rustls" +version = "0.23.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c43ee83903113e03984cb9e5cebe6c04a5116269e900e3ddba8f068a62adda59" +dependencies = [ + "rustls", + "tokio", + "webpki", +] + +[[package]] +name = "tokio-util" +version = "0.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0bb2e075f03b3d66d8d8785356224ba688d2906a371015e225beeb65ca92c740" +dependencies = [ + "bytes", + "futures-core", + "futures-sink", + "pin-project-lite", + "tokio", + "tracing", +] + +[[package]] +name = "tower-service" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b6bc1c9ce2b5135ac7f93c72918fc37feb872bdc6a5533a8b85eb4b86bfdae52" + +[[package]] +name = "tracing" +version = "0.1.37" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8ce8c33a8d48bd45d624a6e523445fd21ec13d3653cd51f681abf67418f54eb8" +dependencies = [ + "cfg-if", + "pin-project-lite", + "tracing-core", +] + +[[package]] +name = "tracing-core" +version = "0.1.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "24eb03ba0eab1fd845050058ce5e616558e8f8d8fca633e6b163fe25c797213a" +dependencies = [ + "once_cell", +] + +[[package]] +name = "try-lock" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3528ecfd12c466c6f163363caf2d02a71161dd5e1cc6ae7b34207ea2d42d81ed" + +[[package]] +name = "unicode-bidi" +version = "0.3.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d54675592c1dbefd78cbd98db9bacd89886e1ca50692a0692baefffdeb92dd58" + +[[package]] +name = "unicode-ident" +version = "1.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "84a22b9f218b40614adcb3f4ff08b703773ad44fa9423e4e0d346d5db86e4ebc" + +[[package]] +name = "unicode-normalization" +version = "0.1.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c5713f0fc4b5db668a2ac63cdb7bb4469d8c9fed047b1d0292cc7b0ce2ba921" +dependencies = [ + "tinyvec", +] + +[[package]] +name = "unicode-segmentation" +version = "1.10.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1dd624098567895118886609431a7c3b8f516e41d30e0643f03d94592a147e36" + +[[package]] +name = "unicode-width" +version = "0.1.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c0edd1e5b14653f783770bce4a4dabb4a5108a5370a5f5d8cfe8710c361f6c8b" + +[[package]] +name = "unicode-xid" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c" + +[[package]] +name = "unsafe-libyaml" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc7ed8ba44ca06be78ea1ad2c3682a43349126c8818054231ee6f4748012aed2" + +[[package]] +name = "untrusted" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" + +[[package]] +name = "url" +version = "2.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d68c799ae75762b8c3fe375feb6600ef5602c883c5d21eb51c09f22b83c4643" +dependencies = [ + "form_urlencoded", + "idna", + "percent-encoding", +] + +[[package]] +name = "uuid" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc5cf98d8186244414c848017f0e2676b3fcb46807f6668a97dfe67359a3c4b7" +dependencies = [ + "getrandom", + "serde", +] + +[[package]] +name = "uuid" +version = "1.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1674845326ee10d37ca60470760d4288a6f80f304007d92e5c53bab78c9cfd79" +dependencies = [ + "getrandom", +] + +[[package]] +name = "vcpkg" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" + +[[package]] +name = "version_check" +version = "0.9.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f" + +[[package]] +name = "want" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1ce8a968cb1cd110d136ff8b819a556d6fb6d919363c61534f6860c7eb172ba0" +dependencies = [ + "log", + "try-lock", +] + +[[package]] +name = "wasi" +version = "0.11.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" + +[[package]] +name = "wasm-bindgen" +version = "0.2.84" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31f8dcbc21f30d9b8f2ea926ecb58f6b91192c17e9d33594b3df58b2007ca53b" +dependencies = [ + "cfg-if", + "wasm-bindgen-macro", +] + +[[package]] +name = "wasm-bindgen-backend" +version = "0.2.84" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95ce90fd5bcc06af55a641a86428ee4229e44e07033963a2290a8e241607ccb9" +dependencies = [ + "bumpalo", + "log", + "once_cell", + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-futures" +version = "0.4.34" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f219e0d211ba40266969f6dbdd90636da12f75bee4fc9d6c23d1260dadb51454" +dependencies = [ + "cfg-if", + "js-sys", + "wasm-bindgen", + "web-sys", +] + +[[package]] +name = "wasm-bindgen-macro" +version = "0.2.84" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c21f77c0bedc37fd5dc21f897894a5ca01e7bb159884559461862ae90c0b4c5" +dependencies = [ + "quote", + "wasm-bindgen-macro-support", +] + +[[package]] +name = "wasm-bindgen-macro-support" +version = "0.2.84" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2aff81306fcac3c7515ad4e177f521b5c9a15f2b08f4e32d823066102f35a5f6" +dependencies = [ + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-backend", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-shared" +version = "0.2.84" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0046fef7e28c3804e5e38bfa31ea2a0f73905319b677e57ebe37e49358989b5d" + +[[package]] +name = "web-sys" +version = "0.3.61" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e33b99f4b23ba3eec1a53ac264e35a755f00e966e0065077d6027c0f575b0b97" +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 = "winapi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" +dependencies = [ + "winapi-i686-pc-windows-gnu", + "winapi-x86_64-pc-windows-gnu", +] + +[[package]] +name = "winapi-i686-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" + +[[package]] +name = "winapi-util" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70ec6ce85bb158151cae5e5c87f95a8e97d2c0c4b001223f33a334e3ce5de178" +dependencies = [ + "winapi", +] + +[[package]] +name = "winapi-x86_64-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" + +[[package]] +name = "windows-sys" +version = "0.42.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5a3e1820f08b8513f676f7ab6c1f99ff312fb97b553d30ff4dd86f9f15728aa7" +dependencies = [ + "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-sys" +version = "0.45.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75283be5efb2831d37ea142365f009c02ec203cd29a3ebecbc093d52315b66d0" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-targets" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e2522491fbfcd58cc84d47aeb2958948c4b8982e9a2d8a2a35bbaed431390e7" +dependencies = [ + "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.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8c9864e83243fdec7fc9c5444389dcbbfd258f745e7853198f365e3c4968a608" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c8b1b673ffc16c47a9ff48570a9d85e25d265735c503681332589af6253c6c7" + +[[package]] +name = "windows_i686_gnu" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "de3887528ad530ba7bdbb1faa8275ec7a1155a45ffa57c37993960277145d640" + +[[package]] +name = "windows_i686_msvc" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bf4d1122317eddd6ff351aa852118a2418ad4214e6613a50e0191f7004372605" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1040f221285e17ebccbc2591ffdc2d44ee1f9186324dd3e84e99ac68d699c45" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "628bfdf232daa22b0d64fdb62b09fcc36bb01f05a3939e20ab73aaf9470d0463" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.42.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "447660ad36a13288b1db4d4248e857b510e8c3a225c822ba4fb748c0aafecffd" + +[[package]] +name = "winreg" +version = "0.10.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "80d0f4e272c85def139476380b12f9ac60926689dd2e01d4923222f40580869d" +dependencies = [ + "winapi", +] diff --git a/Cargo.toml b/Cargo.toml index 011a5fa..d1b57a4 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -24,11 +24,12 @@ clap = { version = "4.0.29", features = ["derive"] } const_format = "0.2.30" serde = { version = "^1.0", features = ["derive"] } serde_json = "^1.0" -cherrybomb-engine = "^0.1" +cherrybomb-engine = "0.1.1" serde_yaml = "^0.9.0" uuid = {version = "1.2.2", features = ["v4"] } dirs = "4.0.0" reqwest = "0.11.13" comfy-table = "6.1.4" serde_derive = "1.0.152" - \ No newline at end of file + + diff --git a/cherrybomb-engine/Cargo.toml b/cherrybomb-engine/Cargo.toml index 1d87b9a..44f8bd4 100644 --- a/cherrybomb-engine/Cargo.toml +++ b/cherrybomb-engine/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "cherrybomb-engine" -version = "0.1.0" +version = "0.1.1" authors = ["BLST Security"] description = """ Cherrybomb enging crate @@ -13,7 +13,7 @@ edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] -cherrybomb-oas = "^0.1" +cherrybomb-oas = "0.1" anyhow = "1.0.66" thiserror = "1.0.37" serde_json = "^1.0" diff --git a/cherrybomb-engine/src/config.rs b/cherrybomb-engine/src/config.rs index 6fb8cae..eb4aaa7 100644 --- a/cherrybomb-engine/src/config.rs +++ b/cherrybomb-engine/src/config.rs @@ -1,7 +1,7 @@ use clap::{Args, ValueEnum}; -use serde::Deserialize; +use serde::{Deserialize, Serialize}; -#[derive(Default, ValueEnum, Deserialize, Clone, Debug)] +#[derive(Default, ValueEnum, Deserialize, Clone, Debug, Serialize)] pub enum Profile { Info, #[default] @@ -27,7 +27,7 @@ pub struct Config { pub no_color: bool, } -#[derive(ValueEnum, Deserialize, Clone, Debug, Default, PartialOrd, PartialEq)] +#[derive(ValueEnum, Deserialize, Clone, Debug, Default, PartialOrd, PartialEq, Serialize, Copy)] pub enum Verbosity { Quiet, #[default] diff --git a/cherrybomb-engine/src/lib.rs b/cherrybomb-engine/src/lib.rs index 34429e9..f2c8c65 100644 --- a/cherrybomb-engine/src/lib.rs +++ b/cherrybomb-engine/src/lib.rs @@ -22,10 +22,12 @@ fn verbose_print(config: &Config, required: Option, message: &str) { } pub async fn run(config: &Config) -> anyhow::Result { - verbose_print(config, None, "Starting Cherrybomb..."); + // receive_parameters(config); + + verbose_print(config, Some(config.verbosity), "Starting Cherrybomb..."); // Reading OAS file to string - verbose_print(config, None, "Opening OAS file..."); + verbose_print(config, Some(config.verbosity), "Opening OAS file..."); let oas_file = match std::fs::read_to_string(&config.file) { Ok(file) => file, Err(e) => { @@ -34,7 +36,7 @@ pub async fn run(config: &Config) -> anyhow::Result { }; // Parsing OAS file to JSON - verbose_print(config, None, "Parsing OAS file..."); + verbose_print(config, Some(config.verbosity), "Parsing OAS file..."); let oas_json: Value = match serde_json::from_str(&oas_file) { Ok(json) => json, Err(e) => { @@ -43,7 +45,7 @@ pub async fn run(config: &Config) -> anyhow::Result { }; // Parsing JSON to OAS struct - verbose_print(config, Some(Verbosity::Debug), "Creating OAS struct..."); + verbose_print(config, Some(config.verbosity), "Creating OAS struct..."); let oas: OAS3_1 = match serde_json::from_value(oas_json.clone()) { Ok(oas) => oas, Err(e) => { @@ -71,7 +73,7 @@ fn run_profile_info(config: &Config, oas: &OAS3_1, oas_json: &Value) -> anyhow:: .collect(); //Creating endpoint - verbose_print(config, None, "Create endpoint list"); + verbose_print(config, Some(config.verbosity), "Create endpoint list"); let ep_table = EpTable::new::(oas_json); let endpoint_result: HashMap<&str, Value> = ep_table .eps @@ -96,10 +98,15 @@ async fn run_active_profile( // Creating active scan struct verbose_print( config, - Some(Verbosity::Debug), + Some(config.verbosity), "Creating active scan struct...", ); - let mut active_scan = match active_scanner::ActiveScan::new(oas.clone(), oas_json.clone()) { + let mut active_scan = match active_scanner::ActiveScan::new( + oas.clone(), + oas_json.clone(), + config.verbosity, + config.ignore_tls_errors, + ) { Ok(scan) => scan, Err(e) => { return Err(anyhow::anyhow!("Error creating active scan struct: {}", e)); @@ -107,7 +114,7 @@ async fn run_active_profile( }; // Running active scan - verbose_print(config, None, "Running active scan..."); + verbose_print(config, Some(config.verbosity), "Running active scan..."); let temp_auth = Authorization::None; active_scan .run(active_scanner::ActiveScanType::Full, &temp_auth) @@ -125,7 +132,7 @@ fn run_passive_profile(config: &Config, oas: &OAS3_1, oas_json: &Value) -> anyho // Creating passive scan struct verbose_print( config, - Some(Verbosity::Debug), + Some(config.verbosity), "Creating passive scan struct...", ); let mut passive_scan = passive_scanner::PassiveSwaggerScan { @@ -174,7 +181,11 @@ async fn run_normal_profile( Ok(report) } -async fn run_full_profile(config: &Config, oas: &OAS3_1, oas_json: &Value) -> anyhow::Result { +async fn run_full_profile( + config: &Config, + oas: &OAS3_1, + oas_json: &Value, +) -> anyhow::Result { let mut report = json!({}); let mut results = HashMap::from([ ("active", run_active_profile(config, oas, oas_json).await), diff --git a/cherrybomb-engine/src/scan/active/active_scanner.rs b/cherrybomb-engine/src/scan/active/active_scanner.rs index b760371..bc85b42 100644 --- a/cherrybomb-engine/src/scan/active/active_scanner.rs +++ b/cherrybomb-engine/src/scan/active/active_scanner.rs @@ -1,5 +1,6 @@ use super::http_client::logs::AttackLog; use super::http_client::*; +use crate::config::Verbosity; use crate::scan::active::http_client::auth::Authorization; use crate::scan::active::utils::send_req; use crate::scan::checks::*; @@ -60,15 +61,21 @@ where { pub oas: T, pub oas_value: Value, - pub verbosity: u8, + pub verbosity: Verbosity, pub checks: Vec, pub payloads: Vec, pub logs: AttackLog, pub path_params: HashMap, + pub ignore_tls_error: bool, } impl Deserialize<'de>> ActiveScan { - pub fn new(oas: T, oas_value: Value) -> Result { + pub fn new( + oas: T, + oas_value: Value, + verbosity: Verbosity, + ignore_tls_error: bool, + ) -> Result { let path_params: HashMap = HashMap::new(); // let path_params = Self::create_hash(&auth_p); let payloads = Self::payloads_generator(&oas, &oas_value); @@ -76,10 +83,11 @@ impl Deserialize<'de>> ActiveScan { oas, oas_value, checks: vec![], - verbosity: 0, + verbosity: verbosity, payloads, logs: AttackLog::default(), path_params, + ignore_tls_error: ignore_tls_error, }) } @@ -109,7 +117,6 @@ impl Deserialize<'de>> ActiveScan { }; } - fn payloads_generator(oas: &T, oas_value: &Value) -> Vec { let mut payloads = vec![]; for (path, path_item) in oas.get_paths() { diff --git a/cherrybomb-engine/src/scan/active/additional_checks.rs b/cherrybomb-engine/src/scan/active/additional_checks.rs index 35c1a55..80e5d43 100644 --- a/cherrybomb-engine/src/scan/active/additional_checks.rs +++ b/cherrybomb-engine/src/scan/active/additional_checks.rs @@ -53,12 +53,11 @@ impl ActiveScan { .headers(h.clone()) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { - ret_val - .1 - .push(&req, &response, "Testing SQLIcarg".to_string()); + ret_val.1.push(&req, &response, "Testing SQLI".to_string()); ret_val.0.push(( ResponseData { location: path.to_string(), @@ -223,7 +222,9 @@ impl ActiveScan { .method(method) .headers(h.clone()) .build(); - let response_vector = req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val .1 @@ -289,8 +290,9 @@ impl ActiveScan { .auth(auth.clone()) .headers(vec![h]) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push( &req, @@ -360,8 +362,9 @@ impl ActiveScan { .headers(vec![]) .auth(auth.clone()) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push(&req, &response, "Testing SSRF".to_string()); ret_val.0.push(( @@ -433,9 +436,9 @@ impl ActiveScan { ) .build(); - print!("POST SSRF : "); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push(&req, &response, "Testing SSRF".to_string()); ret_val.0.push(( @@ -485,11 +488,9 @@ impl ActiveScan { .auth(auth.clone()) .payload(&oas_map.payload.payload.to_string()) .build(); - let _response_vector = - req.send_request_all_servers(self.verbosity > 0).await; - print!("POST SSRF : "); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push(&req, &response, "Testing SSRF".to_string()); ret_val.0.push(( @@ -547,8 +548,9 @@ impl ActiveScan { .headers(vec![]) .auth(auth.clone()) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; // dbg!(&response_vector); for response in response_vector { ret_val.1.push( @@ -598,8 +600,9 @@ impl ActiveScan { .headers(vec![]) .auth(auth.clone()) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push( &req, @@ -669,8 +672,9 @@ impl ActiveScan { .to_string(), ) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val.1.push( &req, @@ -731,8 +735,9 @@ impl ActiveScan { .to_string(), ) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val .1 @@ -802,7 +807,9 @@ impl ActiveScan { .method(Method::GET) .headers(vec![]) .build(); - let response_vector = req.send_request(self.verbosity > 0).await; + let response_vector = req + .send_request(self.verbosity, self.ignore_tls_error) + .await; if let Ok(res) = response_vector { //logging //logging request/response/description @@ -877,8 +884,9 @@ impl ActiveScan { .parameters(vec_param.clone()) .build(); - let response_vector = - req.send_request(self.verbosity > 0).await; + let response_vector = req + .send_request(self.verbosity, self.ignore_tls_error) + .await; if let Ok(res) = response_vector { //logging request/response/description ret_val.1.push(&req, &res, "Testing for BOLA".to_string()); @@ -915,7 +923,9 @@ impl ActiveScan { .headers(vec![]) .auth(auth.clone()) .build(); - let response_vector = req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for (response, server) in response_vector.iter().zip(req.servers.iter()) { ret_val.1.push(&req, response, "Testing SSL".to_string()); ret_val.0.push(( @@ -958,8 +968,9 @@ impl ActiveScan { .payload(&oas_map.payload.payload.to_string()) .build(); - let response_vector = - req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { ret_val .1 @@ -999,7 +1010,9 @@ impl ActiveScan { .headers(vec![]) .parameters(vec_param.clone()) .build(); - let response_vector = req.send_request_all_servers(self.verbosity > 0).await; + let response_vector = req + .send_request_all_servers(self.verbosity, self.ignore_tls_error) + .await; for response in response_vector { //logging request/response/description ret_val diff --git a/cherrybomb-engine/src/scan/active/http_client/req.rs b/cherrybomb-engine/src/scan/active/http_client/req.rs index 1100e1b..66b3d05 100644 --- a/cherrybomb-engine/src/scan/active/http_client/req.rs +++ b/cherrybomb-engine/src/scan/active/http_client/req.rs @@ -1,9 +1,11 @@ +use crate::config::{self, Config, Verbosity}; use crate::scan::active::http_client::auth::Authorization; use crate::scan::active::http_client::{ AttackRequest, AttackResponse, MHeader, QuePay, RequestParameter, }; use cherrybomb_oas::legacy::legacy_oas::*; use cherrybomb_oas::legacy::utils::Method; +use reqwest::Client; use serde::{Deserialize, Serialize}; use std::collections::HashMap; use std::fmt; @@ -227,8 +229,15 @@ impl AttackRequest { } } - pub async fn send_request(&self, print: bool) -> Result { - let client = reqwest::Client::new(); + pub async fn send_request( + &self, + verbose: Verbosity, + ignore_tls_error: bool, + ) -> Result { + let client = Client::builder() + .danger_accept_invalid_certs(ignore_tls_error) + .build() + .unwrap(); let method1 = reqwest::Method::from_bytes(self.method.to_string().as_bytes()).unwrap(); let (req_payload, req_query, path, headers1) = self.params_to_payload(); let h = self.get_headers(&headers1); @@ -240,10 +249,9 @@ impl AttackRequest { //.header("content-type", "application/json") .build() .unwrap(); - // dbg!(&req); match client.execute(req).await { Ok(res) => { - if print { + if verbose.eq(&Verbosity::Debug) { println!("Request: {self}"); } Ok(AttackResponse { @@ -257,13 +265,22 @@ impl AttackRequest { }) } Err(e) => { - println!("FAILED TO EXECUTE: {self}"); + if verbose.eq(&Verbosity::Debug) { + println!("FAILED TO EXECUTE: {self}"); + } Err(e) } } } - pub async fn send_request_all_servers(&self, print: bool) -> Vec { - let client = reqwest::Client::new(); + pub async fn send_request_all_servers( + &self, + print: Verbosity, + ignore_tls_error: bool, + ) -> Vec { + let client = Client::builder() + .danger_accept_invalid_certs(ignore_tls_error) + .build() + .unwrap(); let method1 = reqwest::Method::from_bytes(self.method.to_string().as_bytes()).unwrap(); let (req_payload, req_query, path, headers1) = self.params_to_payload(); let mut h = self.get_headers(&headers1); @@ -282,7 +299,7 @@ impl AttackRequest { .unwrap(); //TODO return builder error match client.execute(req).await { Ok(res) => { - if print { + if print.eq(&Verbosity::Debug) { println!("Request: {self}"); } ret.push(AttackResponse { @@ -296,7 +313,9 @@ impl AttackRequest { }) } Err(e) => { - println!("FAILED TO EXECUTE: {self} - ERROR: {e}"); + if print.eq(&Verbosity::Debug) { + println!("FAILED TO EXECUTE: {self} - ERROR: {e}"); + } } } } diff --git a/cherrybomb-oas/Cargo.toml b/cherrybomb-oas/Cargo.toml index 882ab65..ad679c5 100644 --- a/cherrybomb-oas/Cargo.toml +++ b/cherrybomb-oas/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "cherrybomb-oas" -version = "0.1.0" +version = "0.1.1" authors = ["BLST Security"] description = """ Cherrybomb OpenAPI Specification (OAS) struct and functions diff --git a/src/main.rs b/src/main.rs index b08a12b..e95c08b 100644 --- a/src/main.rs +++ b/src/main.rs @@ -75,7 +75,7 @@ async fn main() -> anyhow::Result { telemetry::send(config.profile.clone(), config.verbosity.clone()).await?; } let json_val = cherrybomb_engine::run(&config).await?; - match print_tables(json_val, &opt) { + match print_tables(json_val, &opt, &config) { Ok(exit_code) => Ok(exit_code), Err(e) => Err(anyhow::anyhow!("Error printing tables: {}", e)), } diff --git a/src/table.rs b/src/table.rs index 17a3d94..28f78cc 100644 --- a/src/table.rs +++ b/src/table.rs @@ -1,6 +1,7 @@ use crate::options; use crate::options::Options; use anyhow::*; +use cherrybomb_engine::config::{self, Config, Verbosity}; use comfy_table::{modifiers::UTF8_ROUND_CORNERS, presets::UTF8_FULL, *}; use serde::{Deserialize, Serialize}; use serde_json::{Map, Value}; @@ -47,6 +48,14 @@ pub struct TableEP { pub statuses: Vec, } +fn print_table_verbosity(verb: &Verbosity, table: Table) { + match verb { + Verbosity::Quiet => (), + Verbosity::Normal => println!("{table}"), + Verbosity::Verbose => println!("{table}"), + Verbosity::Debug => println!("{table}"), + }; +} fn to_format(vec_raw: &mut Vec) -> String { vec_raw.dedup(); vec_raw @@ -63,23 +72,67 @@ enum CheckStatus { Fail, } -pub fn print_tables(json_struct: Value, options: &Options) -> anyhow::Result { +pub fn print_tables( + json_struct: Value, + options: &Options, + conf: &Config, +) -> anyhow::Result { let mut status_vec = vec![]; if let Some(json_struct) = json_struct["passive"].as_object() { - status_vec.push(print_full_alert_table(json_struct, &options.format)?); - //create_table_with_full_verbosity(&json_struct)?; + match &conf.verbosity { + Verbosity::Verbose => status_vec.push(print_full_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Debug => status_vec.push(print_full_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Quiet => status_vec.push(print_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Normal => status_vec.push(print_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + }; } if let Some(json_struct) = json_struct["active"].as_object() { - status_vec.push(print_full_alert_table(json_struct, &options.format)?); - // create_table_with_full_verbosity(&json_struct)?; + match &conf.verbosity { + Verbosity::Verbose => status_vec.push(print_full_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Debug => status_vec.push(print_full_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Quiet => status_vec.push(print_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + Verbosity::Normal => status_vec.push(print_alert_table( + json_struct, + &options.format, + &conf.verbosity, + )?), + }; } match options.format { options::OutputFormat::Table => { if let Some(json_struct) = json_struct["params"].as_object() { - print_param_table(json_struct)?; + print_param_table(json_struct, &conf.verbosity)?; } if let Some(json_struct) = json_struct["endpoints"].as_object() { - print_endpoints_table(json_struct)?; + print_endpoints_table(json_struct, &conf.verbosity)?; } } options::OutputFormat::Json => { @@ -97,7 +150,7 @@ pub fn print_tables(json_struct: Value, options: &Options) -> anyhow::Result) -> anyhow::Result<()> { +fn print_endpoints_table(json_struct: &Map, verb: &Verbosity) -> anyhow::Result<()> { let mut table = Table::new(); table .load_preset(presets::UTF8_FULL) @@ -132,11 +185,11 @@ fn print_endpoints_table(json_struct: &Map) -> anyhow::Result<()> ]); } } - println!("{table}"); + print_table_verbosity(verb, table); Ok(()) } -fn print_param_table(json_struct: &Map) -> anyhow::Result<()> { +fn print_param_table(json_struct: &Map, verb: &Verbosity) -> anyhow::Result<()> { //create a parameter table let mut table = Table::new(); table @@ -167,13 +220,14 @@ fn print_param_table(json_struct: &Map) -> anyhow::Result<()> { } } - println!("{table}"); + print_table_verbosity(verb, table); Ok(()) } fn print_alert_table( json_struct: &Map, output: &options::OutputFormat, + verb: &Verbosity, ) -> anyhow::Result { //display simple table with alerts let mut table = Table::new(); @@ -204,7 +258,7 @@ fn print_alert_table( } } if matches!(output, &options::OutputFormat::Table) { - println!("{table}"); + print_table_verbosity(verb, table) } Ok(return_status) } @@ -212,6 +266,7 @@ fn print_alert_table( fn print_full_alert_table( json_struct: &Map, output: &options::OutputFormat, + verb: &Verbosity, ) -> anyhow::Result { //create a table of alerts with full verbosity let mut table = Table::new(); @@ -242,7 +297,7 @@ fn print_full_alert_table( } } if matches!(output, &options::OutputFormat::Table) { - println!("{table}"); + print_table_verbosity(verb, table); } Ok(return_status) }