Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 0 additions & 18 deletions .changeset/sep-phase1-sdk.md

This file was deleted.

2 changes: 1 addition & 1 deletion go/version.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,4 @@ package e2e
// language artifacts. The real Go "publish" is a git tag (go/v<Version>); 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.0"
const Version = "1.11.1"
2 changes: 1 addition & 1 deletion python/pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[project]
name = "smooai-smooth-operator"
version = "1.11.0"
version = "1.11.1"
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" }
Expand Down
16 changes: 8 additions & 8 deletions rust/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion rust/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -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.0" }
smooth-operator = { package = "smooai-smooth-operator", path = "smooth-operator", version = "1.11.1" }

async-trait = "0.1"
anyhow = "1"
Expand Down
2 changes: 1 addition & 1 deletion rust/adapters/backplane-nats/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-adapter-backplane-nats"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down
2 changes: 1 addition & 1 deletion rust/adapters/backplane-redis/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-adapter-backplane-redis"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down
4 changes: 2 additions & 2 deletions rust/adapters/dynamodb/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-adapter-dynamodb"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand All @@ -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.0" }
smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.1" }
async-trait = { workspace = true }
anyhow = { workspace = true }
chrono = { workspace = true }
Expand Down
2 changes: 1 addition & 1 deletion rust/adapters/in-memory/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-adapter-memory"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down
4 changes: 2 additions & 2 deletions rust/adapters/postgres/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-adapter-postgres"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand All @@ -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.0" }
smooai-smooth-operator-ingestion = { path = "../../ingestion", version = "1.11.1" }
async-trait = { workspace = true }
anyhow = { workspace = true }
chrono = { workspace = true }
Expand Down
2 changes: 1 addition & 1 deletion rust/ingestion/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-ingestion"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down
14 changes: 7 additions & 7 deletions rust/smooth-operator-server/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator-server"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down Expand Up @@ -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.0" }
smooai-smooth-operator-adapter-memory = { path = "../adapters/in-memory", version = "1.11.1" }
# 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.0", optional = true }
smooai-smooth-operator-adapter-dynamodb = { path = "../adapters/dynamodb", version = "1.11.0", optional = true }
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 }
# 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.0", optional = true }
smooai-smooth-operator-adapter-backplane-nats = { path = "../adapters/backplane-nats", version = "1.11.0", optional = true }
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 }
# Admin API surfaces indexing-run status via the ingestion crate's IndexingStore.
smooai-smooth-operator-ingestion = { path = "../ingestion", version = "1.11.0" }
smooai-smooth-operator-ingestion = { path = "../ingestion", version = "1.11.1" }

async-trait = { workspace = true }
anyhow = { workspace = true }
Expand Down
2 changes: 1 addition & 1 deletion rust/smooth-operator/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "smooai-smooth-operator"
version = "1.11.0"
version = "1.11.1"
edition.workspace = true
license.workspace = true
repository.workspace = true
Expand Down
24 changes: 21 additions & 3 deletions typescript/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,23 @@
# @smooai/smooth-operator

## 1.11.1

### Patch Changes

- 940560b: Add the SEP TypeScript extension SDK — Phase 1 (the tool path).

New published package `@smooai/smooth-extension-sdk`: build Smooth Extension Protocol
extensions in TypeScript. `defineExtension`/`defineTool` (zod v4 via `z.toJSONSchema`, with
raw JSON-Schema / TypeBox pass-through), a symmetric JSON-RPC 2.0 `Peer`, an ndjson stdio
transport (plus an in-memory `linkedPair`), `createTestHost` for driving an extension
in-process, and `runConformance` to replay the shared fixtures against a real extension
subprocess. Ships the `hello` demo extension (`hello.greet` — zod schema, streamed
`tool/update` progress, `$/cancel` cancellation). Wired into the TypeScript CI lane.

Extends `spec/extension/conformance/fixtures.json` for the tool path: `is_error` and
`details` tool results, a message-only `tool/update`, and invalid fixtures (missing
`content`, out-of-range `progress`).

## 1.11.0

### Minor Changes
Expand All @@ -8,9 +26,9 @@

New `spec/extension/` tree: `envelope.md` (JSON-RPC 2.0 over ndjson framing, method
catalog, error codes, context tiers, deferred WS binding), `methods/*.schema.json` (draft
2020-12, snake_case: initialize, shutdown, ping, event, hook, tool/execute, tool/update,
$/cancel, command/execute, registry/update, tools/set_active, session/_, exec/run,
ui/request, kv/_, bus/publish, log, plus the JSON-RPC frame envelope), and
2020-12, snake*case: initialize, shutdown, ping, event, hook, tool/execute, tool/update,
$/cancel, command/execute, registry/update, tools/set_active, session/*, exec/run,
ui/request, kv/\_, bus/publish, log, plus the JSON-RPC frame envelope), and
`conformance/fixtures.json` (43 valid + 6 invalid instances) with the dependency-free
`echo.mjs` demo extension. A new `extension-conformance.test.ts` validates every fixture
against its schema, mirroring the existing operator-protocol conformance harness. SEP is a
Expand Down
19 changes: 19 additions & 0 deletions typescript/extension-sdk/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# @smooai/smooth-extension-sdk

## 0.2.0

### Minor Changes

- 940560b: Add the SEP TypeScript extension SDK — Phase 1 (the tool path).

New published package `@smooai/smooth-extension-sdk`: build Smooth Extension Protocol
extensions in TypeScript. `defineExtension`/`defineTool` (zod v4 via `z.toJSONSchema`, with
raw JSON-Schema / TypeBox pass-through), a symmetric JSON-RPC 2.0 `Peer`, an ndjson stdio
transport (plus an in-memory `linkedPair`), `createTestHost` for driving an extension
in-process, and `runConformance` to replay the shared fixtures against a real extension
subprocess. Ships the `hello` demo extension (`hello.greet` — zod schema, streamed
`tool/update` progress, `$/cancel` cancellation). Wired into the TypeScript CI lane.

Extends `spec/extension/conformance/fixtures.json` for the tool path: `is_error` and
`details` tool results, a message-only `tool/update`, and invalid fixtures (missing
`content`, out-of-range `progress`).
2 changes: 1 addition & 1 deletion typescript/extension-sdk/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@smooai/smooth-extension-sdk",
"version": "0.1.0",
"version": "0.2.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",
Expand Down
2 changes: 1 addition & 1 deletion typescript/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@smooai/smooth-operator",
"version": "1.11.0",
"version": "1.11.1",
"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",
Expand Down
Loading