From 136264891257590c969c6dcc4c134d0e6e105a31 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 10:44:57 +0200 Subject: [PATCH 01/10] Update vaultrs Signed-off-by: Ryan Levick --- Cargo.lock | 22 +++++++++++----------- crates/factor-variables/Cargo.toml | 2 +- crates/telemetry/Cargo.toml | 2 +- 3 files changed, 13 insertions(+), 13 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 9f21b99435..a78957d58a 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1826,11 +1826,11 @@ dependencies = [ [[package]] name = "derive_builder" -version = "0.11.2" +version = "0.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d07adf7be193b71cc36b193d0f5fe60b918a3a9db4dad0449f57bcfd519704a3" +checksum = "8d67778784b508018359cbc8696edb3db78160bab2c2a28ba7f56ef6932997f8" dependencies = [ - "derive_builder_macro 0.11.2", + "derive_builder_macro 0.12.0", ] [[package]] @@ -1844,9 +1844,9 @@ dependencies = [ [[package]] name = "derive_builder_core" -version = "0.11.2" +version = "0.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1f91d4cfa921f1c05904dc3c57b4a32c38aed3340cce209f3a6fd1478babafc4" +checksum = "c11bdc11a0c47bc7d37d582b5285da6849c96681023680b906673c5707af7b0f" dependencies = [ "darling 0.14.4", "proc-macro2", @@ -1868,11 +1868,11 @@ dependencies = [ [[package]] name = "derive_builder_macro" -version = "0.11.2" +version = "0.12.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f0314b72bed045f3a68671b3c86328386762c93f82d98c65c3cb5e5f573dd68" +checksum = "ebcda35c7a396850a55ffeac740804b40ffec779b98fffbb1738f4033f0ee79e" dependencies = [ - "derive_builder_core 0.11.2", + "derive_builder_core 0.12.0", "syn 1.0.109", ] @@ -9029,13 +9029,13 @@ checksum = "74797339c3b98616c009c7c3eb53a0ce41e85c8ec66bd3db96ed132d20cfdee8" [[package]] name = "vaultrs" -version = "0.6.2" +version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "267f958930e08323a44c12e6c5461f3eaaa16d88785e9ec8550215b8aafc3d0b" +checksum = "0bb996bb053adadc767f8b0bda2a80bc2b67d24fe89f2b959ae919e200d79a19" dependencies = [ "async-trait", "bytes", - "derive_builder 0.11.2", + "derive_builder 0.12.0", "http 0.2.12", "reqwest 0.11.27", "rustify", diff --git a/crates/factor-variables/Cargo.toml b/crates/factor-variables/Cargo.toml index 5f1a1d9608..e1e16ace88 100644 --- a/crates/factor-variables/Cargo.toml +++ b/crates/factor-variables/Cargo.toml @@ -16,7 +16,7 @@ spin-world = { path = "../world" } tokio = { version = "1", features = ["rt-multi-thread"] } toml = { workspace = true } tracing = { workspace = true } -vaultrs = "0.6.2" +vaultrs = "0.7" [dev-dependencies] spin-factors-test = { path = "../factors-test" } diff --git a/crates/telemetry/Cargo.toml b/crates/telemetry/Cargo.toml index ff797ac2d6..07da37bb6b 100644 --- a/crates/telemetry/Cargo.toml +++ b/crates/telemetry/Cargo.toml @@ -9,7 +9,7 @@ anyhow = { workspace = true } http0 = { version = "0.2.9", package = "http" } http1 = { version = "1.0.0", package = "http" } opentelemetry = { workspace = true } -opentelemetry-otlp = { version = "0.25", default-features = false, features = ["http-proto", "trace", "http", "reqwest-client", "metrics", "grpc-tonic", "logs"] } +opentelemetry-otlp = { version = "0.25", features = ["http-proto", "http", "reqwest-client"] } opentelemetry-semantic-conventions = "0.25" opentelemetry_sdk = { workspace = true } terminal = { path = "../terminal" } From e8f43a794f21858205031d12c85753e5bb4110a1 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 11:07:57 +0200 Subject: [PATCH 02/10] Update component reflection crates Signed-off-by: Ryan Levick --- Cargo.lock | 84 +++--------------------------- crates/componentize/Cargo.toml | 10 ++-- crates/componentize/src/convert.rs | 65 ++++++++++++----------- crates/componentize/src/lib.rs | 3 ++ 4 files changed, 50 insertions(+), 112 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index a78957d58a..30ecfb555b 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -7122,14 +7122,14 @@ dependencies = [ "tokio", "toml 0.8.15", "tracing", - "wasm-encoder 0.200.0", - "wasm-metadata 0.200.0", - "wasmparser 0.200.0", + "wasm-encoder 0.217.0", + "wasm-metadata 0.217.0", + "wasmparser 0.217.0", "wasmtime", "wasmtime-wasi", "wat", - "wit-component 0.200.0", - "wit-parser 0.200.0", + "wit-component 0.217.0", + "wit-parser 0.217.0", ] [[package]] @@ -9384,15 +9384,6 @@ dependencies = [ "wasmparser 0.121.2", ] -[[package]] -name = "wasm-encoder" -version = "0.200.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9e3fb0c8fbddd78aa6095b850dfeedbc7506cf5f81e633f69cf8f2333ab84b9" -dependencies = [ - "leb128", -] - [[package]] name = "wasm-encoder" version = "0.202.0" @@ -9421,22 +9412,6 @@ dependencies = [ "wasmparser 0.217.0", ] -[[package]] -name = "wasm-metadata" -version = "0.200.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c31b8cc0c21f46d55b0aaa419cacce1eadcf28eaebd0e1488d6a6313ee71a586" -dependencies = [ - "anyhow", - "indexmap 2.5.0", - "serde 1.0.210", - "serde_derive", - "serde_json", - "spdx", - "wasm-encoder 0.200.0", - "wasmparser 0.200.0", -] - [[package]] name = "wasm-metadata" version = "0.202.0" @@ -9558,17 +9533,6 @@ dependencies = [ "semver", ] -[[package]] -name = "wasmparser" -version = "0.200.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a03f65ac876612140c57ff6c3b8fe4990067cce97c2cfdb07368a3cc3354b062" -dependencies = [ - "bitflags 2.6.0", - "indexmap 2.5.0", - "semver", -] - [[package]] name = "wasmparser" version = "0.202.0" @@ -9605,6 +9569,7 @@ dependencies = [ "hashbrown 0.14.3", "indexmap 2.5.0", "semver", + "serde 1.0.210", ] [[package]] @@ -10506,25 +10471,6 @@ dependencies = [ "windows-sys 0.52.0", ] -[[package]] -name = "wit-component" -version = "0.200.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39979723340baea490b87b11b2abae05f149d86f2b55c18d41d78a2a2b284c16" -dependencies = [ - "anyhow", - "bitflags 2.6.0", - "indexmap 2.5.0", - "log", - "serde 1.0.210", - "serde_derive", - "serde_json", - "wasm-encoder 0.200.0", - "wasm-metadata 0.200.0", - "wasmparser 0.200.0", - "wit-parser 0.200.0", -] - [[package]] name = "wit-component" version = "0.209.1" @@ -10563,24 +10509,6 @@ dependencies = [ "wit-parser 0.217.0", ] -[[package]] -name = "wit-parser" -version = "0.200.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f717576b37f01c15696bda7f6f13868367b9c5913485f9f0ec8e59fd28c8e13" -dependencies = [ - "anyhow", - "id-arena", - "indexmap 2.5.0", - "log", - "semver", - "serde 1.0.210", - "serde_derive", - "serde_json", - "unicode-xid", - "wasmparser 0.200.0", -] - [[package]] name = "wit-parser" version = "0.209.1" diff --git a/crates/componentize/Cargo.toml b/crates/componentize/Cargo.toml index 0b1a716e37..ee42c600ad 100644 --- a/crates/componentize/Cargo.toml +++ b/crates/componentize/Cargo.toml @@ -11,11 +11,11 @@ rust-version.workspace = true [dependencies] anyhow = { workspace = true } tracing = { workspace = true } -wasm-encoder = "0.200.0" -wasm-metadata = "0.200.0" -wasmparser = "0.200.0" -wit-component = "0.200.0" -wit-parser = "0.200.0" +wasm-encoder = "0.217" +wasm-metadata = "0.217" +wasmparser = "0.217" +wit-component = "0.217" +wit-parser = "0.217" [dev-dependencies] async-trait = { workspace = true } diff --git a/crates/componentize/src/convert.rs b/crates/componentize/src/convert.rs index 42fde379db..39f7d6c945 100644 --- a/crates/componentize/src/convert.rs +++ b/crates/componentize/src/convert.rs @@ -1,11 +1,8 @@ #![allow(clippy::from_over_into)] -use { - wasm_encoder::{ - EntityType, ExportKind, GlobalType, HeapType, MemoryType, RefType, TableType, TagKind, - TagType, ValType, - }, - wasmparser::{ExternalKind, TypeRef}, +use wasm_encoder::{ + AbstractHeapType, EntityType, ExportKind, GlobalType, HeapType, MemoryType, RefType, TableType, + TagKind, TagType, ValType, }; struct IntoHeapType(wasmparser::HeapType); @@ -13,20 +10,26 @@ struct IntoHeapType(wasmparser::HeapType); impl Into for IntoHeapType { fn into(self) -> HeapType { match self.0 { - wasmparser::HeapType::Func => HeapType::Func, - wasmparser::HeapType::Extern => HeapType::Extern, wasmparser::HeapType::Concrete(_) => { panic!("user-defined heap types not yet supported") } - wasmparser::HeapType::Any => HeapType::Any, - wasmparser::HeapType::None => HeapType::None, - wasmparser::HeapType::NoExtern => HeapType::NoExtern, - wasmparser::HeapType::NoFunc => HeapType::NoFunc, - wasmparser::HeapType::Eq => HeapType::Eq, - wasmparser::HeapType::Struct => HeapType::Struct, - wasmparser::HeapType::Array => HeapType::Array, - wasmparser::HeapType::I31 => HeapType::I31, - wasmparser::HeapType::Exn => HeapType::Exn, + wasmparser::HeapType::Abstract { ty, shared } => { + let ty = match ty { + wasmparser::AbstractHeapType::Func => AbstractHeapType::Func, + wasmparser::AbstractHeapType::Extern => AbstractHeapType::Extern, + wasmparser::AbstractHeapType::Any => AbstractHeapType::Any, + wasmparser::AbstractHeapType::None => AbstractHeapType::None, + wasmparser::AbstractHeapType::NoExtern => AbstractHeapType::NoExtern, + wasmparser::AbstractHeapType::NoFunc => AbstractHeapType::NoFunc, + wasmparser::AbstractHeapType::Eq => AbstractHeapType::Eq, + wasmparser::AbstractHeapType::Struct => AbstractHeapType::Struct, + wasmparser::AbstractHeapType::Array => AbstractHeapType::Array, + wasmparser::AbstractHeapType::I31 => AbstractHeapType::I31, + wasmparser::AbstractHeapType::Exn => AbstractHeapType::Exn, + wasmparser::AbstractHeapType::NoExn => AbstractHeapType::NoExn, + }; + HeapType::Abstract { shared, ty } + } } } } @@ -67,28 +70,32 @@ impl Into for IntoTagKind { } } -pub struct IntoEntityType(pub TypeRef); +pub struct IntoEntityType(pub wasmparser::TypeRef); impl Into for IntoEntityType { fn into(self) -> EntityType { match self.0 { - TypeRef::Func(index) => EntityType::Function(index), - TypeRef::Table(ty) => EntityType::Table(TableType { + wasmparser::TypeRef::Func(index) => EntityType::Function(index), + wasmparser::TypeRef::Table(ty) => EntityType::Table(TableType { element_type: IntoRefType(ty.element_type).into(), minimum: ty.initial, maximum: ty.maximum, + table64: ty.table64, + shared: ty.shared, }), - TypeRef::Memory(ty) => EntityType::Memory(MemoryType { + wasmparser::TypeRef::Memory(ty) => EntityType::Memory(MemoryType { minimum: ty.initial, maximum: ty.maximum, memory64: ty.memory64, shared: ty.shared, + page_size_log2: ty.page_size_log2, }), - TypeRef::Global(ty) => EntityType::Global(GlobalType { + wasmparser::TypeRef::Global(ty) => EntityType::Global(GlobalType { val_type: IntoValType(ty.content_type).into(), mutable: ty.mutable, + shared: ty.shared, }), - TypeRef::Tag(ty) => EntityType::Tag(TagType { + wasmparser::TypeRef::Tag(ty) => EntityType::Tag(TagType { kind: IntoTagKind(ty.kind).into(), func_type_idx: ty.func_type_idx, }), @@ -96,16 +103,16 @@ impl Into for IntoEntityType { } } -pub struct IntoExportKind(pub ExternalKind); +pub struct IntoExportKind(pub wasmparser::ExternalKind); impl Into for IntoExportKind { fn into(self) -> ExportKind { match self.0 { - ExternalKind::Func => ExportKind::Func, - ExternalKind::Table => ExportKind::Table, - ExternalKind::Memory => ExportKind::Memory, - ExternalKind::Global => ExportKind::Global, - ExternalKind::Tag => ExportKind::Tag, + wasmparser::ExternalKind::Func => ExportKind::Func, + wasmparser::ExternalKind::Table => ExportKind::Table, + wasmparser::ExternalKind::Memory => ExportKind::Memory, + wasmparser::ExternalKind::Global => ExportKind::Global, + wasmparser::ExternalKind::Tag => ExportKind::Tag, } } } diff --git a/crates/componentize/src/lib.rs b/crates/componentize/src/lib.rs index 7e43389e6e..061530f51c 100644 --- a/crates/componentize/src/lib.rs +++ b/crates/componentize/src/lib.rs @@ -135,6 +135,9 @@ pub fn componentize_old_bindgen(module: &[u8]) -> Result> { .collect::>(); let (adapter, mut bindgen) = metadata::decode(SPIN_ADAPTER)?; + let adapter = adapter.expect( + "adapter module was malformed, and did not contain a 'component-type' custom section", + ); let world = bindgen .resolve From 1aad078739e68288fd3e876574d08bad141d8577 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 11:10:02 +0200 Subject: [PATCH 03/10] Update cap-std Signed-off-by: Ryan Levick --- Cargo.lock | 49 +++++++--------------------------- crates/componentize/Cargo.toml | 2 +- 2 files changed, 11 insertions(+), 40 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 30ecfb555b..2edb83d03f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -959,8 +959,8 @@ version = "3.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "769f8cd02eb04d57f14e2e371ebb533f96817f9b2525d73a5c72b61ca7973747" dependencies = [ - "cap-primitives 3.0.0", - "cap-std 3.0.0", + "cap-primitives", + "cap-std", "io-lifetimes 2.0.3", "windows-sys 0.52.0", ] @@ -971,29 +971,12 @@ version = "3.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "59ff6d3fb274292a9af283417e383afe6ded1fe66f6472d2c781216d3d80c218" dependencies = [ - "cap-primitives 3.0.0", - "cap-std 3.0.0", + "cap-primitives", + "cap-std", "rustix 0.38.32", "smallvec", ] -[[package]] -name = "cap-primitives" -version = "2.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fe16767ed8eee6d3f1f00d6a7576b81c226ab917eb54b96e5f77a5216ef67abb" -dependencies = [ - "ambient-authority", - "fs-set-times", - "io-extras", - "io-lifetimes 2.0.3", - "ipnet", - "maybe-owned", - "rustix 0.38.32", - "windows-sys 0.52.0", - "winx", -] - [[package]] name = "cap-primitives" version = "3.0.0" @@ -1021,25 +1004,13 @@ dependencies = [ "rand 0.8.5", ] -[[package]] -name = "cap-std" -version = "2.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "593db20e4c51f62d3284bae7ee718849c3214f93a3b94ea1899ad85ba119d330" -dependencies = [ - "cap-primitives 2.0.1", - "io-extras", - "io-lifetimes 2.0.3", - "rustix 0.38.32", -] - [[package]] name = "cap-std" version = "3.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "266626ce180cf9709f317d0bf9754e3a5006359d87f4bf792f06c9c5f1b63c0f" dependencies = [ - "cap-primitives 3.0.0", + "cap-primitives", "io-extras", "io-lifetimes 2.0.3", "rustix 0.38.32", @@ -1052,7 +1023,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e1353421ba83c19da60726e35db0a89abef984b3be183ff6f58c5b8084fcd0c5" dependencies = [ "ambient-authority", - "cap-primitives 3.0.0", + "cap-primitives", "iana-time-zone", "once_cell", "rustix 0.38.32", @@ -7112,7 +7083,7 @@ version = "2.8.0-pre0" dependencies = [ "anyhow", "async-trait", - "cap-std 2.0.1", + "cap-std", "rand 0.8.5", "rand_chacha 0.3.1", "rand_core 0.6.4", @@ -7412,7 +7383,7 @@ version = "2.8.0-pre0" dependencies = [ "async-trait", "bytes", - "cap-primitives 3.0.0", + "cap-primitives", "spin-common", "spin-factors", "spin-factors-test", @@ -8205,7 +8176,7 @@ checksum = "b858526d22750088a9b3cf2e3c2aacebd5377f13adeec02860c30d09113010a6" dependencies = [ "bitflags 2.6.0", "cap-fs-ext", - "cap-std 3.0.0", + "cap-std", "fd-lock", "io-lifetimes 2.0.3", "rustix 0.38.32", @@ -9829,7 +9800,7 @@ dependencies = [ "cap-fs-ext", "cap-net-ext", "cap-rand", - "cap-std 3.0.0", + "cap-std", "cap-time-ext", "fs-set-times", "futures", diff --git a/crates/componentize/Cargo.toml b/crates/componentize/Cargo.toml index ee42c600ad..06c549d5d8 100644 --- a/crates/componentize/Cargo.toml +++ b/crates/componentize/Cargo.toml @@ -19,7 +19,7 @@ wit-parser = "0.217" [dev-dependencies] async-trait = { workspace = true } -cap-std = "2.0" +cap-std = "3" rand = { workspace = true } rand_chacha = "0.3" rand_core = "0.6" From c928474069b35261e20adebae9d771908b1e9aab Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 11:13:49 +0200 Subject: [PATCH 04/10] Update llm deps Signed-off-by: Ryan Levick --- Cargo.lock | 35 ++++++++--------------------------- crates/llm-local/Cargo.toml | 12 ++++++------ 2 files changed, 14 insertions(+), 33 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 2edb83d03f..b2f85a4180 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -894,7 +894,7 @@ dependencies = [ "rand 0.8.5", "rand_distr", "rayon", - "safetensors 0.4.4", + "safetensors", "thiserror", "yoke", "zip", @@ -930,7 +930,7 @@ dependencies = [ "metal", "num-traits 0.2.18", "rayon", - "safetensors 0.4.4", + "safetensors", "serde 1.0.210", "thiserror", ] @@ -4181,15 +4181,6 @@ dependencies = [ "logos-codegen 0.14.0", ] -[[package]] -name = "lru" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "71e7d46de488603ffdd5f30afbc64fbba2378214a2c3a2fb83abf3d33126df17" -dependencies = [ - "hashbrown 0.13.2", -] - [[package]] name = "lru" version = "0.12.3" @@ -4460,7 +4451,7 @@ dependencies = [ "futures-sink", "futures-util", "keyed_priority_queue", - "lru 0.12.3", + "lru", "mysql_common", "native-tls", "pem", @@ -6401,16 +6392,6 @@ version = "1.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e86697c916019a8588c99b5fac3cead74ec0b4b819707a682fd4d23fa0ce1ba1" -[[package]] -name = "safetensors" -version = "0.3.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d93279b86b3de76f820a8854dd06cbc33cfa57a417b19c47f6a25280112fb1df" -dependencies = [ - "serde 1.0.210", - "serde_json", -] - [[package]] name = "safetensors" version = "0.4.4" @@ -7175,7 +7156,7 @@ name = "spin-factor-key-value" version = "2.8.0-pre0" dependencies = [ "anyhow", - "lru 0.12.3", + "lru", "serde 1.0.210", "spin-core", "spin-factors", @@ -7512,10 +7493,10 @@ dependencies = [ "candle-nn", "candle-transformers", "chrono", - "lru 0.9.0", + "lru", "num_cpus", "rand 0.8.5", - "safetensors 0.3.3", + "safetensors", "serde 1.0.210", "serde_json", "spin-common", @@ -8415,9 +8396,9 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokenizers" -version = "0.19.1" +version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e500fad1dd3af3d626327e6a3fe5050e664a6eaa4708b8ca92f1794aaf73e6fd" +checksum = "c8a24d7f7d6be5b9d1377418b893ab1808af0074f5d1bb2c64784452ddd2aa70" dependencies = [ "aho-corasick", "derive_builder 0.20.0", diff --git a/crates/llm-local/Cargo.toml b/crates/llm-local/Cargo.toml index b7faed7151..646e2cdf9c 100644 --- a/crates/llm-local/Cargo.toml +++ b/crates/llm-local/Cargo.toml @@ -9,19 +9,19 @@ anyhow = "1.0" candle = { git = "https://github.com/huggingface/candle", rev = "e3261216b157a7305c18ccdd766b6e2a41afe483", package = "candle-core" } candle-nn = { git = "https://github.com/huggingface/candle", rev = "e3261216b157a7305c18ccdd766b6e2a41afe483" } candle-transformers = { git = "https://github.com/huggingface/candle", rev = "e3261216b157a7305c18ccdd766b6e2a41afe483" } -chrono = "0.4.26" -lru = "0.9.0" +chrono = "0.4" +lru = "0.12" num_cpus = "1" rand = { workspace = true } -safetensors = "0.3.3" +safetensors = "0.4" serde = { workspace = true } -serde_json = "1.0.125" +serde_json = "1" spin-common = { path = "../common" } spin-core = { path = "../core" } spin-world = { path = "../world" } terminal = { path = "../terminal" } -tokenizers = "0.19.1" -tokio = { version = "1.32.0", features = ["macros", "sync"] } +tokenizers = "0.20" +tokio = { version = "1", features = ["macros", "sync", "fs"] } tracing = { workspace = true } [features] From ff1b7d0df32ea5659dac2b946dfea46423fcec22 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 11:41:34 +0200 Subject: [PATCH 05/10] Update spin-factor-outbound-networking deps Signed-off-by: Ryan Levick --- Cargo.lock | 4 ++-- crates/factor-llm/src/spin.rs | 4 ++-- crates/factor-outbound-networking/Cargo.toml | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b2f85a4180..c5fec76478 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6355,9 +6355,9 @@ dependencies = [ [[package]] name = "rustls-pki-types" -version = "1.7.0" +version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "976295e77ce332211c0d24d92c0e83e50f5c5f046d11082cea19f3df13a3562d" +checksum = "fc0a2ce646f8655401bb81e7927b812614bd5d91dbc968696be50603510fcaf0" [[package]] name = "rustls-webpki" diff --git a/crates/factor-llm/src/spin.rs b/crates/factor-llm/src/spin.rs index ec0f8d6345..08ad42745d 100644 --- a/crates/factor-llm/src/spin.rs +++ b/crates/factor-llm/src/spin.rs @@ -56,7 +56,7 @@ pub fn default_engine_creator( }; #[cfg(not(feature = "llm"))] let engine = { - let _ = (state_dir); + let _ = state_dir; noop::NoopLlmEngine }; let engine = Arc::new(Mutex::new(engine)) as Arc>; @@ -113,7 +113,7 @@ impl LlmCompute { let engine: Arc> = match self { #[cfg(not(feature = "llm"))] LlmCompute::Spin => { - let _ = (state_dir); + let _ = state_dir; Arc::new(Mutex::new(noop::NoopLlmEngine)) } #[cfg(feature = "llm")] diff --git a/crates/factor-outbound-networking/Cargo.toml b/crates/factor-outbound-networking/Cargo.toml index d6807917db..78ce240d97 100644 --- a/crates/factor-outbound-networking/Cargo.toml +++ b/crates/factor-outbound-networking/Cargo.toml @@ -11,7 +11,7 @@ http = { workspace = true } ipnet = "2" rustls = { workspace = true } rustls-pemfile = { version = "2", optional = true } -rustls-pki-types = "1.7.0" +rustls-pki-types = "1.8" serde = { workspace = true } spin-expressions = { path = "../expressions" } spin-factor-variables = { path = "../factor-variables" } @@ -23,7 +23,7 @@ spin-serde = { path = "../serde" } terminal = { path = "../terminal" } tracing = { workspace = true } url = { workspace = true } -urlencoding = "2.1" +urlencoding = "2" webpki-roots = "0.26" [dev-dependencies] From c8aa2674198965bb8ffccab46479b0943c451cd7 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 11:47:03 +0200 Subject: [PATCH 06/10] Update postgres-native-tls deps Signed-off-by: Ryan Levick --- Cargo.lock | 23 +++++++++++------------ crates/factor-outbound-pg/Cargo.toml | 6 +++--- 2 files changed, 14 insertions(+), 15 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index c5fec76478..604c49b960 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -3329,7 +3329,7 @@ dependencies = [ "httpdate", "itoa", "pin-project-lite", - "socket2 0.5.6", + "socket2 0.4.10", "tokio", "tower-service", "tracing", @@ -4504,11 +4504,10 @@ dependencies = [ [[package]] name = "native-tls" -version = "0.2.11" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07226173c32f2926027b63cce4bcd8076c3552846cbe7925f3aaffeac0a3b92e" +checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466" dependencies = [ - "lazy_static 1.4.0", "libc", "log", "openssl", @@ -5449,11 +5448,11 @@ dependencies = [ [[package]] name = "postgres-protocol" -version = "0.6.6" +version = "0.6.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "49b6c5ef183cd3ab4ba005f1ca64c21e8bd97ce4699cfea9e8d9a2c4958ca520" +checksum = "acda0ebdebc28befa84bee35e651e4c5f09073d668c7aed4cf7e23c3cda84b23" dependencies = [ - "base64 0.21.7", + "base64 0.22.1", "byteorder", "bytes", "fallible-iterator 0.2.0", @@ -5467,9 +5466,9 @@ dependencies = [ [[package]] name = "postgres-types" -version = "0.2.6" +version = "0.2.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d2234cdee9408b523530a9b6d2d6b373d1db34f6a8e51dc03ded1828d7fb67c" +checksum = "f66ea23a2d0e5734297357705193335e0a957696f34bed2f2faefacb2fec336f" dependencies = [ "bytes", "fallible-iterator 0.2.0", @@ -8468,9 +8467,9 @@ dependencies = [ [[package]] name = "tokio-postgres" -version = "0.7.10" +version = "0.7.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d340244b32d920260ae7448cb72b6e238bddc3d4f7603394e7dd46ed8e48f5b8" +checksum = "3b5d3742945bc7d7f210693b0c58ae542c6fd47b17adbbda0885f3dcb34a6bdb" dependencies = [ "async-trait", "byteorder", @@ -8797,7 +8796,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "97fee6b57c6a41524a810daee9286c02d7752c4253064d0b05472833a438f675" dependencies = [ "cfg-if", - "rand 0.8.5", + "rand 0.7.3", "static_assertions", ] diff --git a/crates/factor-outbound-pg/Cargo.toml b/crates/factor-outbound-pg/Cargo.toml index 9a55f08841..687acdaa3c 100644 --- a/crates/factor-outbound-pg/Cargo.toml +++ b/crates/factor-outbound-pg/Cargo.toml @@ -6,15 +6,15 @@ edition = { workspace = true } [dependencies] anyhow = { workspace = true } -native-tls = "0.2.11" -postgres-native-tls = "0.5.0" +native-tls = "0.2" +postgres-native-tls = "0.5" spin-core = { path = "../core" } spin-factor-outbound-networking = { path = "../factor-outbound-networking" } spin-factors = { path = "../factors" } spin-world = { path = "../world" } table = { path = "../table" } tokio = { version = "1", features = ["rt-multi-thread"] } -tokio-postgres = "0.7.7" +tokio-postgres = "0.7" tracing = { workspace = true } [dev-dependencies] From d0cf03f0d8d73db278c2e881ac0757bd027035d2 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 12:07:23 +0200 Subject: [PATCH 07/10] Update redis Signed-off-by: Ryan Levick --- Cargo.lock | 30 ++++++++++-------------- crates/factor-outbound-redis/Cargo.toml | 4 +--- crates/factor-outbound-redis/src/host.rs | 8 +++---- crates/key-value-redis/Cargo.toml | 2 +- crates/key-value-redis/src/store.rs | 8 +++---- 5 files changed, 22 insertions(+), 30 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 604c49b960..73048aa596 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -3329,7 +3329,7 @@ dependencies = [ "httpdate", "itoa", "pin-project-lite", - "socket2 0.4.10", + "socket2 0.5.6", "tokio", "tower-service", "tracing", @@ -4493,7 +4493,7 @@ dependencies = [ "saturating", "serde 1.0.210", "serde_json", - "sha1 0.10.6", + "sha1", "sha2", "smallvec", "subprocess", @@ -5859,9 +5859,9 @@ checksum = "03251193000f4bd3b042892be858ee50e8b3719f2b08e5833ac4353724632430" [[package]] name = "redis" -version = "0.21.7" +version = "0.25.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "152f3863635cbb76b73bc247845781098302c6c9ad2060e1a9a7de56840346b6" +checksum = "e0d7a6955c7511f60f3ba9e86c6d02b3c3f144f8c24b288d1f4e18074ab8bbec" dependencies = [ "async-trait", "bytes", @@ -5872,7 +5872,8 @@ dependencies = [ "percent-encoding", "pin-project-lite", "ryu", - "sha1 0.6.1", + "sha1_smol", + "socket2 0.5.6", "tokio", "tokio-native-tls", "tokio-util", @@ -5891,6 +5892,7 @@ dependencies = [ "combine", "futures-util", "itoa", + "native-tls", "num-bigint", "percent-encoding", "pin-project-lite", @@ -5898,6 +5900,7 @@ dependencies = [ "sha1_smol", "socket2 0.5.6", "tokio", + "tokio-native-tls", "tokio-util", "url", ] @@ -6706,15 +6709,6 @@ dependencies = [ "unsafe-libyaml", ] -[[package]] -name = "sha1" -version = "0.6.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c1da05c97445caa12d05e848c4a4fcbbea29e748ac28f7e80e9b010392063770" -dependencies = [ - "sha1_smol", -] - [[package]] name = "sha1" version = "0.10.6" @@ -7310,7 +7304,7 @@ name = "spin-factor-outbound-redis" version = "2.8.0-pre0" dependencies = [ "anyhow", - "redis 0.21.7", + "redis 0.25.4", "spin-core", "spin-factor-outbound-networking", "spin-factor-variables", @@ -7461,7 +7455,7 @@ name = "spin-key-value-redis" version = "2.8.0-pre0" dependencies = [ "anyhow", - "redis 0.21.7", + "redis 0.27.2", "serde 1.0.210", "spin-core", "spin-factor-key-value", @@ -8796,7 +8790,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "97fee6b57c6a41524a810daee9286c02d7752c4253064d0b05472833a438f675" dependencies = [ "cfg-if", - "rand 0.7.3", + "rand 0.8.5", "static_assertions", ] @@ -10601,7 +10595,7 @@ dependencies = [ "rand 0.8.5", "serde 1.0.210", "serde_repr", - "sha1 0.10.6", + "sha1", "static_assertions", "tracing", "uds_windows", diff --git a/crates/factor-outbound-redis/Cargo.toml b/crates/factor-outbound-redis/Cargo.toml index 5925020b01..5943678a43 100644 --- a/crates/factor-outbound-redis/Cargo.toml +++ b/crates/factor-outbound-redis/Cargo.toml @@ -6,7 +6,7 @@ edition = { workspace = true } [dependencies] anyhow = { workspace = true } -redis = { version = "0.21", features = ["tokio-comp", "tokio-native-tls-comp", "aio"] } +redis = { version = "0.25", features = ["tokio-comp", "tokio-native-tls-comp", "aio"] } spin-core = { path = "../core" } spin-factor-outbound-networking = { path = "../factor-outbound-networking" } spin-factors = { path = "../factors" } @@ -14,12 +14,10 @@ spin-world = { path = "../world" } table = { path = "../table" } tracing = { workspace = true } - [dev-dependencies] spin-factor-variables = { path = "../factor-variables" } spin-factors-test = { path = "../factors-test" } tokio = { version = "1", features = ["macros", "rt"] } -# wasmtime-wasi-http = { workspace = true } [lints] workspace = true diff --git a/crates/factor-outbound-redis/src/host.rs b/crates/factor-outbound-redis/src/host.rs index a2d21d9ba5..112fb5f87c 100644 --- a/crates/factor-outbound-redis/src/host.rs +++ b/crates/factor-outbound-redis/src/host.rs @@ -1,5 +1,5 @@ use anyhow::Result; -use redis::{aio::Connection, AsyncCommands, FromRedisValue, Value}; +use redis::{aio::MultiplexedConnection, AsyncCommands, FromRedisValue, Value}; use spin_core::{async_trait, wasmtime::component::Resource}; use spin_factor_outbound_networking::OutboundAllowedHosts; use spin_world::v1::{redis as v1, redis_types}; @@ -10,7 +10,7 @@ use tracing::{instrument, Level}; pub struct InstanceState { pub allowed_hosts: OutboundAllowedHosts, - pub connections: table::Table, + pub connections: table::Table, } impl InstanceState { @@ -24,7 +24,7 @@ impl InstanceState { ) -> Result, Error> { let conn = redis::Client::open(address.as_str()) .map_err(|_| Error::InvalidAddress)? - .get_async_connection() + .get_multiplexed_async_connection() .await .map_err(other_error)?; self.connections @@ -36,7 +36,7 @@ impl InstanceState { async fn get_conn( &mut self, connection: Resource, - ) -> Result<&mut Connection, Error> { + ) -> Result<&mut MultiplexedConnection, Error> { self.connections .get_mut(connection.rep()) .ok_or(Error::Other( diff --git a/crates/key-value-redis/Cargo.toml b/crates/key-value-redis/Cargo.toml index 7d22696052..57196edf9a 100644 --- a/crates/key-value-redis/Cargo.toml +++ b/crates/key-value-redis/Cargo.toml @@ -6,7 +6,7 @@ edition = { workspace = true } [dependencies] anyhow = { workspace = true } -redis = { version = "0.21", features = ["tokio-comp", "tokio-native-tls-comp"] } +redis = { version = "0.27", features = ["tokio-comp", "tokio-native-tls-comp"] } serde = { workspace = true } spin-core = { path = "../core" } spin-factor-key-value = { path = "../factor-key-value" } diff --git a/crates/key-value-redis/src/store.rs b/crates/key-value-redis/src/store.rs index 8d9dbc11f1..8d2950305f 100644 --- a/crates/key-value-redis/src/store.rs +++ b/crates/key-value-redis/src/store.rs @@ -1,5 +1,5 @@ use anyhow::{Context, Result}; -use redis::{aio::Connection, parse_redis_url, AsyncCommands}; +use redis::{aio::MultiplexedConnection, parse_redis_url, AsyncCommands}; use spin_core::async_trait; use spin_factor_key_value::{log_error, Error, Store, StoreManager}; use std::sync::Arc; @@ -8,7 +8,7 @@ use url::Url; pub struct KeyValueRedis { database_url: Url, - connection: OnceCell>>, + connection: OnceCell>>, } impl KeyValueRedis { @@ -29,7 +29,7 @@ impl StoreManager for KeyValueRedis { .connection .get_or_try_init(|| async { redis::Client::open(self.database_url.clone())? - .get_async_connection() + .get_multiplexed_async_connection() .await .map(Mutex::new) .map(Arc::new) @@ -53,7 +53,7 @@ impl StoreManager for KeyValueRedis { } struct RedisStore { - connection: Arc>, + connection: Arc>, } #[async_trait] From 743ac8fe2b69895e0b3b85234d4b6d98c10eff36 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 12:16:34 +0200 Subject: [PATCH 08/10] Patch updates Signed-off-by: Ryan Levick --- Cargo.lock | 153 +++++++++++++++++++++++++---------------------------- 1 file changed, 72 insertions(+), 81 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 73048aa596..02d7f38b7d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -199,9 +199,9 @@ dependencies = [ [[package]] name = "async-channel" -version = "2.2.0" +version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f28243a43d821d11341ab73c80bed182dc015c514b951616cf79bd4af39af0c3" +checksum = "9f2776ead772134d55b62dd45e59a79e21612d85d0af729b8b7d3967d601a62a" dependencies = [ "concurrent-queue", "event-listener 5.3.0", @@ -225,11 +225,10 @@ dependencies = [ [[package]] name = "async-executor" -version = "1.9.1" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "10b3e585719c2358d2660232671ca8ca4ddb4be4ce8a1842d6c2dc8685303316" +checksum = "b10202063978b3351199d68f8b22c4e47e4b1b822f8d43fd862d5ea8c006b29a" dependencies = [ - "async-lock 3.3.0", "async-task", "concurrent-queue", "fastrand 2.0.2", @@ -255,7 +254,7 @@ version = "2.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "05b1b633a2115cd122d73b955eadd9916c18c8f510ec9cd1686404c60ad1c29c" dependencies = [ - "async-channel 2.2.0", + "async-channel 2.3.0", "async-executor", "async-io 2.3.2", "async-lock 3.3.0", @@ -355,7 +354,7 @@ version = "2.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a53fc6301894e04a92cb2584fedde80cb25ba8e02d9dc39d4a87d036e22f397d" dependencies = [ - "async-channel 2.2.0", + "async-channel 2.3.0", "async-io 2.3.2", "async-lock 3.3.0", "async-signal", @@ -377,7 +376,7 @@ checksum = "30c5ef0ede93efbf733c1a727f3b6b5a1060bbedd5600183e66f6e4be4af0ec5" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -444,7 +443,7 @@ checksum = "16e62a023e7c117e27523144c5d2459f4397fcc3cab0085af8e2224f643a0193" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -474,7 +473,7 @@ checksum = "a27b8a3a6e1a44fa4c8baf1f653e4172e81486d4941f2237e20dc2d0cf4ddff1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -685,22 +684,20 @@ checksum = "3a8241f3ebb85c056b509d4327ad0358fbbba6ffb340bf388f26350aeda225b1" [[package]] name = "bindgen" -version = "0.69.4" +version = "0.70.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a00dc851838a2120612785d195287475a3ac45514741da670b735818822129a0" +checksum = "f49d8fed880d473ea71efb9bf597651e77201bdd4893efe54c9e5d65ae04ce6f" dependencies = [ "bitflags 2.6.0", "cexpr", "clang-sys", - "itertools 0.12.1", - "lazy_static 1.4.0", - "lazycell", + "itertools 0.11.0", "proc-macro2", "quote", "regex", "rustc-hash", "shlex", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -796,7 +793,7 @@ version = "1.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6a37913e8dc4ddcc604f0c6d3bf2887c995153af3611de9e23c352b44c1b9118" dependencies = [ - "async-channel 2.2.0", + "async-channel 2.3.0", "async-lock 3.3.0", "async-task", "fastrand 2.0.2", @@ -808,9 +805,9 @@ dependencies = [ [[package]] name = "bstr" -version = "1.9.1" +version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05efc5cfd9110c8416e471df0e96702d58690178e206e61b7173706673c93706" +checksum = "40723b8fb387abc38f4f4a37c09073622e41dd12327033091ef8950659e6dc0c" dependencies = [ "memchr", "regex-automata 0.4.6", @@ -849,7 +846,7 @@ checksum = "0cc8b54b395f2fcfbb3d90c47b01c7f444d94d05bdeb775811dec868ac3bbc26" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -869,9 +866,9 @@ dependencies = [ [[package]] name = "camino" -version = "1.1.6" +version = "1.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c59e92b5a388f549b863a7bea62612c09f24c8393560709a54558a9abdfb3b9c" +checksum = "8b96ec4966b5813e2c0507c1f86115c8c5abaadc3980879c3424042a02fd1ad3" dependencies = [ "serde 1.0.210", ] @@ -979,9 +976,9 @@ dependencies = [ [[package]] name = "cap-primitives" -version = "3.0.0" +version = "3.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90a0b44fc796b1a84535a63753d50ba3972c4db55c7255c186f79140e63d56d0" +checksum = "6d00bd8d26c4270d950eaaa837387964a2089a1c3c349a690a1fa03221d29531" dependencies = [ "ambient-authority", "fs-set-times", @@ -1006,9 +1003,9 @@ dependencies = [ [[package]] name = "cap-std" -version = "3.0.0" +version = "3.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "266626ce180cf9709f317d0bf9754e3a5006359d87f4bf792f06c9c5f1b63c0f" +checksum = "19eb8e3d71996828751c1ed3908a439639752ac6bdc874e41469ef7fc15fbd7f" dependencies = [ "cap-primitives", "io-extras", @@ -1205,7 +1202,7 @@ dependencies = [ "heck 0.5.0", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1718,7 +1715,7 @@ dependencies = [ "proc-macro2", "quote", "strsim 0.11.1", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1740,7 +1737,7 @@ checksum = "733cabb43482b1a1b53eee8583c2b9e8684d592215ea83efd305dd31bc2f0178" dependencies = [ "darling_core 0.20.9", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1792,7 +1789,7 @@ checksum = "67e77553c4162a157adbf834ebae5b415acbecbeafc7a74b0e886657506a7611" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1834,7 +1831,7 @@ dependencies = [ "darling 0.20.9", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1854,7 +1851,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "206868b8242f27cecce124c19fd88157fbd0dd334df2587f36417bafbc85097b" dependencies = [ "derive_builder_core 0.20.0", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -1973,7 +1970,7 @@ checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -2112,7 +2109,7 @@ dependencies = [ "heck 0.4.1", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -2133,7 +2130,7 @@ checksum = "5c785274071b1b420972453b306eeca06acf4633829db4223b58a2a8c5953bc4" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -2251,7 +2248,7 @@ dependencies = [ "prettyplease", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -2407,7 +2404,7 @@ checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -2560,7 +2557,7 @@ checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -3849,12 +3846,6 @@ version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" -[[package]] -name = "lazycell" -version = "1.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "830d08ce1d1d941e6b30645f1a0eb5643013d835ce3779a5fc208261dbe10f55" - [[package]] name = "leb128" version = "0.2.5" @@ -4079,7 +4070,7 @@ checksum = "3b51f1d220e3fa869e24cfd75915efe3164bd09bb11b3165db3f37f57bf673e3" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4145,7 +4136,7 @@ dependencies = [ "proc-macro2", "quote", "regex-syntax 0.6.29", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4160,7 +4151,7 @@ dependencies = [ "proc-macro2", "quote", "regex-syntax 0.8.3", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4354,7 +4345,7 @@ checksum = "49e7bc1560b95a3c4a25d03de42fe76ca718ab92d1a22a55b9b4cf67b3ae635c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4365,7 +4356,7 @@ checksum = "dcf09caffaac8068c346b6df2a7fc27a177fd20b39421a39ce0a211bde679a6c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4429,7 +4420,7 @@ checksum = "a7ce64b975ed4f123575d11afd9491f2e37bbd5813fbfbc0f09ae1fbddea74e0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4744,7 +4735,7 @@ dependencies = [ "proc-macro-crate", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -4955,7 +4946,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -5263,7 +5254,7 @@ dependencies = [ "pest_meta", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -5343,7 +5334,7 @@ checksum = "2f38a4412a78282e09a2cf38d195ea5420d15ba0602cb375210efbc877243965" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -5494,7 +5485,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8d3928fb5db768cb86f891ff014f0144589297e3c6a1aba6ed7cecfdace270c7" dependencies = [ "proc-macro2", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -5587,7 +5578,7 @@ checksum = "80b776a1b2dc779f5ee0641f8ade0125bc1298dd41a9a0c16d8bd57b42d222b1" dependencies = [ "bytes", "heck 0.5.0", - "itertools 0.12.1", + "itertools 0.11.0", "log", "multimap", "once_cell", @@ -5596,7 +5587,7 @@ dependencies = [ "prost 0.12.4", "prost-types", "regex", - "syn 2.0.75", + "syn 2.0.77", "tempfile", ] @@ -5607,10 +5598,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "19de2de2a00075bf566bee3bd4db014b11587e84184d3f7a791bc17f1a8e9e48" dependencies = [ "anyhow", - "itertools 0.12.1", + "itertools 0.11.0", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -5623,7 +5614,7 @@ dependencies = [ "itertools 0.13.0", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -6580,7 +6571,7 @@ checksum = "243902eda00fad750862fc144cea25caca5e20d615af0a81bee94ca738f1df1f" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -6642,7 +6633,7 @@ checksum = "6c64451ba24fc7a6a2d60fc75dd9c83c90903b19028d4eff35e88fc1e86564e9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -6693,7 +6684,7 @@ dependencies = [ "darling 0.20.9", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -7387,7 +7378,7 @@ dependencies = [ "expander", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8007,7 +7998,7 @@ dependencies = [ "proc-macro2", "quote", "rustversion", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8039,9 +8030,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.75" +version = "2.0.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f6af063034fc1935ede7be0122941bafa9bacb949334d090b77ca98b5817c7d9" +checksum = "9f35bcdf61fd8e7be6caf75f429fdca8beb3ed76584befb503b1569faee373ed" dependencies = [ "proc-macro2", "quote", @@ -8083,7 +8074,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8234,7 +8225,7 @@ version = "0.0.0" dependencies = [ "heck 0.5.0", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8307,7 +8298,7 @@ checksum = "a4558b58466b9ad7ca0f102865eccc95938dca1a74a856f2b57b6629050da261" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8446,7 +8437,7 @@ checksum = "5f5ae998a069d4b5aba8ee9dad856af7d520c3699e6159b185c2acd48155d39a" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -8704,7 +8695,7 @@ checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -9253,7 +9244,7 @@ dependencies = [ "once_cell", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "wasm-bindgen-shared", ] @@ -9287,7 +9278,7 @@ checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "wasm-bindgen-backend", "wasm-bindgen-shared", ] @@ -9631,7 +9622,7 @@ dependencies = [ "anyhow", "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "wasmtime-component-util", "wasmtime-wit-bindgen", "wit-parser 0.209.1", @@ -9758,7 +9749,7 @@ checksum = "de5a9bc4f44ceeb168e9e8e3be4e0b4beb9095b468479663a9e24c667e36826f" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -10040,7 +10031,7 @@ dependencies = [ "proc-macro2", "quote", "shellexpand 2.1.2", - "syn 2.0.75", + "syn 2.0.77", "witx", ] @@ -10052,7 +10043,7 @@ checksum = "cc26129a8aea20b62c961d1b9ab4a3c3b56b10042ed85d004f8678af0f21ba6e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "wiggle-generate", ] @@ -10561,7 +10552,7 @@ checksum = "28cc31741b18cb6f1d5ff12f5b7523e3d6eb0852bbbad19d73905511d9849b95" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "synstructure 0.13.1", ] @@ -10648,7 +10639,7 @@ checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", ] [[package]] @@ -10668,7 +10659,7 @@ checksum = "0ea7b4a3637ea8669cedf0f1fd5c286a17f3de97b8dd5a70a6c167a1730e63a5" dependencies = [ "proc-macro2", "quote", - "syn 2.0.75", + "syn 2.0.77", "synstructure 0.13.1", ] From aa4f43c239d1c4de642a4be6ebabfc40ae915bc2 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 12:33:41 +0200 Subject: [PATCH 09/10] Update dialoguer Signed-off-by: Ryan Levick --- Cargo.lock | 18 +++--------------- Cargo.toml | 2 +- crates/templates/Cargo.toml | 2 +- crates/templates/src/interaction.rs | 8 ++++---- 4 files changed, 9 insertions(+), 21 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 02d7f38b7d..b58be5c88e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1854,18 +1854,6 @@ dependencies = [ "syn 2.0.77", ] -[[package]] -name = "dialoguer" -version = "0.10.4" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "59c6f2989294b9a498d3ad5491a79c6deb604617378e1cdc4bfc1c1361fe2f87" -dependencies = [ - "console", - "shell-words", - "tempfile", - "zeroize", -] - [[package]] name = "dialoguer" version = "0.11.0" @@ -6969,7 +6957,7 @@ dependencies = [ "conformance", "conformance-tests", "ctrlc", - "dialoguer 0.10.4", + "dialoguer", "dirs 5.0.1", "futures", "glob", @@ -7769,7 +7757,7 @@ dependencies = [ "async-trait", "bytes", "console", - "dialoguer 0.10.4", + "dialoguer", "dirs 5.0.1", "fs_extra", "heck 0.5.0", @@ -9093,7 +9081,7 @@ dependencies = [ "async-trait", "bytes", "clap 4.5.4", - "dialoguer 0.11.0", + "dialoguer", "dirs 5.0.1", "futures-util", "indexmap 2.5.0", diff --git a/Cargo.toml b/Cargo.toml index 78a8ae3d51..c150ff12c5 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -24,7 +24,7 @@ clearscreen = "3" comfy-table = "7" command-group = "2" ctrlc = { version = "3.4", features = ["termination"] } -dialoguer = "0.10" +dialoguer = "0.11" dirs = { workspace = true } futures = { workspace = true } glob = { workspace = true } diff --git a/crates/templates/Cargo.toml b/crates/templates/Cargo.toml index b6574c6b86..9146af0b2b 100644 --- a/crates/templates/Cargo.toml +++ b/crates/templates/Cargo.toml @@ -9,7 +9,7 @@ anyhow = { workspace = true } async-trait = { workspace = true } bytes = { workspace = true } console = "0.15" -dialoguer = "0.10" +dialoguer = "0.11" dirs = { workspace = true } fs_extra = "1" heck = "0.5" diff --git a/crates/templates/src/interaction.rs b/crates/templates/src/interaction.rs index a8d36abaec..50025ec386 100644 --- a/crates/templates/src/interaction.rs +++ b/crates/templates/src/interaction.rs @@ -48,7 +48,7 @@ impl InteractionStrategy for Interactive { match crate::interaction::confirm(&prompt) { Ok(true) => Cancellable::Ok(()), Ok(false) => Cancellable::Cancelled, - Err(e) => Cancellable::Err(anyhow::Error::from(e)), + Err(e) => Cancellable::Err(e.into()), } } else { Cancellable::Ok(()) @@ -101,7 +101,7 @@ impl InteractionStrategy for Silent { } } -pub(crate) fn confirm(text: &str) -> std::io::Result { +pub(crate) fn confirm(text: &str) -> dialoguer::Result { Confirm::new().with_prompt(text).interact() } @@ -130,9 +130,9 @@ pub(crate) fn prompt_parameter(parameter: &TemplateParameter) -> Option fn ask_free_text(prompt: &str, default_value: &Option) -> anyhow::Result { let mut input = Input::::new(); - input.with_prompt(prompt); + input = input.with_prompt(prompt); if let Some(s) = default_value { - input.default(s.to_owned()); + input = input.default(s.to_owned()); } let result = input.interact_text()?; Ok(result) From 0fbb84ca0d6e03ea0cfaa0cc2925c0bb239d54b8 Mon Sep 17 00:00:00 2001 From: Ryan Levick Date: Mon, 23 Sep 2024 12:36:56 +0200 Subject: [PATCH 10/10] Minor updates Signed-off-by: Ryan Levick --- Cargo.lock | 44 ++++++++++++++++++++++---------------------- Cargo.toml | 12 ++++++------ 2 files changed, 28 insertions(+), 28 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b58be5c88e..8f60878902 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -691,7 +691,7 @@ dependencies = [ "bitflags 2.6.0", "cexpr", "clang-sys", - "itertools 0.11.0", + "itertools 0.13.0", "proc-macro2", "quote", "regex", @@ -1307,9 +1307,9 @@ dependencies = [ [[package]] name = "concurrent-queue" -version = "2.4.0" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d16048cd947b08fa32c24458a22f5dc5e835264f689f4f5653210c69fd107363" +checksum = "4ca0197aee26d1ae37445ee532fefce43251d24cc7c166799f4d46817f1d3973" dependencies = [ "crossbeam-utils", ] @@ -1320,7 +1320,7 @@ version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1b1b9d958c2b1368a663f05538fc1b5975adce1e19f435acceae987aceeeb369" dependencies = [ - "lazy_static 1.4.0", + "lazy_static 1.5.0", "nom 5.1.3", "rust-ini", "serde 1.0.210", @@ -1362,7 +1362,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0e1f83fc076bd6dd27517eacdf25fef6c4dfe5f1d7448bafaaf3a26f13b5e4eb" dependencies = [ "encode_unicode", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "libc", "unicode-width", "windows-sys 0.52.0", @@ -3314,7 +3314,7 @@ dependencies = [ "httpdate", "itoa", "pin-project-lite", - "socket2 0.5.6", + "socket2 0.4.10", "tokio", "tower-service", "tracing", @@ -3776,7 +3776,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "363387f0019d714aa60cc30ab4fe501a747f4c08fc58f069dd14be971bd495a0" dependencies = [ "byteorder", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "linux-keyutils", "secret-service", "security-framework", @@ -3830,9 +3830,9 @@ checksum = "76f033c7ad61445c5b347c7382dd1237847eb1bce590fe50365dcb33d546be73" [[package]] name = "lazy_static" -version = "1.4.0" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" +checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe" [[package]] name = "leb128" @@ -4135,7 +4135,7 @@ checksum = "8e31badd9de5131fdf4921f6473d457e3dd85b11b7f091ceb50e4df7c3eeb12a" dependencies = [ "beef", "fnv", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "proc-macro2", "quote", "regex-syntax 0.8.3", @@ -4464,7 +4464,7 @@ dependencies = [ "cmake", "crc32fast", "flate2", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "num-bigint", "num-traits 0.2.18", "rand 0.8.5", @@ -4812,7 +4812,7 @@ dependencies = [ "http 1.1.0", "http-auth", "jwt", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "olpc-cjson", "regex", "reqwest 0.12.7", @@ -4836,7 +4836,7 @@ dependencies = [ "http 1.1.0", "http-auth", "jwt", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "olpc-cjson", "regex", "reqwest 0.12.7", @@ -5566,7 +5566,7 @@ checksum = "80b776a1b2dc779f5ee0641f8ade0125bc1298dd41a9a0c16d8bd57b42d222b1" dependencies = [ "bytes", "heck 0.5.0", - "itertools 0.11.0", + "itertools 0.12.1", "log", "multimap", "once_cell", @@ -5586,7 +5586,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "19de2de2a00075bf566bee3bd4db014b11587e84184d3f7a791bc17f1a8e9e48" dependencies = [ "anyhow", - "itertools 0.11.0", + "itertools 0.12.1", "proc-macro2", "quote", "syn 2.0.77", @@ -6398,7 +6398,7 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2ed72fbaf78e6f2d41744923916966c4fbe3d7c74e3037a8ee482f1115572603" dependencies = [ - "lazy_static 1.4.0", + "lazy_static 1.5.0", "regex", ] @@ -6535,7 +6535,7 @@ version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6a3a4e0ea8a88553209f6cc6cfe8724ecad22e1acf372793c27d995290fe74f8" dependencies = [ - "lazy_static 1.4.0", + "lazy_static 1.5.0", "num-traits 0.1.43", "regex", "serde 0.8.23", @@ -6735,7 +6735,7 @@ version = "0.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" dependencies = [ - "lazy_static 1.4.0", + "lazy_static 1.5.0", ] [[package]] @@ -6968,7 +6968,7 @@ dependencies = [ "indicatif", "is-terminal", "itertools 0.13.0", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "levenshtein", "nix 0.29.0", "openssl", @@ -7505,7 +7505,7 @@ dependencies = [ "glob", "indexmap 2.5.0", "itertools 0.13.0", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "mime_guess", "path-absolutize", "regex", @@ -7763,7 +7763,7 @@ dependencies = [ "heck 0.5.0", "indexmap 2.5.0", "itertools 0.13.0", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "liquid", "liquid-core", "liquid-derive", @@ -8378,7 +8378,7 @@ dependencies = [ "getrandom 0.2.12", "indicatif", "itertools 0.12.1", - "lazy_static 1.4.0", + "lazy_static 1.5.0", "log", "macro_rules_attribute", "monostate", diff --git a/Cargo.toml b/Cargo.toml index c150ff12c5..7ceb818630 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -31,16 +31,16 @@ glob = { workspace = true } indicatif = "0.17" is-terminal = "0.4" itertools = { workspace = true } -lazy_static = "1.4.0" -levenshtein = "1.0.5" +lazy_static = "1.5" +levenshtein = "1" nix = { version = "0.29", features = ["signal"] } -path-absolutize = "3.0.11" +path-absolutize = "3" rand = { workspace = true } regex = { workspace = true } reqwest = { workspace = true } -rpassword = "7.0" -semver = "1.0" -serde = { version = "1.0", features = ["derive"] } +rpassword = "7" +semver = "1" +serde = { version = "1", features = ["derive"] } serde_json = { workspace = true } sha2 = { workspace = true } subprocess = "0.2"