2026-05-10 23:51:24 +02:00
|
|
|
# KTX
|
2026-05-10 23:12:26 +02:00
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
KTX is a workspace-first context layer for database agents. It stores warehouse
|
2026-05-10 23:12:26 +02:00
|
|
|
memory in a project directory, generates and validates semantic-layer YAML,
|
|
|
|
|
indexes knowledge, scans database schemas, and exposes the result through a CLI
|
|
|
|
|
and MCP server.
|
|
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
KTX projects are plain files: YAML, Markdown, SQLite state, and generated
|
2026-05-10 23:12:26 +02:00
|
|
|
artifacts. You can inspect them, commit them, and serve them to any MCP client.
|
|
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
## What KTX provides
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
- Durable warehouse memory with semantic-layer sources and knowledge pages.
|
|
|
|
|
- Native scan connectors for SQLite, Postgres, MySQL, ClickHouse, SQL Server,
|
2026-05-10 20:44:07 -07:00
|
|
|
BigQuery, and Snowflake.
|
2026-05-10 23:12:26 +02:00
|
|
|
- Agentic ingest with provenance links, tool transcripts, and replay metadata.
|
|
|
|
|
- Local semantic-layer query planning and optional query execution.
|
|
|
|
|
- A stdio MCP server with tools for connections, knowledge, semantic-layer
|
|
|
|
|
sources, ingest reports, and replay.
|
|
|
|
|
|
|
|
|
|
## Quick start
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
Run the pre-seeded demo through the public npm package:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx @kaelio/ktx setup demo --no-input
|
|
|
|
|
npx @kaelio/ktx setup demo inspect
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
The default demo uses packaged sample data and prebuilt context. It does not
|
|
|
|
|
require API keys, network access, or an LLM provider.
|
|
|
|
|
|
|
|
|
|
To replay the packaged ingest run, use:
|
|
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx @kaelio/ktx setup demo --mode replay --no-input
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
To run the full agentic demo with an LLM provider, set a provider key for the
|
|
|
|
|
current process:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
ANTHROPIC_API_KEY=$YOUR_ANTHROPIC_API_KEY \
|
2026-05-11 15:50:34 +02:00
|
|
|
npx @kaelio/ktx setup demo --mode full --no-input
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Interactive full-demo setup can prompt for a provider key without writing the
|
2026-05-10 23:51:24 +02:00
|
|
|
key to `ktx.yaml`.
|
2026-05-10 23:12:26 +02:00
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
You can also install the CLI in a project or globally:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm install @kaelio/ktx
|
|
|
|
|
npx ktx --help
|
|
|
|
|
npm install -g @kaelio/ktx
|
|
|
|
|
ktx --help
|
|
|
|
|
```
|
|
|
|
|
|
2026-05-10 23:12:26 +02:00
|
|
|
## Build a local project
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
Create a project from a local workspace:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npm install @kaelio/ktx
|
2026-05-10 23:51:24 +02:00
|
|
|
PROJECT_DIR="$(mktemp -d)/ktx-demo"
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx init "$PROJECT_DIR" --name ktx-demo
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Create a SQLite warehouse:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
python - "$PROJECT_DIR/demo.db" <<'PY'
|
|
|
|
|
import sqlite3
|
|
|
|
|
import sys
|
|
|
|
|
|
|
|
|
|
conn = sqlite3.connect(sys.argv[1])
|
|
|
|
|
conn.executescript("""
|
|
|
|
|
DROP TABLE IF EXISTS accounts;
|
|
|
|
|
CREATE TABLE accounts (
|
|
|
|
|
account_id INTEGER PRIMARY KEY,
|
|
|
|
|
account_name TEXT NOT NULL,
|
|
|
|
|
segment TEXT NOT NULL,
|
|
|
|
|
region TEXT NOT NULL
|
|
|
|
|
);
|
|
|
|
|
INSERT INTO accounts VALUES
|
|
|
|
|
(1, 'Acme Analytics', 'Mid-Market', 'NA'),
|
|
|
|
|
(2, 'Beacon Bank', 'Enterprise', 'EMEA'),
|
|
|
|
|
(3, 'Cobalt Coffee', 'SMB', 'NA'),
|
|
|
|
|
(4, 'Delta Devices', 'Mid-Market', 'APAC'),
|
|
|
|
|
(5, 'Evergreen Energy', 'Enterprise', 'NA');
|
|
|
|
|
""")
|
|
|
|
|
conn.close()
|
|
|
|
|
PY
|
|
|
|
|
```
|
|
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
Replace the generated `ktx.yaml`:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
2026-05-10 23:51:24 +02:00
|
|
|
cat > "$PROJECT_DIR/ktx.yaml" <<YAML
|
|
|
|
|
project: ktx-demo
|
2026-05-10 23:12:26 +02:00
|
|
|
connections:
|
|
|
|
|
warehouse:
|
|
|
|
|
driver: sqlite
|
|
|
|
|
path: $PROJECT_DIR/demo.db
|
|
|
|
|
readonly: true
|
|
|
|
|
storage:
|
|
|
|
|
state: sqlite
|
|
|
|
|
search: sqlite-fts5
|
|
|
|
|
git:
|
|
|
|
|
auto_commit: true
|
2026-05-10 23:51:24 +02:00
|
|
|
author: "ktx <ktx@example.com>"
|
2026-05-10 23:12:26 +02:00
|
|
|
memory:
|
|
|
|
|
auto_commit: true
|
|
|
|
|
YAML
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Write and validate a semantic-layer source:
|
|
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx sl write accounts --project-dir "$PROJECT_DIR" \
|
2026-05-10 23:12:26 +02:00
|
|
|
--connection-id warehouse --yaml 'name: accounts
|
|
|
|
|
table: accounts
|
|
|
|
|
description: CRM accounts with segmentation attributes.
|
|
|
|
|
grain:
|
|
|
|
|
- account_id
|
|
|
|
|
columns:
|
|
|
|
|
- name: account_id
|
|
|
|
|
type: number
|
|
|
|
|
- name: account_name
|
|
|
|
|
type: string
|
|
|
|
|
- name: segment
|
|
|
|
|
type: string
|
|
|
|
|
- name: region
|
|
|
|
|
type: string
|
|
|
|
|
measures:
|
|
|
|
|
- name: account_count
|
|
|
|
|
expr: count(account_id)
|
|
|
|
|
joins: []
|
|
|
|
|
'
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx sl validate accounts --project-dir "$PROJECT_DIR" \
|
2026-05-10 23:12:26 +02:00
|
|
|
--connection-id warehouse
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Generate SQL and execute the query:
|
|
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx sl query --project-dir "$PROJECT_DIR" \
|
2026-05-10 23:12:26 +02:00
|
|
|
--connection-id warehouse \
|
|
|
|
|
--measure accounts.account_count \
|
|
|
|
|
--dimension accounts.segment \
|
|
|
|
|
--order-by accounts.account_count:desc \
|
|
|
|
|
--limit 5 \
|
|
|
|
|
--format sql
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx sl query --project-dir "$PROJECT_DIR" \
|
2026-05-10 23:12:26 +02:00
|
|
|
--connection-id warehouse \
|
|
|
|
|
--measure accounts.account_count \
|
|
|
|
|
--dimension accounts.segment \
|
|
|
|
|
--order-by accounts.account_count:desc \
|
|
|
|
|
--limit 5 \
|
|
|
|
|
--execute \
|
|
|
|
|
--max-rows 5
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
List and test the warehouse connection:
|
|
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx connection list --project-dir "$PROJECT_DIR"
|
|
|
|
|
npx ktx connection test warehouse --project-dir "$PROJECT_DIR"
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
The connection test prints the configured driver and discovered table count:
|
|
|
|
|
|
|
|
|
|
```text
|
|
|
|
|
Driver: sqlite
|
|
|
|
|
Tables: 1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Scan the demo warehouse
|
|
|
|
|
|
|
|
|
|
Scan artifacts are written under
|
|
|
|
|
`raw-sources/warehouse/live-database/<syncId>/` in the project directory.
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
SCAN_OUTPUT="$(npx ktx scan warehouse --project-dir "$PROJECT_DIR")"
|
2026-05-10 23:12:26 +02:00
|
|
|
printf '%s\n' "$SCAN_OUTPUT"
|
|
|
|
|
SCAN_RUN_ID="$(printf '%s\n' "$SCAN_OUTPUT" | awk '/^Run: / { print $2 }')"
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx scan status --project-dir "$PROJECT_DIR" "$SCAN_RUN_ID"
|
|
|
|
|
npx ktx scan report --project-dir "$PROJECT_DIR" "$SCAN_RUN_ID"
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
For non-SQLite drivers, prefer credential references such as `--url env:NAME`
|
|
|
|
|
or `--url file:PATH` over literal credential URLs.
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
## Managed Python runtime
|
|
|
|
|
|
|
|
|
|
KTX installs its Python runtime only when a Python-backed command needs it.
|
|
|
|
|
The runtime lives outside the npm cache, is versioned by the installed CLI
|
|
|
|
|
version, and is managed by `ktx runtime` commands.
|
2026-05-10 23:12:26 +02:00
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
KTX requires `uv` on `PATH` to create the managed runtime. Install `uv` with
|
|
|
|
|
your system package manager or the official installer before running Python-
|
|
|
|
|
backed KTX commands. KTX doesn't download `uv` automatically; run
|
|
|
|
|
`ktx runtime doctor` if runtime installation fails:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx runtime install --yes
|
|
|
|
|
npx ktx runtime status
|
|
|
|
|
npx ktx runtime doctor
|
|
|
|
|
npx ktx runtime start
|
|
|
|
|
npx ktx runtime stop
|
|
|
|
|
npx ktx runtime prune --dry-run
|
|
|
|
|
npx ktx runtime prune --yes
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Use `runtime prune --dry-run` to preview stale runtime directories from older
|
|
|
|
|
CLI versions. Add `--yes` to remove those stale directories after daemon
|
|
|
|
|
processes are stopped.
|
|
|
|
|
|
|
|
|
|
Commands such as `npx @kaelio/ktx sl query ... --yes` can install the core
|
|
|
|
|
runtime lazily from the bundled wheel. Local embeddings remain lazy; prepare
|
|
|
|
|
them only when you select local `sentence-transformers` embeddings:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npx ktx runtime install --feature local-embeddings --yes
|
|
|
|
|
npx ktx runtime start --feature local-embeddings
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
## Serve MCP
|
|
|
|
|
|
|
|
|
|
Start the stdio MCP server from the project directory:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
2026-05-11 15:50:34 +02:00
|
|
|
npx ktx serve --mcp stdio --project-dir "$PROJECT_DIR" \
|
2026-05-10 23:12:26 +02:00
|
|
|
--user-id local \
|
2026-05-11 15:50:34 +02:00
|
|
|
--semantic-compute \
|
|
|
|
|
--execute-queries \
|
|
|
|
|
--yes
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
The `--semantic-compute` flag uses the managed Python runtime when no explicit
|
|
|
|
|
semantic compute URL is provided. KTX starts or reuses the managed runtime as
|
|
|
|
|
needed.
|
|
|
|
|
|
2026-05-10 23:12:26 +02:00
|
|
|
The MCP server exposes `connection_list`, `knowledge_search`,
|
|
|
|
|
`knowledge_read`, `knowledge_write`, `sl_list_sources`, `sl_read_source`,
|
|
|
|
|
`sl_write_source`, `sl_validate`, `sl_query`, `ingest_trigger`,
|
|
|
|
|
`ingest_status`, `ingest_report`, and `ingest_replay`.
|
|
|
|
|
|
|
|
|
|
## Workspace packages
|
|
|
|
|
|
|
|
|
|
- `packages/context`: core TypeScript context library.
|
|
|
|
|
- `packages/cli`: CLI wrapper over the context package.
|
|
|
|
|
- `packages/llm`: LLM and embedding provider helpers.
|
|
|
|
|
- `packages/connector-bigquery`: BigQuery scan connector.
|
|
|
|
|
- `packages/connector-clickhouse`: ClickHouse scan connector.
|
|
|
|
|
- `packages/connector-mysql`: MySQL scan connector.
|
|
|
|
|
- `packages/connector-postgres`: Postgres scan connector.
|
|
|
|
|
- `packages/connector-snowflake`: Snowflake scan connector.
|
|
|
|
|
- `packages/connector-sqlite`: SQLite scan connector.
|
|
|
|
|
- `packages/connector-sqlserver`: SQL Server scan connector.
|
2026-05-10 23:51:24 +02:00
|
|
|
- `python/ktx-sl`: semantic-layer engine.
|
|
|
|
|
- `python/ktx-daemon`: portable compute service for semantic-layer operations.
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
## Development
|
|
|
|
|
|
|
|
|
|
Install dependencies and run checks:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
pnpm install
|
|
|
|
|
pnpm run check
|
|
|
|
|
uv sync --all-packages
|
|
|
|
|
source .venv/bin/activate
|
|
|
|
|
uv run pytest
|
|
|
|
|
```
|
|
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
Use the optional development binary when you want a local `ktx-dev` command:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
pnpm run link:dev
|
2026-05-10 23:51:24 +02:00
|
|
|
ktx-dev --help
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
The repository uses `pnpm` for TypeScript packages and `uv` for Python
|
|
|
|
|
packages.
|
|
|
|
|
|
|
|
|
|
## Release status
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
This repository builds one public npm artifact named `@kaelio/ktx`. The release
|
|
|
|
|
artifact manifest contains the public npm tarball and the bundled `kaelio-ktx`
|
|
|
|
|
runtime wheel. The first public npm handoff is policy-gated through
|
|
|
|
|
`release-policy.json`, which keeps Python package publishing disabled because
|
|
|
|
|
KTX-owned Python code ships inside the npm package as a bundled wheel. The
|
|
|
|
|
`python/ktx-sl` and `python/ktx-daemon` directories remain source packages for
|
|
|
|
|
development, not public release artifacts.
|
2026-05-10 23:12:26 +02:00
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
Build local package artifacts and verify the guarded dry-run publish path with:
|
2026-05-10 23:12:26 +02:00
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
source .venv/bin/activate
|
|
|
|
|
pnpm run artifacts:check
|
|
|
|
|
pnpm run release:readiness
|
2026-05-11 15:50:34 +02:00
|
|
|
pnpm run release:npm-publish
|
2026-05-10 23:12:26 +02:00
|
|
|
```
|
|
|
|
|
|
2026-05-11 15:50:34 +02:00
|
|
|
Run the live npm publish only from the manual `KTX Release` workflow with the
|
|
|
|
|
`publish_live` input enabled after the `NPM_TOKEN` secret is configured.
|
|
|
|
|
|
2026-05-10 23:12:26 +02:00
|
|
|
## License
|
|
|
|
|
|
2026-05-10 23:51:24 +02:00
|
|
|
KTX is licensed under the Apache License, Version 2.0. See `LICENSE`.
|