From 901cb3b07dae6719fa72005efb029a771502ca05 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 3 Jul 2026 06:51:57 +0000 Subject: [PATCH] =?UTF-8?q?=F0=9F=A6=8B=20New=20version=20release?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .changeset/sep-phase2-sdk.md | 23 ----------------------- go/version.go | 2 +- python/pyproject.toml | 2 +- rust/Cargo.lock | 16 ++++++++-------- rust/Cargo.toml | 2 +- rust/adapters/backplane-nats/Cargo.toml | 2 +- rust/adapters/backplane-redis/Cargo.toml | 2 +- rust/adapters/dynamodb/Cargo.toml | 4 ++-- rust/adapters/in-memory/Cargo.toml | 2 +- rust/adapters/postgres/Cargo.toml | 4 ++-- rust/ingestion/Cargo.toml | 2 +- rust/smooth-operator-server/Cargo.toml | 14 +++++++------- rust/smooth-operator/Cargo.toml | 2 +- typescript/CHANGELOG.md | 23 +++++++++++++++++++++++ typescript/extension-sdk/CHANGELOG.md | 23 +++++++++++++++++++++++ typescript/extension-sdk/package.json | 2 +- typescript/package.json | 2 +- 17 files changed, 75 insertions(+), 52 deletions(-) delete mode 100644 .changeset/sep-phase2-sdk.md diff --git a/.changeset/sep-phase2-sdk.md b/.changeset/sep-phase2-sdk.md deleted file mode 100644 index a829cdb..0000000 --- a/.changeset/sep-phase2-sdk.md +++ /dev/null @@ -1,23 +0,0 @@ ---- -"@smooai/smooth-extension-sdk": minor -"@smooai/smooth-operator": patch ---- - -SEP Phase 2 (SDK + spec) — hooks + the observe event bus. - -`@smooai/smooth-extension-sdk` gains **hook handlers**: `smooth.on(name, handler)` -now covers both observe events (return ignored) and intercept hooks (return a -`HookResult` — `{ block, reason? }` to veto or `{ patch }` to rewrite the input). -The extension answers the `hook` request by folding its own handlers in -registration order (first `block` short-circuits; `patch`es shallow-merge and -thread to the next), and the host chains the outcome across extensions. Hook -names are kept out of the reported event `subscriptions`. `createTestHost` gains -`callHook(hook, input)`; new `permission-gate` demo extension blocks dangerous -`bash` commands via a fail-closed `tool_call` hook. - -`spec/extension`: the event schema gains an optional `seq` (per-connection -monotonic sequence; absent on the out-of-band `events_lost` marker) with a -`model_select → AgentEvent::ModelResolved` parity note, and fixtures add a -seq-numbered event, the `events_lost` marker (drop-N → count), a -`tool_execution_start` event, and the `tool_result` hook input + a result-shaped -`modify` outcome. Rust and TypeScript conformance replays stay green. diff --git a/go/version.go b/go/version.go index 8651436..735b276 100644 --- a/go/version.go +++ b/go/version.go @@ -5,4 +5,4 @@ package e2e // language artifacts. The real Go "publish" is a git tag (go/v); this // constant is the anchor that scripts/sync-versions.mjs keeps in sync with the // canonical npm version on every changeset release. -const Version = "1.11.1" +const Version = "1.11.2" diff --git a/python/pyproject.toml b/python/pyproject.toml index 0bc419e..e52c223 100644 --- a/python/pyproject.toml +++ b/python/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "smooai-smooth-operator" -version = "1.11.1" +version = "1.11.2" description = "Python protocol types and native async WebSocket client for the smooth-operator protocol. Generated from the language-neutral JSON Schemas in spec/." readme = "README.md" license = { text = "MIT" } diff --git a/rust/Cargo.lock b/rust/Cargo.lock index e0d8541..93c41ae 100644 --- a/rust/Cargo.lock +++ b/rust/Cargo.lock @@ -3974,7 +3974,7 @@ checksum = "8ed6a63f02c8539c91a8685a86f4099661ba3da017932f6ebbea6de3f0fa7c90" [[package]] name = "smooai-smooth-operator" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4006,7 +4006,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-adapter-backplane-nats" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-nats", @@ -4022,7 +4022,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-adapter-backplane-redis" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4038,7 +4038,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-adapter-dynamodb" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4059,7 +4059,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-adapter-memory" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4072,7 +4072,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-adapter-postgres" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4158,7 +4158,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-ingestion" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", @@ -4205,7 +4205,7 @@ dependencies = [ [[package]] name = "smooai-smooth-operator-server" -version = "1.11.1" +version = "1.11.2" dependencies = [ "anyhow", "async-trait", diff --git a/rust/Cargo.toml b/rust/Cargo.toml index b1b32a5..e3505f3 100644 --- a/rust/Cargo.toml +++ b/rust/Cargo.toml @@ -29,7 +29,7 @@ smooai-smooth-operator-core = { path = "../../smooth-operator-core/rust/smooth-o # Intra-workspace dep on the reference lib carries its version so the adapters / # ingestion / server that depend on it are publishable (path = local dev, # version = the crates.io requirement). -smooth-operator = { package = "smooai-smooth-operator", path = "smooth-operator", version = "1.11.1" } +smooth-operator = { package = "smooai-smooth-operator", path = "smooth-operator", version = "1.11.2" } async-trait = "0.1" anyhow = "1" diff --git a/rust/adapters/backplane-nats/Cargo.toml b/rust/adapters/backplane-nats/Cargo.toml index f908a97..6306e3a 100644 --- a/rust/adapters/backplane-nats/Cargo.toml +++ b/rust/adapters/backplane-nats/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-adapter-backplane-nats" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true diff --git a/rust/adapters/backplane-redis/Cargo.toml b/rust/adapters/backplane-redis/Cargo.toml index b11ffaa..05cf0ee 100644 --- a/rust/adapters/backplane-redis/Cargo.toml +++ b/rust/adapters/backplane-redis/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-adapter-backplane-redis" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true diff --git a/rust/adapters/dynamodb/Cargo.toml b/rust/adapters/dynamodb/Cargo.toml index 69c3d74..04f6896 100644 --- a/rust/adapters/dynamodb/Cargo.toml +++ b/rust/adapters/dynamodb/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-adapter-dynamodb" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true @@ -19,7 +19,7 @@ s3-vectors = ["dep:aws-sdk-s3vectors", "dep:aws-smithy-types"] smooth-operator = { workspace = true } smooai-smooth-operator-core = { workspace = true } # IndexingStore / IndexingRun for the persistent admin indexing-runs store. -smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.1" } +smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.2" } async-trait = { workspace = true } anyhow = { workspace = true } chrono = { workspace = true } diff --git a/rust/adapters/in-memory/Cargo.toml b/rust/adapters/in-memory/Cargo.toml index b3bf50e..f25edeb 100644 --- a/rust/adapters/in-memory/Cargo.toml +++ b/rust/adapters/in-memory/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-adapter-memory" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true diff --git a/rust/adapters/postgres/Cargo.toml b/rust/adapters/postgres/Cargo.toml index 9c5dc0d..f9af38d 100644 --- a/rust/adapters/postgres/Cargo.toml +++ b/rust/adapters/postgres/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-adapter-postgres" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true @@ -15,7 +15,7 @@ smooth-operator = { workspace = true } # `postgres` feature pulls in PostgresCheckpointStore (sync r2d2 path). smooai-smooth-operator-core = { workspace = true, features = ["postgres"] } # IndexingStore / IndexingRun for the persistent admin indexing-runs store. -smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.1" } +smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.2" } async-trait = { workspace = true } anyhow = { workspace = true } chrono = { workspace = true } diff --git a/rust/ingestion/Cargo.toml b/rust/ingestion/Cargo.toml index fca3703..66a63ce 100644 --- a/rust/ingestion/Cargo.toml +++ b/rust/ingestion/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-ingestion" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true diff --git a/rust/smooth-operator-server/Cargo.toml b/rust/smooth-operator-server/Cargo.toml index 304b51a..7620c26 100644 --- a/rust/smooth-operator-server/Cargo.toml +++ b/rust/smooth-operator-server/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator-server" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true @@ -35,22 +35,22 @@ smooth-operator = { workspace = true } smooai-smooth-operator-core = { workspace = true } # In-memory storage + backplane — ALWAYS included. The local-flavor default and # the lean (`--no-default-features`) build run entirely on these. -smooai-smooth-operator-adapter-memory = { path = "../adapters/in-memory", version = "1.11.1" } +smooai-smooth-operator-adapter-memory = { path = "../adapters/in-memory", version = "1.11.2" } # Persistent storage + admin-store backends, selected at runtime to match the # configured storage backend (Postgres / DynamoDB; default in-memory). Optional: # gated behind the `postgres` / `dynamodb` features so a lean local/embed build # can exclude tokio-postgres / the AWS SDK. The `postgres` crate also provides the # gateway-backed embedder/reranker, so the `postgres` feature additionally enables # the semantic-retrieval path in `embedder.rs` / `reranker.rs`. -smooai-smooth-operator-adapter-postgres = { path = "../adapters/postgres", version = "1.11.1", optional = true } -smooai-smooth-operator-adapter-dynamodb = { path = "../adapters/dynamodb", version = "1.11.1", optional = true } +smooai-smooth-operator-adapter-postgres = { path = "../adapters/postgres", version = "1.11.2", optional = true } +smooai-smooth-operator-adapter-dynamodb = { path = "../adapters/dynamodb", version = "1.11.2", optional = true } # Distributed Backplane backends for horizontal scale-out, selected at runtime # via SMOOTH_AGENT_BACKPLANE (default in-memory / single-process). Optional: gated # behind the `redis` / `nats` features so a lean build excludes their drivers. -smooai-smooth-operator-adapter-backplane-redis = { path = "../adapters/backplane-redis", version = "1.11.1", optional = true } -smooai-smooth-operator-adapter-backplane-nats = { path = "../adapters/backplane-nats", version = "1.11.1", optional = true } +smooai-smooth-operator-adapter-backplane-redis = { path = "../adapters/backplane-redis", version = "1.11.2", optional = true } +smooai-smooth-operator-adapter-backplane-nats = { path = "../adapters/backplane-nats", version = "1.11.2", optional = true } # Admin API surfaces indexing-run status via the ingestion crate's IndexingStore. -smooai-smooth-operator-ingestion = { path = "../ingestion", version = "1.11.1" } +smooai-smooth-operator-ingestion = { path = "../ingestion", version = "1.11.2" } async-trait = { workspace = true } anyhow = { workspace = true } diff --git a/rust/smooth-operator/Cargo.toml b/rust/smooth-operator/Cargo.toml index 9264e4b..4bc7b05 100644 --- a/rust/smooth-operator/Cargo.toml +++ b/rust/smooth-operator/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "smooai-smooth-operator" -version = "1.11.1" +version = "1.11.2" edition.workspace = true license.workspace = true repository.workspace = true diff --git a/typescript/CHANGELOG.md b/typescript/CHANGELOG.md index 971a1d0..d75f489 100644 --- a/typescript/CHANGELOG.md +++ b/typescript/CHANGELOG.md @@ -1,5 +1,28 @@ # @smooai/smooth-operator +## 1.11.2 + +### Patch Changes + +- 1c8f26f: SEP Phase 2 (SDK + spec) — hooks + the observe event bus. + + `@smooai/smooth-extension-sdk` gains **hook handlers**: `smooth.on(name, handler)` + now covers both observe events (return ignored) and intercept hooks (return a + `HookResult` — `{ block, reason? }` to veto or `{ patch }` to rewrite the input). + The extension answers the `hook` request by folding its own handlers in + registration order (first `block` short-circuits; `patch`es shallow-merge and + thread to the next), and the host chains the outcome across extensions. Hook + names are kept out of the reported event `subscriptions`. `createTestHost` gains + `callHook(hook, input)`; new `permission-gate` demo extension blocks dangerous + `bash` commands via a fail-closed `tool_call` hook. + + `spec/extension`: the event schema gains an optional `seq` (per-connection + monotonic sequence; absent on the out-of-band `events_lost` marker) with a + `model_select → AgentEvent::ModelResolved` parity note, and fixtures add a + seq-numbered event, the `events_lost` marker (drop-N → count), a + `tool_execution_start` event, and the `tool_result` hook input + a result-shaped + `modify` outcome. Rust and TypeScript conformance replays stay green. + ## 1.11.1 ### Patch Changes diff --git a/typescript/extension-sdk/CHANGELOG.md b/typescript/extension-sdk/CHANGELOG.md index a0e30e0..89be22c 100644 --- a/typescript/extension-sdk/CHANGELOG.md +++ b/typescript/extension-sdk/CHANGELOG.md @@ -1,5 +1,28 @@ # @smooai/smooth-extension-sdk +## 0.3.0 + +### Minor Changes + +- 1c8f26f: SEP Phase 2 (SDK + spec) — hooks + the observe event bus. + + `@smooai/smooth-extension-sdk` gains **hook handlers**: `smooth.on(name, handler)` + now covers both observe events (return ignored) and intercept hooks (return a + `HookResult` — `{ block, reason? }` to veto or `{ patch }` to rewrite the input). + The extension answers the `hook` request by folding its own handlers in + registration order (first `block` short-circuits; `patch`es shallow-merge and + thread to the next), and the host chains the outcome across extensions. Hook + names are kept out of the reported event `subscriptions`. `createTestHost` gains + `callHook(hook, input)`; new `permission-gate` demo extension blocks dangerous + `bash` commands via a fail-closed `tool_call` hook. + + `spec/extension`: the event schema gains an optional `seq` (per-connection + monotonic sequence; absent on the out-of-band `events_lost` marker) with a + `model_select → AgentEvent::ModelResolved` parity note, and fixtures add a + seq-numbered event, the `events_lost` marker (drop-N → count), a + `tool_execution_start` event, and the `tool_result` hook input + a result-shaped + `modify` outcome. Rust and TypeScript conformance replays stay green. + ## 0.2.0 ### Minor Changes diff --git a/typescript/extension-sdk/package.json b/typescript/extension-sdk/package.json index ed7fe40..4cd5544 100644 --- a/typescript/extension-sdk/package.json +++ b/typescript/extension-sdk/package.json @@ -1,6 +1,6 @@ { "name": "@smooai/smooth-extension-sdk", - "version": "0.2.0", + "version": "0.3.0", "description": "TypeScript SDK for building Smooth Extension Protocol (SEP) extensions: `defineExtension`, `defineTool`, a stdio JSON-RPC transport, an in-process test host, and a conformance runner. Extensions are subprocesses speaking JSON-RPC 2.0 ndjson to any SEP host (smooth-operator-core and its polyglot servers).", "license": "MIT", "type": "module", diff --git a/typescript/package.json b/typescript/package.json index 8838b3b..ac876b6 100644 --- a/typescript/package.json +++ b/typescript/package.json @@ -1,6 +1,6 @@ { "name": "@smooai/smooth-operator", - "version": "1.11.1", + "version": "1.11.2", "description": "TypeScript SDK for the smooth-operator WebSocket protocol: the native client (`.`), React bindings (`./react`), and the embeddable web-component chat widget (`./widget`). Generated from the language-neutral JSON Schemas in spec/.", "license": "MIT", "type": "module",