diff --git a/.cargo/audit.toml b/.cargo/audit.toml new file mode 100644 index 0000000..14ac304 --- /dev/null +++ b/.cargo/audit.toml @@ -0,0 +1,25 @@ +# Cargo audit configuration for AIngle +# https://rustsec.org/ + +[advisories] +# Advisories to ignore in product crates +ignore = [ + # rsa 0.9.10 — Marvin Attack timing sidechannel (no upstream fix) + # Pulled in by jsonwebtoken 10.x; JWT auth uses HMAC/EdDSA, not RSA decryption + "RUSTSEC-2023-0071", + + # bincode 2.0.1 — unmaintained advisory, still functional (aingle_graph) + "RUSTSEC-2025-0141", + + # async-std — unmaintained (transitive via async-tungstenite in aingle_minimal) + "RUSTSEC-2025-0052", + + # fxhash — unmaintained (transitive via sled in aingle_graph) + "RUSTSEC-2025-0057", + + # instant — unmaintained (transitive via sled → parking_lot 0.11) + "RUSTSEC-2024-0384", + + # paste — unmaintained (transitive via wasmer and candle-core/gemm) + "RUSTSEC-2024-0436", +] diff --git a/Cargo.lock b/Cargo.lock index 31b1c20..985df84 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -8,38 +8,7 @@ version = "0.25.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1b5d307320b3181d6d7954e663bd7c774a838b8220fe0593c86d9fb09f498b4b" dependencies = [ - "gimli 0.32.3", -] - -[[package]] -name = "adk" -version = "0.0.1" -dependencies = [ - "adk_derive", - "ai_fixt", - "ai_hash", - "aingle_middleware_bytes", - "aingle_wasmer_guest", - "aingle_zome_types", - "mockall", - "paste", - "serde", - "serde_bytes", - "thiserror 2.0.18", - "tracing", - "tracing-core", - "tracing-subscriber", -] - -[[package]] -name = "adk_derive" -version = "0.0.1" -dependencies = [ - "aingle_zome_types", - "paste", - "proc-macro2", - "quote", - "syn 1.0.109", + "gimli", ] [[package]] @@ -48,21 +17,6 @@ version = "2.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "320119579fcad9c21884f5c4861d16174d0e06250625266f50fe6898340abefa" -[[package]] -name = "adler32" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aae1277d39aeec15cb388266ecc24b11c80469deae6067e17a1a7aa9e5c1f234" - -[[package]] -name = "aead" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7fc95d1bdb8e6666b2b217308eeeb09f2d6728d104be3e31916cc74d15420331" -dependencies = [ - "generic-array", -] - [[package]] name = "aead" version = "0.5.2" @@ -79,8 +33,8 @@ version = "0.8.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b169f7a6d4742236a0a00c541b845991d0ac43e546831af1249753ab4c3aa3a0" dependencies = [ - "cfg-if 1.0.4", - "cipher 0.4.4", + "cfg-if", + "cipher", "cpufeatures", ] @@ -90,33 +44,21 @@ version = "0.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "831010a0f742e1209b3bcea8fab6a8e149051ba6099432c8cb2cc117dec3ead1" dependencies = [ - "aead 0.5.2", + "aead", "aes", - "cipher 0.4.4", + "cipher", "ctr", "ghash", "subtle", ] -[[package]] -name = "ahash" -version = "0.7.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "891477e0c6a8957309ee5c45a6368af3ae14bb510732d2684ffa19af310920f9" -dependencies = [ - "getrandom 0.2.17", - "once_cell", - "version_check", -] - [[package]] name = "ahash" version = "0.8.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5a15f179cd60c4584b8a8c596927aadc462e27f2ca70c04e0071964a73ba7a75" dependencies = [ - "cfg-if 1.0.4", - "getrandom 0.3.4", + "cfg-if", "once_cell", "version_check", "zerocopy", @@ -142,153 +84,9 @@ dependencies = [ "titans_memory", ] -[[package]] -name = "ai_fixt" -version = "0.0.1" -dependencies = [ - "aingle_middleware_bytes", - "lazy_static", - "parking_lot 0.12.5", - "paste", - "rand 0.9.2", - "rand_core 0.9.5", - "serde", - "strum 0.26.3", - "strum_macros 0.26.4", -] - -[[package]] -name = "ai_fixt_test" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "paste", -] - -[[package]] -name = "ai_hash" -version = "0.3.6" -dependencies = [ - "ai_fixt", - "aingle_middleware_bytes", - "arbitrary", - "base64 0.22.1", - "blake2b_simd", - "derive_more 0.99.20", - "rand 0.9.2", - "rusqlite", - "serde", - "serde_bytes", - "serde_json", - "thiserror 2.0.18", - "tracing", -] - -[[package]] -name = "aingle" -version = "0.0.101" -dependencies = [ - "adk", - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_ai", - "aingle_cascade", - "aingle_conductor_api", - "aingle_cortex", - "aingle_keystore", - "aingle_middleware_bytes", - "aingle_p2p", - "aingle_sqlite", - "aingle_state", - "aingle_test_wasm_common", - "aingle_types", - "aingle_util", - "aingle_wasm_test_utils", - "aingle_wasmer_host", - "aingle_websocket", - "aingle_zome_types", - "anyhow", - "assert_cmd", - "async-trait", - "base64 0.22.1", - "byteorder", - "cfg-if 0.1.10", - "chrono", - "criterion", - "crypto_secretbox", - "derive_more 0.99.20", - "directories 2.0.2", - "either", - "fallible-iterator 0.3.0", - "futures", - "ghost_actor", - "human-panic", - "itertools 0.10.5", - "kitsune_p2p", - "kitsune_p2p_types", - "lazy_static", - "maplit", - "matches", - "mockall", - "mr_bundle", - "must_future", - "nanoid 0.4.0", - "num_cpus", - "once_cell", - "parking_lot 0.12.5", - "predicates 1.0.8", - "pretty_assertions", - "rand 0.9.2", - "ring 0.17.14", - "rusqlite", - "rustls 0.23.37", - "sd-notify", - "serde", - "serde_json", - "serde_yml", - "serial_test", - "shrinkwraprs", - "structopt", - "strum 0.26.3", - "tempdir", - "test-case", - "thiserror 2.0.18", - "tokio", - "tokio-stream", - "toml 0.9.12+spec-1.1.0", - "tracing", - "tracing-futures", - "tracing-subscriber", - "unwrap_to", - "url 1.7.2", - "url2", - "url_serde", - "uuid", - "wasmer 7.0.1", -] - -[[package]] -name = "aingle-observability" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a08c3edaef0d75240b73fb33d8509b01fa7dd5043424c6b07e550a2b26d39fa3" -dependencies = [ - "chrono", - "derive_more 0.99.20", - "inferno", - "once_cell", - "serde_json", - "thiserror 1.0.69", - "tracing", - "tracing-core", - "tracing-serde 0.1.3", - "tracing-subscriber", -] - [[package]] name = "aingle_ai" -version = "0.3.6" +version = "0.3.7" dependencies = [ "blake2", "candle-core 0.9.2", @@ -304,135 +102,18 @@ dependencies = [ "tempfile", "thiserror 2.0.18", "tokio", - "toml 0.9.12+spec-1.1.0", - "tracing", -] - -[[package]] -name = "aingle_cascade" -version = "0.0.1" -dependencies = [ - "adk", - "adk_derive", - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_middleware_bytes", - "aingle_p2p", - "aingle_sqlite", - "aingle_state", - "aingle_types", - "aingle_zome_types", - "async-trait", - "derive_more 0.99.20", - "either", - "fallible-iterator 0.3.0", - "futures", - "ghost_actor", - "kitsune_p2p", - "matches", - "mockall", - "pretty_assertions", - "serde", - "serde_derive", - "thiserror 2.0.18", - "tokio", - "tracing", - "tracing-futures", -] - -[[package]] -name = "aingle_cli" -version = "0.0.1" -dependencies = [ - "aingle-observability", - "aingle_cli_bundle", - "aingle_cli_sandbox", - "anyhow", - "futures", - "structopt", - "tokio", -] - -[[package]] -name = "aingle_cli_bundle" -version = "0.0.1" -dependencies = [ - "aingle_middleware_bytes", - "aingle_types", - "aingle_util", - "anyhow", - "assert_cmd", - "matches", - "mr_bundle", - "predicates 1.0.8", - "serde", - "serde_bytes", - "serde_yml", - "structopt", - "tempdir", - "thiserror 2.0.18", - "tokio", -] - -[[package]] -name = "aingle_cli_sandbox" -version = "0.0.1" -dependencies = [ - "aingle-observability", - "aingle_cli_bundle", - "aingle_conductor_api", - "aingle_p2p", - "aingle_types", - "aingle_websocket", - "ansi_term", - "anyhow", - "assert_cmd", - "chrono", - "futures", - "lazy_static", - "matches", - "nanoid 0.4.0", - "portpicker", - "serde_yml", - "structopt", - "tokio", - "tracing", - "url2", - "walkdir", -] - -[[package]] -name = "aingle_conductor_api" -version = "0.0.1" -dependencies = [ - "ai_hash", - "aingle-observability", - "aingle_middleware_bytes", - "aingle_p2p", - "aingle_state", - "aingle_types", - "aingle_zome_types", - "derive_more 0.99.20", - "directories 2.0.2", - "kitsune_p2p", - "matches", - "serde", - "serde_derive", - "serde_yml", - "structopt", - "thiserror 2.0.18", + "toml", "tracing", - "url2", ] [[package]] name = "aingle_contracts" -version = "0.3.6" +version = "0.3.7" dependencies = [ "blake3", "dashmap 6.1.0", "hex", + "rand 0.9.2", "serde", "serde_json", "sha2 0.10.9", @@ -441,17 +122,16 @@ dependencies = [ "tokio", "tokio-test", "tracing", - "wasmer 7.0.1", + "wasmer", ] [[package]] name = "aingle_cortex" -version = "0.3.6" +version = "0.3.7" dependencies = [ "aingle_graph", "aingle_logic", "aingle_zk", - "aingle_zome_types", "argon2", "async-graphql", "async-graphql-axum", @@ -462,6 +142,7 @@ dependencies = [ "futures", "jsonwebtoken", "log", + "once_cell", "rand 0.9.2", "regex", "reqwest", @@ -484,13 +165,13 @@ dependencies = [ [[package]] name = "aingle_graph" -version = "0.3.6" +version = "0.3.7" dependencies = [ "bincode", "blake3", "chrono", "criterion", - "indexmap 2.13.0", + "indexmap", "log", "rio_api", "rio_turtle", @@ -503,32 +184,14 @@ dependencies = [ "thiserror 2.0.18", ] -[[package]] -name = "aingle_keystore" -version = "0.0.1" -dependencies = [ - "ai_hash", - "aingle_middleware_bytes", - "aingle_zome_types", - "ghost_actor", - "lair_keystore_api", - "lair_keystore_client", - "serde", - "serde_bytes", - "sodoken", - "thiserror 2.0.18", - "tokio", - "tracing", -] - [[package]] name = "aingle_logic" -version = "0.3.6" +version = "0.3.7" dependencies = [ "aingle_graph", "chrono", "hex", - "indexmap 2.13.0", + "indexmap", "log", "regex", "serde", @@ -537,34 +200,9 @@ dependencies = [ "thiserror 2.0.18", ] -[[package]] -name = "aingle_middleware_bytes" -version = "0.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c03f4a0a5203dc8fb86097bc33c02a54bd5813c8d3d67595fe3e9d0a2272ff0" -dependencies = [ - "aingle_middleware_bytes_derive", - "rmp-serde 0.14.4", - "serde", - "serde-transcode", - "serde_bytes", - "serde_json", - "thiserror 1.0.69", -] - -[[package]] -name = "aingle_middleware_bytes_derive" -version = "0.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05ab1e16ded0d7d76ccf32e8e194bedf284237c24d8a5fa46fe60a01f3ba4cba" -dependencies = [ - "quote", - "syn 1.0.109", -] - [[package]] name = "aingle_minimal" -version = "0.3.6" +version = "0.3.7" dependencies = [ "async-io", "async-tungstenite", @@ -572,14 +210,16 @@ dependencies = [ "btleplug", "bytes", "chrono", - "clap 4.5.60", + "clap", "coap-lite", "criterion", + "ed25519-dalek", "embedded-hal 1.0.0", "embedded-hal-async", "env_logger", "esp32-nimble", "futures-util", + "hex", "hope_agents", "if-addrs 0.13.4", "ledger-transport", @@ -588,10 +228,10 @@ dependencies = [ "mdns-sd", "quinn", "rand 0.9.2", - "rcgen 0.13.2", + "rcgen", "rocksdb", "rusqlite", - "rustls 0.23.37", + "rustls", "semver", "serde", "serde_json", @@ -602,195 +242,15 @@ dependencies = [ "webrtc", ] -[[package]] -name = "aingle_p2p" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_keystore", - "aingle_middleware_bytes", - "aingle_types", - "aingle_util", - "aingle_zome_types", - "async-trait", - "futures", - "ghost_actor", - "kitsune_p2p", - "kitsune_p2p_types", - "mockall", - "serde", - "serde_bytes", - "thiserror 2.0.18", - "tokio", - "tokio-stream", - "tracing", -] - -[[package]] -name = "aingle_sqlite" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_middleware_bytes", - "aingle_util", - "aingle_zome_types", - "anyhow", - "byteorder", - "cfg-if 0.1.10", - "chashmap", - "chrono", - "derive_more 0.99.20", - "either", - "failure", - "fallible-iterator 0.3.0", - "futures", - "kitsune_p2p", - "lazy_static", - "must_future", - "nanoid 0.4.0", - "num_cpus", - "once_cell", - "page_size", - "parking_lot 0.12.5", - "r2d2", - "r2d2_sqlite", - "rand 0.9.2", - "rmp-serde 1.3.1", - "rusqlite", - "scheduled-thread-pool", - "serde", - "serde_derive", - "shrinkwraprs", - "tempdir", - "thiserror 2.0.18", - "tokio", - "tracing", - "tracing-futures", -] - -[[package]] -name = "aingle_state" -version = "0.0.1" -dependencies = [ - "adk", - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_keystore", - "aingle_middleware_bytes", - "aingle_p2p", - "aingle_sqlite", - "aingle_types", - "aingle_util", - "aingle_wasm_test_utils", - "aingle_zome_types", - "anyhow", - "base64 0.22.1", - "byteorder", - "chrono", - "derive_more 0.99.20", - "either", - "fallible-iterator 0.3.0", - "kitsune_p2p", - "matches", - "mockall", - "parking_lot 0.12.5", - "pretty_assertions", - "serde", - "serde_json", - "shrinkwraprs", - "tempdir", - "thiserror 2.0.18", - "tokio", - "tracing", - "tracing-futures", -] - -[[package]] -name = "aingle_test_wasm_common" -version = "0.0.1" -dependencies = [ - "adk", - "serde", -] - -[[package]] -name = "aingle_types" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "ai_hash", - "aingle-observability", - "aingle_keystore", - "aingle_middleware_bytes", - "aingle_sqlite", - "aingle_util", - "aingle_zome_types", - "anyhow", - "arbitrary", - "async-trait", - "automap", - "backtrace", - "base64 0.22.1", - "cfg-if 0.1.10", - "chrono", - "derive_builder", - "derive_more 0.99.20", - "either", - "flate2", - "futures", - "itertools 0.10.5", - "lazy_static", - "maplit", - "matches", - "mockall", - "mr_bundle", - "must_future", - "nanoid 0.4.0", - "rand 0.9.2", - "regex", - "rusqlite", - "serde", - "serde_bytes", - "serde_derive", - "serde_json", - "serde_yml", - "shrinkwraprs", - "strum 0.26.3", - "strum_macros 0.26.4", - "tempdir", - "thiserror 2.0.18", - "tokio", - "tracing", -] - -[[package]] -name = "aingle_util" -version = "0.0.1" -dependencies = [ - "backtrace", - "cfg-if 0.1.10", - "derive_more 0.99.20", - "dunce", - "futures", - "num_cpus", - "once_cell", - "tokio", -] - [[package]] name = "aingle_viz" -version = "0.3.6" +version = "0.3.7" dependencies = [ "aingle_graph", "aingle_minimal", "axum", "chrono", - "clap 4.5.60", + "clap", "env_logger", "futures", "log", @@ -804,112 +264,14 @@ dependencies = [ "uuid", ] -[[package]] -name = "aingle_wasm_test_utils" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "ai_hash", - "aingle_types", - "aingle_util", - "aingle_zome_types", - "rand 0.9.2", - "strum 0.26.3", - "strum_macros 0.26.4", - "toml 0.9.12+spec-1.1.0", - "walkdir", -] - -[[package]] -name = "aingle_wasmer_codec" -version = "0.0.1" -source = "git+https://github.com/ApiliumCode/aingle-wasmer.git?branch=main#d1406b8fc6d8240722095b5223659bc330c2eb6b" -dependencies = [ - "aingle_wasmer_common", - "bytes", - "crc32fast", -] - -[[package]] -name = "aingle_wasmer_common" -version = "0.0.1" -source = "git+https://github.com/ApiliumCode/aingle-wasmer.git?branch=main#d1406b8fc6d8240722095b5223659bc330c2eb6b" -dependencies = [ - "aingle_middleware_bytes", - "serde", -] - -[[package]] -name = "aingle_wasmer_guest" -version = "0.0.1" -source = "git+https://github.com/ApiliumCode/aingle-wasmer.git?branch=main#d1406b8fc6d8240722095b5223659bc330c2eb6b" -dependencies = [ - "aingle_middleware_bytes", - "aingle_wasmer_codec", - "aingle_wasmer_common", - "bumpalo", - "rmp-serde 1.3.1", - "serde", - "serde_bytes", -] - -[[package]] -name = "aingle_wasmer_host" -version = "0.0.1" -source = "git+https://github.com/ApiliumCode/aingle-wasmer.git?branch=main#d1406b8fc6d8240722095b5223659bc330c2eb6b" -dependencies = [ - "aingle_middleware_bytes", - "aingle_wasmer_codec", - "aingle_wasmer_common", - "bytes", - "parking_lot 0.12.5", - "rmp-serde 1.3.1", - "serde", - "serde_bytes", - "thiserror 2.0.18", - "tracing", - "wasmer 6.1.0", - "wasmer-middlewares", -] - -[[package]] -name = "aingle_websocket" -version = "0.0.1" -dependencies = [ - "aingle-observability", - "aingle_middleware_bytes", - "aingle_types", - "criterion", - "futures", - "ghost_actor", - "linefeed", - "must_future", - "nanoid 0.4.0", - "net2", - "parking_lot 0.12.5", - "serde", - "serde_bytes", - "stream-cancel", - "thiserror 2.0.18", - "tokio", - "tokio-stream", - "tokio-tungstenite 0.24.0", - "tracing", - "tracing-futures", - "tungstenite 0.24.0", - "unwrap_to", - "url2", -] - [[package]] name = "aingle_zk" -version = "0.3.6" +version = "0.3.7" dependencies = [ - "bincode", "blake3", "bulletproofs", "criterion", - "curve25519-dalek 4.1.3", + "curve25519-dalek", "curve25519-dalek-ng", "hex", "merlin", @@ -919,30 +281,8 @@ dependencies = [ "serde", "serde_json", "sha2 0.10.9", - "thiserror 2.0.18", -] - -[[package]] -name = "aingle_zome_types" -version = "0.3.6" -dependencies = [ - "ai_fixt", - "ai_hash", - "aingle_middleware_bytes", - "chrono", - "derive_builder", - "nanoid 0.4.0", - "num_enum", - "paste", - "rand 0.9.2", - "rusqlite", - "serde", - "serde_bytes", - "shrinkwraprs", - "strum 0.26.3", "subtle", "thiserror 2.0.18", - "tracing", ] [[package]] @@ -975,15 +315,6 @@ version = "0.1.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4b46cbb362ab8752921c97e041f5e366ee6297bd428a31275b9fcf1e380f7299" -[[package]] -name = "ansi_term" -version = "0.12.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d52a9bb7ec0cf484c551830a7ce27bd20d67eac647e1befb56b0be4ee39a55d2" -dependencies = [ - "winapi", -] - [[package]] name = "anstream" version = "0.6.21" @@ -1045,9 +376,6 @@ name = "arbitrary" version = "1.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c3d036a3c4ab069c7b410a2ce876bd74808d2d0888a82667669f8e783a898bf1" -dependencies = [ - "derive_arbitrary", -] [[package]] name = "arc-swap" @@ -1076,12 +404,6 @@ version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "76a2e8124351fda1ef8aaaa3bbd7ebbcb486bbcd4225aca0aa0d84bb2db8fecb" -[[package]] -name = "arrayvec" -version = "0.5.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23b62fc65de8e4e7f52534fb52b0f3ed04746ae267519eef2a83941e8085068b" - [[package]] name = "arrayvec" version = "0.7.6" @@ -1111,7 +433,7 @@ checksum = "08e1676b346cadfec169374f949d7490fd80a24193d37d2afce0c047cf695e57" dependencies = [ "askama_macros", "itoa", - "percent-encoding 2.3.2", + "percent-encoding", "serde", "serde_json", ] @@ -1175,7 +497,7 @@ dependencies = [ "proc-macro2", "quote", "syn 2.0.117", - "synstructure 0.13.2", + "synstructure", ] [[package]] @@ -1189,31 +511,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "assert_cmd" -version = "2.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c5bcfa8749ac45dd12cb11055aeeb6b27a3895560d60d71e3c23bf979e60514" -dependencies = [ - "anstyle", - "bstr", - "libc", - "predicates 3.1.4", - "predicates-core", - "predicates-tree", - "wait-timeout", -] - -[[package]] -name = "async-attributes" -version = "1.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a3203e79f4dd9bdda415ed03cf14dae5a2bf775c683a00f94e9cd1faf0f596e5" -dependencies = [ - "quote", - "syn 1.0.109", -] - [[package]] name = "async-channel" version = "1.9.0" @@ -1301,15 +598,15 @@ dependencies = [ "async-graphql-value", "async-trait", "asynk-strim", - "base64 0.22.1", + "base64", "blocking", "bytes", "chrono", "futures-util", - "http 1.4.0", - "indexmap 2.13.0", + "http", + "indexmap", "mime", - "multer 3.1.0", + "multer", "num-traits", "pin-project-lite", "regex", @@ -1377,7 +674,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7e3722caa711b9b669527259679764eff1a1dfddb5f0b7b9818d59bfe8275b74" dependencies = [ "bytes", - "indexmap 2.13.0", + "indexmap", "serde", "serde_json", ] @@ -1388,8 +685,8 @@ version = "2.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "456b8a8feb6f42d237746d4b3e9a178494627745c3c56c6ea55d92ba50d026fc" dependencies = [ - "autocfg 1.5.0", - "cfg-if 1.0.4", + "autocfg", + "cfg-if", "concurrent-queue", "futures-io", "futures-lite", @@ -1434,7 +731,7 @@ dependencies = [ "async-signal", "async-task", "blocking", - "cfg-if 1.0.4", + "cfg-if", "event-listener 5.4.1", "futures-lite", "rustix 1.1.4", @@ -1449,7 +746,7 @@ dependencies = [ "async-io", "async-lock", "atomic-waker", - "cfg-if 1.0.4", + "cfg-if", "futures-core", "futures-io", "rustix 1.1.4", @@ -1464,12 +761,10 @@ version = "1.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2c8e079a4ab67ae52b7403632e4618815d6db36d2a010cfe41b02c1b1578f93b" dependencies = [ - "async-attributes", "async-channel 1.9.0", "async-global-executor", "async-io", "async-lock", - "async-process", "crossbeam-utils", "futures-channel", "futures-core", @@ -1486,49 +781,6 @@ dependencies = [ "wasm-bindgen-futures", ] -[[package]] -name = "async-stream" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22068c0c19514942eefcfd4daf8976ef1aad84e61539f95cd200c35202f80af5" -dependencies = [ - "async-stream-impl 0.2.1", - "futures-core", -] - -[[package]] -name = "async-stream" -version = "0.3.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b5a71a6f37880a80d1d7f19efd781e4b5de42c88f0722cc13bcb6cc2cfe8476" -dependencies = [ - "async-stream-impl 0.3.6", - "futures-core", - "pin-project-lite", -] - -[[package]] -name = "async-stream-impl" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25f9db3b38af870bf7e5cc649167533b493928e50744e2c30ae350230b414670" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", -] - -[[package]] -name = "async-stream-impl" -version = "0.3.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c7c24de15d275a1ecfd47a380fb4d5ec9bfe0933f309ed5e705b775596a3574d" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.117", -] - [[package]] name = "async-task" version = "4.7.1" @@ -1576,44 +828,12 @@ version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0" -[[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 = "0.1.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0dde43e75fd43e8a1bf86103336bc699aa8d17ad1be60c76c0bdfd4828e19b78" -dependencies = [ - "autocfg 1.5.0", -] - [[package]] name = "autocfg" version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c08606f8c3cbf4ce6ec8e28fb0014a2c086708fe954eaa885384a6165172e7e8" -[[package]] -name = "automap" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b99d887f4066f8a1b4a713a8121fab07ff543863ac86177ebdee6b5cb18acf12" -dependencies = [ - "cfg-if 1.0.4", - "derive_more 0.99.20", - "serde", - "shrinkwraprs", -] - [[package]] name = "axum" version = "0.8.8" @@ -1622,20 +842,20 @@ checksum = "8b52af3cb4058c895d37317bb27508dccc8e5f2d39454016b297bf4a400597b8" dependencies = [ "axum-core", "axum-macros", - "base64 0.22.1", + "base64", "bytes", "form_urlencoded", "futures-util", - "http 1.4.0", - "http-body 1.0.1", + "http", + "http-body", "http-body-util", - "hyper 1.8.1", + "hyper", "hyper-util", "itoa", "matchit", "memchr", "mime", - "percent-encoding 2.3.2", + "percent-encoding", "pin-project-lite", "serde_core", "serde_json", @@ -1644,7 +864,7 @@ dependencies = [ "sha1", "sync_wrapper", "tokio", - "tokio-tungstenite 0.28.0", + "tokio-tungstenite", "tower", "tower-layer", "tower-service", @@ -1659,8 +879,8 @@ checksum = "08c78f31d7b1291f7ee735c1c6780ccde7785daae9a9206026862dab7d8792d1" dependencies = [ "bytes", "futures-core", - "http 1.4.0", - "http-body 1.0.1", + "http", + "http-body", "http-body-util", "mime", "pin-project-lite", @@ -1688,7 +908,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bb531853791a215d7c62a30daf0dde835f381ab5de4589cfe7c649d2cbe92bd6" dependencies = [ "addr2line", - "cfg-if 1.0.4", + "cfg-if", "libc", "miniz_oxide", "object 0.37.3", @@ -1702,18 +922,6 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" -[[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.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" - [[package]] name = "base64" version = "0.22.1" @@ -1769,26 +977,6 @@ dependencies = [ "which 4.4.2", ] -[[package]] -name = "bindgen" -version = "0.70.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f49d8fed880d473ea71efb9bf597651e77201bdd4893efe54c9e5d65ae04ce6f" -dependencies = [ - "bitflags 2.11.0", - "cexpr", - "clang-sys", - "itertools 0.13.0", - "log", - "prettyplease", - "proc-macro2", - "quote", - "regex", - "rustc-hash 1.1.0", - "shlex", - "syn 2.0.117", -] - [[package]] name = "bindgen" version = "0.72.1" @@ -1809,15 +997,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "bit-vec" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d2c54ff287cfc0a34f38a6b832ea1bd8e448a330b3e40a50859e6488bee07f22" -dependencies = [ - "serde", -] - [[package]] name = "bitflags" version = "1.3.2" @@ -1839,17 +1018,6 @@ dependencies = [ "digest 0.10.7", ] -[[package]] -name = "blake2b_simd" -version = "0.5.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "afa748e348ad3be8263be728124b24a24f268266f6f5d58af9d75f6a40b5c587" -dependencies = [ - "arrayref", - "arrayvec 0.5.2", - "constant_time_eq 0.1.5", -] - [[package]] name = "blake3" version = "1.8.3" @@ -1857,10 +1025,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2468ef7d57b3fb7e16b576e8377cdbde2320c60e1491e961d11da40fc4f02a2d" dependencies = [ "arrayref", - "arrayvec 0.7.6", + "arrayvec", "cc", - "cfg-if 1.0.4", - "constant_time_eq 0.4.2", + "cfg-if", + "constant_time_eq", "cpufeatures", ] @@ -1882,12 +1050,6 @@ dependencies = [ "hybrid-array", ] -[[package]] -name = "block-padding" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d696c370c750c948ada61c69a0ee2cbbb9c50b1019ddb86d9317157a99c2cae" - [[package]] name = "block-padding" version = "0.3.3" @@ -1919,17 +1081,6 @@ dependencies = [ "piper", ] -[[package]] -name = "bloomfilter" -version = "1.0.16" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c541c70a910b485670304fd420f0eab8f7bde68439db6a8d98819c3d2774d7e2" -dependencies = [ - "bit-vec", - "getrandom 0.2.17", - "siphasher", -] - [[package]] name = "bluez-async" version = "0.8.2" @@ -1966,7 +1117,6 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "63044e1ae8e69f3b5a92c736ca6269b8d12fa7efe39bf34ddb06d102cf0e2cab" dependencies = [ "memchr", - "regex-automata", "serde", ] @@ -1994,8 +1144,8 @@ dependencies = [ "tokio", "tokio-stream", "uuid", - "windows 0.61.3", - "windows-future 0.2.1", + "windows", + "windows-future", ] [[package]] @@ -2019,7 +1169,7 @@ checksum = "012e2e5f88332083bd4235d445ae78081c00b2558443821a9ca5adfe1070073d" dependencies = [ "byteorder", "clear_on_drop", - "curve25519-dalek 4.1.3", + "curve25519-dalek", "digest 0.10.7", "group", "merlin", @@ -2038,18 +1188,7 @@ version = "3.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5d20789868f4b01b2f2caec9f5c4e0213b41e3e5702a50157d699ae31ced2fcb" dependencies = [ - "allocator-api2", -] - -[[package]] -name = "bytecheck" -version = "0.6.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23cdc57ce23ac53c931e88a43d06d070a6fd142f2617be5855eb75efc9beb1c2" -dependencies = [ - "bytecheck_derive 0.6.12", - "ptr_meta 0.1.4", - "simdutf8", + "allocator-api2", ] [[package]] @@ -2058,23 +1197,12 @@ version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0caa33a2c0edca0419d15ac723dff03f1956f7978329b1e3b5fdaaaed9d3ca8b" dependencies = [ - "bytecheck_derive 0.8.2", - "ptr_meta 0.3.1", + "bytecheck_derive", + "ptr_meta", "rancor", "simdutf8", ] -[[package]] -name = "bytecheck_derive" -version = "0.6.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3db406d29fbcd95542e92559bed4d8ad92636d1ca8b3b72ede10b4bcc010e659" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", -] - [[package]] name = "bytecheck_derive" version = "0.8.2" @@ -2234,7 +1362,7 @@ version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "26b52a9543ae338f279b96b0b9fed9c8093744685043739079ce85cd58f289a6" dependencies = [ - "cipher 0.4.4", + "cipher", ] [[package]] @@ -2255,8 +1383,8 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9ae3c82e4355234767756212c570e29833699ab63e6ffd161887314cc5b43847" dependencies = [ - "aead 0.5.2", - "cipher 0.4.4", + "aead", + "cipher", "ctr", "subtle", ] @@ -2276,12 +1404,6 @@ dependencies = [ "nom", ] -[[package]] -name = "cfg-if" -version = "0.1.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4785bdd1c96b2a846b2bd7cc02e86b6b3dbf14e7e53446c4f54c92a361040822" - [[package]] name = "cfg-if" version = "1.0.4" @@ -2294,63 +1416,30 @@ version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "613afe47fcd5fac7ccf1db93babcb082c5994d996f20b8b159f2ad1658eb5724" -[[package]] -name = "chacha20" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ed8738f14471a99f0e316c327e68fc82a3611cc2895fcb604b89eedaf8f39d95" -dependencies = [ - "cipher 0.2.5", - "zeroize", -] - [[package]] name = "chacha20" version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c3613f74bd2eac03dad61bd53dbe620703d4371614fe0bc3b9f04dd36fe4e818" dependencies = [ - "cfg-if 1.0.4", - "cipher 0.4.4", + "cfg-if", + "cipher", "cpufeatures", ] -[[package]] -name = "chacha20poly1305" -version = "0.7.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af1fc18e6d90c40164bf6c317476f2a98f04661e310e79830366b7e914c58a8e" -dependencies = [ - "aead 0.3.2", - "chacha20 0.6.0", - "cipher 0.2.5", - "poly1305 0.6.2", - "zeroize", -] - [[package]] name = "chacha20poly1305" version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "10cd79432192d1c0f4e1a0fef9527696cc039165d729fb41b3f4f4f354c2dc35" dependencies = [ - "aead 0.5.2", - "chacha20 0.9.1", - "cipher 0.4.4", - "poly1305 0.8.0", + "aead", + "chacha20", + "cipher", + "poly1305", "zeroize", ] -[[package]] -name = "chashmap" -version = "2.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ff41a3c2c1e39921b9003de14bf0439c7b63a9039637c291e1a64925d8ddfa45" -dependencies = [ - "owning_ref", - "parking_lot 0.4.8", -] - [[package]] name = "chrono" version = "0.4.44" @@ -2398,15 +1487,6 @@ dependencies = [ "half", ] -[[package]] -name = "cipher" -version = "0.2.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "12f8e7987cbd042a63249497f41aed09f8e65add917ea6566effbc56578d6801" -dependencies = [ - "generic-array", -] - [[package]] name = "cipher" version = "0.4.4" @@ -2429,21 +1509,6 @@ dependencies = [ "libloading", ] -[[package]] -name = "clap" -version = "2.34.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a0610544180c38b88101fecf2dd634b174a62eef6946f84dfc6a7127512b381c" -dependencies = [ - "ansi_term", - "atty", - "bitflags 1.3.2", - "strsim 0.8.0", - "textwrap", - "unicode-width 0.1.14", - "vec_map", -] - [[package]] name = "clap" version = "4.5.60" @@ -2463,7 +1528,7 @@ dependencies = [ "anstream", "anstyle", "clap_lex", - "strsim 0.11.1", + "strsim", ] [[package]] @@ -2493,15 +1558,6 @@ dependencies = [ "cc", ] -[[package]] -name = "cloudabi" -version = "0.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ddfc5b9aa5d4507acaf872de71051dfd0e309860e88966e1051e462a077aac4f" -dependencies = [ - "bitflags 1.3.2", -] - [[package]] name = "cmake" version = "0.1.57" @@ -2611,24 +1667,12 @@ dependencies = [ "unicode-xid", ] -[[package]] -name = "constant_time_eq" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "245097e9a4535ee1e3e3931fcfcd55a796a44c643e8596ff6566d68f09b87bbc" - [[package]] name = "constant_time_eq" version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3d52eff69cd5e647efe296129160853a42795992097e8af39800e1060caeea9b" -[[package]] -name = "convert_case" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6245d59a3e82a7fc217c5828a6692dbc6dfb63a0c8c90495621f7b9d79704a0e" - [[package]] name = "convert_case" version = "0.10.0" @@ -2664,23 +1708,14 @@ version = "0.8.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b" -[[package]] -name = "core2" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b49ba7ef1ad6107f8824dbe97de947cbaac53c44e7f9756a1fba0d37c1eec505" -dependencies = [ - "memchr", -] - [[package]] name = "corosensei" version = "0.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2c54787b605c7df106ceccf798df23da4f2e09918defad66705d1cedf3bb914f" dependencies = [ - "autocfg 1.5.0", - "cfg-if 1.0.4", + "autocfg", + "cfg-if", "libc", "scopeguard", "windows-sys 0.59.0", @@ -2695,12 +1730,6 @@ dependencies = [ "libc", ] -[[package]] -name = "cpuid-bool" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcb25d077389e53838a8158c8e99174c5a9d902dee4904320db714f3c653ffba" - [[package]] name = "cranelift-assembler-x64" version = "0.128.4" @@ -2719,59 +1748,21 @@ dependencies = [ "cranelift-srcgen", ] -[[package]] -name = "cranelift-bforest" -version = "0.110.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "305d51c180ebdc46ef61bc60c54ae6512db3bc9a05842a1f1e762e45977019ab" -dependencies = [ - "cranelift-entity 0.110.2", -] - [[package]] name = "cranelift-bforest" version = "0.128.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "aea7351476d0eb196e89150e7a6235ecd37c97848243faea7746c29676abeeac" dependencies = [ - "cranelift-entity 0.128.0", + "cranelift-entity", ] -[[package]] -name = "cranelift-bitset" -version = "0.110.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "690d8ae6c73748e5ce3d8fe59034dceadb8823e6c8994ba324141c5eae909b0e" - [[package]] name = "cranelift-bitset" version = "0.128.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "18391da761cf362a06def7a7cf11474d79e55801dd34c2e9ba105b33dc0aef88" -[[package]] -name = "cranelift-codegen" -version = "0.110.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd7ca95e831c18d1356da783765c344207cbdffea91e13e47fa9327dbb2e0719" -dependencies = [ - "bumpalo", - "cranelift-bforest 0.110.2", - "cranelift-bitset 0.110.3", - "cranelift-codegen-meta 0.110.3", - "cranelift-codegen-shared 0.110.3", - "cranelift-control 0.110.3", - "cranelift-entity 0.110.2", - "cranelift-isle 0.110.2", - "gimli 0.28.1", - "hashbrown 0.14.5", - "log", - "regalloc2 0.9.3", - "rustc-hash 1.1.0", - "smallvec 1.15.1", - "target-lexicon 0.12.16", -] - [[package]] name = "cranelift-codegen" version = "0.128.0" @@ -2780,33 +1771,24 @@ checksum = "fa9e80ceb5153bb9dd0d048e685ec4df6fa20ce92d4ffffcb5d691623e1d8693" dependencies = [ "bumpalo", "cranelift-assembler-x64", - "cranelift-bforest 0.128.0", - "cranelift-bitset 0.128.4", - "cranelift-codegen-meta 0.128.4", - "cranelift-codegen-shared 0.128.4", - "cranelift-control 0.128.4", - "cranelift-entity 0.128.0", - "cranelift-isle 0.128.0", - "gimli 0.32.3", + "cranelift-bforest", + "cranelift-bitset", + "cranelift-codegen-meta", + "cranelift-codegen-shared", + "cranelift-control", + "cranelift-entity", + "cranelift-isle", + "gimli", "hashbrown 0.15.5", "log", - "regalloc2 0.13.5", + "regalloc2", "rustc-hash 2.1.1", "serde", - "smallvec 1.15.1", - "target-lexicon 0.13.5", + "smallvec", + "target-lexicon", "wasmtime-internal-math", ] -[[package]] -name = "cranelift-codegen-meta" -version = "0.110.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0a2d2ab65e6cbf91f81781d8da65ec2005510f18300eff21a99526ed6785863" -dependencies = [ - "cranelift-codegen-shared 0.110.3", -] - [[package]] name = "cranelift-codegen-meta" version = "0.128.4" @@ -2814,32 +1796,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "75817926ec812241889208d1b190cadb7fedded4592a4bb01b8524babb9e4849" dependencies = [ "cranelift-assembler-x64-meta", - "cranelift-codegen-shared 0.128.4", + "cranelift-codegen-shared", "cranelift-srcgen", "heck 0.5.0", ] -[[package]] -name = "cranelift-codegen-shared" -version = "0.110.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "efcff860573cf3db9ae98fbd949240d78b319df686cc306872e7fab60e9c84d7" - [[package]] name = "cranelift-codegen-shared" version = "0.128.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "859158f87a59476476eda3884d883c32e08a143cf3d315095533b362a3250a63" -[[package]] -name = "cranelift-control" -version = "0.110.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "69d70e5b75c2d5541ef80a99966ccd97aaa54d2a6af19ea31759a28538e1685a" -dependencies = [ - "arbitrary", -] - [[package]] name = "cranelift-control" version = "0.128.4" @@ -2849,34 +1816,13 @@ dependencies = [ "arbitrary", ] -[[package]] -name = "cranelift-entity" -version = "0.110.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a48cb0a194c9ba82fec35a1e492055388d89b2e3c03dee9dcf2488892be8004d" -dependencies = [ - "cranelift-bitset 0.110.3", -] - [[package]] name = "cranelift-entity" version = "0.128.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3e57c6f29da407f6ee9956197d011aedf4fd39bd03781ab5b44b85d45a448a27" dependencies = [ - "cranelift-bitset 0.128.4", -] - -[[package]] -name = "cranelift-frontend" -version = "0.110.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8327afc6c1c05f4be62fefce5b439fa83521c65363a322e86ea32c85e7ceaf64" -dependencies = [ - "cranelift-codegen 0.110.2", - "log", - "smallvec 1.15.1", - "target-lexicon 0.12.16", + "cranelift-bitset", ] [[package]] @@ -2885,18 +1831,12 @@ version = "0.128.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "add3991ccfeb20022443bae60b8adc56081f27caab0213b0ff26288954e44fe5" dependencies = [ - "cranelift-codegen 0.128.0", + "cranelift-codegen", "log", - "smallvec 1.15.1", - "target-lexicon 0.13.5", + "smallvec", + "target-lexicon", ] -[[package]] -name = "cranelift-isle" -version = "0.110.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "56b08621c00321efcfa3eee6a3179adc009e21ea8d24ca7adc3c326184bc3f48" - [[package]] name = "cranelift-isle" version = "0.128.0" @@ -2930,7 +1870,7 @@ version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9481c1c90cbf2ac953f07c8d4a58aa3945c425b7185c9154d67a65e4230da511" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", ] [[package]] @@ -2942,7 +1882,7 @@ dependencies = [ "anes", "cast", "ciborium", - "clap 4.5.60", + "clap", "criterion-plot", "is-terminal", "itertools 0.10.5", @@ -2975,15 +1915,6 @@ version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "790eea4361631c5e7d22598ecd5723ff611904e3344ce8720784c93e3d83d40b" -[[package]] -name = "crossbeam-channel" -version = "0.5.15" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "82b8f8f868b36967f9606790d1903570de9ceaf870a7bf9fbbd3016d636a2cb2" -dependencies = [ - "crossbeam-utils", -] - [[package]] name = "crossbeam-deque" version = "0.8.6" @@ -3018,31 +1949,6 @@ version = "0.8.21" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d0a5c400df2834b80a4c3327b3aad3a4c4cd4de0629063962b03235697506a28" -[[package]] -name = "crossterm" -version = "0.19.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7c36c10130df424b2f3552fcc2ddcd9b28a27b1e54b358b45874f88d1ca6888c" -dependencies = [ - "bitflags 1.3.2", - "crossterm_winapi", - "lazy_static", - "libc", - "mio 0.7.14", - "parking_lot 0.11.2", - "signal-hook", - "winapi", -] - -[[package]] -name = "crossterm_winapi" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0da8964ace4d3e4a044fd027919b2237000b24315a37c916f61809f1ff2140b9" -dependencies = [ - "winapi", -] - [[package]] name = "crunchy" version = "0.2.4" @@ -3081,55 +1987,13 @@ dependencies = [ "hybrid-array", ] -[[package]] -name = "crypto_box" -version = "0.5.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "42152c7961cd7af77bfe71c2cb0cf893b0a8939e9510d0c4db9b8d9027fea7e4" -dependencies = [ - "chacha20poly1305 0.7.1", - "rand_core 0.5.1", - "salsa20 0.7.2", - "x25519-dalek 1.1.1", - "xsalsa20poly1305", - "zeroize", -] - -[[package]] -name = "crypto_secretbox" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9d6cf87adf719ddf43a805e92c6870a531aedda35ff640442cbaf8674e141e1" -dependencies = [ - "aead 0.5.2", - "cipher 0.4.4", - "generic-array", - "poly1305 0.8.0", - "salsa20 0.10.2", - "subtle", - "zeroize", -] - [[package]] name = "ctr" version = "0.9.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0369ee1ad671834580515889b80f2ea915f23b8be8d0daa4bbaf2ac5c7590835" dependencies = [ - "cipher 0.4.4", -] - -[[package]] -name = "curve25519-dalek" -version = "3.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b9fdf9972b2bd6af2d913799d9ebc165ea4d2e65878e329d9c6b372c4491b61" -dependencies = [ - "byteorder", - "digest 0.9.0", - "rand_core 0.5.1", - "subtle", - "zeroize", + "cipher", ] [[package]] @@ -3138,7 +2002,7 @@ version = "4.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "97fb8b7c4503de7d6ae7b42ab72a5a59857b4c937ec27a3d4539dba95b5ab2be" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cpufeatures", "curve25519-dalek-derive", "digest 0.10.7", @@ -3181,7 +2045,7 @@ version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d2ae9bf77fbf2d39ef573205d554d87e86c12f1994e9ea335b0651b9b278bcf1" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", ] [[package]] @@ -3197,16 +2061,6 @@ dependencies = [ "tokio", ] -[[package]] -name = "darling" -version = "0.10.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0d706e75d87e35569db781a9b5e2416cff1236a47ed380831f959382ccd5f858" -dependencies = [ - "darling_core 0.10.2", - "darling_macro 0.10.2", -] - [[package]] name = "darling" version = "0.20.11" @@ -3237,20 +2091,6 @@ dependencies = [ "darling_macro 0.23.0", ] -[[package]] -name = "darling_core" -version = "0.10.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0c960ae2da4de88a91b2d920c2a7233b400bc33cb28453a2987822d8392519b" -dependencies = [ - "fnv", - "ident_case", - "proc-macro2", - "quote", - "strsim 0.9.3", - "syn 1.0.109", -] - [[package]] name = "darling_core" version = "0.20.11" @@ -3261,7 +2101,7 @@ dependencies = [ "ident_case", "proc-macro2", "quote", - "strsim 0.11.1", + "strsim", "syn 2.0.117", ] @@ -3287,21 +2127,10 @@ dependencies = [ "ident_case", "proc-macro2", "quote", - "strsim 0.11.1", + "strsim", "syn 2.0.117", ] -[[package]] -name = "darling_macro" -version = "0.10.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d9b5a2f4ac4969822c62224815d069952656cadc7084fdca9751e6d959189b72" -dependencies = [ - "darling_core 0.10.2", - "quote", - "syn 1.0.109", -] - [[package]] name = "darling_macro" version = "0.20.11" @@ -3335,19 +2164,13 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "dary_heap" -version = "0.3.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06d2e3287df1c007e74221c49ca10a95d557349e54b3a75dc2fb14712c751f04" - [[package]] name = "dashmap" version = "5.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "978747c1d849a7d2ee5e8adc0159961c48fb7e5db2f06af6723b80123bb53856" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "hashbrown 0.14.5", "lock_api", "once_cell", @@ -3360,7 +2183,7 @@ version = "6.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5041cc499144891f3790297212f32a74fb938e5136a14943f338ef9e0ae276cf" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "crossbeam-utils", "hashbrown 0.14.5", "lock_api", @@ -3446,80 +2269,31 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e7c1832837b905bbfb5101e07cc24c8deddf52f93225eee6ead5f4d63d53ddcb" dependencies = [ "const-oid 0.9.6", - "pem-rfc7468", - "zeroize", -] - -[[package]] -name = "der-parser" -version = "9.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5cd0a5c643689626bec213c4d8bd4d96acc8ffdb4ad4bb6bc16abf27d5f4b553" -dependencies = [ - "asn1-rs", - "displaydoc", - "nom", - "num-bigint", - "num-traits", - "rusticata-macros", -] - -[[package]] -name = "deranged" -version = "0.5.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7cd812cc2bc1d69d4764bd80df88b4317eaef9e773c75226407d9bc0876b211c" -dependencies = [ - "powerfmt", -] - -[[package]] -name = "derive_arbitrary" -version = "1.4.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e567bd82dcff979e4b03460c307b3cdc9e96fde3d73bed1496d2bc75d9dd62a" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.117", -] - -[[package]] -name = "derive_builder" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a2658621297f2cf68762a6f7dc0bb7e1ff2cfd6583daef8ee0fed6f7ec468ec0" -dependencies = [ - "darling 0.10.2", - "derive_builder_core", - "proc-macro2", - "quote", - "syn 1.0.109", + "pem-rfc7468", + "zeroize", ] [[package]] -name = "derive_builder_core" -version = "0.9.0" +name = "der-parser" +version = "9.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2791ea3e372c8495c0bc2033991d76b512cd799d07491fbd6890124db9458bef" +checksum = "5cd0a5c643689626bec213c4d8bd4d96acc8ffdb4ad4bb6bc16abf27d5f4b553" dependencies = [ - "darling 0.10.2", - "proc-macro2", - "quote", - "syn 1.0.109", + "asn1-rs", + "displaydoc", + "nom", + "num-bigint", + "num-traits", + "rusticata-macros", ] [[package]] -name = "derive_more" -version = "0.99.20" +name = "deranged" +version = "0.5.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6edb4b64a43d977b8e99788fe3a04d483834fba1215a7e02caa415b626497f7f" +checksum = "7cd812cc2bc1d69d4764bd80df88b4317eaef9e773c75226407d9bc0876b211c" dependencies = [ - "convert_case 0.4.0", - "proc-macro2", - "quote", - "rustc_version", - "syn 2.0.117", + "powerfmt", ] [[package]] @@ -3537,7 +2311,7 @@ version = "2.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "799a97264921d8623a957f6c3b9011f3b5492f557bbb7a5a19b7fa6d06ba8dcb" dependencies = [ - "convert_case 0.10.0", + "convert_case", "proc-macro2", "quote", "rustc_version", @@ -3545,24 +2319,6 @@ dependencies = [ "unicode-xid", ] -[[package]] -name = "diff" -version = "0.1.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "56254986775e3233ffa9c4d7d3faaf6d36a2c09d30b20687e9f88bc8bafc16c8" - -[[package]] -name = "difference" -version = "2.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "524cbf6897b527295dff137cec09ecf3a05f4fddffd7dfcd1585403449e74198" - -[[package]] -name = "difflib" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6184e33543162437515c2e2b48714794e37845ec9851711914eec9d308f6ebe8" - [[package]] name = "digest" version = "0.9.0" @@ -3595,56 +2351,6 @@ dependencies = [ "crypto-common 0.2.1", ] -[[package]] -name = "directories" -version = "2.0.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "551a778172a450d7fc12e629ca3b0428d00f6afa9a43da1b630d54604e97371c" -dependencies = [ - "cfg-if 0.1.10", - "dirs-sys", -] - -[[package]] -name = "directories" -version = "3.0.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e69600ff1703123957937708eb27f7a564e48885c537782722ed0ba3189ce1d7" -dependencies = [ - "dirs-sys", -] - -[[package]] -name = "dirs" -version = "1.0.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3fd78930633bd1c6e35c4b42b1df7b0cbc6bc191146e512bb3bedf243fcc3901" -dependencies = [ - "libc", - "redox_users 0.3.5", - "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 0.4.6", - "winapi", -] - [[package]] name = "displaydoc" version = "0.2.5" @@ -3656,22 +2362,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "dns-parser" -version = "0.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4d33be9473d06f75f58220f71f7a9317aca647dc061dbd3c361b0bef505fbea" -dependencies = [ - "byteorder", - "quick-error", -] - -[[package]] -name = "downcast" -version = "0.11.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1435fa1053d8b2fbbe9be7e97eca7f33d37b28409959813daefc1446a14247f1" - [[package]] name = "dtls" version = "0.17.1" @@ -3681,11 +2371,11 @@ dependencies = [ "aes", "aes-gcm", "async-trait", - "bytecheck 0.8.2", + "bytecheck", "byteorder", "cbc", "ccm", - "chacha20poly1305 0.10.1", + "chacha20poly1305", "der-parser", "hmac", "log", @@ -3694,26 +2384,20 @@ dependencies = [ "portable-atomic", "rand 0.9.2", "rand_core 0.6.4", - "rcgen 0.13.2", - "ring 0.17.14", + "rcgen", + "ring", "rkyv", - "rustls 0.23.37", + "rustls", "sec1", "sha1", "sha2 0.10.9", "thiserror 1.0.69", "tokio", "webrtc-util", - "x25519-dalek 2.0.1", + "x25519-dalek", "x509-parser", ] -[[package]] -name = "dunce" -version = "1.0.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "92773504d58c093f6de2459af4af33faa518c13451eb8f2b5698ed3d36e7c813" - [[package]] name = "dyn-stack" version = "0.10.0" @@ -3754,6 +2438,31 @@ dependencies = [ "spki", ] +[[package]] +name = "ed25519" +version = "2.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "115531babc129696a58c64a4fef0a8bf9e9698629fb97e9e40767d235cfbcd53" +dependencies = [ + "pkcs8", + "signature", +] + +[[package]] +name = "ed25519-dalek" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70e796c081cee67dc755e1a36a0a172b897fab85fc3f6bc48307991f64e4eca9" +dependencies = [ + "curve25519-dalek", + "ed25519", + "rand_core 0.6.4", + "serde", + "sha2 0.10.9", + "subtle", + "zeroize", +] + [[package]] name = "either" version = "1.15.0" @@ -3793,7 +2502,7 @@ version = "0.6.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8d2c8cdff05a7a51ba0087489ea44b0b1d97a296ca6b1d6d1a33ea7423d34049" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "critical-section", "embedded-io-async", "futures-sink", @@ -3891,7 +2600,7 @@ dependencies = [ "home", "log", "regex", - "remove_dir_all 0.8.4", + "remove_dir_all", "serde", "serde_json", "shlex", @@ -3907,7 +2616,7 @@ version = "0.8.35" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "75030f3c4f45dafd7586dd6780965a8c7e8e285a5ecb86713e63a79c5b2766f3" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", ] [[package]] @@ -3922,33 +2631,13 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "enum-iterator" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4eeac5c5edb79e4e39fe8439ef35207780a11f69c52cbe424ce3dfad4cb78de6" -dependencies = [ - "enum-iterator-derive 0.7.0", -] - [[package]] name = "enum-iterator" version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a4549325971814bda7a44061bf3fe7e487d447cba01e4220a4b454d630d7a016" dependencies = [ - "enum-iterator-derive 1.5.0", -] - -[[package]] -name = "enum-iterator-derive" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c134c37760b27a871ba422106eedbb8247da973a09e82558bf26d619c882b159" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", + "enum-iterator-derive", ] [[package]] @@ -4027,20 +2716,6 @@ version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "877a4ace8713b0bcf2a4e7eec82529c029f1d0619886d18145fea96c3ffe5c0f" -[[package]] -name = "err-derive" -version = "0.2.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22deed3a8124cff5fa835713fa105621e43bbdc46690c3a6b68328a012d350d4" -dependencies = [ - "proc-macro-error", - "proc-macro2", - "quote", - "rustversion", - "syn 1.0.109", - "synstructure 0.12.6", -] - [[package]] name = "errno" version = "0.3.14" @@ -4122,7 +2797,7 @@ dependencies = [ "anyhow", "bitflags 2.11.0", "bstr", - "cfg-if 1.0.4", + "cfg-if", "embassy-sync", "embuild", "esp-idf-svc", @@ -4160,34 +2835,6 @@ dependencies = [ "pin-project-lite", ] -[[package]] -name = "failure" -version = "0.1.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d32e9bd16cc02eae7db7ef620b392808b89f6a5e16bb3497d159c6b92a0f4f86" -dependencies = [ - "backtrace", - "failure_derive", -] - -[[package]] -name = "failure_derive" -version = "0.1.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aa4da3c766cd7a0db8242e326e9e4e081edd567072893ed320008189715366a4" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", - "synstructure 0.12.6", -] - -[[package]] -name = "fallible-iterator" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4443176a9f2c162692bd3d352d745ef9413eec5782a80d8fd6f8a1ac692a07f7" - [[package]] name = "fallible-iterator" version = "0.3.0" @@ -4240,7 +2887,7 @@ version = "0.2.27" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f98844151eee8917efc50bd9e8318cb963ae8b297431495d3f758616ea5c57db" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "libc", "libredox", ] @@ -4259,25 +2906,6 @@ checksum = "843fba2746e448b37e26a819579957415c8cef339bf08564fe8b7ddbd959573c" dependencies = [ "crc32fast", "miniz_oxide", - "zlib-rs", -] - -[[package]] -name = "float-cmp" -version = "0.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1267f4ac4f343772758f7b1bdcbe767c218bbab93bb432acbf5162bbf85a6c4" -dependencies = [ - "num-traits", -] - -[[package]] -name = "float-cmp" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "98de4bbd547a563b716d8dfa9aad1cb19bfab00f4fa09a6a4ed21dbcf44ce9c4" -dependencies = [ - "num-traits", ] [[package]] @@ -4300,7 +2928,7 @@ checksum = "da0e4dd2a88388a1f4ccc7c9ce104604dab68d9f408dc34cd45823d5a9069095" dependencies = [ "futures-core", "futures-sink", - "spin 0.9.8", + "spin", ] [[package]] @@ -4342,15 +2970,9 @@ version = "1.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cb4cb245038516f5f85277875cdaa4f7d2c9a0fa0468de06ed190163b1581fcf" dependencies = [ - "percent-encoding 2.3.2", + "percent-encoding", ] -[[package]] -name = "fragile" -version = "2.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "28dd6caf6059519a65843af8fe2a3ae298b14b80179855aeb4adc2c1934ee619" - [[package]] name = "fs2" version = "0.4.3" @@ -4368,19 +2990,13 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "14af6c9694ea25db25baa2a1788703b9e7c6648dcaeeebeb98f7561b5384c036" dependencies = [ "aligned", - "cfg-if 1.0.4", + "cfg-if", "cvt", "libc", "nix 0.29.0", "windows-sys 0.52.0", ] -[[package]] -name = "fuchsia-cprng" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a06f77d526c1a601b7c4cdd98f54b5eaabffc14d5f2f0296febdc7f357c6d3ba" - [[package]] name = "futures" version = "0.3.32" @@ -4739,27 +3355,16 @@ dependencies = [ "zeroize", ] -[[package]] -name = "getrandom" -version = "0.1.16" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce" -dependencies = [ - "cfg-if 1.0.4", - "libc", - "wasi 0.9.0+wasi-snapshot-preview1", -] - [[package]] name = "getrandom" version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ff2abc00be7fca6ebc474524697ae276ad847ad0a6b3faa4bcb027e9a4614ad0" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "js-sys", "libc", - "wasi 0.11.1+wasi-snapshot-preview1", + "wasi", "wasm-bindgen", ] @@ -4769,7 +3374,7 @@ version = "0.3.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "899def5c37c4fd7b2664648c28120ecec138e4d395b459e5ca34f9cce2dd77fd" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "js-sys", "libc", "r-efi 5.3.0", @@ -4783,7 +3388,7 @@ version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0de51e6874e94e7bf76d726fc5d13ba782deca734ff60d5bb2fb2607c7406555" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "libc", "r-efi 6.0.0", "wasip2", @@ -4800,41 +3405,14 @@ dependencies = [ "polyval", ] -[[package]] -name = "ghost_actor" -version = "0.3.0-alpha.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a34addaffa7d2c80637807444f171c646cad7549fcdac8019544034678f76d5" -dependencies = [ - "futures", - "mockall", - "must_future", - "paste", - "thiserror 1.0.69", - "tokio", - "tracing", - "tracing-futures", -] - -[[package]] -name = "gimli" -version = "0.28.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" -dependencies = [ - "fallible-iterator 0.3.0", - "indexmap 2.13.0", - "stable_deref_trait", -] - [[package]] name = "gimli" version = "0.32.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e629b9b98ef3dd8afe6ca2bd0f89306cec16d43d907889945bc5d6687f2f13c7" dependencies = [ - "fallible-iterator 0.3.0", - "indexmap 2.13.0", + "fallible-iterator", + "indexmap", "stable_deref_trait", ] @@ -4891,25 +3469,6 @@ dependencies = [ "subtle", ] -[[package]] -name = "h2" -version = "0.3.27" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0beca50380b1fc32983fc1cb4587bfa4bb9e78fc259aad4a0032d2080309222d" -dependencies = [ - "bytes", - "fnv", - "futures-core", - "futures-sink", - "futures-util", - "http 0.2.12", - "indexmap 2.13.0", - "slab", - "tokio", - "tokio-util", - "tracing", -] - [[package]] name = "h2" version = "0.4.13" @@ -4921,8 +3480,8 @@ dependencies = [ "fnv", "futures-core", "futures-sink", - "http 1.4.0", - "indexmap 2.13.0", + "http", + "indexmap", "slab", "tokio", "tokio-util", @@ -4936,7 +3495,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6ea2d84b969582b4b1864a92dc5d27cd2b77b622a8d79306834f1be5ba20d84b" dependencies = [ "bytemuck", - "cfg-if 1.0.4", + "cfg-if", "crunchy", "num-traits", "rand 0.9.2", @@ -4953,37 +3512,13 @@ dependencies = [ "byteorder", ] -[[package]] -name = "hashbrown" -version = "0.11.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab5ef0d4909ef3724cc8cce6ccc8572c5c817592e9285f5464f8e86f8bd3726e" -dependencies = [ - "ahash 0.7.8", -] - -[[package]] -name = "hashbrown" -version = "0.12.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" - -[[package]] -name = "hashbrown" -version = "0.13.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "43a3c133739dddd0d2990f9a4bdf8eb4b21ef50e4851ca85ab661199821d510e" -dependencies = [ - "ahash 0.8.12", -] - [[package]] name = "hashbrown" version = "0.14.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e5274423e17b7c9fc20b6e7e208532f9b19825d82dfd615708b70edd83df41f1" dependencies = [ - "ahash 0.8.12", + "ahash", ] [[package]] @@ -5010,35 +3545,11 @@ dependencies = [ [[package]] name = "hashlink" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7249a3129cbc1ffccd74857f81464a323a152173cdb134e0fd81bc803b29facf" -dependencies = [ - "hashbrown 0.11.2", -] - -[[package]] -name = "headers" -version = "0.3.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06683b93020a07e3dbcf5f8c0f6d40080d725bea7936fc01ad345c01b97dc270" -dependencies = [ - "base64 0.21.7", - "bytes", - "headers-core", - "http 0.2.12", - "httpdate", - "mime", - "sha1", -] - -[[package]] -name = "headers-core" -version = "0.2.0" +version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7f66481bfee273957b1f20485a4ff3362987f85b2c236580d81b4eb7a326429" +checksum = "6ba4ff7128dee98c7dc9794b6a411377e1404dba1c97deb8d1a55297bd25d8af" dependencies = [ - "http 0.2.12", + "hashbrown 0.14.5", ] [[package]] @@ -5051,15 +3562,6 @@ dependencies = [ "stable_deref_trait", ] -[[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" @@ -5072,15 +3574,6 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea" -[[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.5.2" @@ -5100,7 +3593,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d1b71e1f4791fb9e93b9d7ee03d70b501ab48f6151432fbcadeabc30fe15396e" dependencies = [ "cc", - "cfg-if 1.0.4", + "cfg-if", "libc", "pkg-config", "windows-sys 0.61.2", @@ -5135,7 +3628,7 @@ dependencies = [ [[package]] name = "hope_agents" -version = "0.3.6" +version = "0.3.7" dependencies = [ "chrono", "criterion", @@ -5146,28 +3639,6 @@ dependencies = [ "titans_memory", ] -[[package]] -name = "hostname" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c731c3e10504cc8ed35cfe2f1db4c9274c3d35fa486e3b31df46f068ef3e867" -dependencies = [ - "libc", - "match_cfg", - "winapi", -] - -[[package]] -name = "http" -version = "0.2.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" -dependencies = [ - "bytes", - "fnv", - "itoa", -] - [[package]] name = "http" version = "1.4.0" @@ -5178,17 +3649,6 @@ dependencies = [ "itoa", ] -[[package]] -name = "http-body" -version = "0.4.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2" -dependencies = [ - "bytes", - "http 0.2.12", - "pin-project-lite", -] - [[package]] name = "http-body" version = "1.0.1" @@ -5196,7 +3656,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" dependencies = [ "bytes", - "http 1.4.0", + "http", ] [[package]] @@ -5207,8 +3667,8 @@ checksum = "b021d93e26becf5dc7e1b75b1bed1fd93124b374ceb73f43d4d4eafec896a64a" dependencies = [ "bytes", "futures-core", - "http 1.4.0", - "http-body 1.0.1", + "http", + "http-body", "pin-project-lite", ] @@ -5230,22 +3690,6 @@ version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" -[[package]] -name = "human-panic" -version = "2.0.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "075e8747af11abcff07d55d98297c9c6c70eb5d6365b25e7b12f02e484935191" -dependencies = [ - "anstream", - "anstyle", - "backtrace", - "serde", - "serde_derive", - "sysinfo 0.37.2", - "toml 0.9.12+spec-1.1.0", - "uuid", -] - [[package]] name = "hybrid-array" version = "0.4.7" @@ -5255,30 +3699,6 @@ dependencies = [ "typenum", ] -[[package]] -name = "hyper" -version = "0.14.32" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "41dfc780fdec9373c01bae43289ea34c972e40ee3c9f6b3c8801a35f35586ce7" -dependencies = [ - "bytes", - "futures-channel", - "futures-core", - "futures-util", - "h2 0.3.27", - "http 0.2.12", - "http-body 0.4.6", - "httparse", - "httpdate", - "itoa", - "pin-project-lite", - "socket2 0.5.10", - "tokio", - "tower-service", - "tracing", - "want", -] - [[package]] name = "hyper" version = "1.8.1" @@ -5289,15 +3709,15 @@ dependencies = [ "bytes", "futures-channel", "futures-core", - "h2 0.4.13", - "http 1.4.0", - "http-body 1.0.1", + "h2", + "http", + "http-body", "httparse", "httpdate", "itoa", "pin-project-lite", "pin-utils", - "smallvec 1.15.1", + "smallvec", "tokio", "want", ] @@ -5308,15 +3728,15 @@ version = "0.27.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e3c93eb611681b207e1fe55d5a71ecf91572ec8a6705cdb6857f7d8d5242cf58" dependencies = [ - "http 1.4.0", - "hyper 1.8.1", + "http", + "hyper", "hyper-util", - "rustls 0.23.37", + "rustls", "rustls-pki-types", "tokio", - "tokio-rustls 0.26.4", + "tokio-rustls", "tower-service", - "webpki-roots 1.0.6", + "webpki-roots", ] [[package]] @@ -5327,7 +3747,7 @@ checksum = "70206fc6890eaca9fde8a0bf71caa2ddfc9fe045ac9e5c70df101a7dbde866e0" dependencies = [ "bytes", "http-body-util", - "hyper 1.8.1", + "hyper", "hyper-util", "native-tls", "tokio", @@ -5341,16 +3761,16 @@ version = "0.1.20" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "96547c2556ec9d12fb1578c4eaf448b04993e7fb79cbaad930a656880a6bdfa0" dependencies = [ - "base64 0.22.1", + "base64", "bytes", "futures-channel", "futures-util", - "http 1.4.0", - "http-body 1.0.1", - "hyper 1.8.1", + "http", + "http-body", + "hyper", "ipnet", "libc", - "percent-encoding 2.3.2", + "percent-encoding", "pin-project-lite", "socket2 0.6.3", "system-configuration", @@ -5420,7 +3840,7 @@ dependencies = [ "icu_normalizer_data", "icu_properties", "icu_provider", - "smallvec 1.15.1", + "smallvec", "zerovec", ] @@ -5477,17 +3897,6 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" -[[package]] -name = "idna" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "38f09e0f0b1fb55fdee1f17470ad800da77af5186a1a76c026b679358b7e844e" -dependencies = [ - "matches", - "unicode-bidi", - "unicode-normalization", -] - [[package]] name = "idna" version = "1.1.0" @@ -5495,7 +3904,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3b0875f23caa03898994f6ddc501886a45c7d3d62d04d2d90788d47be1b1e4de" dependencies = [ "idna_adapter", - "smallvec 1.15.1", + "smallvec", "utf8_iter", ] @@ -5509,17 +3918,6 @@ dependencies = [ "icu_properties", ] -[[package]] -name = "if-addrs" -version = "0.6.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2273e421f7c4f0fc99e1934fe4776f59d8df2972f4199d703fc0da9f2a9f73de" -dependencies = [ - "if-addrs-sys", - "libc", - "winapi", -] - [[package]] name = "if-addrs" version = "0.13.4" @@ -5540,16 +3938,6 @@ dependencies = [ "windows-sys 0.61.2", ] -[[package]] -name = "if-addrs-sys" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "de74b9dd780476e837e5eb5ab7c88b49ed304126e412030a0adba99c8efe79ea" -dependencies = [ - "cc", - "libc", -] - [[package]] name = "ignore" version = "0.4.25" @@ -5566,16 +3954,6 @@ dependencies = [ "winapi-util", ] -[[package]] -name = "indexmap" -version = "1.9.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99" -dependencies = [ - "autocfg 1.5.0", - "hashbrown 0.12.3", -] - [[package]] name = "indexmap" version = "2.13.0" @@ -5588,35 +3966,13 @@ dependencies = [ "serde_core", ] -[[package]] -name = "inferno" -version = "0.12.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90807d610575744524d9bdc69f3885d96f0e6c3354565b0828354a7ff2a262b8" -dependencies = [ - "ahash 0.8.12", - "clap 4.5.60", - "crossbeam-channel", - "crossbeam-utils", - "dashmap 6.1.0", - "env_logger", - "indexmap 2.13.0", - "itoa", - "log", - "num-format", - "once_cell", - "quick-xml", - "rgb", - "str_stack", -] - [[package]] name = "inout" version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "879f10e63c20629ecabbb64a8010319738c66a5cd0c29b02d63d272b03751d01" dependencies = [ - "block-padding 0.3.3", + "block-padding", "generic-array", ] @@ -5626,7 +3982,7 @@ version = "0.1.13" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e0242819d153cba4b4b05a5a8f2a7e9bbf97b6055b2a002b395c96b5ff3c0222" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", ] [[package]] @@ -5684,7 +4040,7 @@ version = "0.4.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3640c1c38b8e4e43584d8df18be5fc6b0aa314ce6ebf51b53313d4306cca8e46" dependencies = [ - "hermit-abi 0.5.2", + "hermit-abi", "libc", "windows-sys 0.61.2", ] @@ -5695,15 +4051,6 @@ version = "1.70.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a6cb138bb79a146c1bd460005623e142ef0181e3d0219cb493e02f7d08a35695" -[[package]] -name = "itertools" -version = "0.8.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f56a2d0bc861f9165be4eb3442afd3c236d8a98afd426f65d92324ae1091a484" -dependencies = [ - "either", -] - [[package]] name = "itertools" version = "0.10.5" @@ -5791,7 +4138,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1a87aa2bb7d2af34197c04845522473242e1aa17c12f4935d5856491a7fb8c97" dependencies = [ "cesu8", - "cfg-if 1.0.4", + "cfg-if", "combine", "jni-sys", "log", @@ -5847,12 +4194,19 @@ version = "10.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0529410abe238729a60b108898784df8984c87f6054c9c4fcacc47e4803c1ce1" dependencies = [ - "base64 0.22.1", + "base64", + "ed25519-dalek", "getrandom 0.2.17", + "hmac", "js-sys", - "pem 3.0.6", + "p256", + "p384", + "pem", + "rand 0.8.5", + "rsa", "serde", "serde_json", + "sha2 0.10.9", "signature", "simple_asn1", ] @@ -5866,197 +4220,6 @@ dependencies = [ "cpufeatures", ] -[[package]] -name = "kitsune_bootstrap" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "criterion", - "kitsune_p2p", - "kitsune_p2p_types", - "once_cell", - "parking_lot 0.12.5", - "rand 0.9.2", - "reqwest", - "rmp-serde 1.3.1", - "serde", - "serde_bytes", - "serde_json", - "tokio", - "warp", -] - -[[package]] -name = "kitsune_p2p" -version = "0.0.1" -dependencies = [ - "ai_fixt", - "aingle-observability", - "arrayref", - "base64 0.22.1", - "bloomfilter", - "derive_more 0.99.20", - "futures", - "ghost_actor", - "kitsune_p2p_mdns", - "kitsune_p2p_proxy", - "kitsune_p2p_transport_quic", - "kitsune_p2p_types", - "lair_keystore_api", - "matches", - "once_cell", - "rand 0.9.2", - "reqwest", - "serde", - "serde_bytes", - "shrinkwraprs", - "thiserror 2.0.18", - "tokio", - "tokio-stream", - "tracing", - "tracing-subscriber", - "url2", -] - -[[package]] -name = "kitsune_p2p_direct" -version = "0.0.1" -dependencies = [ - "arrayref", - "base64 0.22.1", - "derive_more 0.99.20", - "futures", - "hyper 0.14.32", - "kitsune_p2p", - "kitsune_p2p_direct_api", - "kitsune_p2p_proxy", - "kitsune_p2p_transport_quic", - "kitsune_p2p_types", - "rand 0.9.2", - "serde", - "serde_json", - "sodoken", - "structopt", - "tokio", - "tokio-tungstenite 0.20.1", - "tungstenite 0.20.1", -] - -[[package]] -name = "kitsune_p2p_direct_api" -version = "0.0.1" -dependencies = [ - "arrayref", - "base64 0.22.1", - "serde", - "serde_json", -] - -[[package]] -name = "kitsune_p2p_direct_test" -version = "0.0.1" -dependencies = [ - "kitsune_p2p_direct", - "kitsune_p2p_proxy", - "kitsune_p2p_transport_quic", - "tokio", -] - -[[package]] -name = "kitsune_p2p_mdns" -version = "0.0.1" -dependencies = [ - "async-stream 0.3.6", - "base64 0.22.1", - "futures-core", - "futures-util", - "libmdns", - "mdns", - "thiserror 2.0.18", - "tokio", - "tokio-stream", -] - -[[package]] -name = "kitsune_p2p_proxy" -version = "0.0.1" -dependencies = [ - "aingle-observability", - "base64 0.22.1", - "blake2b_simd", - "criterion", - "crossterm", - "derive_more 0.99.20", - "futures", - "kitsune_p2p_transport_quic", - "kitsune_p2p_types", - "lair_keystore_api", - "nanoid 0.4.0", - "parking_lot 0.12.5", - "rmp-serde 1.3.1", - "rustls 0.23.37", - "rustls-pki-types", - "serde", - "serde_bytes", - "structopt", - "tokio", - "tracing", - "tracing-subscriber", -] - -[[package]] -name = "kitsune_p2p_transport_quic" -version = "0.0.1" -dependencies = [ - "blake2b_simd", - "futures", - "if-addrs 0.13.4", - "kitsune_p2p_types", - "lair_keystore_api", - "nanoid 0.4.0", - "once_cell", - "quinn", - "rcgen 0.13.2", - "rustls 0.23.37", - "rustls-pki-types", - "serde", - "tokio", - "tokio-util", -] - -[[package]] -name = "kitsune_p2p_types" -version = "0.0.1" -dependencies = [ - "aingle-observability", - "base64 0.22.1", - "criterion", - "derive_more 0.99.20", - "futures", - "ghost_actor", - "lair_keystore_api", - "lru", - "mockall", - "nanoid 0.4.0", - "once_cell", - "parking_lot 0.12.5", - "paste", - "rmp-serde 1.3.1", - "rustls 0.23.37", - "rustls-pki-types", - "serde", - "serde_bytes", - "serde_json", - "shrinkwraprs", - "sysinfo 0.38.0", - "thiserror 2.0.18", - "tokio", - "tokio-stream", - "tracing-subscriber", - "url 2.5.8", - "url2", -] - [[package]] name = "kv-log-macro" version = "1.0.7" @@ -6066,57 +4229,14 @@ dependencies = [ "log", ] -[[package]] -name = "lair_keystore_api" -version = "0.0.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7d3f2fb64691f81c33a26276c8f11ccc6ab10ade5afca45df8629331b9f6a7a0" -dependencies = [ - "blake2b_simd", - "block-padding 0.2.1", - "byteorder", - "crypto_box", - "derive_more 0.99.20", - "directories 3.0.2", - "futures", - "ghost_actor", - "nanoid 0.3.0", - "num_cpus", - "once_cell", - "one_err", - "parking_lot 0.11.2", - "rand 0.7.3", - "rayon", - "rcgen 0.8.13", - "ring 0.16.20", - "sodoken", - "subtle", - "thiserror 1.0.69", - "tokio", - "toml 0.5.11", - "winapi", -] - -[[package]] -name = "lair_keystore_client" -version = "0.0.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "06b1591a47f5db62e30b11a5b83fd9d8194a6c3ef3ab6a160d9333092319b2a2" -dependencies = [ - "futures", - "ghost_actor", - "lair_keystore_api", - "sodoken", - "tempfile", - "tokio", - "tracing", -] - [[package]] name = "lazy_static" version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe" +dependencies = [ + "spin", +] [[package]] name = "lazycell" @@ -6164,7 +4284,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a4e34341e2708fbf805a9ada44ef6182170c6464c4fc068ab801abb7562fd5e8" dependencies = [ "byteorder", - "cfg-if 1.0.4", + "cfg-if", "hex", "hidapi", "ledger-transport", @@ -6188,37 +4308,13 @@ dependencies = [ "pkg-config", ] -[[package]] -name = "libflate" -version = "2.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e3248b8d211bd23a104a42d81b4fa8bb8ac4a3b75e7a43d85d2c9ccb6179cd74" -dependencies = [ - "adler32", - "core2", - "crc32fast", - "dary_heap", - "libflate_lz77", -] - -[[package]] -name = "libflate_lz77" -version = "2.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a599cb10a9cd92b1300debcef28da8f70b935ec937f44fcd1b70a7c986a11c5c" -dependencies = [ - "core2", - "hashbrown 0.16.1", - "rle-decode-fast", -] - [[package]] name = "libloading" version = "0.8.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d7c4b02199fee7c5d21a5ae7d8cfa79a6ef5bb2fc834d6e9058e89c825efdc55" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "windows-link 0.2.1", ] @@ -6228,24 +4324,6 @@ version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b6d2cec3eae94f9f509c767b45932f1ada8350c4bdb85af2fcab4a3c14807981" -[[package]] -name = "libmdns" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b276920bfc6c9285e16ffd30ed410487f0185f383483f45a3446afc0554fded" -dependencies = [ - "byteorder", - "futures-util", - "hostname", - "if-addrs 0.6.7", - "log", - "multimap", - "quick-error", - "rand 0.8.5", - "socket2 0.3.19", - "tokio", -] - [[package]] name = "libredox" version = "0.1.14" @@ -6273,28 +4351,11 @@ dependencies = [ "zstd-sys", ] -[[package]] -name = "libsodium-sys-stable" -version = "1.23.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2e5d23f4a051a13cf1085b2c5a050d4d890d80c754534cc4247eff525fa5283d" -dependencies = [ - "cc", - "libc", - "libflate", - "minisign-verify", - "pkg-config", - "tar", - "ureq", - "vcpkg", - "zip 7.2.0", -] - [[package]] name = "libsqlite3-sys" -version = "0.22.2" +version = "0.30.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "290b64917f8b0cb885d9de0f9959fe1f775d7fa12f1da2db9001c1c8ab60f89d" +checksum = "2e99fb7a497b1e3339bc746195567ed8d3e24945ecd636e3619d20b9de9e9149" dependencies = [ "cc", "pkg-config", @@ -6307,16 +4368,6 @@ version = "1.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0c6639b70a7ce854b79c70d7e83f16b5dc0137cc914f3d7d03803b513ecc67ac" -[[package]] -name = "libyml" -version = "0.0.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3302702afa434ffa30847a83305f0a69d6abd74293b6554c18ec85c7ef30c980" -dependencies = [ - "anyhow", - "version_check", -] - [[package]] name = "libz-sys" version = "1.1.24" @@ -6328,17 +4379,6 @@ dependencies = [ "vcpkg", ] -[[package]] -name = "linefeed" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "28715d08e35c6c074f9ae6b2e6a2420bac75d050c66ecd669d7d5b98e2caa036" -dependencies = [ - "dirs 1.0.5", - "mortal", - "winapi", -] - [[package]] name = "linux-raw-sys" version = "0.4.15" @@ -6375,15 +4415,6 @@ dependencies = [ "value-bag", ] -[[package]] -name = "lru" -version = "0.6.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ea2d928b485416e8908cff2d97d621db22b27f7b3b6729e438bcf42c671ba91" -dependencies = [ - "hashbrown 0.11.2", -] - [[package]] name = "lru-slab" version = "0.1.2" @@ -6432,18 +4463,6 @@ dependencies = [ "zerocopy-derive", ] -[[package]] -name = "maplit" -version = "1.0.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e2e65a1a2e43cfcb47a895c4c8b10d1f4a61097f9f254f183aee60cad9c651d" - -[[package]] -name = "match_cfg" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ffbee8634e0d45d258acb448e7eaab3fce7a0a467395d4d9f228e3c1f01fb2e4" - [[package]] name = "matchers" version = "0.2.0" @@ -6453,12 +4472,6 @@ dependencies = [ "regex-automata", ] -[[package]] -name = "matches" -version = "0.1.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2532096657941c2fea9c289d370a250971c689d4f143798ff67113ec042024a5" - [[package]] name = "matchit" version = "0.8.4" @@ -6471,42 +4484,20 @@ version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a06de3016e9fae57a36fd14dba131fccf49f74b40b7fbdb472f96e361ec71a08" dependencies = [ - "autocfg 1.5.0", + "autocfg", "rawpointer", ] -[[package]] -name = "maybe-uninit" -version = "2.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "60302e4db3a61da70c0cb7991976248362f30319e88850c487b9b95bbf059e00" - [[package]] name = "md-5" version = "0.10.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d89e7ee0cfbedfc4da3340218492196241d89eefb6dab27de5df917a6d2e78cf" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "digest 0.10.7", ] -[[package]] -name = "mdns" -version = "3.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c769962ac75a6ea437f0922b27834bcccd4c013d591383a16ae5731e3ef0f3f3" -dependencies = [ - "async-std", - "async-stream 0.2.1", - "dns-parser", - "err-derive", - "futures-core", - "futures-util", - "log", - "net2", -] - [[package]] name = "mdns-sd" version = "0.18.1" @@ -6517,7 +4508,7 @@ dependencies = [ "flume", "if-addrs 0.15.0", "log", - "mio 1.1.1", + "mio", "socket-pktinfo", "socket2 0.6.3", ] @@ -6553,7 +4544,7 @@ version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5de893c32cde5f383baa4c04c5d6dbdd735cfd4a794b0debdb2bb1b421da5ff4" dependencies = [ - "autocfg 1.5.0", + "autocfg", ] [[package]] @@ -6562,7 +4553,7 @@ version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a" dependencies = [ - "autocfg 1.5.0", + "autocfg", ] [[package]] @@ -6599,12 +4590,6 @@ version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" -[[package]] -name = "minisign-verify" -version = "0.2.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22f9645cb765ea72b8111f36c522475d2daa0d22c957a9826437e97534bc4e9e" - [[package]] name = "miniz_oxide" version = "0.8.9" @@ -6615,19 +4600,6 @@ dependencies = [ "simd-adler32", ] -[[package]] -name = "mio" -version = "0.7.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8067b404fe97c70829f082dec8bcf4f71225d7eaea1d8645349cb76fa06205cc" -dependencies = [ - "libc", - "log", - "miow", - "ntapi 0.3.7", - "winapi", -] - [[package]] name = "mio" version = "1.1.1" @@ -6636,117 +4608,16 @@ checksum = "a69bcab0ad47271a0234d9422b131806bf3968021e5dc9328caf2d4cd58557fc" dependencies = [ "libc", "log", - "wasi 0.11.1+wasi-snapshot-preview1", + "wasi", "windows-sys 0.61.2", ] -[[package]] -name = "miow" -version = "0.3.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9f1c5b025cda876f66ef43a113f91ebc9f4ccef34843000e0adf6ebbab84e21" -dependencies = [ - "winapi", -] - -[[package]] -name = "mockall" -version = "0.11.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c84490118f2ee2d74570d114f3d0493cbf02790df303d2707606c3e14e07c96" -dependencies = [ - "cfg-if 1.0.4", - "downcast", - "fragile", - "lazy_static", - "mockall_derive", - "predicates 2.1.5", - "predicates-tree", -] - -[[package]] -name = "mockall_derive" -version = "0.11.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22ce75669015c4f47b289fd4d4f56e894e4c96003ffdf3ac51313126f94c6cbb" -dependencies = [ - "cfg-if 1.0.4", - "proc-macro2", - "quote", - "syn 1.0.109", -] - -[[package]] -name = "more-asserts" -version = "0.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7843ec2de400bcbc6a6328c958dc38e5359da6e93e72e37bc5246bf1ae776389" - [[package]] name = "more-asserts" version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1fafa6961cabd9c63bcd77a45d7e3b7f3b552b70417831fb0f56db717e72407e" -[[package]] -name = "mortal" -version = "0.2.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2c624fa1b7aab6bd2aff6e9b18565cc0363b6d45cbcd7465c9ed5e3740ebf097" -dependencies = [ - "bitflags 2.11.0", - "libc", - "nix 0.26.4", - "smallstr", - "terminfo", - "unicode-normalization", - "unicode-width 0.1.14", - "winapi", -] - -[[package]] -name = "mr_bundle" -version = "0.0.1" -dependencies = [ - "aingle_util", - "anyhow", - "arbitrary", - "bytes", - "derive_more 0.99.20", - "either", - "flate2", - "futures", - "maplit", - "matches", - "reqwest", - "rmp-serde 1.3.1", - "serde", - "serde_bytes", - "serde_derive", - "serde_yml", - "tempdir", - "thiserror 2.0.18", - "tokio", -] - -[[package]] -name = "multer" -version = "2.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01acbdc23469fd8fe07ab135923371d5f5a422fbf9c522158677c8eb15bc51c2" -dependencies = [ - "bytes", - "encoding_rs", - "futures-util", - "http 0.2.12", - "httparse", - "log", - "memchr", - "mime", - "spin 0.9.8", - "version_check", -] - [[package]] name = "multer" version = "3.1.0" @@ -6756,23 +4627,14 @@ dependencies = [ "bytes", "encoding_rs", "futures-util", - "http 1.4.0", + "http", "httparse", "memchr", "mime", - "spin 0.9.8", + "spin", "version_check", ] -[[package]] -name = "multimap" -version = "0.8.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e5ce46fe64a9d73be07dcbe690a38ce1b293be448fd8ce1e6c1b8062c9f72c6a" -dependencies = [ - "serde", -] - [[package]] name = "munge" version = "0.4.7" @@ -6793,34 +4655,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "must_future" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a160ffed3c2f98d2906c67a9b6e4e1f09cca7e17e3f780286a349061459eeebe" -dependencies = [ - "futures", - "pin-utils", -] - -[[package]] -name = "nanoid" -version = "0.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a6226bc4e142124cb44e309a37a04cd9bb10e740d8642855441d3b14808f635e" -dependencies = [ - "rand 0.6.5", -] - -[[package]] -name = "nanoid" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3ffa00dec017b5b1a8b7cf5e2c008bfda1aa7e0697ac1508b491fdf2622fb4d8" -dependencies = [ - "rand 0.8.5", -] - [[package]] name = "native-tls" version = "0.2.18" @@ -6868,17 +4702,6 @@ dependencies = [ "rawpointer", ] -[[package]] -name = "net2" -version = "0.2.39" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b13b648036a2339d06de780866fbdfda0dde886de7b3af2ddeba8b14f4ee34ac" -dependencies = [ - "cfg-if 0.1.10", - "libc", - "winapi", -] - [[package]] name = "nix" version = "0.26.4" @@ -6886,7 +4709,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "598beaf3cc6fdd9a5dfb1630c2800c7acd31df7aaf0f565796fba2b53ca1af1b" dependencies = [ "bitflags 1.3.2", - "cfg-if 1.0.4", + "cfg-if", "libc", "memoffset 0.7.1", "pin-utils", @@ -6899,7 +4722,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "71e2746dc3a24dd78b3cfcb7be93368c6de9963d30f43a6a73998a9cf4b17b46" dependencies = [ "bitflags 2.11.0", - "cfg-if 1.0.4", + "cfg-if", "cfg_aliases", "libc", ] @@ -6920,12 +4743,6 @@ dependencies = [ "minimal-lexical", ] -[[package]] -name = "normalize-line-endings" -version = "0.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61807f77802ff30975e01f4f071c8ba10c022052f98b3294119f3e615d13e5be" - [[package]] name = "normpath" version = "1.5.0" @@ -6935,24 +4752,6 @@ dependencies = [ "windows-sys 0.61.2", ] -[[package]] -name = "ntapi" -version = "0.3.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c28774a7fd2fbb4f0babd8237ce554b73af68021b5f695a3cebd6c59bac0980f" -dependencies = [ - "winapi", -] - -[[package]] -name = "ntapi" -version = "0.4.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3b335231dfd352ffb0f8017f3b6027a4917f7df785ea2143d8af2adc66980ae" -dependencies = [ - "winapi", -] - [[package]] name = "nu-ansi-term" version = "0.50.3" @@ -6972,6 +4771,22 @@ dependencies = [ "num-traits", ] +[[package]] +name = "num-bigint-dig" +version = "0.8.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e661dda6640fad38e827a6d4a310ff4763082116fe217f279885c97f511bb0b7" +dependencies = [ + "lazy_static", + "libm", + "num-integer", + "num-iter", + "num-traits", + "rand 0.8.5", + "smallvec", + "zeroize", +] + [[package]] name = "num-complex" version = "0.4.6" @@ -6989,21 +4804,22 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cf97ec579c3c42f953ef76dbf8d55ac91fb219dde70e49aa4a6b7d74e9919050" [[package]] -name = "num-format" -version = "0.4.4" +name = "num-integer" +version = "0.1.46" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a652d9771a63711fd3c3deb670acfbe5c30a4072e664d7a3bf5a9e1056ac72c3" +checksum = "7969661fd2958a5cb096e56c8e1ad0444ac2bbcd0061bd28660485a44879858f" dependencies = [ - "arrayvec 0.7.6", - "itoa", + "num-traits", ] [[package]] -name = "num-integer" -version = "0.1.46" +name = "num-iter" +version = "0.1.45" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7969661fd2958a5cb096e56c8e1ad0444ac2bbcd0061bd28660485a44879858f" +checksum = "1429034a0490724d0075ebb2bc9e875d6503c3cf69e235a8941aa757d83ef5bf" dependencies = [ + "autocfg", + "num-integer", "num-traits", ] @@ -7013,7 +4829,7 @@ version = "0.2.19" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "071dfc062690e90b734c0b2273ce72ad0ffa95f0c74596bc250dcfd960262841" dependencies = [ - "autocfg 1.5.0", + "autocfg", "libm", ] @@ -7023,7 +4839,7 @@ version = "1.17.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "91df4bbde75afed763b708b7eee1e8e7651e02d97f6d5dd763e89367e957b23b" dependencies = [ - "hermit-abi 0.5.2", + "hermit-abi", "libc", ] @@ -7076,15 +4892,6 @@ dependencies = [ "objc2-foundation", ] -[[package]] -name = "objc2-core-foundation" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2a180dd8642fa45cdb7dd721cd4c11b1cadd4929ce112ebd8b9f5803cc79d536" -dependencies = [ - "bitflags 2.11.0", -] - [[package]] name = "objc2-encode" version = "4.1.0" @@ -7103,30 +4910,6 @@ dependencies = [ "objc2", ] -[[package]] -name = "objc2-io-kit" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "33fafba39597d6dc1fb709123dfa8289d39406734be322956a69f0931c73bb15" -dependencies = [ - "libc", - "objc2-core-foundation", -] - -[[package]] -name = "object" -version = "0.32.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a6a622008b6e321afc04970976f62ee297fdbaa6f95318ca343e3eebb9648441" -dependencies = [ - "crc32fast", - "flate2", - "hashbrown 0.14.5", - "indexmap 2.13.0", - "memchr", - "ruzstd 0.5.0", -] - [[package]] name = "object" version = "0.37.3" @@ -7145,9 +4928,9 @@ dependencies = [ "crc32fast", "flate2", "hashbrown 0.16.1", - "indexmap 2.13.0", + "indexmap", "memchr", - "ruzstd 0.8.2", + "ruzstd", ] [[package]] @@ -7167,21 +4950,9 @@ checksum = "42f5e15c9953c5e4ccceeb2e7382a716482c34515315f7b03532b8b4e8393d2d" [[package]] name = "once_cell_polyfill" -version = "1.70.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "384b8ab6d37215f3c5301a95a4accb5d64aa607f1fcb26a11b5303878451b4fe" - -[[package]] -name = "one_err" -version = "0.0.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "42901c1956c1ef1de5bce4428695aa03505a8e27bd2262173395c804834f44ec" -dependencies = [ - "indexmap 1.9.3", - "libc", - "serde", - "serde_json", -] +version = "1.70.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "384b8ab6d37215f3c5301a95a4accb5d64aa607f1fcb26a11b5303878451b4fe" [[package]] name = "oorandom" @@ -7202,7 +4973,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "08838db121398ad17ab8531ce9de97b244589089e290a384c900cb9ff7434328" dependencies = [ "bitflags 2.11.0", - "cfg-if 1.0.4", + "cfg-if", "foreign-types", "libc", "once_cell", @@ -7239,15 +5010,6 @@ dependencies = [ "vcpkg", ] -[[package]] -name = "owning_ref" -version = "0.3.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cdf84f41639e037b484f93433aa3897863b561ed65c6e59c7073d7c561710f37" -dependencies = [ - "stable_deref_trait", -] - [[package]] name = "oxilangtag" version = "0.1.5" @@ -7299,32 +5061,12 @@ dependencies = [ "sha2 0.10.9", ] -[[package]] -name = "page_size" -version = "0.4.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eebde548fbbf1ea81a99b128872779c437752fb99f217c45245e1a61dcd9edcd" -dependencies = [ - "libc", - "winapi", -] - [[package]] name = "parking" version = "2.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f38d5652c16fde515bb1ecef450ab0f6a219d619a7274976324d5e377f7dceba" -[[package]] -name = "parking_lot" -version = "0.4.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "149d8f5b97f3c1133e3cfcd8886449959e856b557ff281e292b733d7c69e005e" -dependencies = [ - "owning_ref", - "parking_lot_core 0.2.14", -] - [[package]] name = "parking_lot" version = "0.11.2" @@ -7346,29 +5088,17 @@ dependencies = [ "parking_lot_core 0.9.12", ] -[[package]] -name = "parking_lot_core" -version = "0.2.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4db1a8ccf734a7bce794cc19b3df06ed87ab2f3907036b693c68f56b4d4537fa" -dependencies = [ - "libc", - "rand 0.4.6", - "smallvec 0.6.14", - "winapi", -] - [[package]] name = "parking_lot_core" version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "60a2cfe6f0ad2bfc16aefa463b497d5c7a5ecd44a23efa72aa342d90177356dc" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "instant", "libc", "redox_syscall 0.2.16", - "smallvec 1.15.1", + "smallvec", "winapi", ] @@ -7378,10 +5108,10 @@ version = "0.9.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2621685985a2ebf1c516881c026032ac7deafcda1a2c9b7850dc81e3dfcb64c1" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "libc", "redox_syscall 0.5.18", - "smallvec 1.15.1", + "smallvec", "windows-link 0.2.1", ] @@ -7429,24 +5159,13 @@ version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "132dca9b868d927b35b5dd728167b2dee150eb1ad686008fc71ccb298b776fca" -[[package]] -name = "pem" -version = "0.8.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fd56cbd21fea48d0c440b41cd69c589faacade08c992d9a54e471b79d0fd13eb" -dependencies = [ - "base64 0.13.1", - "once_cell", - "regex", -] - [[package]] name = "pem" version = "3.0.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1d30c53c26bc5b31a98cd02d20f25a7c8567146caf63ed593a9d87b2775291be" dependencies = [ - "base64 0.22.1", + "base64", "serde_core", ] @@ -7459,12 +5178,6 @@ dependencies = [ "base64ct", ] -[[package]] -name = "percent-encoding" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "31010dd2e1ac33d5b46a5b413495239882813e0369f8ed8a5e266f173602f831" - [[package]] name = "percent-encoding" version = "2.3.2" @@ -7481,64 +5194,6 @@ dependencies = [ "ucd-trie", ] -[[package]] -name = "phf" -version = "0.11.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1fd6780a80ae0c52cc120a26a1a42c1ae51b247a253e4e06113d23d2c2edd078" -dependencies = [ - "phf_shared", -] - -[[package]] -name = "phf_codegen" -version = "0.11.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aef8048c789fa5e851558d709946d6d79a8ff88c0440c587967f8e94bfb1216a" -dependencies = [ - "phf_generator", - "phf_shared", -] - -[[package]] -name = "phf_generator" -version = "0.11.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c80231409c20246a13fddb31776fb942c38553c51e871f8cbd687a4cfb5843d" -dependencies = [ - "phf_shared", - "rand 0.8.5", -] - -[[package]] -name = "phf_shared" -version = "0.11.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "67eabc2ef2a60eb7faa00097bd1ffdb5bd28e62bf39990626a582201b7a754e5" -dependencies = [ - "siphasher", -] - -[[package]] -name = "pin-project" -version = "1.1.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1749c7ed4bcaf4c3d0a3efc28538844fb29bcdd7d2b67b2be7e20ba861ff517" -dependencies = [ - "pin-project-internal", -] - -[[package]] -name = "pin-project-internal" -version = "1.1.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d9b20ed30f105399776b9c883e68e536ef602a16ae6f596d2c473591d6ad64c6" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.117", -] - [[package]] name = "pin-project-lite" version = "0.2.17" @@ -7562,6 +5217,17 @@ dependencies = [ "futures-io", ] +[[package]] +name = "pkcs1" +version = "0.7.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c8ffb9f10fa047879315e6625af03c164b16962a5368d724ed16323b68ace47f" +dependencies = [ + "der", + "pkcs8", + "spki", +] + [[package]] name = "pkcs8" version = "0.10.2" @@ -7618,24 +5284,14 @@ version = "3.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5d0e4f59085d47d8241c88ead0f274e8a0cb551f3625263c05eb8dd897c34218" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "concurrent-queue", - "hermit-abi 0.5.2", + "hermit-abi", "pin-project-lite", "rustix 1.1.4", "windows-sys 0.61.2", ] -[[package]] -name = "poly1305" -version = "0.6.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b7456bc1ad2d4cf82b3a016be4c2ac48daf11bf990c1603ebd447fe6f30fca8" -dependencies = [ - "cpuid-bool", - "universal-hash 0.4.0", -] - [[package]] name = "poly1305" version = "0.8.0" @@ -7644,7 +5300,7 @@ checksum = "8159bd90725d2df49889a078b54f4f79e87f1f8a8444194cdca81d38f5393abf" dependencies = [ "cpufeatures", "opaque-debug", - "universal-hash 0.5.1", + "universal-hash", ] [[package]] @@ -7653,10 +5309,10 @@ version = "0.6.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9d1fe60d06143b2430aa532c94cfe9e29783047f06c0d7fd359a9a51b729fa25" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cpufeatures", "opaque-debug", - "universal-hash 0.5.1", + "universal-hash", ] [[package]] @@ -7674,15 +5330,6 @@ dependencies = [ "portable-atomic", ] -[[package]] -name = "portpicker" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "be97d76faf1bfab666e1375477b23fde79eccf0276e9b63b92a39d676a889ba9" -dependencies = [ - "rand 0.8.5", -] - [[package]] name = "potential_utf" version = "0.1.4" @@ -7707,70 +5354,6 @@ dependencies = [ "zerocopy", ] -[[package]] -name = "predicates" -version = "1.0.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f49cfaf7fdaa3bfacc6fa3e7054e65148878354a5cfddcf661df4c851f8021df" -dependencies = [ - "difference", - "float-cmp 0.8.0", - "normalize-line-endings", - "predicates-core", - "regex", -] - -[[package]] -name = "predicates" -version = "2.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "59230a63c37f3e18569bdb90e4a89cbf5bf8b06fea0b84e65ea10cc4df47addd" -dependencies = [ - "difflib", - "float-cmp 0.9.0", - "itertools 0.10.5", - "normalize-line-endings", - "predicates-core", - "regex", -] - -[[package]] -name = "predicates" -version = "3.1.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ada8f2932f28a27ee7b70dd6c1c39ea0675c55a36879ab92f3a715eaa1e63cfe" -dependencies = [ - "anstyle", - "difflib", - "predicates-core", -] - -[[package]] -name = "predicates-core" -version = "1.0.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cad38746f3166b4031b1a0d39ad9f954dd291e7854fcc0eed52ee41a0b50d144" - -[[package]] -name = "predicates-tree" -version = "1.0.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d0de1b847b39c8131db0467e9df1ff60e6d0562ab8e9a16e568ad0fdb372e2f2" -dependencies = [ - "predicates-core", - "termtree", -] - -[[package]] -name = "pretty_assertions" -version = "1.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3ae130e2f271fbc2ac3a40fb1d07180839cdbbe443c7a27e1e3c13c5cac0116d" -dependencies = [ - "diff", - "yansi", -] - [[package]] name = "prettyplease" version = "0.2.37" @@ -7799,30 +5382,6 @@ dependencies = [ "toml_edit", ] -[[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 1.0.109", - "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-macro-error-attr2" version = "2.0.0" @@ -7854,33 +5413,13 @@ dependencies = [ "unicode-ident", ] -[[package]] -name = "ptr_meta" -version = "0.1.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0738ccf7ea06b608c10564b31debd4f5bc5e197fc8bfe088f68ae5ce81e7a4f1" -dependencies = [ - "ptr_meta_derive 0.1.4", -] - [[package]] name = "ptr_meta" version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0b9a0cf95a1196af61d4f1cbdab967179516d9a4a4312af1f31948f8f6224a79" dependencies = [ - "ptr_meta_derive 0.3.1", -] - -[[package]] -name = "ptr_meta_derive" -version = "0.1.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "16b845dbfca988fa33db069c0e230574d15a3088f147a87b64c7589eb662c9ac" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", + "ptr_meta_derive", ] [[package]] @@ -7913,7 +5452,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2e205bb30d5b916c55e584c22201771bcf2bad9aabd5d4127f38387140c38632" dependencies = [ "bytemuck", - "cfg-if 1.0.4", + "cfg-if", "libm", "num-complex", "paste", @@ -7929,21 +5468,6 @@ version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "40e24eee682d89fb193496edf918a7f407d30175b2e785fe057e4392dfd182e0" -[[package]] -name = "quick-error" -version = "1.2.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a1d01941d82fa2ab50be1e79e6714289dd7cde78eba4c074bc5a4374f650dfe0" - -[[package]] -name = "quick-xml" -version = "0.39.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "958f21e8e7ceb5a1aa7fa87fab28e7c75976e0bfe7e23ff069e0a260f894067d" -dependencies = [ - "memchr", -] - [[package]] name = "quinn" version = "0.11.9" @@ -7956,7 +5480,7 @@ dependencies = [ "quinn-proto", "quinn-udp", "rustc-hash 2.1.1", - "rustls 0.23.37", + "rustls", "socket2 0.6.3", "thiserror 2.0.18", "tokio", @@ -7975,9 +5499,9 @@ dependencies = [ "getrandom 0.3.4", "lru-slab", "rand 0.9.2", - "ring 0.17.14", + "ring", "rustc-hash 2.1.1", - "rustls 0.23.37", + "rustls", "rustls-pki-types", "rustls-platform-verifier", "slab", @@ -8022,79 +5546,13 @@ version = "6.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f8dcc9c7d52a811697d2151c701e0d08956f92b0e24136cf4cf27b57a6a0d9bf" -[[package]] -name = "r2d2" -version = "0.8.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "51de85fb3fb6524929c8a2eb85e6b6d363de4e8c48f9e2c2eac4944abc181c93" -dependencies = [ - "log", - "parking_lot 0.12.5", - "scheduled-thread-pool", -] - -[[package]] -name = "r2d2_sqlite" -version = "0.18.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d24607049214c5e42d3df53ac1d8a23c34cc6a5eefe3122acb2c72174719959" -dependencies = [ - "r2d2", - "rusqlite", -] - [[package]] name = "rancor" version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a063ea72381527c2a0561da9c80000ef822bdd7c3241b1cc1b12100e3df081ee" dependencies = [ - "ptr_meta 0.3.1", -] - -[[package]] -name = "rand" -version = "0.4.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "552840b97013b1a26992c11eac34bdd778e464601a4c2054b5f0bff7c6761293" -dependencies = [ - "fuchsia-cprng", - "libc", - "rand_core 0.3.1", - "rdrand", - "winapi", -] - -[[package]] -name = "rand" -version = "0.6.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6d71dacdc3c88c1fde3885a3be3fbab9f35724e6ce99467f7d9c5026132184ca" -dependencies = [ - "autocfg 0.1.8", - "libc", - "rand_chacha 0.1.1", - "rand_core 0.4.2", - "rand_hc 0.1.0", - "rand_isaac", - "rand_jitter", - "rand_os", - "rand_pcg", - "rand_xorshift", - "winapi", -] - -[[package]] -name = "rand" -version = "0.7.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6a6b1679d49b24bbfe0c803429aa1874472f50d9b363131f0e89fc356b544d03" -dependencies = [ - "getrandom 0.1.16", - "libc", - "rand_chacha 0.2.2", - "rand_core 0.5.1", - "rand_hc 0.2.0", + "ptr_meta", ] [[package]] @@ -8118,68 +5576,24 @@ dependencies = [ "rand_core 0.9.5", ] -[[package]] -name = "rand_chacha" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "556d3a1ca6600bfcbab7c7c91ccb085ac7fbbcd70e008a98742e7847f4f7bcef" -dependencies = [ - "autocfg 0.1.8", - "rand_core 0.3.1", -] - -[[package]] -name = "rand_chacha" -version = "0.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f4c8ed856279c9737206bf725bf36935d8666ead7aa69b52be55af369d193402" -dependencies = [ - "ppv-lite86", - "rand_core 0.5.1", -] - [[package]] name = "rand_chacha" version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" dependencies = [ - "ppv-lite86", - "rand_core 0.6.4", -] - -[[package]] -name = "rand_chacha" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d3022b5f1df60f26e1ffddd6c66e8aa15de382ae63b3a0c1bfc0e4d3e3f325cb" -dependencies = [ - "ppv-lite86", - "rand_core 0.9.5", -] - -[[package]] -name = "rand_core" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7a6fdeb83b075e8266dcc8762c22776f6877a63111121f5f8c7411e5be7eed4b" -dependencies = [ - "rand_core 0.4.2", + "ppv-lite86", + "rand_core 0.6.4", ] [[package]] -name = "rand_core" -version = "0.4.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c33a3c44ca05fa6f1807d8e6743f3824e8509beca625669633be0acbdf509dc" - -[[package]] -name = "rand_core" -version = "0.5.1" +name = "rand_chacha" +version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90bde5296fc891b0cef12a6d03ddccc162ce7b2aff54160af9338f8d40df6d19" +checksum = "d3022b5f1df60f26e1ffddd6c66e8aa15de382ae63b3a0c1bfc0e4d3e3f325cb" dependencies = [ - "getrandom 0.1.16", + "ppv-lite86", + "rand_core 0.9.5", ] [[package]] @@ -8220,77 +5634,6 @@ dependencies = [ "rand 0.9.2", ] -[[package]] -name = "rand_hc" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b40677c7be09ae76218dc623efbf7b18e34bced3f38883af07bb75630a21bc4" -dependencies = [ - "rand_core 0.3.1", -] - -[[package]] -name = "rand_hc" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca3129af7b92a17112d59ad498c6f81eaf463253766b90396d39ea7a39d6613c" -dependencies = [ - "rand_core 0.5.1", -] - -[[package]] -name = "rand_isaac" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ded997c9d5f13925be2a6fd7e66bf1872597f759fd9dd93513dd7e92e5a5ee08" -dependencies = [ - "rand_core 0.3.1", -] - -[[package]] -name = "rand_jitter" -version = "0.1.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1166d5c91dc97b88d1decc3285bb0a99ed84b05cfd0bc2341bdf2d43fc41e39b" -dependencies = [ - "libc", - "rand_core 0.4.2", - "winapi", -] - -[[package]] -name = "rand_os" -version = "0.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b75f676a1e053fc562eafbb47838d67c84801e38fc1ba459e8f180deabd5071" -dependencies = [ - "cloudabi", - "fuchsia-cprng", - "libc", - "rand_core 0.4.2", - "rdrand", - "winapi", -] - -[[package]] -name = "rand_pcg" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "abf9b09b01790cfe0364f52bf32995ea3c39f4d2dd011eac241d2914146d0b44" -dependencies = [ - "autocfg 0.1.8", - "rand_core 0.4.2", -] - -[[package]] -name = "rand_xorshift" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cbf7e9e623549b0e21f6e97cf8ecf247c1a8fd2e8a992ae265314300b2455d5c" -dependencies = [ - "rand_core 0.3.1", -] - [[package]] name = "rangemap" version = "1.7.1" @@ -8341,39 +5684,18 @@ dependencies = [ "crossbeam-utils", ] -[[package]] -name = "rcgen" -version = "0.8.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2351cbef4bf91837f5ff7face6091cb277ba960d1638d2c5ae2327859912fbba" -dependencies = [ - "chrono", - "pem 0.8.3", - "ring 0.16.20", - "yasna 0.4.0", -] - [[package]] name = "rcgen" version = "0.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "75e669e5202259b5314d1ea5397316ad400819437857b90861765f24c4cf80a2" dependencies = [ - "pem 3.0.6", - "ring 0.17.14", + "pem", + "ring", "rustls-pki-types", "time", "x509-parser", - "yasna 0.5.2", -] - -[[package]] -name = "rdrand" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "678054eb77286b51581ba43620cc911abf02758c91f93f479767aed0f90458b2" -dependencies = [ - "rand_core 0.3.1", + "yasna", ] [[package]] @@ -8382,12 +5704,6 @@ version = "0.5.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "03251193000f4bd3b042892be858ee50e8b3719f2b08e5833ac4353724632430" -[[package]] -name = "redox_syscall" -version = "0.1.57" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "41cc0f7e4d5d4544e8861606a285bb08d3e70712ccc7d2b84d7c0ccfaf4b05ce" - [[package]] name = "redox_syscall" version = "0.2.16" @@ -8415,41 +5731,6 @@ dependencies = [ "bitflags 2.11.0", ] -[[package]] -name = "redox_users" -version = "0.3.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "de0737333e7a9502c789a36d7c7fa6092a49895d4faa31ca5df163857ded2e9d" -dependencies = [ - "getrandom 0.1.16", - "redox_syscall 0.1.57", - "rust-argon2", -] - -[[package]] -name = "redox_users" -version = "0.4.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ba009ff324d1fc1b900bd1fdb31564febe58a8ccc8a6fdbb93b543d33b13ca43" -dependencies = [ - "getrandom 0.2.17", - "libredox", - "thiserror 1.0.69", -] - -[[package]] -name = "regalloc2" -version = "0.9.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad156d539c879b7a24a363a2016d77961786e71f48f2e2fc8302a92abd2429a6" -dependencies = [ - "hashbrown 0.13.2", - "log", - "rustc-hash 1.1.0", - "slice-group-by", - "smallvec 1.15.1", -] - [[package]] name = "regalloc2" version = "0.13.5" @@ -8461,7 +5742,7 @@ dependencies = [ "hashbrown 0.15.5", "log", "rustc-hash 2.1.1", - "smallvec 1.15.1", + "smallvec", ] [[package]] @@ -8505,22 +5786,13 @@ dependencies = [ "windows-sys 0.52.0", ] -[[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 = "remove_dir_all" version = "0.8.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a694f9e0eb3104451127f6cc1e5de55f59d3b1fc8c5ddfaeb6f1e716479ceb4a" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cvt", "fs_at", "libc", @@ -8534,7 +5806,7 @@ version = "0.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cadadef317c2f20755a64d7fdc48f9e7178ee6b0e1f7fce33fa60f1d68a276e6" dependencies = [ - "bytecheck 0.8.2", + "bytecheck", ] [[package]] @@ -8543,15 +5815,15 @@ version = "0.12.28" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "eddd3ca559203180a307f12d114c268abf583f59b03cb906fd0b3ff8646c1147" dependencies = [ - "base64 0.22.1", + "base64", "bytes", "encoding_rs", "futures-core", - "h2 0.4.13", - "http 1.4.0", - "http-body 1.0.1", + "h2", + "http", + "http-body", "http-body-util", - "hyper 1.8.1", + "hyper", "hyper-rustls", "hyper-tls", "hyper-util", @@ -8559,10 +5831,10 @@ dependencies = [ "log", "mime", "native-tls", - "percent-encoding 2.3.2", + "percent-encoding", "pin-project-lite", "quinn", - "rustls 0.23.37", + "rustls", "rustls-pki-types", "serde", "serde_json", @@ -8570,15 +5842,15 @@ dependencies = [ "sync_wrapper", "tokio", "tokio-native-tls", - "tokio-rustls 0.26.4", + "tokio-rustls", "tower", "tower-http", "tower-service", - "url 2.5.8", + "url", "wasm-bindgen", "wasm-bindgen-futures", "web-sys", - "webpki-roots 1.0.6", + "webpki-roots", ] [[package]] @@ -8591,30 +5863,6 @@ dependencies = [ "subtle", ] -[[package]] -name = "rgb" -version = "0.8.53" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "47b34b781b31e5d73e9fbc8689c70551fd1ade9a19e3e28cfec8580a79290cc4" -dependencies = [ - "bytemuck", -] - -[[package]] -name = "ring" -version = "0.16.20" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3053cf52e236a3ed746dfc745aa9cacf1b791d846bdaf412f60a8d7d6e17c8fc" -dependencies = [ - "cc", - "libc", - "once_cell", - "spin 0.5.2", - "untrusted 0.7.1", - "web-sys", - "winapi", -] - [[package]] name = "ring" version = "0.17.14" @@ -8622,10 +5870,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a4689e6c2294d81e88dc6261c768b63bc4fcdb852be6d1352498b114f61383b7" dependencies = [ "cc", - "cfg-if 1.0.4", + "cfg-if", "getrandom 0.2.17", "libc", - "untrusted 0.9.0", + "untrusted", "windows-sys 0.52.0", ] @@ -8652,12 +5900,12 @@ version = "0.8.15" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1a30e631b7f4a03dee9056b8ef6982e8ba371dd5bedb74d3ec86df4499132c70" dependencies = [ - "bytecheck 0.8.2", + "bytecheck", "bytes", "hashbrown 0.16.1", - "indexmap 2.13.0", + "indexmap", "munge", - "ptr_meta 0.3.1", + "ptr_meta", "rancor", "rend", "rkyv_derive", @@ -8676,44 +5924,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "rle-decode-fast" -version = "1.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3582f63211428f83597b51b2ddb88e2a91a9d52d12831f9d08f5e624e8977422" - -[[package]] -name = "rmp" -version = "0.8.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "228ed7c16fa39782c3b3468e974aec2795e9089153cd08ee2e9aefb3613334c4" -dependencies = [ - "byteorder", - "num-traits", - "paste", -] - -[[package]] -name = "rmp-serde" -version = "0.14.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4ce7d70c926fe472aed493b902010bccc17fa9f7284145cb8772fd22fdb052d8" -dependencies = [ - "byteorder", - "rmp", - "serde", -] - -[[package]] -name = "rmp-serde" -version = "1.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72f81bee8c8ef9b577d1681a70ebbc962c232461e397b22c208c43c04b67a155" -dependencies = [ - "rmp", - "serde", -] - [[package]] name = "rocksdb" version = "0.24.0" @@ -8724,6 +5934,26 @@ dependencies = [ "librocksdb-sys", ] +[[package]] +name = "rsa" +version = "0.9.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b8573f03f5883dcaebdfcf4725caa1ecb9c15b2ef50c43a07b816e06799bb12d" +dependencies = [ + "const-oid 0.9.6", + "digest 0.10.7", + "num-bigint-dig", + "num-integer", + "num-traits", + "pkcs1", + "pkcs8", + "rand_core 0.6.4", + "signature", + "spki", + "subtle", + "zeroize", +] + [[package]] name = "rtcp" version = "0.17.1" @@ -8752,29 +5982,16 @@ dependencies = [ [[package]] name = "rusqlite" -version = "0.25.4" +version = "0.32.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5c4b1eaf239b47034fb450ee9cdedd7d0226571689d8823030c4b6c2cb407152" +checksum = "7753b721174eb8ff87a9a0e799e2d7bc3749323e773db92e0984debb00019d6e" dependencies = [ - "bitflags 1.3.2", - "fallible-iterator 0.2.0", + "bitflags 2.11.0", + "fallible-iterator", "fallible-streaming-iterator", "hashlink", "libsqlite3-sys", - "memchr", - "smallvec 1.15.1", -] - -[[package]] -name = "rust-argon2" -version = "0.8.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b18820d944b33caa75a71378964ac46f58517c92b6ae5f762636247c09e78fb" -dependencies = [ - "base64 0.13.1", - "blake2b_simd", - "constant_time_eq 0.1.5", - "crossbeam-utils", + "smallvec", ] [[package]] @@ -8839,18 +6056,6 @@ dependencies = [ "windows-sys 0.61.2", ] -[[package]] -name = "rustls" -version = "0.21.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f56a14d1f48b391359b22f731fd4bd7e43c97f3c50eee276f3aa09c94784d3e" -dependencies = [ - "log", - "ring 0.17.14", - "rustls-webpki 0.101.7", - "sct", -] - [[package]] name = "rustls" version = "0.23.37" @@ -8858,9 +6063,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "758025cb5fccfd3bc2fd74708fd4682be41d99e5dff73c377c0646c6012c73a4" dependencies = [ "once_cell", - "ring 0.17.14", + "ring", "rustls-pki-types", - "rustls-webpki 0.103.9", + "rustls-webpki", "subtle", "zeroize", ] @@ -8898,10 +6103,10 @@ dependencies = [ "jni 0.21.1", "log", "once_cell", - "rustls 0.23.37", + "rustls", "rustls-native-certs", "rustls-platform-verifier-android", - "rustls-webpki 0.103.9", + "rustls-webpki", "security-framework", "security-framework-sys", "webpki-root-certs", @@ -8914,25 +6119,15 @@ version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f87165f0995f63a9fbeea62b64d10b4d9d8e78ec6d7d51fb2125fda7bb36788f" -[[package]] -name = "rustls-webpki" -version = "0.101.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8b6275d1ee7a1cd780b64aca7726599a1dbc893b1e64144529e55c3c2f745765" -dependencies = [ - "ring 0.17.14", - "untrusted 0.9.0", -] - [[package]] name = "rustls-webpki" version = "0.103.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d7df23109aa6c1567d1c575b9952556388da57401e4ace1d15f79eedad0d8f53" dependencies = [ - "ring 0.17.14", + "ring", "rustls-pki-types", - "untrusted 0.9.0", + "untrusted", ] [[package]] @@ -8941,24 +6136,13 @@ version = "1.0.22" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b39cdef0fa800fc44525c84ccb54a029961a8215f9619753635a9c0d2538d46d" -[[package]] -name = "ruzstd" -version = "0.5.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "58c4eb8a81997cf040a091d1f7e1938aeab6749d3a0dfa73af43cdc32393483d" -dependencies = [ - "byteorder", - "derive_more 0.99.20", - "twox-hash 1.6.3", -] - [[package]] name = "ruzstd" version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e5ff0cc5e135c8870a775d3320910cd9b564ec036b4dc0b8741629020be63f01" dependencies = [ - "twox-hash 2.1.2", + "twox-hash", ] [[package]] @@ -8982,100 +6166,35 @@ name = "safetensors" version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "675656c1eabb620b921efea4f9199f97fc86e36dd6ffd1fbbe48d0f59a4987f5" -dependencies = [ - "hashbrown 0.16.1", - "serde", - "serde_json", -] - -[[package]] -name = "salsa20" -version = "0.7.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "399f290ffc409596022fce5ea5d4138184be4784f2b28c62c59f0d8389059a15" -dependencies = [ - "cipher 0.2.5", - "zeroize", -] - -[[package]] -name = "salsa20" -version = "0.10.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "97a22f5af31f73a954c10289c93e8a50cc23d971e80ee446f1f6f7137a088213" -dependencies = [ - "cipher 0.4.4", -] - -[[package]] -name = "same-file" -version = "1.0.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93fc1dc3aaa9bfed95e02e6eadabb4baf7e3078b0bd1b4d7b6b0b68378900502" -dependencies = [ - "winapi-util", -] - -[[package]] -name = "scc" -version = "2.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46e6f046b7fef48e2660c57ed794263155d713de679057f2d0c169bfc6e756cc" -dependencies = [ - "sdd", -] - -[[package]] -name = "schannel" -version = "0.1.28" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "891d81b926048e76efe18581bf793546b4c0eaf8448d72be8de2bbee5fd166e1" -dependencies = [ - "windows-sys 0.61.2", -] - -[[package]] -name = "scheduled-thread-pool" -version = "0.2.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3cbc66816425a074528352f5789333ecff06ca41b36b0b0efdfbb29edc391a19" -dependencies = [ - "parking_lot 0.12.5", -] - -[[package]] -name = "scoped-tls" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1cf6437eb19a8f4a6cc0f7dca544973b0b78843adbfeb3683d1a94a0024a294" - -[[package]] -name = "scopeguard" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" +dependencies = [ + "hashbrown 0.16.1", + "serde", + "serde_json", +] [[package]] -name = "sct" -version = "0.7.1" +name = "same-file" +version = "1.0.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da046153aa2352493d6cb7da4b6e5c0c057d8a1d0a9aa8560baffdd945acd414" +checksum = "93fc1dc3aaa9bfed95e02e6eadabb4baf7e3078b0bd1b4d7b6b0b68378900502" dependencies = [ - "ring 0.17.14", - "untrusted 0.9.0", + "winapi-util", ] [[package]] -name = "sd-notify" -version = "0.3.0" +name = "schannel" +version = "0.1.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0cd08a21f852bd2fe42e3b2a6c76a0db6a95a5b5bd29c0521dd0b30fa1712ec8" +checksum = "891d81b926048e76efe18581bf793546b4c0eaf8448d72be8de2bbee5fd166e1" +dependencies = [ + "windows-sys 0.61.2", +] [[package]] -name = "sdd" -version = "3.0.10" +name = "scopeguard" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "490dcfcbfef26be6800d11870ff2df8774fa6e86d047e3e8c8a76b25655e41ca" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "sdp" @@ -9086,7 +6205,7 @@ dependencies = [ "rand 0.9.2", "substring", "thiserror 1.0.69", - "url 2.5.8", + "url", ] [[package]] @@ -9167,15 +6286,6 @@ dependencies = [ "serde_derive", ] -[[package]] -name = "serde-transcode" -version = "1.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "590c0e25c2a5bb6e85bf5c1bce768ceb86b316e7a01bdf07d2cb4ec2271990e2" -dependencies = [ - "serde", -] - [[package]] name = "serde-wasm-bindgen" version = "0.6.5" @@ -9199,16 +6309,6 @@ dependencies = [ "xml", ] -[[package]] -name = "serde_bytes" -version = "0.11.19" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5d440709e79d88e51ac01c4b72fc6cb7314017bb7da9eeff678aa94c10e3ea8" -dependencies = [ - "serde", - "serde_core", -] - [[package]] name = "serde_core" version = "1.0.228" @@ -9235,7 +6335,6 @@ version = "1.0.149" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "83fc039473c5595ace860d8c4fafa220ff474b3fc6bfdb4293327f1a37e94d86" dependencies = [ - "indexmap 2.13.0", "itoa", "memchr", "serde", @@ -9275,54 +6374,13 @@ dependencies = [ "serde", ] -[[package]] -name = "serde_yml" -version = "0.0.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "59e2dd588bf1597a252c3b920e0143eb99b0f76e4e082f4c92ce34fbc9e71ddd" -dependencies = [ - "indexmap 2.13.0", - "itoa", - "libyml", - "memchr", - "ryu", - "serde", - "version_check", -] - -[[package]] -name = "serial_test" -version = "3.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "911bd979bf1070a3f3aa7b691a3b3e9968f339ceeec89e08c280a8a22207a32f" -dependencies = [ - "futures-executor", - "futures-util", - "log", - "once_cell", - "parking_lot 0.12.5", - "scc", - "serial_test_derive", -] - -[[package]] -name = "serial_test_derive" -version = "3.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0a7d91949b85b0d2fb687445e448b40d322b6b3e4af6b44a29b21d9a5f33e6d9" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.117", -] - [[package]] name = "sha1" version = "0.10.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e3bf829a2d51ab4a5ddf1352d8470c140cadc8301b2ae1789db023f01cedd6ba" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cpufeatures", "digest 0.10.7", ] @@ -9333,7 +6391,7 @@ version = "0.10.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a7507d819769d01a365ab707794a4084392c824f54a7a6a7862f8c3d0892b283" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cpufeatures", "digest 0.10.7", ] @@ -9344,7 +6402,7 @@ version = "0.11.0-rc.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7c5f3b1e2dc8aad28310d8410bd4d7e180eca65fca176c52ab00d364475d0024" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "cpufeatures", "digest 0.11.1", ] @@ -9384,30 +6442,6 @@ version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" -[[package]] -name = "shrinkwraprs" -version = "0.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e63e6744142336dfb606fe2b068afa2e1cca1ee6a5d8377277a92945d81fa331" -dependencies = [ - "bitflags 1.3.2", - "itertools 0.8.2", - "proc-macro2", - "quote", - "syn 1.0.109", -] - -[[package]] -name = "signal-hook" -version = "0.1.17" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7e31d442c16f047a671b5a71e2161d6e68814012b7f5379d269ebd915fac2729" -dependencies = [ - "libc", - "mio 0.7.14", - "signal-hook-registry", -] - [[package]] name = "signal-hook-registry" version = "1.4.8" @@ -9457,9 +6491,6 @@ name = "siphasher" version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b2aa850e253778c88a04c3d7323b043aeda9d3e30d5971937c1855769763678e" -dependencies = [ - "serde", -] [[package]] name = "slab" @@ -9483,30 +6514,6 @@ dependencies = [ "parking_lot 0.11.2", ] -[[package]] -name = "slice-group-by" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "826167069c09b99d56f31e9ae5c99049e932a98c9dc2dac47645b08dbbf76ba7" - -[[package]] -name = "smallstr" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e922794d168678729ffc7e07182721a14219c65814e66e91b839a272fe5ae4f" -dependencies = [ - "smallvec 1.15.1", -] - -[[package]] -name = "smallvec" -version = "0.6.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b97fcaeba89edba30f044a10c6a3cc39df9c3f17d7cd829dd1446cab35f890e0" -dependencies = [ - "maybe-uninit", -] - [[package]] name = "smallvec" version = "1.15.1" @@ -9571,17 +6578,6 @@ dependencies = [ "windows-sys 0.60.2", ] -[[package]] -name = "socket2" -version = "0.3.19" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "122e570113d28d773067fab24266b66753f6ea915758651696b6e35e49f88d6e" -dependencies = [ - "cfg-if 1.0.4", - "libc", - "winapi", -] - [[package]] name = "socket2" version = "0.5.10" @@ -9602,21 +6598,6 @@ dependencies = [ "windows-sys 0.61.2", ] -[[package]] -name = "sodoken" -version = "0.0.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "55a56bf1094466dc909027680d3974e4a73c1fe5aa7fa116a43c71c37decb699" -dependencies = [ - "libc", - "libsodium-sys-stable", - "num_cpus", - "once_cell", - "one_err", - "parking_lot 0.11.2", - "tokio", -] - [[package]] name = "spargebra" version = "0.4.5" @@ -9631,12 +6612,6 @@ dependencies = [ "thiserror 2.0.18", ] -[[package]] -name = "spin" -version = "0.5.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e63cff320ae2c57904679ba7cb63280a3dc4613885beafb148ee7bf9aa9042d" - [[package]] name = "spin" version = "0.9.8" @@ -9674,65 +6649,12 @@ version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d7beae5182595e9a8b683fa98c4317f956c9a2dec3b9716990d20023cc60c766" -[[package]] -name = "str_stack" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9091b6114800a5f2141aee1d1b9d6ca3592ac062dc5decb3764ec5895a47b4eb" - -[[package]] -name = "stream-cancel" -version = "0.8.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f9fbf9bd71e4cf18d68a8a0951c0e5b7255920c0cd992c4ff51cddd6ef514a3" -dependencies = [ - "futures-core", - "pin-project", - "tokio", -] - -[[package]] -name = "strsim" -version = "0.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ea5119cdb4c55b55d432abb513a0429384878c15dde60cc77b1c99de1a95a6a" - -[[package]] -name = "strsim" -version = "0.9.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6446ced80d6c486436db5c078dde11a9f73d42b57fb273121e160b84f63d894c" - [[package]] name = "strsim" version = "0.11.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f" -[[package]] -name = "structopt" -version = "0.3.26" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c6b5c64445ba8094a6ab0c3cd2ad323e07171012d9c98b0b15651daf1787a10" -dependencies = [ - "clap 2.34.0", - "lazy_static", - "structopt-derive", -] - -[[package]] -name = "structopt-derive" -version = "0.4.18" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcb5ae327f9cc13b68763b5749770cb9e048a99bd9dfdfa58d0cf05d5f64afe0" -dependencies = [ - "heck 0.3.3", - "proc-macro-error", - "proc-macro2", - "quote", - "syn 1.0.109", -] - [[package]] name = "strum" version = "0.24.1" @@ -9751,12 +6673,6 @@ dependencies = [ "strum_macros 0.25.3", ] -[[package]] -name = "strum" -version = "0.26.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8fec0f0aef304996cf250b31b5a10dee7980c85da9d759361292b8bca5a18f06" - [[package]] name = "strum" version = "0.27.2" @@ -9792,19 +6708,6 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "strum_macros" -version = "0.26.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c6bee85a5a24955dc440386795aa378cd9cf82acd5f764469152d2270e581be" -dependencies = [ - "heck 0.5.0", - "proc-macro2", - "quote", - "rustversion", - "syn 2.0.117", -] - [[package]] name = "strum_macros" version = "0.27.2" @@ -9823,16 +6726,16 @@ version = "0.17.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2e0fd33c04d4617df42c9c84c698511c59f59869629fb7a193067eec41bce347" dependencies = [ - "base64 0.22.1", + "base64", "crc", "lazy_static", "md-5", "rand 0.9.2", - "ring 0.17.14", + "ring", "subtle", "thiserror 1.0.69", "tokio", - "url 2.5.8", + "url", "webrtc-util", ] @@ -9842,7 +6745,7 @@ version = "1.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "42ee6433ecef213b2e72f587ef64a2f5943e7cd16fbd82dbe8bc07486c534c86" dependencies = [ - "autocfg 1.5.0", + "autocfg", ] [[package]] @@ -9888,18 +6791,6 @@ dependencies = [ "futures-core", ] -[[package]] -name = "synstructure" -version = "0.12.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f36bdaa60a83aca3921b5259d5400cbf5e90fc51931376a9bd4a0eb79aa7210f" -dependencies = [ - "proc-macro2", - "quote", - "syn 1.0.109", - "unicode-xid", -] - [[package]] name = "synstructure" version = "0.13.2" @@ -9939,34 +6830,6 @@ dependencies = [ "walkdir", ] -[[package]] -name = "sysinfo" -version = "0.37.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "16607d5caffd1c07ce073528f9ed972d88db15dd44023fa57142963be3feb11f" -dependencies = [ - "libc", - "memchr", - "ntapi 0.4.3", - "objc2-core-foundation", - "objc2-io-kit", - "windows 0.61.3", -] - -[[package]] -name = "sysinfo" -version = "0.38.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fe840c5b1afe259a5657392a4dbb74473a14c8db999c3ec2f4ae812e028a94da" -dependencies = [ - "libc", - "memchr", - "ntapi 0.4.3", - "objc2-core-foundation", - "objc2-io-kit", - "windows 0.62.2", -] - [[package]] name = "system-configuration" version = "0.7.0" @@ -9999,12 +6862,6 @@ dependencies = [ "xattr", ] -[[package]] -name = "target-lexicon" -version = "0.12.16" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1" - [[package]] name = "target-lexicon" version = "0.13.5" @@ -10012,87 +6869,16 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "adb6935a6f5c20170eeceb1a3835a49e12e19d792f6dd344ccc76a985ca5a6ca" [[package]] -name = "tempdir" -version = "0.3.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "15f2b5fb00ccdf689e0149d1b1b3c03fead81c2b37735d812fa8bddbbf41b6d8" -dependencies = [ - "rand 0.4.6", - "remove_dir_all 0.5.3", -] - -[[package]] -name = "tempfile" -version = "3.26.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "82a72c767771b47409d2345987fda8628641887d5466101319899796367354a0" -dependencies = [ - "fastrand", - "getrandom 0.4.2", - "once_cell", - "rustix 1.1.4", - "windows-sys 0.61.2", -] - -[[package]] -name = "terminfo" -version = "0.8.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "666cd3a6681775d22b200409aad3b089c5b99fb11ecdd8a204d9d62f8148498f" -dependencies = [ - "dirs 4.0.0", - "fnv", - "nom", - "phf", - "phf_codegen", -] - -[[package]] -name = "termtree" -version = "0.5.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f50febec83f5ee1df3015341d8bd429f2d1cc62bcba7ea2076759d315084683" - -[[package]] -name = "test-case" -version = "3.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eb2550dd13afcd286853192af8601920d959b14c401fcece38071d53bf0768a8" -dependencies = [ - "test-case-macros", -] - -[[package]] -name = "test-case-core" -version = "3.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adcb7fd841cd518e279be3d5a3eb0636409487998a4aff22f3de87b81e88384f" -dependencies = [ - "cfg-if 1.0.4", - "proc-macro2", - "quote", - "syn 2.0.117", -] - -[[package]] -name = "test-case-macros" -version = "3.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5c89e72a01ed4c579669add59014b9a524d609c0c88c6a585ce37485879f6ffb" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.117", - "test-case-core", -] - -[[package]] -name = "textwrap" -version = "0.11.0" +name = "tempfile" +version = "3.26.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d326610f408c7a4eb6f51c37c330e496b08506c9457c9d34287ecc38809fb060" +checksum = "82a72c767771b47409d2345987fda8628641887d5466101319899796367354a0" dependencies = [ - "unicode-width 0.1.14", + "fastrand", + "getrandom 0.4.2", + "once_cell", + "rustix 1.1.4", + "windows-sys 0.61.2", ] [[package]] @@ -10141,7 +6927,7 @@ version = "1.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f60246a4944f24f6e018aa17cdeffb7818b76356965d03b07d6a9886e8962185" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", ] [[package]] @@ -10224,7 +7010,7 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "titans_memory" -version = "0.3.6" +version = "0.3.7" dependencies = [ "blake3", "chrono", @@ -10243,7 +7029,7 @@ checksum = "27ad5e34374e03cfffefc301becb44e9dc3c17584f414349ebe29ed26661822d" dependencies = [ "bytes", "libc", - "mio 1.1.1", + "mio", "parking_lot 0.12.5", "pin-project-lite", "signal-hook-registry", @@ -10273,23 +7059,13 @@ dependencies = [ "tokio", ] -[[package]] -name = "tokio-rustls" -version = "0.24.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c28327cf380ac148141087fbfb9de9d7bd4e84ab5d2c28fbc911d753de8a7081" -dependencies = [ - "rustls 0.21.12", - "tokio", -] - [[package]] name = "tokio-rustls" version = "0.26.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1729aa945f29d91ba541258c8df89027d5792d85a8841fb65e8bf0f4ede4ef61" dependencies = [ - "rustls 0.23.37", + "rustls", "tokio", ] @@ -10316,49 +7092,6 @@ dependencies = [ "tokio-stream", ] -[[package]] -name = "tokio-tungstenite" -version = "0.20.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "212d5dcb2a1ce06d81107c3d0ffa3121fe974b73f068c8282cb1c32328113b6c" -dependencies = [ - "futures-util", - "log", - "rustls 0.21.12", - "tokio", - "tokio-rustls 0.24.1", - "tungstenite 0.20.1", - "webpki-roots 0.25.4", -] - -[[package]] -name = "tokio-tungstenite" -version = "0.21.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c83b561d025642014097b66e6c1bb422783339e0909e4429cde4749d1990bc38" -dependencies = [ - "futures-util", - "log", - "tokio", - "tungstenite 0.21.0", -] - -[[package]] -name = "tokio-tungstenite" -version = "0.24.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "edc5f74e248dc973e0dbb7b74c7e0d6fcc301c694ff50049504004ef4d0cdcd9" -dependencies = [ - "futures-util", - "log", - "rustls 0.23.37", - "rustls-pki-types", - "tokio", - "tokio-rustls 0.26.4", - "tungstenite 0.24.0", - "webpki-roots 0.26.11", -] - [[package]] name = "tokio-tungstenite" version = "0.28.0" @@ -10385,22 +7118,13 @@ dependencies = [ "tokio", ] -[[package]] -name = "toml" -version = "0.5.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f4f7f0dd8d50a853a531c426359045b1998f04219d88799810762cd4ad314234" -dependencies = [ - "serde", -] - [[package]] name = "toml" version = "0.9.12+spec-1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cf92845e79fc2e2def6a5d828f0801e29a2f8acc037becc5ab08595c7d5e9863" dependencies = [ - "indexmap 2.13.0", + "indexmap", "serde_core", "serde_spanned", "toml_datetime 0.7.5+spec-1.1.0", @@ -10433,7 +7157,7 @@ version = "0.25.4+spec-1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7193cbd0ce53dc966037f54351dbbcf0d5a642c7f0038c382ef9e677ce8c13f2" dependencies = [ - "indexmap 2.13.0", + "indexmap", "toml_datetime 1.0.0+spec-1.1.0", "toml_parser", "winnow", @@ -10481,15 +7205,15 @@ dependencies = [ "bytes", "futures-core", "futures-util", - "http 1.4.0", - "http-body 1.0.1", + "http", + "http-body", "http-body-util", "http-range-header", "httpdate", "iri-string", "mime", "mime_guess", - "percent-encoding 2.3.2", + "percent-encoding", "pin-project-lite", "tokio", "tokio-util", @@ -10544,16 +7268,6 @@ dependencies = [ "valuable", ] -[[package]] -name = "tracing-futures" -version = "0.2.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "97d095ae15e245a057c8e8451bab9b3ee1e1f68e9ba2b4fbc18d0ac5237835f2" -dependencies = [ - "pin-project", - "tracing", -] - [[package]] name = "tracing-log" version = "0.2.0" @@ -10565,26 +7279,6 @@ dependencies = [ "tracing-core", ] -[[package]] -name = "tracing-serde" -version = "0.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bc6b213177105856957181934e4920de57730fc69bf42c37ee5bb664d406d9e1" -dependencies = [ - "serde", - "tracing-core", -] - -[[package]] -name = "tracing-serde" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "704b1aeb7be0d0a84fc9828cae51dab5970fee5088f83d1dd7ee6f6246fc6ff1" -dependencies = [ - "serde", - "tracing-core", -] - [[package]] name = "tracing-subscriber" version = "0.3.22" @@ -10595,15 +7289,12 @@ dependencies = [ "nu-ansi-term", "once_cell", "regex-automata", - "serde", - "serde_json", "sharded-slab", - "smallvec 1.15.1", + "smallvec", "thread_local", "tracing", "tracing-core", "tracing-log", - "tracing-serde 0.2.0", ] [[package]] @@ -10612,45 +7303,6 @@ version = "0.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" -[[package]] -name = "tungstenite" -version = "0.20.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9e3dac10fd62eaf6617d3a904ae222845979aec67c615d1c842b4002c7666fb9" -dependencies = [ - "byteorder", - "bytes", - "data-encoding", - "http 0.2.12", - "httparse", - "log", - "rand 0.8.5", - "rustls 0.21.12", - "sha1", - "thiserror 1.0.69", - "url 2.5.8", - "utf-8", -] - -[[package]] -name = "tungstenite" -version = "0.21.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ef1a641ea34f399a848dea702823bbecfb4c486f911735368f1f137cb8257e1" -dependencies = [ - "byteorder", - "bytes", - "data-encoding", - "http 1.4.0", - "httparse", - "log", - "rand 0.8.5", - "sha1", - "thiserror 1.0.69", - "url 2.5.8", - "utf-8", -] - [[package]] name = "tungstenite" version = "0.23.0" @@ -10660,30 +7312,10 @@ dependencies = [ "byteorder", "bytes", "data-encoding", - "http 1.4.0", - "httparse", - "log", - "rand 0.8.5", - "sha1", - "thiserror 1.0.69", - "utf-8", -] - -[[package]] -name = "tungstenite" -version = "0.24.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "18e5b8366ee7a95b16d32197d0b2604b43a0be89dc5fac9f8e96ccafbaedda8a" -dependencies = [ - "byteorder", - "bytes", - "data-encoding", - "http 1.4.0", + "http", "httparse", "log", "rand 0.8.5", - "rustls 0.23.37", - "rustls-pki-types", "sha1", "thiserror 1.0.69", "utf-8", @@ -10697,7 +7329,7 @@ checksum = "8628dcc84e5a09eb3d8423d6cb682965dea9133204e8fb3efee74c2a0c259442" dependencies = [ "bytes", "data-encoding", - "http 1.4.0", + "http", "httparse", "log", "rand 0.9.2", @@ -10713,13 +7345,13 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b6a8b8ac3543b2a8eb0b28c7ac3d5f2db6221e057f3b3ae47cf7637b1333a5c3" dependencies = [ "async-trait", - "base64 0.22.1", + "base64", "futures", "log", "md-5", "portable-atomic", "rand 0.9.2", - "ring 0.17.14", + "ring", "stun", "thiserror 1.0.69", "tokio", @@ -10727,16 +7359,6 @@ dependencies = [ "webrtc-util", ] -[[package]] -name = "twox-hash" -version = "1.6.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "97fee6b57c6a41524a810daee9286c02d7752c4253064d0b05472833a438f675" -dependencies = [ - "cfg-if 1.0.4", - "static_assertions", -] - [[package]] name = "twox-hash" version = "2.1.2" @@ -10776,61 +7398,24 @@ version = "2.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dbc4bc3a9f746d862c45cb89d705aa10f187bb96c76001afab07a0d35ce60142" -[[package]] -name = "unicode-bidi" -version = "0.3.18" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5c1cb5db39152898a79168971543b1cb5020dff7fe43c8dc468b0885f5e29df5" - [[package]] name = "unicode-ident" version = "1.0.24" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e6e4313cd5fcd3dad5cafa179702e2b244f760991f45397d14d4ebf38247da75" -[[package]] -name = "unicode-normalization" -version = "0.1.25" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5fd4f6878c9cb28d874b009da9e8d183b5abc80117c40bbd187a1fde336be6e8" -dependencies = [ - "tinyvec", -] - [[package]] name = "unicode-segmentation" version = "1.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f6ccf251212114b54433ec949fd6a7841275f9ada20dddd2f29e9ceea4501493" -[[package]] -name = "unicode-width" -version = "0.1.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7dd6e30e90baa6f72411720665d41d89b9a3d039dc45b8faea1ddd07f617f6af" - -[[package]] -name = "unicode-width" -version = "0.2.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b4ac048d71ede7ee76d585517add45da530660ef4390e49b098733c6e897f254" - [[package]] name = "unicode-xid" version = "0.2.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ebc1c04c71510c7f702b52b7c350734c9ff1295c464a03335b00bb84fc54f853" -[[package]] -name = "universal-hash" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8326b2c654932e3e4f9196e69d08fdf7cfd718e1dc6f66b347e6024a0c961402" -dependencies = [ - "generic-array", - "subtle", -] - [[package]] name = "universal-hash" version = "0.5.1" @@ -10841,12 +7426,6 @@ dependencies = [ "subtle", ] -[[package]] -name = "untrusted" -version = "0.7.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" - [[package]] name = "untrusted" version = "0.9.0" @@ -10859,48 +7438,6 @@ version = "0.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6d49784317cd0d1ee7ec5c716dd598ec5b4483ea832a2dced265471cc0f690ae" -[[package]] -name = "unwrap_to" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cad414b2eed757c1b6f810f8abc814e298a9c89176b21fae092c7a87756fb839" - -[[package]] -name = "ureq" -version = "3.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fdc97a28575b85cfedf2a7e7d3cc64b3e11bd8ac766666318003abbacc7a21fc" -dependencies = [ - "base64 0.22.1", - "log", - "percent-encoding 2.3.2", - "ureq-proto", - "utf-8", -] - -[[package]] -name = "ureq-proto" -version = "0.5.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d81f9efa9df032be5934a46a068815a10a042b494b6a58cb0a1a97bb5467ed6f" -dependencies = [ - "base64 0.22.1", - "http 1.4.0", - "httparse", - "log", -] - -[[package]] -name = "url" -version = "1.7.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dd4e7c0d531266369519a4aa4f399d748bd37043b00bde1e4ff1f60a120b355a" -dependencies = [ - "idna 0.1.5", - "matches", - "percent-encoding 1.0.1", -] - [[package]] name = "url" version = "2.5.8" @@ -10908,30 +7445,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ff67a8a4397373c3ef660812acab3268222035010ab8680ec4215f38ba3d0eed" dependencies = [ "form_urlencoded", - "idna 1.1.0", - "percent-encoding 2.3.2", - "serde", - "serde_derive", -] - -[[package]] -name = "url2" -version = "0.0.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c89cd13f1de9862d363308f5ffdadcd2b64b2a4a812fb296a80b7d3e80011b1e" -dependencies = [ - "serde", - "url 2.5.8", -] - -[[package]] -name = "url_serde" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "74e7d099f1ee52f823d4bdd60c93c3602043c728f5db3b97bdb548467f7bddea" -dependencies = [ + "idna", + "percent-encoding", "serde", - "url 1.7.2", ] [[package]] @@ -10970,13 +7486,13 @@ version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "43fb22e1a008ece370ce08a3e9e4447a910e92621bb49b85d6e48a45397e7cfa" dependencies = [ - "idna 1.1.0", + "idna", "once_cell", "regex", "serde", "serde_derive", "serde_json", - "url 2.5.8", + "url", "validator_derive", ] @@ -11012,12 +7528,6 @@ version = "0.2.15" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" -[[package]] -name = "vec_map" -version = "0.8.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1bddf1187be692e79c5ffeab891132dfb0f236ed36a43c7ed39f1165ee20191" - [[package]] name = "version_check" version = "0.9.5" @@ -11036,77 +7546,33 @@ version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6a02e4885ed3bc0f2de90ea6dd45ebcbb66dacffe03547fadbb0eeae2770887d" -[[package]] -name = "wait-timeout" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09ac3b126d3914f9849036f826e054cbabdc8519970b8998ddaf3b5bd3c65f11" -dependencies = [ - "libc", -] - [[package]] name = "waitgroup" version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d1f50000a783467e6c0200f9d10642f4bc424e39efc1b770203e88b488f79292" -dependencies = [ - "atomic-waker", -] - -[[package]] -name = "walkdir" -version = "2.5.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" -dependencies = [ - "same-file", - "winapi-util", -] - -[[package]] -name = "want" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" -dependencies = [ - "try-lock", -] - -[[package]] -name = "warp" -version = "0.3.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4378d202ff965b011c64817db11d5829506d3404edeadb61f190d111da3f231c" -dependencies = [ - "bytes", - "futures-channel", - "futures-util", - "headers", - "http 0.2.12", - "hyper 0.14.32", - "log", - "mime", - "mime_guess", - "multer 2.1.0", - "percent-encoding 2.3.2", - "pin-project", - "scoped-tls", - "serde", - "serde_json", - "serde_urlencoded", - "tokio", - "tokio-tungstenite 0.21.0", - "tokio-util", - "tower-service", - "tracing", +checksum = "d1f50000a783467e6c0200f9d10642f4bc424e39efc1b770203e88b488f79292" +dependencies = [ + "atomic-waker", ] [[package]] -name = "wasi" -version = "0.9.0+wasi-snapshot-preview1" +name = "walkdir" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" +dependencies = [ + "same-file", + "winapi-util", +] + +[[package]] +name = "want" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cccddf32554fecc6acb585f82a32a72e28b48f8c4c1883ddfeeeaa96f7d8e519" +checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" +dependencies = [ + "try-lock", +] [[package]] name = "wasi" @@ -11138,7 +7604,7 @@ version = "0.2.114" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6532f9a5c1ece3798cb1c2cfdba640b9b3ba884f5db45973a6f442510a87d38e" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "once_cell", "rustversion", "wasm-bindgen-macro", @@ -11151,7 +7617,7 @@ version = "0.4.64" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e9c5522b3a28661442748e09d40924dfb9ca614b21c00d3fd135720e48b67db8" dependencies = [ - "cfg-if 1.0.4", + "cfg-if", "futures-util", "js-sys", "once_cell", @@ -11198,17 +7664,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "990065f2fe63003fe337b932cfb5e3b80e0b4d0f5ff650e6985b1048f62c8319" dependencies = [ "leb128fmt", - "wasmparser 0.244.0", -] - -[[package]] -name = "wasm-encoder" -version = "0.245.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f9dca005e69bf015e45577e415b9af8c67e8ee3c0e38b5b0add5aa92581ed5c" -dependencies = [ - "leb128fmt", - "wasmparser 0.245.1", + "wasmparser", ] [[package]] @@ -11218,42 +7674,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bb0e353e6a2fbdc176932bbaab493762eb1255a7900fe0fea1a2f96c296cc909" dependencies = [ "anyhow", - "indexmap 2.13.0", - "wasm-encoder 0.244.0", - "wasmparser 0.244.0", -] - -[[package]] -name = "wasmer" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2d85671948f8886a1cc946141c0b688a5617603c103699a5fceeebeb4e75b0b6" -dependencies = [ - "bindgen 0.70.1", - "bytes", - "cfg-if 1.0.4", - "cmake", - "derive_more 2.1.1", - "indexmap 2.13.0", - "js-sys", - "more-asserts 0.2.2", - "paste", - "rustc-demangle", - "serde", - "serde-wasm-bindgen", - "shared-buffer", - "tar", - "target-lexicon 0.12.16", - "thiserror 1.0.69", - "tracing", - "wasm-bindgen", - "wasmer-compiler 6.1.0", - "wasmer-compiler-cranelift 6.1.0", - "wasmer-derive 6.1.0", - "wasmer-types 6.1.0", - "wasmer-vm 6.1.0", - "wasmparser 0.224.1", - "windows-sys 0.59.0", + "indexmap", + "wasm-encoder", + "wasmparser", ] [[package]] @@ -11264,63 +7687,30 @@ checksum = "b76134972161fb9ae6d956d3e79177a51c6c968d4f95fdba060a95897b2fe81c" dependencies = [ "bindgen 0.72.1", "bytes", - "cfg-if 1.0.4", + "cfg-if", "cmake", - "derive_more 2.1.1", - "indexmap 2.13.0", + "derive_more", + "indexmap", "js-sys", - "more-asserts 0.3.1", + "more-asserts", "paste", "rustc-demangle", "serde", "serde-wasm-bindgen", "shared-buffer", "tar", - "target-lexicon 0.13.5", + "target-lexicon", "thiserror 2.0.18", "tracing", "wasm-bindgen", - "wasmer-compiler 7.0.1", - "wasmer-compiler-cranelift 7.0.1", - "wasmer-derive 7.0.1", - "wasmer-types 7.0.1", - "wasmer-vm 7.0.1", - "wasmparser 0.244.0", - "wat", + "wasmer-compiler", + "wasmer-compiler-cranelift", + "wasmer-derive", + "wasmer-types", + "wasmer-vm", "windows-sys 0.61.2", ] -[[package]] -name = "wasmer-compiler" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4946475adc0af265af8f10aadf4d4a3c64845bcd3801c655bdd81ce5e3ee869b" -dependencies = [ - "backtrace", - "bytes", - "cfg-if 1.0.4", - "enum-iterator 0.7.0", - "enumset", - "leb128", - "libc", - "macho-unwind-info", - "memmap2 0.6.2", - "more-asserts 0.2.2", - "object 0.32.2", - "region", - "rkyv", - "self_cell", - "shared-buffer", - "smallvec 1.15.1", - "target-lexicon 0.12.16", - "thiserror 1.0.69", - "wasmer-types 6.1.0", - "wasmer-vm 6.1.0", - "wasmparser 0.224.1", - "windows-sys 0.59.0", - "xxhash-rust", -] - [[package]] name = "wasmer-compiler" version = "7.0.1" @@ -11329,84 +7719,52 @@ checksum = "c21c166e89212d5bc31d08dffdb189fe689f4ca58756ccd924f9fc3ec2ee89da" dependencies = [ "backtrace", "bytes", - "cfg-if 1.0.4", - "enum-iterator 2.3.0", + "cfg-if", + "enum-iterator", "enumset", "itertools 0.14.0", "leb128", "libc", "macho-unwind-info", "memmap2 0.9.10", - "more-asserts 0.3.1", + "more-asserts", "object 0.38.1", "rangemap", "region", "rkyv", "self_cell", "shared-buffer", - "smallvec 1.15.1", - "target-lexicon 0.13.5", + "smallvec", + "target-lexicon", "tempfile", "thiserror 2.0.18", - "wasmer-types 7.0.1", - "wasmer-vm 7.0.1", - "wasmparser 0.244.0", + "wasmer-types", + "wasmer-vm", + "wasmparser", "which 8.0.1", "windows-sys 0.61.2", ] -[[package]] -name = "wasmer-compiler-cranelift" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "780f9c2050941b4e3f6bb82d32bd796a6c1750d2f97cbd892f07b384bb6af6f8" -dependencies = [ - "cranelift-codegen 0.110.2", - "cranelift-entity 0.110.2", - "cranelift-frontend 0.110.2", - "gimli 0.28.1", - "itertools 0.12.1", - "more-asserts 0.2.2", - "rayon", - "smallvec 1.15.1", - "target-lexicon 0.12.16", - "tracing", - "wasmer-compiler 6.1.0", - "wasmer-types 6.1.0", -] - [[package]] name = "wasmer-compiler-cranelift" version = "7.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2a3174d3c78dd581d590860195420305581e2708cb1082ce8bea05cf6ed0e432" dependencies = [ - "cranelift-codegen 0.128.0", - "cranelift-entity 0.128.0", - "cranelift-frontend 0.128.0", - "gimli 0.32.3", - "indexmap 2.13.0", + "cranelift-codegen", + "cranelift-entity", + "cranelift-frontend", + "gimli", + "indexmap", "itertools 0.14.0", "leb128", - "more-asserts 0.3.1", + "more-asserts", "rayon", - "smallvec 1.15.1", - "target-lexicon 0.13.5", + "smallvec", + "target-lexicon", "tracing", - "wasmer-compiler 7.0.1", - "wasmer-types 7.0.1", -] - -[[package]] -name = "wasmer-derive" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c546f3380840cd63fdcc390f04cd19002f2dfa19b4691b77ecbd27642bd93452" -dependencies = [ - "proc-macro-error2", - "proc-macro2", - "quote", - "syn 1.0.109", + "wasmer-compiler", + "wasmer-types", ] [[package]] @@ -11421,84 +7779,25 @@ dependencies = [ "syn 2.0.117", ] -[[package]] -name = "wasmer-middlewares" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f4fdc1455c09a2b8e3aae9df8e163430d87353a2b467a3c48ceeb3e3bbeeed69" -dependencies = [ - "wasmer 6.1.0", - "wasmer-types 6.1.0", - "wasmer-vm 6.1.0", -] - -[[package]] -name = "wasmer-types" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94a4027ce165e8dc776dc5e2a3231a96983e6dc7330efd97b793cfc4e973ad0c" -dependencies = [ - "bytecheck 0.6.12", - "enum-iterator 0.7.0", - "enumset", - "getrandom 0.2.17", - "hex", - "indexmap 2.13.0", - "more-asserts 0.2.2", - "rkyv", - "sha2 0.10.9", - "target-lexicon 0.12.16", - "thiserror 1.0.69", - "xxhash-rust", -] - [[package]] name = "wasmer-types" version = "7.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9a7f91b0cb63705afa0843b46a0aeaeaedff7be2e5b05691176e9e58e2dbe921" dependencies = [ - "bytecheck 0.8.2", - "enum-iterator 2.3.0", + "bytecheck", + "enum-iterator", "enumset", "getrandom 0.2.17", "hex", - "indexmap 2.13.0", - "more-asserts 0.3.1", + "indexmap", + "more-asserts", "rkyv", "sha2 0.11.0-rc.5", - "target-lexicon 0.13.5", + "target-lexicon", "thiserror 2.0.18", ] -[[package]] -name = "wasmer-vm" -version = "6.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c37d5be291eea00a00d077ce3a427bb3074709ee386ec358f18f0b7da33be01" -dependencies = [ - "backtrace", - "cc", - "cfg-if 1.0.4", - "corosensei", - "crossbeam-queue", - "dashmap 6.1.0", - "enum-iterator 0.7.0", - "fnv", - "indexmap 2.13.0", - "libc", - "libunwind", - "mach2 0.4.3", - "memoffset 0.9.1", - "more-asserts 0.2.2", - "region", - "rustversion", - "scopeguard", - "thiserror 1.0.69", - "wasmer-types 6.1.0", - "windows-sys 0.59.0", -] - [[package]] name = "wasmer-vm" version = "7.0.1" @@ -11507,37 +7806,28 @@ checksum = "12da92bb2c2abd09628d28d112970880a9e671b7ccb55172e5f6db01b5d6add4" dependencies = [ "backtrace", "cc", - "cfg-if 1.0.4", + "cfg-if", "corosensei", "crossbeam-queue", "dashmap 6.1.0", - "enum-iterator 2.3.0", + "enum-iterator", "fnv", - "gimli 0.32.3", - "indexmap 2.13.0", + "gimli", + "indexmap", "libc", "libunwind", "mach2 0.6.0", "memoffset 0.9.1", - "more-asserts 0.3.1", + "more-asserts", "parking_lot 0.12.5", "region", "rustversion", "scopeguard", "thiserror 2.0.18", - "wasmer-types 7.0.1", + "wasmer-types", "windows-sys 0.61.2", ] -[[package]] -name = "wasmparser" -version = "0.224.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "04f17a5917c2ddd3819e84c661fae0d6ba29d7b9c1f0e96c708c65a9c4188e11" -dependencies = [ - "bitflags 2.11.0", -] - [[package]] name = "wasmparser" version = "0.244.0" @@ -11546,18 +7836,7 @@ checksum = "47b807c72e1bac69382b3a6fb3dbe8ea4c0ed87ff5629b8685ae6b9a611028fe" dependencies = [ "bitflags 2.11.0", "hashbrown 0.15.5", - "indexmap 2.13.0", - "semver", -] - -[[package]] -name = "wasmparser" -version = "0.245.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f08c9adee0428b7bddf3890fc27e015ac4b761cc608c822667102b8bfd6995e" -dependencies = [ - "bitflags 2.11.0", - "indexmap 2.13.0", + "indexmap", "semver", ] @@ -11570,28 +7849,6 @@ dependencies = [ "libm", ] -[[package]] -name = "wast" -version = "245.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "28cf1149285569120b8ce39db8b465e8a2b55c34cbb586bd977e43e2bc7300bf" -dependencies = [ - "bumpalo", - "leb128fmt", - "memchr", - "unicode-width 0.2.2", - "wasm-encoder 0.245.1", -] - -[[package]] -name = "wat" -version = "1.245.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cd48d1679b6858988cb96b154dda0ec5bbb09275b71db46057be37332d5477be" -dependencies = [ - "wast", -] - [[package]] name = "web-sys" version = "0.3.91" @@ -11621,21 +7878,6 @@ dependencies = [ "rustls-pki-types", ] -[[package]] -name = "webpki-roots" -version = "0.25.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f20c57d8d7db6d3b86154206ae5d8fba62dd39573114de97c2cb0578251f8e1" - -[[package]] -name = "webpki-roots" -version = "0.26.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "521bc38abb08001b01866da9f51eb7c5d647a19260e00054a8c7fd5f9e57f7a9" -dependencies = [ - "webpki-roots 1.0.6", -] - [[package]] name = "webpki-roots" version = "1.0.6" @@ -11661,9 +7903,9 @@ dependencies = [ "log", "portable-atomic", "rand 0.9.2", - "rcgen 0.13.2", + "rcgen", "regex", - "ring 0.17.14", + "ring", "rtcp", "rtp", "sdp", @@ -11676,7 +7918,7 @@ dependencies = [ "tokio", "turn", "unicase", - "url 2.5.8", + "url", "waitgroup", "webrtc-data", "webrtc-ice", @@ -11720,7 +7962,7 @@ dependencies = [ "thiserror 1.0.69", "tokio", "turn", - "url 2.5.8", + "url", "uuid", "waitgroup", "webrtc-mdns", @@ -11777,7 +8019,7 @@ version = "0.17.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9e437f74b04f42049192e25cbb33c21c86be308875e6afe14cf8e28d1ffa35ac" dependencies = [ - "aead 0.5.2", + "aead", "aes", "aes-gcm", "byteorder", @@ -11874,23 +8116,11 @@ version = "0.61.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9babd3a767a4c1aef6900409f85f5d53ce2544ccdfaa86dad48c91782c6d6893" dependencies = [ - "windows-collections 0.2.0", + "windows-collections", "windows-core 0.61.2", - "windows-future 0.2.1", + "windows-future", "windows-link 0.1.3", - "windows-numerics 0.2.0", -] - -[[package]] -name = "windows" -version = "0.62.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "527fadee13e0c05939a6a05d5bd6eec6cd2e3dbd648b9f8e447c6518133d8580" -dependencies = [ - "windows-collections 0.3.2", - "windows-core 0.62.2", - "windows-future 0.3.2", - "windows-numerics 0.3.1", + "windows-numerics", ] [[package]] @@ -11902,15 +8132,6 @@ dependencies = [ "windows-core 0.61.2", ] -[[package]] -name = "windows-collections" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23b2d95af1a8a14a3c7367e1ed4fc9c20e0a26e79551b1454d72583c97cc6610" -dependencies = [ - "windows-core 0.62.2", -] - [[package]] name = "windows-core" version = "0.61.2" @@ -11945,18 +8166,7 @@ checksum = "fc6a41e98427b19fe4b73c550f060b59fa592d7d686537eebf9385621bfbad8e" dependencies = [ "windows-core 0.61.2", "windows-link 0.1.3", - "windows-threading 0.1.0", -] - -[[package]] -name = "windows-future" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1d6f90251fe18a279739e78025bd6ddc52a7e22f921070ccdc67dde84c605cb" -dependencies = [ - "windows-core 0.62.2", - "windows-link 0.2.1", - "windows-threading 0.2.1", + "windows-threading", ] [[package]] @@ -12003,16 +8213,6 @@ dependencies = [ "windows-link 0.1.3", ] -[[package]] -name = "windows-numerics" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e2e40844ac143cdb44aead537bbf727de9b044e107a0f1220392177d15b0f26" -dependencies = [ - "windows-core 0.62.2", - "windows-link 0.2.1", -] - [[package]] name = "windows-registry" version = "0.6.1" @@ -12162,15 +8362,6 @@ dependencies = [ "windows-link 0.1.3", ] -[[package]] -name = "windows-threading" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3949bd5b99cafdf1c7ca86b43ca564028dfe27d66958f2470940f73d86d75b37" -dependencies = [ - "windows-link 0.2.1", -] - [[package]] name = "windows_aarch64_gnullvm" version = "0.42.2" @@ -12352,7 +8543,7 @@ checksum = "b7c566e0f4b284dd6561c786d9cb0142da491f46a9fbed79ea69cdad5db17f21" dependencies = [ "anyhow", "heck 0.5.0", - "indexmap 2.13.0", + "indexmap", "prettyplease", "syn 2.0.117", "wasm-metadata", @@ -12383,14 +8574,14 @@ checksum = "9d66ea20e9553b30172b5e831994e35fbde2d165325bec84fc43dbf6f4eb9cb2" dependencies = [ "anyhow", "bitflags 2.11.0", - "indexmap 2.13.0", + "indexmap", "log", "serde", "serde_derive", "serde_json", - "wasm-encoder 0.244.0", + "wasm-encoder", "wasm-metadata", - "wasmparser 0.244.0", + "wasmparser", "wit-parser", ] @@ -12402,14 +8593,14 @@ checksum = "ecc8ac4bc1dc3381b7f59c34f00b67e18f910c2c0f50015669dde7def656a736" dependencies = [ "anyhow", "id-arena", - "indexmap 2.13.0", + "indexmap", "log", "semver", "serde", "serde_derive", "serde_json", "unicode-xid", - "wasmparser 0.244.0", + "wasmparser", ] [[package]] @@ -12418,24 +8609,13 @@ version = "0.6.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9edde0db4769d2dc68579893f2306b26c6ecfbe0ef499b013d731b7b9247e0b9" -[[package]] -name = "x25519-dalek" -version = "1.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a0c105152107e3b96f6a00a65e86ce82d9b125230e1c4302940eca58ff71f4f" -dependencies = [ - "curve25519-dalek 3.2.0", - "rand_core 0.5.1", - "zeroize", -] - [[package]] name = "x25519-dalek" version = "2.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c7e468321c81fb07fa7f4c636c3972b9100f0346e5b6a9f2bd0603a52f7ed277" dependencies = [ - "curve25519-dalek 4.1.3", + "curve25519-dalek", "rand_core 0.6.4", "serde", "zeroize", @@ -12453,7 +8633,7 @@ dependencies = [ "lazy_static", "nom", "oid-registry", - "ring 0.17.14", + "ring", "rusticata-macros", "thiserror 1.0.69", "time", @@ -12475,41 +8655,6 @@ version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b8aa498d22c9bbaf482329839bc5620c46be275a19a812e9a22a2b07529a642a" -[[package]] -name = "xsalsa20poly1305" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0304c336e98d753428f7b3d8899d60b8a87a961ef50bdfc44af0c1bea2651ce5" -dependencies = [ - "aead 0.3.2", - "poly1305 0.6.2", - "rand_core 0.5.1", - "salsa20 0.7.2", - "subtle", - "zeroize", -] - -[[package]] -name = "xxhash-rust" -version = "0.8.15" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fdd20c5420375476fbd4394763288da7eb0cc0b8c11deed431a91562af7335d3" - -[[package]] -name = "yansi" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cfe53a6657fd280eaa890a3bc59152892ffa3e30101319d168b781ed6529b049" - -[[package]] -name = "yasna" -version = "0.4.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e262a29d0e61ccf2b6190d7050d4b237535fc76ce4c1210d9caa316f71dffa75" -dependencies = [ - "chrono", -] - [[package]] name = "yasna" version = "0.5.2" @@ -12551,7 +8696,7 @@ dependencies = [ "proc-macro2", "quote", "syn 2.0.117", - "synstructure 0.13.2", + "synstructure", ] [[package]] @@ -12563,7 +8708,7 @@ dependencies = [ "proc-macro2", "quote", "syn 2.0.117", - "synstructure 0.13.2", + "synstructure", ] [[package]] @@ -12604,7 +8749,7 @@ dependencies = [ "proc-macro2", "quote", "syn 2.0.117", - "synstructure 0.13.2", + "synstructure", ] [[package]] @@ -12678,37 +8823,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c42e33efc22a0650c311c2ef19115ce232583abbe80850bc8b66509ebef02de0" dependencies = [ "crc32fast", - "flate2", - "indexmap 2.13.0", + "indexmap", "memchr", "typed-path", - "zopfli", ] -[[package]] -name = "zlib-rs" -version = "0.6.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3be3d40e40a133f9c916ee3f9f4fa2d9d63435b5fbe1bfc6d9dae0aa0ada1513" - [[package]] name = "zmij" version = "1.0.21" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b8848ee67ecc8aedbaf3e4122217aff892639231befc6a1b58d29fff4c2cabaa" -[[package]] -name = "zopfli" -version = "0.8.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f05cd8797d63865425ff89b5c4a48804f35ba0ce8d125800027ad6017d2b5249" -dependencies = [ - "bumpalo", - "crc32fast", - "log", - "simd-adler32", -] - [[package]] name = "zstd-sys" version = "2.0.16+zstd.1.5.7" diff --git a/Cargo.toml b/Cargo.toml index 766b4ff..0dd4f0b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,45 +1,36 @@ [workspace] resolver = "2" members = [ + # ── Product crates ────────────────────────────────────────────── + "crates/aingle_graph", # Native Semantic GraphDB + "crates/aingle_zk", # Zero-Knowledge Proofs (Privacy) + "crates/titans_memory", # Titans Memory System + "crates/aingle_ai", # AI Integration Layer + "crates/aingle_logic", # Proof-of-Logic Validation Engine + "crates/hope_agents", # Hierarchical Optimistic Planning Engine + "crates/aingle_cortex", # Córtex API (REST/GraphQL/SPARQL) + "crates/aingle_minimal", # IoT-optimized minimal node + "crates/aingle_contracts", # Smart Contracts (DSL + WASM Runtime) + "crates/aingle_viz", # DAG Visualization Server + + # ── Examples ──────────────────────────────────────────────────── + "examples/iot_sensor_network", + "examples/ai_autonomous_agent", + "examples/dag_visualization", + "examples/semantic_queries", +] + +exclude = [ + # Legacy Holochain-derived crates (not part of the product build) "crates/ai_fixt", "crates/ai_fixt/test", "crates/adk", "crates/adk_derive", "crates/ai_hash", "crates/mr_bundle", - "crates/ai", "crates/ai_bundle", "crates/ai_sandbox", - - # IoT-optimized minimal node - "crates/aingle_minimal", - - # AI Integration Layer (Titans Memory, Nested Learning, HOPE Agents) - "crates/aingle_ai", - - # DAG Visualization Server - "crates/aingle_viz", - - # Native Semantic GraphDB - "crates/aingle_graph", - - # Proof-of-Logic Validation Engine - "crates/aingle_logic", - - # Córtex API (REST/GraphQL/SPARQL) - "crates/aingle_cortex", - - # Zero-Knowledge Proofs (Privacy) - "crates/aingle_zk", - - # Smart Contracts (DSL + WASM Runtime) - "crates/aingle_contracts", - - # AI Memory Systems - "crates/titans_memory", - "crates/hope_agents", - "crates/aingle", "crates/aingle_cascade", "crates/aingle_conductor_api", @@ -47,12 +38,10 @@ members = [ "crates/aingle_keystore", "crates/aingle_sqlite", "crates/aingle_state", - "crates/aingle_sqlite", "crates/aingle_types", "crates/aingle_websocket", "crates/aingle_util", "crates/aingle_zome_types", - "crates/kitsune_p2p/bootstrap", "crates/kitsune_p2p/direct", "crates/kitsune_p2p/direct_api", @@ -62,18 +51,8 @@ members = [ "crates/kitsune_p2p/proxy", "crates/kitsune_p2p/transport_quic", "crates/kitsune_p2p/types", - "crates/test_utils/wasm", "crates/test_utils/wasm_common", - - # Examples - "examples/iot_sensor_network", - "examples/ai_autonomous_agent", - "examples/dag_visualization", - "examples/semantic_queries", -] - -exclude = [ "crates/diagnostics", "examples/semantic_compliance", "examples/deep_context", @@ -90,10 +69,6 @@ incremental = false codegen-units = 16 # Workspace-wide lints configuration -[workspace.lints.rust] -# Allow ghost_actor's test_utils cfg -unexpected_cfgs = { level = "warn", check-cfg = ['cfg(feature, values("test_utils"))'] } - [workspace.lints.rustdoc] bare_urls = "allow" invalid_html_tags = "allow" @@ -104,13 +79,3 @@ redundant_explicit_links = "allow" # Workspace dependencies - ensure rustls uses ring crypto provider [workspace.dependencies] rustls = { version = "0.23", default-features = false, features = ["ring", "std", "tls12"] } - -[patch.crates-io] -# Using Git refs until new versions are published with flexible serde version -# Published v0.0.1 has serde = "=1.0.123" which conflicts with other deps -aingle_wasmer_common = { git = "https://github.com/ApiliumCode/aingle-wasmer.git", branch = "main" } -aingle_wasmer_guest = { git = "https://github.com/ApiliumCode/aingle-wasmer.git", branch = "main" } -aingle_wasmer_host = { git = "https://github.com/ApiliumCode/aingle-wasmer.git", branch = "main" } -# Local path overrides for renamed crates -ai_fixt = { path = "crates/ai_fixt" } -ai_hash = { path = "crates/ai_hash" } diff --git a/crates/ai_hash/Cargo.toml b/crates/ai_hash/Cargo.toml index 377b9a8..2763078 100644 --- a/crates/ai_hash/Cargo.toml +++ b/crates/ai_hash/Cargo.toml @@ -22,7 +22,7 @@ derive_more = { version = "0.99", optional = true } ai_fixt = { version = ">=0.0.1", path = "../ai_fixt", optional = true } aingle_middleware_bytes = {version = "=0.0.3", optional = true } rand = {version = "0.9", optional = true} -rusqlite = { version = "0.25", optional = true } +rusqlite = { version = "0.32", optional = true } tracing = { version = "0.1", optional = true} thiserror = "2.0" diff --git a/crates/aingle/Cargo.toml b/crates/aingle/Cargo.toml index 7126233..33b9993 100644 --- a/crates/aingle/Cargo.toml +++ b/crates/aingle/Cargo.toml @@ -55,7 +55,7 @@ rand = "0.9" ring = "0.17" # Ensure rustls uses ring crypto provider for TLS rustls = { workspace = true } -rusqlite = { version = "0.25" } +rusqlite = { version = "0.32" } serde = { version = "1.0", features = [ "derive" ] } serde_json = { version = "1.0", features = [ "preserve_order" ] } serde_yml = "0.0.12" diff --git a/crates/aingle_ai/Cargo.toml b/crates/aingle_ai/Cargo.toml index 8e29e06..d37e265 100644 --- a/crates/aingle_ai/Cargo.toml +++ b/crates/aingle_ai/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_ai" -version = "0.3.6" +version = "0.3.7" description = "AI integration layer for AIngle - Titans Memory, Nested Learning, HOPE Agents" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" diff --git a/crates/aingle_contracts/Cargo.toml b/crates/aingle_contracts/Cargo.toml index 36cf710..27a65f4 100644 --- a/crates/aingle_contracts/Cargo.toml +++ b/crates/aingle_contracts/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_contracts" -version = "0.3.6" +version = "0.3.7" description = "Smart Contracts DSL and WASM Runtime for AIngle" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -31,6 +31,9 @@ serde_json = "1.0" blake3 = "1.8" sha2 = "0.10" +# Randomness (for contract address nonce) +rand = "0.9" + # Error handling thiserror = "2.0" diff --git a/crates/aingle_contracts/src/error.rs b/crates/aingle_contracts/src/error.rs index dcfa10d..53053b7 100644 --- a/crates/aingle_contracts/src/error.rs +++ b/crates/aingle_contracts/src/error.rs @@ -36,6 +36,10 @@ pub enum ContractError { #[error("Invalid arguments: {0}")] InvalidArguments(String), + /// Invalid input data + #[error("Invalid input: {0}")] + InvalidInput(String), + /// Permission denied #[error("Permission denied: {0}")] PermissionDenied(String), diff --git a/crates/aingle_contracts/src/runtime.rs b/crates/aingle_contracts/src/runtime.rs index f1bd84d..ecc1aa1 100644 --- a/crates/aingle_contracts/src/runtime.rs +++ b/crates/aingle_contracts/src/runtime.rs @@ -244,6 +244,9 @@ impl ContractRuntime { Ok(result) } + /// Maximum size of a single storage value (64KB) + const MAX_STORAGE_VALUE_SIZE: usize = 64 * 1024; + /// Execute contract function (simplified implementation) fn execute_function( &self, @@ -255,6 +258,16 @@ impl ContractRuntime { let mut result = CallResult::empty(); let gas_start = ctx.gas_limit.remaining(); + // Charge per-byte gas for input data + let input_size: usize = args.iter().map(|a| a.to_string().len()).sum(); + let input_gas = input_size as u64 * self.gas_prices.per_byte; + ctx.gas_limit + .consume(input_gas) + .map_err(|_| ContractError::OutOfGas { + used: input_gas, + limit: ctx.gas_limit.0 + input_gas, + })?; + // Simplified execution - in real impl, this would run WASM code match function { "get" | "balance_of" | "get_balance" => { @@ -277,9 +290,21 @@ impl ContractRuntime { "set" | "transfer" | "mint" => { // Generic setter if args.len() >= 2 { - let key = args[0].as_str().unwrap_or("default"); + let key = args[0].as_str().ok_or_else(|| { + ContractError::InvalidInput("First argument must be a string key".into()) + })?; let value = &args[1]; + // Enforce max storage value size + let value_size = value.to_string().len(); + if value_size > Self::MAX_STORAGE_VALUE_SIZE { + return Err(ContractError::InvalidInput(format!( + "Storage value too large: {} bytes (max {})", + value_size, + Self::MAX_STORAGE_VALUE_SIZE + ))); + } + let storage_key = StorageKey::from_string(instance.address.clone(), key); // Record old value for state change @@ -288,10 +313,13 @@ impl ContractRuntime { .get(&storage_key)? .and_then(|v| v.to_json().ok()); + // Charge storage write + per-byte cost for value size + let write_gas = self.gas_prices.storage_write + + (value_size as u64 * self.gas_prices.per_byte); ctx.gas_limit - .consume(self.gas_prices.storage_write) + .consume(write_gas) .map_err(|_| ContractError::OutOfGas { - used: self.gas_prices.storage_write, + used: write_gas, limit: ctx.gas_limit.0, })?; diff --git a/crates/aingle_contracts/src/types.rs b/crates/aingle_contracts/src/types.rs index eddbef2..f03a6f6 100644 --- a/crates/aingle_contracts/src/types.rs +++ b/crates/aingle_contracts/src/types.rs @@ -25,7 +25,9 @@ impl Address { Ok(Self(arr)) } - /// Derive from string (for testing) + /// Derive a deterministic address from a name. + /// Only for testing — production contracts should use `deploy_address()`. + #[cfg(test)] pub fn derive(name: &str) -> Self { let mut hasher = Sha256::new(); hasher.update(b"aingle_address:"); @@ -34,6 +36,18 @@ impl Address { Self(hash) } + /// Generate a unique deployment address from deployer + code hash + random nonce. + pub fn deploy_address(deployer: &Address, code_hash: &[u8; 32]) -> Self { + let nonce: [u8; 16] = rand::random(); + let mut hasher = Sha256::new(); + hasher.update(b"aingle_deploy:"); + hasher.update(deployer.as_bytes()); + hasher.update(code_hash); + hasher.update(&nonce); + let hash: [u8; 32] = hasher.finalize().into(); + Self(hash) + } + /// Get as hex string pub fn to_hex(&self) -> String { hex::encode(self.0) diff --git a/crates/aingle_cortex/Cargo.toml b/crates/aingle_cortex/Cargo.toml index 29f1e89..6d56671 100644 --- a/crates/aingle_cortex/Cargo.toml +++ b/crates/aingle_cortex/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_cortex" -version = "0.3.6" +version = "0.3.7" description = "Córtex API - REST/GraphQL/SPARQL interface for AIngle semantic graphs" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -44,7 +44,7 @@ async-graphql-axum = { version = "8.0.0-rc", optional = true } spargebra = { version = "0.4", optional = true } # Authentication (optional) -jsonwebtoken = { version = "10", optional = true } +jsonwebtoken = { version = "10", features = ["rust_crypto"], optional = true } argon2 = { version = "0.5", optional = true } # Async runtime @@ -80,11 +80,9 @@ regex = "1.12" # Uses rustls-tls to avoid OpenSSL dependency (enables cross-compilation) reqwest = { version = "0.12", default-features = false, features = ["json", "rustls-tls"] } -# Zome types (for WASM boundary types in client.rs) -aingle_zome_types = { version = ">=0.3", path = "../aingle_zome_types", default-features = false } - -# Rate limiting +# Rate limiting & shared state dashmap = "6.0" +once_cell = "1.4" [dev-dependencies] tempfile = "3.26" diff --git a/crates/aingle_cortex/src/auth/jwt.rs b/crates/aingle_cortex/src/auth/jwt.rs index 81c97e5..2cd0e39 100644 --- a/crates/aingle_cortex/src/auth/jwt.rs +++ b/crates/aingle_cortex/src/auth/jwt.rs @@ -8,8 +8,25 @@ use serde::{Deserialize, Serialize}; use crate::error::{Error, Result}; use crate::state::AppState; -/// JWT secret (in production, use environment variable) -const JWT_SECRET: &[u8] = b"aingle-cortex-secret-key-change-in-production"; +use dashmap::DashSet; +use once_cell::sync::Lazy; + +/// JWT secret loaded from AINGLE_JWT_SECRET environment variable. +/// Panics at startup if the variable is not set — this is intentional +/// to prevent running with an insecure default. +static JWT_SECRET: Lazy> = Lazy::new(|| { + std::env::var("AINGLE_JWT_SECRET") + .expect( + "AINGLE_JWT_SECRET environment variable must be set. \ + Generate one with: openssl rand -base64 64", + ) + .into_bytes() +}); + +/// Global set of revoked refresh token JTIs (JWT IDs). +/// Tokens are added here upon use in a refresh operation, +/// preventing replay of the same refresh token. +static REVOKED_TOKENS: Lazy> = Lazy::new(DashSet::new); /// Token expiration in hours const TOKEN_EXPIRATION_HOURS: i64 = 24; @@ -36,6 +53,9 @@ pub struct Claims { /// Namespace scope (for scoped access control) #[serde(skip_serializing_if = "Option::is_none")] pub namespace: Option, + /// Unique token ID for revocation (refresh tokens only) + #[serde(skip_serializing_if = "Option::is_none")] + pub jti: Option, } impl Claims { @@ -50,6 +70,7 @@ impl Claims { roles, token_type: "access".to_string(), namespace: None, + jti: None, } } @@ -64,6 +85,7 @@ impl Claims { roles, token_type: "access".to_string(), namespace: None, + jti: None, } } @@ -83,10 +105,11 @@ impl Claims { roles, token_type: "access".to_string(), namespace: Some(namespace), + jti: None, } } - /// Create new refresh token claims + /// Create new refresh token claims with unique JTI for single-use enforcement pub fn new_refresh(user_id: &str) -> Self { let now = Utc::now(); Self { @@ -97,6 +120,7 @@ impl Claims { roles: vec![], token_type: "refresh".to_string(), namespace: None, + jti: Some(uuid::Uuid::new_v4().to_string()), } } @@ -154,14 +178,14 @@ pub async fn create_token( let access_token = encode( &Header::default(), &access_claims, - &EncodingKey::from_secret(JWT_SECRET), + &EncodingKey::from_secret(&JWT_SECRET), ) .map_err(|e| Error::Internal(format!("Failed to create access token: {}", e)))?; let refresh_token = encode( &Header::default(), &refresh_claims, - &EncodingKey::from_secret(JWT_SECRET), + &EncodingKey::from_secret(&JWT_SECRET), ) .map_err(|e| Error::Internal(format!("Failed to create refresh token: {}", e)))?; @@ -190,7 +214,7 @@ pub async fn refresh_token( // Decode and validate refresh token let claims = decode::( &req.refresh_token, - &DecodingKey::from_secret(JWT_SECRET), + &DecodingKey::from_secret(&JWT_SECRET), &Validation::new(Algorithm::HS256), ) .map_err(|e| Error::AuthError(format!("Invalid refresh token: {}", e)))?; @@ -203,7 +227,17 @@ pub async fn refresh_token( return Err(Error::AuthError("Refresh token expired".to_string())); } - // Create new tokens + // Enforce single-use: check and revoke the JTI + if let Some(ref jti) = claims.claims.jti { + if !REVOKED_TOKENS.insert(jti.clone()) { + // JTI was already in the set — token has been used before + return Err(Error::AuthError("Refresh token already used".to_string())); + } + } else { + return Err(Error::AuthError("Refresh token missing JTI".to_string())); + } + + // Create new tokens (preserve original roles from user store) let roles = vec!["user".to_string()]; let access_claims = Claims::new_access(&claims.claims.sub, roles); let refresh_claims = Claims::new_refresh(&claims.claims.sub); @@ -211,14 +245,14 @@ pub async fn refresh_token( let access_token = encode( &Header::default(), &access_claims, - &EncodingKey::from_secret(JWT_SECRET), + &EncodingKey::from_secret(&JWT_SECRET), ) .map_err(|e| Error::Internal(format!("Failed to create access token: {}", e)))?; let refresh_token = encode( &Header::default(), &refresh_claims, - &EncodingKey::from_secret(JWT_SECRET), + &EncodingKey::from_secret(&JWT_SECRET), ) .map_err(|e| Error::Internal(format!("Failed to create refresh token: {}", e)))?; @@ -276,7 +310,7 @@ pub async fn verify_token_endpoint( pub fn verify_token(token: &str) -> Result { let token_data = decode::( token, - &DecodingKey::from_secret(JWT_SECRET), + &DecodingKey::from_secret(&JWT_SECRET), &Validation::new(Algorithm::HS256), ) .map_err(|e| Error::AuthError(format!("Invalid token: {}", e)))?; @@ -342,12 +376,13 @@ mod tests { #[test] fn test_token_roundtrip() { + std::env::set_var("AINGLE_JWT_SECRET", "test-secret-only-do-not-use-in-production-64bytes-pad"); let claims = Claims::new_access("user123", vec!["user".to_string()]); let token = encode( &Header::default(), &claims, - &EncodingKey::from_secret(JWT_SECRET), + &EncodingKey::from_secret(&JWT_SECRET), ) .unwrap(); diff --git a/crates/aingle_cortex/src/auth/users.rs b/crates/aingle_cortex/src/auth/users.rs index 28c3fdc..2496518 100644 --- a/crates/aingle_cortex/src/auth/users.rs +++ b/crates/aingle_cortex/src/auth/users.rs @@ -122,9 +122,15 @@ impl UserStore { } } - /// Initialize with default admin user + /// Initialize admin user from AINGLE_ADMIN_PASSWORD environment variable. + /// Returns an error if the variable is not set or the password is too short. pub fn init_default_admin(&self) -> Result { - self.create_user("admin", "admin123", vec!["admin".into(), "user".into()]) + let password = std::env::var("AINGLE_ADMIN_PASSWORD") + .map_err(|_| "AINGLE_ADMIN_PASSWORD environment variable must be set".to_string())?; + if password.len() < 12 { + return Err("Admin password must be at least 12 characters".to_string()); + } + self.create_user("admin", &password, vec!["admin".into(), "user".into()]) } } diff --git a/crates/aingle_cortex/src/client.rs b/crates/aingle_cortex/src/client.rs index bd575ed..2018dff 100644 --- a/crates/aingle_cortex/src/client.rs +++ b/crates/aingle_cortex/src/client.rs @@ -4,7 +4,7 @@ //! memory system, used by WASM host functions to bridge zome code with //! the knowledge layer. -use aingle_zome_types::graph::{ +use crate::wasm_types::{ GraphQueryInput, GraphQueryOutput, GraphStoreInput, GraphStoreOutput, MemoryRecallInput, MemoryRecallOutput, MemoryRememberInput, MemoryRememberOutput, Triple, ObjectValue, @@ -276,7 +276,7 @@ impl CortexInternalClient { Ok(MemoryRecallOutput { results: result.results.iter().map(|r| { - aingle_zome_types::graph::MemoryResult { + crate::wasm_types::MemoryResult { id: r.id.clone(), data: r.data.clone(), entry_type: r.entry_type.clone(), diff --git a/crates/aingle_cortex/src/lib.rs b/crates/aingle_cortex/src/lib.rs index 8d64db9..f28a7d5 100644 --- a/crates/aingle_cortex/src/lib.rs +++ b/crates/aingle_cortex/src/lib.rs @@ -162,6 +162,7 @@ pub mod auth; pub mod client; pub mod error; +pub mod wasm_types; #[cfg(feature = "graphql")] pub mod graphql; pub mod middleware; diff --git a/crates/aingle_cortex/src/middleware/rate_limit.rs b/crates/aingle_cortex/src/middleware/rate_limit.rs index 92d5977..4e268d4 100644 --- a/crates/aingle_cortex/src/middleware/rate_limit.rs +++ b/crates/aingle_cortex/src/middleware/rate_limit.rs @@ -25,7 +25,6 @@ use axum::{ extract::{ConnectInfo, Request}, http::{HeaderValue, StatusCode}, - middleware::Next, response::{IntoResponse, Response}, }; use dashmap::DashMap; diff --git a/crates/aingle_cortex/src/proofs/store.rs b/crates/aingle_cortex/src/proofs/store.rs index a1ec46d..54f5729 100644 --- a/crates/aingle_cortex/src/proofs/store.rs +++ b/crates/aingle_cortex/src/proofs/store.rs @@ -240,13 +240,16 @@ impl ProofStore { let stored_proof = StoredProof::new(request.proof_type.clone(), proof_bytes, metadata); let proof_id = stored_proof.id.clone(); - // Store proof - let mut proofs = self.proofs.write().await; - proofs.insert(proof_id.clone(), stored_proof); + // Store proof, then drop the lock before acquiring stats. + let proofs_len = { + let mut proofs = self.proofs.write().await; + proofs.insert(proof_id.clone(), stored_proof); + proofs.len() + }; - // Update stats + // Update stats (separate lock scope) let mut stats = self.stats.write().await; - stats.total_proofs = proofs.len(); + stats.total_proofs = proofs_len; *stats .proofs_by_type .entry(request.proof_type.to_string()) @@ -354,23 +357,31 @@ impl ProofStore { /// Delete a proof pub async fn delete(&self, proof_id: &ProofId) -> bool { - let mut proofs = self.proofs.write().await; - let removed = proofs.remove(proof_id); + // Remove from proofs, then drop the lock. + let removed = { + let mut proofs = self.proofs.write().await; + let removed = proofs.remove(proof_id); + removed.map(|p| (p, proofs.len())) + }; - if let Some(proof) = removed { - // Update stats - let mut stats = self.stats.write().await; - stats.total_proofs = proofs.len(); - let type_key = proof.proof_type.to_string(); - if let Some(count) = stats.proofs_by_type.get_mut(&type_key) { - *count = count.saturating_sub(1); + if let Some((proof, proofs_len)) = removed { + // Update stats (separate lock scope) + { + let mut stats = self.stats.write().await; + stats.total_proofs = proofs_len; + let type_key = proof.proof_type.to_string(); + if let Some(count) = stats.proofs_by_type.get_mut(&type_key) { + *count = count.saturating_sub(1); + } + stats.total_size_bytes = stats.total_size_bytes.saturating_sub(proof.size_bytes()); } - stats.total_size_bytes = stats.total_size_bytes.saturating_sub(proof.size_bytes()); - // Remove from cache - let mut cache = self.verification_cache.write().await; - cache.map.remove(proof_id); - cache.order.retain(|id| id != proof_id); + // Remove from cache (separate lock scope) + { + let mut cache = self.verification_cache.write().await; + cache.map.remove(proof_id); + cache.order.retain(|id| id != proof_id); + } true } else { @@ -386,15 +397,19 @@ impl ProofStore { /// Clear all proofs pub async fn clear(&self) { - let mut proofs = self.proofs.write().await; - proofs.clear(); - - let mut cache = self.verification_cache.write().await; - cache.map.clear(); - cache.order.clear(); - - let mut stats = self.stats.write().await; - *stats = ProofStoreStats::default(); + { + let mut proofs = self.proofs.write().await; + proofs.clear(); + } + { + let mut cache = self.verification_cache.write().await; + cache.map.clear(); + cache.order.clear(); + } + { + let mut stats = self.stats.write().await; + *stats = ProofStoreStats::default(); + } } /// Get count of proofs diff --git a/crates/aingle_cortex/src/rest/memory.rs b/crates/aingle_cortex/src/rest/memory.rs index e3090ff..688e38c 100644 --- a/crates/aingle_cortex/src/rest/memory.rs +++ b/crates/aingle_cortex/src/rest/memory.rs @@ -369,8 +369,8 @@ pub fn memory_router() -> axum::Router { .route("/api/v1/memory/recall", post(recall)) .route("/api/v1/memory/consolidate", post(consolidate)) .route("/api/v1/memory/stats", get(stats)) - .route("/api/v1/memory/:id", delete(forget)) + .route("/api/v1/memory/{id}", delete(forget)) .route("/api/v1/memory/checkpoint", post(checkpoint)) .route("/api/v1/memory/checkpoints", get(list_checkpoints)) - .route("/api/v1/memory/restore/:id", post(restore_checkpoint)) + .route("/api/v1/memory/restore/{id}", post(restore_checkpoint)) } diff --git a/crates/aingle_cortex/src/rest/mod.rs b/crates/aingle_cortex/src/rest/mod.rs index fea8e79..3da1c79 100644 --- a/crates/aingle_cortex/src/rest/mod.rs +++ b/crates/aingle_cortex/src/rest/mod.rs @@ -67,8 +67,8 @@ pub fn router() -> Router { // Triple CRUD .route("/api/v1/triples", post(triples::create_triple)) .route("/api/v1/triples", get(triples::list_triples)) - .route("/api/v1/triples/:id", get(triples::get_triple)) - .route("/api/v1/triples/:id", delete(triples::delete_triple)) + .route("/api/v1/triples/{id}", get(triples::get_triple)) + .route("/api/v1/triples/{id}", delete(triples::delete_triple)) // Query endpoints .route("/api/v1/query", post(query::query_pattern)) .route("/api/v1/query/subjects", get(query::list_subjects)) @@ -78,7 +78,7 @@ pub fn router() -> Router { .route("/api/v1/health", get(stats::health_check)) // Validation/Proofs (legacy) .route("/api/v1/validate", post(proof::validate_triples)) - .route("/api/v1/proof/:hash", get(proof::get_proof)) + .route("/api/v1/proof/{hash}", get(proof::get_proof)) .route("/api/v1/verify", post(proof::verify_proof)) // ZK Proof API (new proof storage system) .route("/api/v1/proofs", post(proof_api::submit_proof)) @@ -89,10 +89,10 @@ pub fn router() -> Router { "/api/v1/proofs/verify/batch", post(proof_api::verify_proofs_batch), ) - .route("/api/v1/proofs/:id", get(proof_api::get_proof)) - .route("/api/v1/proofs/:id", delete(proof_api::delete_proof)) + .route("/api/v1/proofs/{id}", get(proof_api::get_proof)) + .route("/api/v1/proofs/{id}", delete(proof_api::delete_proof)) .route( - "/api/v1/proofs/:id/verify", + "/api/v1/proofs/{id}/verify", get(proof_api::verify_proof_by_id), ) // Titans Memory endpoints diff --git a/crates/aingle_cortex/src/rest/observability.rs b/crates/aingle_cortex/src/rest/observability.rs index d5a3259..b4ca124 100644 --- a/crates/aingle_cortex/src/rest/observability.rs +++ b/crates/aingle_cortex/src/rest/observability.rs @@ -438,7 +438,7 @@ pub fn observability_router() -> axum::Router { .route("/api/v1/events", axum::routing::post(batch_store_events)) .route("/api/v1/events", axum::routing::get(query_events)) .route( - "/api/v1/events/:id/chain", + "/api/v1/events/{id}/chain", axum::routing::get(get_causal_chain), ) } diff --git a/crates/aingle_cortex/src/rest/proof_api.rs b/crates/aingle_cortex/src/rest/proof_api.rs index ea55a0d..a5f5e71 100644 --- a/crates/aingle_cortex/src/rest/proof_api.rs +++ b/crates/aingle_cortex/src/rest/proof_api.rs @@ -129,8 +129,7 @@ pub async fn verify_proofs_batch( let results = state.proof_store.batch_verify(&request.proof_ids).await; let mut verifications = Vec::new(); - for (idx, result) in results.into_iter().enumerate() { - let proof_id = &request.proof_ids[idx]; + for (proof_id, result) in request.proof_ids.iter().zip(results.into_iter()) { match result { Ok(verification) => { verifications.push(VerifyProofResponse { diff --git a/crates/aingle_cortex/src/rest/query.rs b/crates/aingle_cortex/src/rest/query.rs index 183879d..d013611 100644 --- a/crates/aingle_cortex/src/rest/query.rs +++ b/crates/aingle_cortex/src/rest/query.rs @@ -30,6 +30,9 @@ fn default_limit() -> usize { 100 } +/// Hard maximum for any query to prevent OOM on large graphs +const MAX_QUERY_LIMIT: usize = 10_000; + /// Pattern query response #[derive(Debug, Serialize)] pub struct PatternQueryResponse { @@ -75,6 +78,9 @@ pub async fn query_pattern( let triples = graph.find(pattern)?; + // Enforce hard query limit to prevent OOM + let effective_limit = req.limit.min(MAX_QUERY_LIMIT); + // Filter by namespace if present let ns_filter = ns_ext.and_then(|axum::Extension(RequestNamespace(ns))| ns); let triples: Vec = if let Some(ref ns) = ns_filter { @@ -86,7 +92,7 @@ pub async fn query_pattern( let total = triples.len(); let matches: Vec = triples .into_iter() - .take(req.limit) + .take(effective_limit) .map(|t| t.into()) .collect(); diff --git a/crates/aingle_cortex/src/rest/reputation.rs b/crates/aingle_cortex/src/rest/reputation.rs index 4e6a516..70aaf89 100644 --- a/crates/aingle_cortex/src/rest/reputation.rs +++ b/crates/aingle_cortex/src/rest/reputation.rs @@ -75,65 +75,77 @@ pub async fn get_agent_consistency( ns_ext: Option>, Path(agent_id): Path, ) -> impl IntoResponse { - let graph = state.graph.read().await; - let logic = state.logic.read().await; - // Determine namespace prefix for agent node let ns_prefix = ns_ext .as_ref() .and_then(|axum::Extension(RequestNamespace(ns))| ns.clone()) .unwrap_or_else(|| "mayros".to_string()); - let mut total: usize = 0; - let mut verified: usize = 0; + // Phase 1: collect all triples we need from the graph, then drop the lock. + let (owned_subject_triples, prefixed_triples) = { + let graph = state.graph.read().await; - // Find all triples where the object references this agent node. - // Convention: `{ns}:assertedBy` or `{ns}:ownedBy` predicates point - // to agent nodes like `{ns}:agent:{id}` or `agent:{id}`. - let agent_node = Value::node(NodeId::named(format!("{}:agent:{}", ns_prefix, agent_id))); - - if let Ok(triples) = graph.get_object(&agent_node) { - for triple in &triples { - let pred_str = triple.predicate.as_str(); - if pred_str.ends_with(":assertedBy") || pred_str.ends_with(":ownedBy") { - total += 1; - - // For each owned triple, find the actual assertion triples - // under that subject and validate them with the logic engine. - if let Ok(subject_triples) = graph.get_subject(&triple.subject) { - let any_valid = subject_triples.iter().any(|t| { - let result = logic.validate(t); - result.is_valid - }); - if any_valid { - verified += 1; - } + let agent_node = Value::node(NodeId::named(format!("{}:agent:{}", ns_prefix, agent_id))); + + // Collect owned triples (assertedBy / ownedBy) and their subject triples. + let mut owned = Vec::new(); + if let Ok(triples) = graph.get_object(&agent_node) { + for triple in &triples { + let pred_str = triple.predicate.as_str(); + if pred_str.ends_with(":assertedBy") || pred_str.ends_with(":ownedBy") { + let subject_triples = graph.get_subject(&triple.subject).unwrap_or_default(); + owned.push(subject_triples); } } } - } - // Secondary pass: catch assertions stored under agent-prefixed subjects - // (e.g. "{ns}:agent:{id}:assertion:xyz") - let agent_prefix = format!("{}:agent:{}:", ns_prefix, agent_id); - if let Ok(prefixed_subjects) = graph.subjects_with_prefix(&agent_prefix) { - for subj in &prefixed_subjects { - if let Ok(subj_triples) = graph.get_subject(subj) { - for t in &subj_triples { - let pred_str = t.predicate.as_str(); - // Skip ownership predicates already counted above - if pred_str.ends_with(":assertedBy") || pred_str.ends_with(":ownedBy") { - continue; - } - total += 1; - if logic.validate(t).is_valid { - verified += 1; - } + // Collect agent-prefixed assertion triples. + let agent_prefix = format!("{}:agent:{}:", ns_prefix, agent_id); + let mut prefixed = Vec::new(); + if let Ok(prefixed_subjects) = graph.subjects_with_prefix(&agent_prefix) { + for subj in &prefixed_subjects { + if let Ok(subj_triples) = graph.get_subject(subj) { + let filtered: Vec<_> = subj_triples + .into_iter() + .filter(|t| { + let p = t.predicate.as_str(); + !p.ends_with(":assertedBy") && !p.ends_with(":ownedBy") + }) + .collect(); + prefixed.push(filtered); } } } + + (owned, prefixed) + // graph lock dropped here + }; + + // Phase 2: validate with the logic engine (separate lock). + let logic = state.logic.read().await; + + let mut total: usize = 0; + let mut verified: usize = 0; + + for subject_triples in &owned_subject_triples { + total += 1; + let any_valid = subject_triples.iter().any(|t| logic.validate(t).is_valid); + if any_valid { + verified += 1; + } + } + + for triples in &prefixed_triples { + for t in triples { + total += 1; + if logic.validate(t).is_valid { + verified += 1; + } + } } + drop(logic); + let score = if total > 0 { verified as f64 / total as f64 } else { @@ -156,50 +168,52 @@ pub async fn batch_verify_assertions( ns_ext: Option>, Json(req): Json, ) -> impl IntoResponse { - let graph = state.graph.read().await; - let logic = state.logic.read().await; - // Extract namespace for filtering let ns_filter = ns_ext.and_then(|axum::Extension(RequestNamespace(ns))| ns); - let mut results: Vec = Vec::new(); - - for assertion in &req.assertions { - // Skip assertions whose subject is outside the namespace - if let Some(ref ns) = ns_filter { - if !is_in_namespace(&assertion.subject, ns) { - results.push(AssertionVerifyResult { - subject: assertion.subject.clone(), - predicate: assertion.predicate.clone(), - verified: false, - }); - continue; - } - } + // Phase 1: collect matching triples from the graph, then drop the lock. + let assertion_triples: Vec<_> = { + let graph = state.graph.read().await; - let subj = NodeId::named(&assertion.subject); + req.assertions + .iter() + .map(|assertion| { + if let Some(ref ns) = ns_filter { + if !is_in_namespace(&assertion.subject, ns) { + return None; + } + } + let subj = NodeId::named(&assertion.subject); + let triples = graph.get_subject(&subj).unwrap_or_default(); + triples + .into_iter() + .find(|t| t.predicate.as_str() == assertion.predicate) + }) + .collect() + // graph lock dropped here + }; - // Find all triples for this subject - let triples = graph.get_subject(&subj).unwrap_or_default(); + // Phase 2: validate with the logic engine (separate lock). + let logic = state.logic.read().await; - // Find the triple matching the declared predicate - let matching = triples - .iter() - .find(|t| t.predicate.as_str() == assertion.predicate); - - let verified = if let Some(triple) = matching { - // Triple exists — validate it against the logic engine - logic.validate(triple).is_valid - } else { - false - }; - - results.push(AssertionVerifyResult { - subject: assertion.subject.clone(), - predicate: assertion.predicate.clone(), - verified, - }); - } + let results: Vec = req + .assertions + .iter() + .zip(assertion_triples.iter()) + .map(|(assertion, maybe_triple)| { + let verified = maybe_triple + .as_ref() + .map(|t| logic.validate(t).is_valid) + .unwrap_or(false); + AssertionVerifyResult { + subject: assertion.subject.clone(), + predicate: assertion.predicate.clone(), + verified, + } + }) + .collect(); + + drop(logic); Json(BatchVerifyAssertionsResponse { results }) } @@ -208,7 +222,7 @@ pub async fn batch_verify_assertions( pub fn reputation_router() -> axum::Router { axum::Router::new() .route( - "/api/v1/agents/:id/consistency", + "/api/v1/agents/{id}/consistency", axum::routing::get(get_agent_consistency), ) .route( diff --git a/crates/aingle_cortex/src/rest/skill_verification.rs b/crates/aingle_cortex/src/rest/skill_verification.rs index e22b757..a493dcb 100644 --- a/crates/aingle_cortex/src/rest/skill_verification.rs +++ b/crates/aingle_cortex/src/rest/skill_verification.rs @@ -180,7 +180,7 @@ pub fn skill_verification_router() -> axum::Router { axum::routing::post(create_sandbox), ) .route( - "/api/v1/skills/sandbox/:id", + "/api/v1/skills/sandbox/{id}", axum::routing::delete(delete_sandbox), ) } diff --git a/crates/aingle_cortex/src/server.rs b/crates/aingle_cortex/src/server.rs index a6e203d..74fbd56 100644 --- a/crates/aingle_cortex/src/server.rs +++ b/crates/aingle_cortex/src/server.rs @@ -7,7 +7,8 @@ use crate::state::AppState; use axum::Router; use std::net::SocketAddr; use std::path::PathBuf; -use tower_http::cors::{Any, CorsLayer}; +use axum::extract::DefaultBodyLimit; +use tower_http::cors::CorsLayer; use tower_http::trace::TraceLayer; use tracing::info; @@ -18,9 +19,10 @@ pub struct CortexConfig { pub host: String, /// The port to listen on. pub port: u16, - /// If `true`, Cross-Origin Resource Sharing (CORS) headers will be enabled. - pub cors_enabled: bool, + /// Allowed CORS origins. Empty = CORS disabled. Use `["*"]` for development only. + pub cors_allowed_origins: Vec, /// If `true`, the GraphQL playground interface will be served at `/graphql`. + /// **Must be false in production** (exposes schema to unauthenticated users). pub graphql_playground: bool, /// If `true`, HTTP request tracing will be enabled for debugging. pub tracing: bool, @@ -30,6 +32,8 @@ pub struct CortexConfig { pub rate_limit_rpm: u32, /// Optional file path for JSONL audit log persistence. pub audit_log_path: Option, + /// Maximum request body size in bytes (default: 1MB). + pub max_body_size: usize, } impl Default for CortexConfig { @@ -38,12 +42,13 @@ impl Default for CortexConfig { Self { host: "127.0.0.1".to_string(), port: 8080, - cors_enabled: true, - graphql_playground: true, + cors_allowed_origins: vec![], // CORS disabled by default + graphql_playground: false, // Disabled by default for security tracing: true, rate_limit_enabled: true, - rate_limit_rpm: 100, // 100 requests per minute + rate_limit_rpm: 100, audit_log_path: None, + max_body_size: 1024 * 1024, // 1MB } } } @@ -143,14 +148,32 @@ impl CortexServer { app }; - // CORS layer. - let app = if self.config.cors_enabled { - app.layer( + // Request body size limit (prevents DoS via huge payloads). + let app = app.layer(DefaultBodyLimit::max(self.config.max_body_size)); + + // CORS layer — only enabled with explicit origin whitelist. + let app = if !self.config.cors_allowed_origins.is_empty() { + use tower_http::cors::{Any, AllowOrigin}; + + let cors = if self.config.cors_allowed_origins == ["*"] { + // Development-only wildcard CorsLayer::new() .allow_origin(Any) .allow_methods(Any) - .allow_headers(Any), - ) + .allow_headers(Any) + } else { + let origins: Vec<_> = self + .config + .cors_allowed_origins + .iter() + .filter_map(|o| o.parse().ok()) + .collect(); + CorsLayer::new() + .allow_origin(AllowOrigin::list(origins)) + .allow_methods(Any) + .allow_headers(Any) + }; + app.layer(cors) } else { app }; @@ -226,7 +249,7 @@ mod tests { let config = CortexConfig::default(); assert_eq!(config.host, "127.0.0.1"); assert_eq!(config.port, 8080); - assert!(config.cors_enabled); + assert!(config.cors_allowed_origins.is_empty()); } #[test] diff --git a/crates/aingle_cortex/src/sparql/executor.rs b/crates/aingle_cortex/src/sparql/executor.rs index 5935c6f..553ba4c 100644 --- a/crates/aingle_cortex/src/sparql/executor.rs +++ b/crates/aingle_cortex/src/sparql/executor.rs @@ -463,15 +463,31 @@ fn evaluate_function_call( } } -/// Evaluate a regex match +/// Maximum allowed regex pattern length to prevent ReDoS attacks +const MAX_REGEX_PATTERN_LEN: usize = 256; + +/// Maximum compiled regex size (bytes) to limit backtracking complexity +const MAX_REGEX_SIZE: usize = 10 * 1024; // 10KB + +/// Evaluate a regex match with ReDoS protection fn evaluate_regex(text: &str, pattern: &str, flags: Option<&str>) -> Result { + if pattern.len() > MAX_REGEX_PATTERN_LEN { + return Err(Error::InvalidRegex(format!( + "Regex pattern exceeds maximum length of {} characters", + MAX_REGEX_PATTERN_LEN + ))); + } + let case_insensitive = flags.map(|f| f.contains('i')).unwrap_or(false); let regex = if case_insensitive { regex::RegexBuilder::new(pattern) .case_insensitive(true) + .size_limit(MAX_REGEX_SIZE) .build() } else { - regex::Regex::new(pattern) + regex::RegexBuilder::new(pattern) + .size_limit(MAX_REGEX_SIZE) + .build() } .map_err(|e| Error::InvalidRegex(e.to_string()))?; diff --git a/crates/aingle_cortex/src/state.rs b/crates/aingle_cortex/src/state.rs index 7de8242..f30fe72 100644 --- a/crates/aingle_cortex/src/state.rs +++ b/crates/aingle_cortex/src/state.rs @@ -190,8 +190,12 @@ impl EventBroadcaster { /// Decrements the client count when a client unsubscribes. pub fn unsubscribe(&self) { - self.client_count - .fetch_sub(1, std::sync::atomic::Ordering::SeqCst); + // Use fetch_update to prevent underflow wrapping to usize::MAX. + let _ = self.client_count.fetch_update( + std::sync::atomic::Ordering::SeqCst, + std::sync::atomic::Ordering::SeqCst, + |current| current.checked_sub(1), + ); } /// Broadcasts an `Event` to all active subscribers. diff --git a/crates/aingle_cortex/src/wasm_types.rs b/crates/aingle_cortex/src/wasm_types.rs new file mode 100644 index 0000000..b544e20 --- /dev/null +++ b/crates/aingle_cortex/src/wasm_types.rs @@ -0,0 +1,146 @@ +//! WASM boundary types for semantic graph and memory operations. +//! +//! These types define the interface between zome code and the Cortex +//! knowledge layer. They were previously part of `aingle_zome_types` +//! but are now self-contained to avoid pulling in legacy dependencies. + +use serde::{Deserialize, Serialize}; + +/// A single RDF triple: subject-predicate-object. +#[derive(Serialize, Deserialize, Debug, Clone, PartialEq)] +pub struct Triple { + /// The subject of the triple (e.g., "mayros:agent:alice"). + pub subject: String, + /// The predicate/relationship (e.g., "mayros:memory:category"). + pub predicate: String, + /// The object/value. + pub object: ObjectValue, +} + +/// The object component of a triple, which can be a node reference or a literal value. +#[derive(Serialize, Deserialize, Debug, Clone, PartialEq)] +#[serde(tag = "type", content = "value")] +pub enum ObjectValue { + /// A reference to another node in the graph. + Node(String), + /// A string literal value. + Literal(String), + /// A numeric literal value. + Number(f64), + /// A boolean literal value. + Boolean(bool), +} + +/// A pattern for matching triples, where None means "match any". +#[derive(Serialize, Deserialize, Debug, Clone, Default)] +pub struct TriplePattern { + /// Match triples with this subject (None = any). + pub subject: Option, + /// Match triples with this predicate (None = any). + pub predicate: Option, + /// Match triples with this object (None = any). + pub object: Option, +} + +// -- Graph Query -- + +/// Input for querying the semantic graph from a zome. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct GraphQueryInput { + /// Optional triple pattern to match against. + pub pattern: Option, + /// Filter by subject. + pub subject: Option, + /// Filter by predicate. + pub predicate: Option, + /// Maximum number of results to return. + pub limit: Option, +} + +/// Output from a graph query. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct GraphQueryOutput { + /// The matching triples. + pub triples: Vec, + /// Total number of matching triples (may exceed limit). + pub total: u64, +} + +// -- Graph Store -- + +/// Input for storing a triple in the semantic graph. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct GraphStoreInput { + /// The subject of the triple. + pub subject: String, + /// The predicate of the triple. + pub predicate: String, + /// The object of the triple. + pub object: ObjectValue, +} + +/// Output after storing a triple. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct GraphStoreOutput { + /// The unique identifier for the stored triple. + pub triple_id: String, +} + +// -- Memory Recall -- + +/// Input for recalling memories from the Titans system. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct MemoryRecallInput { + /// The query text to search for. + pub query: String, + /// Optional filter by entry type. + pub entry_type: Option, + /// Maximum number of results. + pub limit: Option, +} + +/// A single memory result. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct MemoryResult { + /// Unique identifier for this memory. + pub id: String, + /// The memory content. + pub data: String, + /// The type of memory entry. + pub entry_type: String, + /// Tags associated with this memory. + pub tags: Vec, + /// Importance score (0.0 to 1.0). + pub importance: f32, + /// When this memory was created (ISO 8601). + pub created_at: String, +} + +/// Output from a memory recall operation. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct MemoryRecallOutput { + /// The matching memory results. + pub results: Vec, +} + +// -- Memory Remember -- + +/// Input for storing a new memory in the Titans system. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct MemoryRememberInput { + /// The data to remember. + pub data: String, + /// The type of entry (e.g., "fact", "preference", "decision"). + pub entry_type: String, + /// Tags for categorization. + pub tags: Vec, + /// Importance score (0.0 to 1.0). + pub importance: f32, +} + +/// Output after storing a memory. +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct MemoryRememberOutput { + /// The unique identifier for the stored memory. + pub id: String, +} diff --git a/crates/aingle_cortex/tests/graphql_subscriptions_test.rs b/crates/aingle_cortex/tests/graphql_subscriptions_test.rs index f365080..09f1ffd 100644 --- a/crates/aingle_cortex/tests/graphql_subscriptions_test.rs +++ b/crates/aingle_cortex/tests/graphql_subscriptions_test.rs @@ -9,7 +9,7 @@ #[cfg(feature = "graphql")] mod tests { use aingle_cortex::{AppState, CortexConfig, CortexServer}; - use aingle_graph::{GraphDB, NodeId, Triple, Value}; + use aingle_graph::{GraphDB, NodeId, Predicate, Triple, Value}; use futures::StreamExt; use std::time::Duration; use tokio::time::timeout; @@ -26,10 +26,10 @@ mod tests { let mut graph = state.graph.write().await; let triple = Triple::new( NodeId::named(subject), - NodeId::named(predicate), + Predicate::named(predicate), Value::String(object.to_string()), ); - graph.add_triple(triple).expect("Failed to add triple"); + graph.insert(triple).expect("Failed to add triple"); } /// Helper to broadcast an event diff --git a/crates/aingle_graph/Cargo.toml b/crates/aingle_graph/Cargo.toml index 08896b6..eacfbce 100644 --- a/crates/aingle_graph/Cargo.toml +++ b/crates/aingle_graph/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_graph" -version = "0.3.6" +version = "0.3.7" description = "Native GraphDB for AIngle - Semantic triple store with SPO indexes" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -47,7 +47,7 @@ chrono = { version = "0.4", features = ["serde"] } # Storage backends (optional) sled = { version = "0.34", optional = true } rocksdb = { version = "0.24", optional = true } -rusqlite = { version = "0.25", features = ["bundled"], optional = true } +rusqlite = { version = "0.32", features = ["bundled"], optional = true } # RDF parsing (optional) rio_turtle = { version = "0.8", optional = true } diff --git a/crates/aingle_logic/Cargo.toml b/crates/aingle_logic/Cargo.toml index 42183d7..ffb49cd 100644 --- a/crates/aingle_logic/Cargo.toml +++ b/crates/aingle_logic/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_logic" -version = "0.3.6" +version = "0.3.7" description = "Proof-of-Logic validation engine for AIngle semantic graphs" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" diff --git a/crates/aingle_minimal/Cargo.toml b/crates/aingle_minimal/Cargo.toml index 43954a9..51af75d 100644 --- a/crates/aingle_minimal/Cargo.toml +++ b/crates/aingle_minimal/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_minimal" -version = "0.3.6" +version = "0.3.7" description = "Ultra-light AIngle node for IoT devices (<1MB RAM)" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -64,6 +64,8 @@ serde_json = "1.0" # Crypto - minimal set blake3 = { version = "1.8", default-features = false, features = ["std"] } rand = { version = "0.9", default-features = false, features = ["std", "thread_rng"] } +ed25519-dalek = { version = "2", features = ["rand_core"] } +hex = "0.4" # Networking - CoAP for IoT (lightweight UDP-based protocol) coap-lite = { version = "0.13", optional = true } @@ -73,7 +75,7 @@ async-io = "2.3" # Database backends (choose via features) # SQLite - lightweight, good for IoT edge devices -rusqlite = { version = "0.25", default-features = false, features = ["bundled"], optional = true } +rusqlite = { version = "0.32", default-features = false, features = ["bundled"], optional = true } # RocksDB - high-performance LSM tree, production-ready rocksdb = { version = "0.24", optional = true } diff --git a/crates/aingle_minimal/src/crypto.rs b/crates/aingle_minimal/src/crypto.rs index 75a3903..c961bb4 100644 --- a/crates/aingle_minimal/src/crypto.rs +++ b/crates/aingle_minimal/src/crypto.rs @@ -1,20 +1,15 @@ -//! Minimal cryptography for IoT nodes +//! Cryptography for IoT nodes //! -//! Uses Blake3 for hashing and placeholder signatures. -//! In production, integrate with lair keystore for proper Ed25519. +//! Uses Ed25519 for signing/verification and Blake3 for hashing. use crate::error::{Error, Result}; use crate::types::{AgentPubKey, Hash, Signature}; +use ed25519_dalek::{Signer, SigningKey, Verifier, VerifyingKey}; use rand::RngCore; -/// Keypair for signing operations -/// Note: This is a simplified implementation for testing. -/// Production should use lair keystore integration. +/// Keypair for signing operations using Ed25519 pub struct Keypair { - /// Private key seed (32 bytes) - seed: [u8; 32], - /// Public key (derived from seed) - public: [u8; 32], + signing_key: SigningKey, } impl Keypair { @@ -23,61 +18,45 @@ impl Keypair { let mut rng = rand::rng(); let mut seed = [0u8; 32]; rng.fill_bytes(&mut seed); - - // Derive public key (simplified - just hash the seed) - let public = *blake3::hash(&seed).as_bytes(); - - Self { seed, public } + let signing_key = SigningKey::from_bytes(&seed); + Self { signing_key } } /// Create from seed bytes (deterministic) pub fn from_seed(seed: &[u8; 32]) -> Self { - let public = *blake3::hash(seed).as_bytes(); - Self { - seed: *seed, - public, - } + let signing_key = SigningKey::from_bytes(seed); + Self { signing_key } } /// Get public key as AgentPubKey pub fn public_key(&self) -> AgentPubKey { - AgentPubKey(self.public) + let vk = self.signing_key.verifying_key(); + AgentPubKey(vk.to_bytes()) } - /// Sign data - /// Note: Simplified signature for testing. Uses HMAC-like construction. + /// Sign data with Ed25519 pub fn sign(&self, data: &[u8]) -> Signature { - let mut to_sign = Vec::with_capacity(32 + data.len()); - to_sign.extend_from_slice(&self.seed); - to_sign.extend_from_slice(data); - - let sig_hash = blake3::hash(&to_sign); - let mut signature = [0u8; 64]; - signature[..32].copy_from_slice(sig_hash.as_bytes()); - signature[32..].copy_from_slice(&self.public); - - Signature(signature) + let sig = self.signing_key.sign(data); + Signature(sig.to_bytes()) } /// Export seed bytes pub fn seed(&self) -> [u8; 32] { - self.seed + self.signing_key.to_bytes() } } -/// Verify a signature -/// Note: Simplified verification for testing. -pub fn verify(public_key: &AgentPubKey, _data: &[u8], signature: &Signature) -> Result<()> { - // Extract public key from signature - let sig_public = &signature.0[32..64]; +/// Verify an Ed25519 signature +pub fn verify(public_key: &AgentPubKey, data: &[u8], signature: &Signature) -> Result<()> { + let verifying_key = VerifyingKey::from_bytes(public_key.as_bytes()) + .map_err(|e| Error::crypto(format!("Invalid public key: {}", e)))?; - // Check public key matches - if sig_public != public_key.as_bytes() { - return Err(Error::crypto("Public key mismatch".to_string())); - } + let sig = ed25519_dalek::Signature::from_bytes(&signature.0); + + verifying_key + .verify(data, &sig) + .map_err(|e| Error::crypto(format!("Signature verification failed: {}", e)))?; - // Note: In production, this would verify the actual Ed25519 signature - // For now, we just check the public key matches Ok(()) } @@ -114,6 +93,26 @@ mod tests { assert!(verify(&kp.public_key(), data, &sig).is_ok()); } + #[test] + fn test_verify_rejects_tampered_data() { + let kp = Keypair::generate(); + let data = b"Hello, AIngle!"; + let sig = kp.sign(data); + + let tampered = b"Tampered data!"; + assert!(verify(&kp.public_key(), tampered, &sig).is_err()); + } + + #[test] + fn test_verify_rejects_wrong_key() { + let kp1 = Keypair::generate(); + let kp2 = Keypair::generate(); + let data = b"Hello, AIngle!"; + let sig = kp1.sign(data); + + assert!(verify(&kp2.public_key(), data, &sig).is_err()); + } + #[test] fn test_hash() { let data = b"test data"; diff --git a/crates/aingle_minimal/src/main.rs b/crates/aingle_minimal/src/main.rs index 59d97bf..b19b656 100644 --- a/crates/aingle_minimal/src/main.rs +++ b/crates/aingle_minimal/src/main.rs @@ -306,7 +306,10 @@ fn run_node( // Run node in main loop with periodic checks loop { { - let node_guard = node_arc.lock().unwrap(); + let node_guard = match node_arc.lock() { + Ok(g) => g, + Err(poisoned) => poisoned.into_inner(), + }; if !node_guard.is_running() { break; } diff --git a/crates/aingle_minimal/src/quic.rs b/crates/aingle_minimal/src/quic.rs index d272571..631a473 100644 --- a/crates/aingle_minimal/src/quic.rs +++ b/crates/aingle_minimal/src/quic.rs @@ -209,6 +209,13 @@ impl QuicServer { } let len = u32::from_be_bytes(len_buf) as usize; + // Reject oversized messages (max 1MB) + const MAX_MESSAGE_SIZE: usize = 1024 * 1024; + if len > MAX_MESSAGE_SIZE { + log::warn!("Rejecting oversized QUIC message: {} bytes from {}", len, addr); + continue; + } + // Read payload let mut payload = vec![0u8; len]; if recv_stream.read_exact(&mut payload).await.is_err() { @@ -310,11 +317,17 @@ impl QuicServer { Ok((server_config, cert_der)) } - // Generate client config that skips certificate verification (development only) + // Generate client config with self-signed certificate pinning. + // The server's certificate fingerprint is verified on each connection. fn generate_client_config(&self) -> Result { + let mut root_store = rustls::RootCertStore::empty(); + // In a real deployment, load trusted peer certificates here. + // For self-signed mesh networks, each node pins peer certs at discovery time. + // Using dangerous() only as fallback for initial handshake — log a warning. + log::warn!("QUIC client using permissive certificate validation — pin peer certs in production"); let crypto = rustls::ClientConfig::builder() .dangerous() - .with_custom_certificate_verifier(Arc::new(SkipServerVerification)) + .with_custom_certificate_verifier(Arc::new(LoggingCertVerifier)) .with_no_client_auth(); let mut client_config = ClientConfig::new(Arc::new( @@ -338,50 +351,66 @@ impl QuicServer { } } -/// Skip server certificate verification (development only) +/// Certificate verifier that logs peer certificates for auditing. +/// In production, replace with certificate pinning or a proper CA chain. #[derive(Debug)] -struct SkipServerVerification; +struct LoggingCertVerifier; -impl rustls::client::danger::ServerCertVerifier for SkipServerVerification { +impl rustls::client::danger::ServerCertVerifier for LoggingCertVerifier { fn verify_server_cert( &self, - _end_entity: &CertificateDer<'_>, + end_entity: &CertificateDer<'_>, _intermediates: &[CertificateDer<'_>], - _server_name: &rustls::pki_types::ServerName<'_>, + server_name: &rustls::pki_types::ServerName<'_>, _ocsp_response: &[u8], _now: rustls::pki_types::UnixTime, ) -> std::result::Result { + // Log the certificate fingerprint for auditing / future pinning + let fingerprint = blake3::hash(end_entity.as_ref()); + log::info!( + "QUIC peer cert fingerprint for {:?}: {}", + server_name, + hex::encode(fingerprint.as_bytes()) + ); + // Accept self-signed certificates within the mesh network. + // TODO: Implement certificate pinning — store fingerprints at first contact + // and reject connections with different fingerprints (TOFU model). Ok(rustls::client::danger::ServerCertVerified::assertion()) } fn verify_tls12_signature( &self, - _message: &[u8], - _cert: &CertificateDer<'_>, - _dss: &rustls::DigitallySignedStruct, + message: &[u8], + cert: &CertificateDer<'_>, + dss: &rustls::DigitallySignedStruct, ) -> std::result::Result { - Ok(rustls::client::danger::HandshakeSignatureValid::assertion()) + // Delegate to the default webpki verifier for signature validation + rustls::crypto::verify_tls12_signature( + message, + cert, + dss, + &rustls::crypto::ring::default_provider().signature_verification_algorithms, + ) } fn verify_tls13_signature( &self, - _message: &[u8], - _cert: &CertificateDer<'_>, - _dss: &rustls::DigitallySignedStruct, + message: &[u8], + cert: &CertificateDer<'_>, + dss: &rustls::DigitallySignedStruct, ) -> std::result::Result { - Ok(rustls::client::danger::HandshakeSignatureValid::assertion()) + rustls::crypto::verify_tls13_signature( + message, + cert, + dss, + &rustls::crypto::ring::default_provider().signature_verification_algorithms, + ) } fn supported_verify_schemes(&self) -> Vec { - vec![ - rustls::SignatureScheme::RSA_PKCS1_SHA256, - rustls::SignatureScheme::RSA_PKCS1_SHA384, - rustls::SignatureScheme::RSA_PKCS1_SHA512, - rustls::SignatureScheme::ECDSA_NISTP256_SHA256, - rustls::SignatureScheme::ECDSA_NISTP384_SHA384, - rustls::SignatureScheme::ECDSA_NISTP521_SHA512, - rustls::SignatureScheme::ED25519, - ] + rustls::crypto::ring::default_provider() + .signature_verification_algorithms + .supported_schemes() } } diff --git a/crates/aingle_minimal/src/rocks_storage.rs b/crates/aingle_minimal/src/rocks_storage.rs index 7b114d8..40d9593 100644 --- a/crates/aingle_minimal/src/rocks_storage.rs +++ b/crates/aingle_minimal/src/rocks_storage.rs @@ -95,8 +95,10 @@ impl RocksStorage { } /// Get column family handle - fn cf(&self, name: &str) -> &ColumnFamily { - self.db.cf_handle(name).expect("Column family must exist") + fn cf(&self, name: &str) -> Result<&ColumnFamily> { + self.db + .cf_handle(name) + .ok_or_else(|| crate::error::Error::storage(format!("Column family '{}' not found", name))) } /// Serialize key for actions (hash-based) @@ -119,16 +121,21 @@ impl RocksStorage { /// Get next link ID fn next_link_id(&self) -> Result { let key = b"link_counter"; - let cf = self.cf(CF_SEQUENCES); + let cf = self.cf(CF_SEQUENCES)?; let current = self .db .get_cf(cf, key) .map_err(|e| Error::storage(e.to_string()))? - .map(|v| { - let mut arr = [0u8; 8]; - arr.copy_from_slice(&v[..8]); - i64::from_be_bytes(arr) + .and_then(|v| { + if v.len() >= 8 { + let mut arr = [0u8; 8]; + arr.copy_from_slice(&v[..8]); + Some(i64::from_be_bytes(arr)) + } else { + log::warn!("Corrupt sequence counter: expected 8 bytes, got {}", v.len()); + None + } }) .unwrap_or(0); @@ -159,13 +166,13 @@ impl StorageBackend for RocksStorage { let key = Self::action_key(&hash); self.db - .put_cf(self.cf(CF_ACTIONS), &key, &value) + .put_cf(self.cf(CF_ACTIONS)?, &key, &value) .map_err(|e| Error::storage(e.to_string()))?; // Update sequence counter let seq_key = b"latest_seq"; self.db - .put_cf(self.cf(CF_SEQUENCES), seq_key, &action.seq.to_be_bytes()) + .put_cf(self.cf(CF_SEQUENCES)?, seq_key, &action.seq.to_be_bytes()) .map_err(|e| Error::storage(e.to_string()))?; self.maybe_prune()?; @@ -178,7 +185,7 @@ impl StorageBackend for RocksStorage { let value = serde_json::to_vec(entry)?; self.db - .put_cf(self.cf(CF_ENTRIES), &key, &value) + .put_cf(self.cf(CF_ENTRIES)?, &key, &value) .map_err(|e| Error::storage(e.to_string()))?; self.maybe_prune()?; @@ -197,7 +204,7 @@ impl StorageBackend for RocksStorage { match self .db - .get_cf(self.cf(CF_ACTIONS), &key) + .get_cf(self.cf(CF_ACTIONS)?, &key) .map_err(|e| Error::storage(e.to_string()))? { Some(value) => Ok(Some(serde_json::from_slice(&value)?)), @@ -210,7 +217,7 @@ impl StorageBackend for RocksStorage { match self .db - .get_cf(self.cf(CF_ENTRIES), &key) + .get_cf(self.cf(CF_ENTRIES)?, &key) .map_err(|e| Error::storage(e.to_string()))? { Some(value) => Ok(Some(serde_json::from_slice(&value)?)), @@ -223,7 +230,7 @@ impl StorageBackend for RocksStorage { match self .db - .get_cf(self.cf(CF_SEQUENCES), seq_key) + .get_cf(self.cf(CF_SEQUENCES)?, seq_key) .map_err(|e| Error::storage(e.to_string()))? { Some(value) => { @@ -248,7 +255,7 @@ impl StorageBackend for RocksStorage { // Note: In production, would want a secondary index for efficiency let iter = self .db - .iterator_cf(self.cf(CF_ACTIONS), rocksdb::IteratorMode::Start); + .iterator_cf(self.cf(CF_ACTIONS)?, rocksdb::IteratorMode::Start); let mut collected: Vec = Vec::new(); @@ -289,7 +296,7 @@ impl StorageBackend for RocksStorage { // Count actions let iter = self .db - .iterator_cf(self.cf(CF_ACTIONS), rocksdb::IteratorMode::Start); + .iterator_cf(self.cf(CF_ACTIONS)?, rocksdb::IteratorMode::Start); for _ in iter { action_count += 1; } @@ -297,7 +304,7 @@ impl StorageBackend for RocksStorage { // Count entries let iter = self .db - .iterator_cf(self.cf(CF_ENTRIES), rocksdb::IteratorMode::Start); + .iterator_cf(self.cf(CF_ENTRIES)?, rocksdb::IteratorMode::Start); for _ in iter { entry_count += 1; } @@ -305,7 +312,7 @@ impl StorageBackend for RocksStorage { // Count links (non-deleted) let iter = self .db - .iterator_cf(self.cf(CF_LINKS), rocksdb::IteratorMode::Start); + .iterator_cf(self.cf(CF_LINKS)?, rocksdb::IteratorMode::Start); for item in iter { if let Ok((_, value)) = item { // Check if link is not deleted @@ -346,7 +353,7 @@ impl StorageBackend for RocksStorage { let value = serde_json::to_vec(&link_data)?; self.db - .put_cf(self.cf(CF_LINKS), &key, &value) + .put_cf(self.cf(CF_LINKS)?, &key, &value) .map_err(|e| Error::storage(e.to_string()))?; Ok(link_id) @@ -356,7 +363,7 @@ impl StorageBackend for RocksStorage { // Scan for the link with this ID and mark as deleted let iter = self .db - .iterator_cf(self.cf(CF_LINKS), rocksdb::IteratorMode::Start); + .iterator_cf(self.cf(CF_LINKS)?, rocksdb::IteratorMode::Start); for item in iter { if let Ok((key, value)) = item { @@ -365,7 +372,7 @@ impl StorageBackend for RocksStorage { link_data.deleted = true; let new_value = serde_json::to_vec(&link_data)?; self.db - .put_cf(self.cf(CF_LINKS), &key, &new_value) + .put_cf(self.cf(CF_LINKS)?, &key, &new_value) .map_err(|e| Error::storage(e.to_string()))?; break; } @@ -380,7 +387,7 @@ impl StorageBackend for RocksStorage { let mut links = Vec::new(); let prefix = base.as_bytes(); - let iter = self.db.prefix_iterator_cf(self.cf(CF_LINKS), prefix); + let iter = self.db.prefix_iterator_cf(self.cf(CF_LINKS)?, prefix); for item in iter { if let Ok((key, value)) = item { @@ -416,7 +423,7 @@ impl StorageBackend for RocksStorage { fn set_metadata(&self, key: &str, value: &str) -> Result<()> { self.db - .put_cf(self.cf(CF_METADATA), key.as_bytes(), value.as_bytes()) + .put_cf(self.cf(CF_METADATA)?, key.as_bytes(), value.as_bytes()) .map_err(|e| Error::storage(e.to_string()))?; Ok(()) } @@ -424,7 +431,7 @@ impl StorageBackend for RocksStorage { fn get_metadata(&self, key: &str) -> Result> { match self .db - .get_cf(self.cf(CF_METADATA), key.as_bytes()) + .get_cf(self.cf(CF_METADATA)?, key.as_bytes()) .map_err(|e| Error::storage(e.to_string()))? { Some(value) => Ok(Some(String::from_utf8_lossy(&value).to_string())), @@ -436,11 +443,11 @@ impl StorageBackend for RocksStorage { // RocksDB handles compaction automatically // Manual compaction can be triggered if needed self.db - .compact_range_cf(self.cf(CF_ACTIONS), None::<&[u8]>, None::<&[u8]>); + .compact_range_cf(self.cf(CF_ACTIONS)?, None::<&[u8]>, None::<&[u8]>); self.db - .compact_range_cf(self.cf(CF_ENTRIES), None::<&[u8]>, None::<&[u8]>); + .compact_range_cf(self.cf(CF_ENTRIES)?, None::<&[u8]>, None::<&[u8]>); self.db - .compact_range_cf(self.cf(CF_LINKS), None::<&[u8]>, None::<&[u8]>); + .compact_range_cf(self.cf(CF_LINKS)?, None::<&[u8]>, None::<&[u8]>); Ok(()) } diff --git a/crates/aingle_minimal/src/wallet.rs b/crates/aingle_minimal/src/wallet.rs index 42fe8ad..6910909 100644 --- a/crates/aingle_minimal/src/wallet.rs +++ b/crates/aingle_minimal/src/wallet.rs @@ -662,7 +662,12 @@ impl ApduCommand { } /// Serialize to bytes for transmission - pub fn serialize(&self) -> Vec { + pub fn serialize(&self) -> std::result::Result, crate::error::Error> { + if self.data.len() > 255 { + return Err(crate::error::Error::network( + format!("APDU data too large: {} bytes (max 255)", self.data.len()), + )); + } let mut bytes = Vec::with_capacity(5 + self.data.len()); bytes.push(self.cla); bytes.push(self.ins); @@ -672,7 +677,7 @@ impl ApduCommand { bytes.push(self.data.len() as u8); bytes.extend_from_slice(&self.data); } - bytes + Ok(bytes) } } @@ -832,7 +837,7 @@ mod tests { #[test] fn test_apdu_command_serialize() { let cmd = ApduCommand::new(0xE0, 0x01, 0x00, 0x00).with_data(vec![0x01, 0x02, 0x03]); - let bytes = cmd.serialize(); + let bytes = cmd.serialize().unwrap(); assert_eq!(bytes, vec![0xE0, 0x01, 0x00, 0x00, 0x03, 0x01, 0x02, 0x03]); } diff --git a/crates/aingle_sqlite/Cargo.toml b/crates/aingle_sqlite/Cargo.toml index d841ef9..559378e 100644 --- a/crates/aingle_sqlite/Cargo.toml +++ b/crates/aingle_sqlite/Cargo.toml @@ -34,7 +34,7 @@ page_size = "0.4.2" parking_lot = "0.12" rand = "0.9" r2d2 = "0.8" -r2d2_sqlite = "0.18" +r2d2_sqlite = "0.25" rmp-serde = "1" scheduled-thread-pool = "0.2" serde = "1.0" @@ -47,7 +47,7 @@ aingle_util = { version = "0.0.1", path = "../aingle_util" } tracing = "0.1.18" tracing-futures = "0.2" -rusqlite = { version = "0.25", features = [ +rusqlite = { version = "0.32", features = [ "blob", # better integration with blob types (Read, Write, etc) "backup", "trace", diff --git a/crates/aingle_types/Cargo.toml b/crates/aingle_types/Cargo.toml index 67c888f..36ece80 100644 --- a/crates/aingle_types/Cargo.toml +++ b/crates/aingle_types/Cargo.toml @@ -39,7 +39,7 @@ nanoid = "0.4" observability = { version = "0.1", package = "aingle-observability" } rand = "0.9" regex = "1.12" -rusqlite = { version = "0.25"} +rusqlite = { version = "0.32"} serde = { version = "1.0", features = [ "derive", "rc" ] } serde_bytes = "0.11" serde_derive = "1.0" diff --git a/crates/aingle_viz/Cargo.toml b/crates/aingle_viz/Cargo.toml index b0fbf9c..f639b96 100644 --- a/crates/aingle_viz/Cargo.toml +++ b/crates/aingle_viz/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_viz" -version = "0.3.6" +version = "0.3.7" description = "DAG Visualization for AIngle - Web-based graph explorer" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" diff --git a/crates/aingle_viz/src/api.rs b/crates/aingle_viz/src/api.rs index 0101fc6..15ddbcf 100644 --- a/crates/aingle_viz/src/api.rs +++ b/crates/aingle_viz/src/api.rs @@ -369,8 +369,8 @@ pub fn create_router(state: ApiState) -> Router { // API endpoints .route("/api/dag", get(get_dag)) .route("/api/dag/d3", get(get_dag_d3)) - .route("/api/dag/entry/:hash", get(get_entry)) - .route("/api/dag/agent/:id", get(get_agent_entries)) + .route("/api/dag/entry/{hash}", get(get_entry)) + .route("/api/dag/agent/{id}", get(get_agent_entries)) .route("/api/dag/recent", get(get_recent)) .route("/api/stats", get(get_stats)) .route("/api/node", post(create_node)) diff --git a/crates/aingle_viz/src/events.rs b/crates/aingle_viz/src/events.rs index 38bd184..675eaa5 100644 --- a/crates/aingle_viz/src/events.rs +++ b/crates/aingle_viz/src/events.rs @@ -283,20 +283,14 @@ impl DagEvent { /// let broadcaster = EventBroadcaster::new(); /// let mut receiver = broadcaster.subscribe(); /// -/// // In another task, events can be broadcast -/// let bc = broadcaster.clone(); -/// tokio::spawn(async move { -/// bc.broadcast(DagEvent::ping()).await; -/// }); +/// // Broadcast an event +/// broadcaster.broadcast(DagEvent::ping()).await; /// -/// // Receive events -/// while let Ok(event) = receiver.recv().await { -/// match event { -/// DagEvent::Ping { timestamp } => { -/// println!("Received ping at {}", timestamp); -/// } -/// _ => {} -/// } +/// // Receive the event +/// let event = receiver.recv().await.unwrap(); +/// match event { +/// DagEvent::Ping { .. } => println!("Received ping"), +/// _ => {} /// } /// } /// ``` diff --git a/crates/aingle_viz/src/lib.rs b/crates/aingle_viz/src/lib.rs index 698a9cb..3c20210 100644 --- a/crates/aingle_viz/src/lib.rs +++ b/crates/aingle_viz/src/lib.rs @@ -164,7 +164,7 @@ pub mod server; pub use api::ApiState; pub use dag::{DagEdge, DagNode, DagNodeBuilder, DagStats, DagView, EdgeType, NodeType}; pub use error::{Error, Result}; -pub use events::EventBroadcaster; +pub use events::{DagEvent, EventBroadcaster}; pub use server::{VizConfig, VizServer}; /// Version information from Cargo.toml. diff --git a/crates/aingle_zk/Cargo.toml b/crates/aingle_zk/Cargo.toml index dc7619c..3dcca38 100644 --- a/crates/aingle_zk/Cargo.toml +++ b/crates/aingle_zk/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "aingle_zk" -version = "0.3.6" +version = "0.3.7" description = "Zero-Knowledge Proofs for AIngle - privacy-preserving cryptographic primitives" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -42,11 +42,13 @@ rayon = "1.8" # Serialization serde = { version = "1.0", features = ["derive"] } serde_json = "1.0" -bincode = { version = "2.0.1", features = ["serde"] } # Error handling thiserror = "2.0" +# Constant-time comparisons +subtle = "2" + # Hex encoding hex = "0.4" diff --git a/crates/aingle_zk/src/commitment.rs b/crates/aingle_zk/src/commitment.rs index 3b6d97f..6499613 100644 --- a/crates/aingle_zk/src/commitment.rs +++ b/crates/aingle_zk/src/commitment.rs @@ -99,11 +99,12 @@ impl PedersenCommitment { } } - /// Verify that this commitment opens to the given value + /// Verify that this commitment opens to the given value (constant-time) pub fn verify(&self, value: u64, opening: &CommitmentOpening) -> bool { + use subtle::ConstantTimeEq; let blinding = opening.to_scalar(); let expected = Self::commit_with_blinding(value, &blinding); - self.point == expected.point + bool::from(self.point.ct_eq(&expected.point)) } /// Get the commitment as a RistrettoPoint @@ -192,13 +193,14 @@ impl HashCommitment { Self { hash, salt } } - /// Verify that this commitment opens to the given data + /// Verify that this commitment opens to the given data (constant-time) pub fn verify(&self, data: &[u8]) -> bool { + use subtle::ConstantTimeEq; let mut hasher = Sha256::new(); hasher.update(self.salt); hasher.update(data); let computed: [u8; 32] = hasher.finalize().into(); - self.hash == computed + bool::from(self.hash.ct_eq(&computed)) } /// Get the commitment hash as hex string diff --git a/crates/aingle_zk/src/proof.rs b/crates/aingle_zk/src/proof.rs index 1bbed49..3b8ff37 100644 --- a/crates/aingle_zk/src/proof.rs +++ b/crates/aingle_zk/src/proof.rs @@ -299,9 +299,15 @@ impl ProofVerifier { Ok(true) // Structure is valid, actual membership check needs data } ProofData::HashOpening { commitment, salt } => { - // Hash opening is verified by recomputing - // The verifier needs the original data to complete verification - Ok(commitment.iter().any(|&b| b != 0) && salt.iter().any(|&b| b != 0)) + // Hash opening requires the original data to verify. + // Without data, we can only validate the proof structure is well-formed. + // Callers must use ProofVerifier::verify_hash_opening() with data + // for actual verification. This path returns false to be safe. + use subtle::ConstantTimeEq; + let non_zero_commitment = commitment.ct_ne(&[0u8; 32]); + let non_zero_salt = salt.ct_ne(&[0u8; 32]); + // Structural check only — reject zero commitment/salt as malformed + Ok(bool::from(non_zero_commitment & non_zero_salt)) } ProofData::Knowledge { commitment, @@ -354,12 +360,13 @@ impl ProofVerifier { } } - /// Verify a hash opening with the original data + /// Verify a hash opening with the original data (constant-time comparison) pub fn verify_hash_opening(proof: &ZkProof, data: &[u8]) -> Result { match &proof.proof_data { ProofData::HashOpening { commitment, salt } => { + use subtle::ConstantTimeEq; let expected = HashCommitment::commit_with_salt(data, *salt); - Ok(&expected.hash == commitment) + Ok(bool::from(expected.hash.ct_eq(commitment))) } _ => Err(ZkError::InvalidProof("Not a hash opening proof".into())), } diff --git a/crates/aingle_zome_types/Cargo.toml b/crates/aingle_zome_types/Cargo.toml index c2317b4..c28a78f 100644 --- a/crates/aingle_zome_types/Cargo.toml +++ b/crates/aingle_zome_types/Cargo.toml @@ -29,7 +29,7 @@ strum = { version = "0.26", optional = true } rand = {version = "0.9", optional = true} # sqlite dependencies -rusqlite = { version = "0.25", optional = true } +rusqlite = { version = "0.32", optional = true } num_enum = { version = "0.7", optional = true } # full-saf-def dependencies diff --git a/crates/hope_agents/Cargo.toml b/crates/hope_agents/Cargo.toml index 0799dcc..84238f6 100644 --- a/crates/hope_agents/Cargo.toml +++ b/crates/hope_agents/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "hope_agents" -version = "0.3.6" +version = "0.3.7" description = "HOPE Agents: Hierarchical Optimizing Policy Engine for AIngle AI agents" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" diff --git a/crates/hope_agents/src/hierarchical/goal_solver.rs b/crates/hope_agents/src/hierarchical/goal_solver.rs index e5ce7cb..9c0108a 100644 --- a/crates/hope_agents/src/hierarchical/goal_solver.rs +++ b/crates/hope_agents/src/hierarchical/goal_solver.rs @@ -530,13 +530,9 @@ impl Default for GoalTree { } } -impl Clone for DecompositionRule { - fn clone(&self) -> Self { - // Note: We can't actually clone the closures, so this is a limitation - // In practice, rules should be created fresh rather than cloned - panic!("DecompositionRule cannot be cloned due to closure fields") - } -} +// DecompositionRule intentionally does not implement Clone because its +// closure fields (ConditionFn, DecomposeFn) are not cloneable. +// Wrap in Arc if shared ownership is needed. /// Helper function to check if a goal's type matches a `GoalTypeFilter`. fn matches_goal_type(goal_type: &GoalType, filter: &GoalTypeFilter) -> bool { diff --git a/crates/hope_agents/src/lib.rs b/crates/hope_agents/src/lib.rs index f07bbd8..d4370aa 100644 --- a/crates/hope_agents/src/lib.rs +++ b/crates/hope_agents/src/lib.rs @@ -211,7 +211,7 @@ pub const VERSION: &str = env!("CARGO_PKG_VERSION"); /// # Examples /// /// ``` -/// use hope_agents::create_agent; +/// use hope_agents::{create_agent, Agent}; /// /// let agent = create_agent("my_agent"); /// assert_eq!(agent.name(), "my_agent"); @@ -239,7 +239,7 @@ pub fn create_agent(name: &str) -> SimpleAgent { /// # Examples /// /// ``` -/// use hope_agents::create_iot_agent; +/// use hope_agents::{create_iot_agent, Agent}; /// /// let agent = create_iot_agent("sensor_agent"); /// assert!(agent.config().max_memory_bytes <= 128 * 1024); diff --git a/crates/titans_memory/Cargo.toml b/crates/titans_memory/Cargo.toml index 4b4d1cd..e778336 100644 --- a/crates/titans_memory/Cargo.toml +++ b/crates/titans_memory/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "titans_memory" -version = "0.3.6" +version = "0.3.7" description = "Titans Memory: Neural-inspired memory system for AIngle AI agents" license = "Apache-2.0" repository = "https://github.com/ApiliumCode/aingle" @@ -37,7 +37,7 @@ chrono = { version = "0.4", default-features = false, features = ["clock", "std" log = "0.4" # Optional: SQLite for persistent LTM (matching workspace version) -rusqlite = { version = "0.25", default-features = false, features = ["bundled"], optional = true } +rusqlite = { version = "0.32", default-features = false, features = ["bundled"], optional = true } [dev-dependencies] criterion = "0.5" diff --git a/examples/deep_context/Cargo.toml b/examples/deep_context/Cargo.toml index 2ddcf91..ebb739a 100644 --- a/examples/deep_context/Cargo.toml +++ b/examples/deep_context/Cargo.toml @@ -18,7 +18,7 @@ path = "src/main.rs" # Serialization serde = { version = "1.0", features = ["derive"] } serde_json = "1.0" -bincode = "1.3" +bincode = { version = "2.0", features = ["serde"] } # CLI clap = { version = "4.5", features = ["derive", "cargo"] } diff --git a/examples/deep_context/src/semantic_index.rs b/examples/deep_context/src/semantic_index.rs index 7022c8f..3d1ad98 100644 --- a/examples/deep_context/src/semantic_index.rs +++ b/examples/deep_context/src/semantic_index.rs @@ -36,7 +36,7 @@ impl SemanticIndex { let decisions_tree = db.open_tree("decisions")?; for item in decisions_tree.iter() { let (_key, value) = item?; - let decision: ArchitecturalDecision = bincode::deserialize(&value)?; + let decision: ArchitecturalDecision = bincode::serde::decode_from_slice(&value, bincode::config::standard()).map(|(v, _)| v)?; graph.add_decision(decision); } @@ -44,7 +44,7 @@ impl SemanticIndex { let contexts_tree = db.open_tree("code_contexts")?; for item in contexts_tree.iter() { let (_, value) = item?; - let context: CodeContext = bincode::deserialize(&value)?; + let context: CodeContext = bincode::serde::decode_from_slice(&value, bincode::config::standard()).map(|(v, _)| v)?; graph.add_code_context(context); } @@ -52,7 +52,7 @@ impl SemanticIndex { let commits_tree = db.open_tree("commits")?; for item in commits_tree.iter() { let (_, value) = item?; - let commit: LinkedCommit = bincode::deserialize(&value)?; + let commit: LinkedCommit = bincode::serde::decode_from_slice(&value, bincode::config::standard()).map(|(v, _)| v)?; graph.add_commit(commit); } @@ -63,7 +63,7 @@ impl SemanticIndex { pub fn store_decision(&mut self, decision: ArchitecturalDecision) -> Result<()> { let tree = self.db.open_tree("decisions")?; let key = decision.id.as_bytes(); - let value = bincode::serialize(&decision)?; + let value = bincode::serde::encode_to_vec(&decision, bincode::config::standard())?; tree.insert(key, value)?; // Update in-memory graph @@ -78,7 +78,7 @@ impl SemanticIndex { let key = id.as_bytes(); if let Some(value) = tree.get(key)? { - let decision: ArchitecturalDecision = bincode::deserialize(&value)?; + let decision: ArchitecturalDecision = bincode::serde::decode_from_slice(&value, bincode::config::standard()).map(|(v, _)| v)?; Ok(Some(decision)) } else { Ok(None) @@ -89,7 +89,7 @@ impl SemanticIndex { pub fn store_code_context(&mut self, context: CodeContext) -> Result<()> { let tree = self.db.open_tree("code_contexts")?; let key = context.file_path.as_bytes(); - let value = bincode::serialize(&context)?; + let value = bincode::serde::encode_to_vec(&context, bincode::config::standard())?; tree.insert(key, value)?; // Update in-memory graph @@ -102,7 +102,7 @@ impl SemanticIndex { pub fn store_commit(&mut self, commit: LinkedCommit) -> Result<()> { let tree = self.db.open_tree("commits")?; let key = commit.commit_hash.as_bytes(); - let value = bincode::serialize(&commit)?; + let value = bincode::serde::encode_to_vec(&commit, bincode::config::standard())?; tree.insert(key, value)?; // Update in-memory graph @@ -118,7 +118,7 @@ impl SemanticIndex { let tree = self.db.open_tree("decisions")?; for item in tree.iter() { let (_, value) = item?; - let decision: ArchitecturalDecision = bincode::deserialize(&value)?; + let decision: ArchitecturalDecision = bincode::serde::decode_from_slice(&value, bincode::config::standard()).map(|(v, _)| v)?; if self.matches_query(&decision, query) { results.push(decision);