ktxby Kaelio
Docs
CLI Reference

ktx setup

Set up or resume a local ktx project.

ktx setup is the guided configuration flow for a local ktx project. It can create or resume ktx.yaml, configure LLM and embedding providers, add database and context-source connections, prepare required runtime features, build initial context, and install agent integrations.

When you run bare ktx in an interactive terminal outside any ktx project, the CLI starts this same setup flow. Inside an existing project, ktx setup resumes from incomplete setup state or opens the setup menu.

Command signature

ktx setup [options]

Visible Options

The help output intentionally keeps setup focused on the common interactive flags. Automation flags are accepted by the same command and are documented below.

FlagDescriptionDefault
--agentsInstall agent configuration and rules onlyfalse
--target <target>Agent target: claude-code, claude-desktop, codex, cursor, opencode, or universal-
--globalInstall agent integration into the global target scope for claude-code or codexfalse
--yesAccept project creation and runtime install defaults where setup asks for confirmationfalse
--no-inputDisable interactive terminal input-

Use the global --project-dir <path> option when setup should target a specific directory.

Automation Options

These flags are useful for repeatable setup in examples, tests, CI fixtures, and scripted project creation. They are not shown in ktx setup --help.

Project Creation

Setup resumes an existing ktx.yaml when one is present. When no project exists, interactive setup prompts for where to create it. In scripts, pass --project-dir <dir> --no-input --yes to create the target directory without prompts.

LLM Provider

FlagDescription
--llm-backend <backend>LLM backend: anthropic, vertex, or claude-code
--llm-backend claude-codeUse the local Claude Code session for ktx LLM calls
--llm-model <model>LLM model ID or backend model alias to validate and save
--anthropic-api-key-env <name>Environment variable containing the Anthropic API key
--anthropic-api-key-file <path>File containing the Anthropic API key
--vertex-project <project>Vertex AI project ID, env:NAME, or file:/path reference
--vertex-location <location>Vertex AI location, env:NAME, or file:/path reference
--skip-llmLeave LLM setup incomplete

Choose only one Anthropic credential source. Anthropic credential flags are only valid with the Anthropic backend; Vertex flags are only valid with the Vertex backend. The claude-code backend uses local Claude Code authentication instead of Anthropic API key or Vertex flags. For Claude Code, --llm-model accepts sonnet, opus, haiku, or a full Claude model ID.

Embeddings

FlagDescription
--embedding-backend <backend>Embedding backend: openai or sentence-transformers
--embedding-api-key-env <name>Environment variable containing the embedding provider API key
--embedding-api-key-file <path>File containing the embedding provider API key
--skip-embeddingsLeave embedding setup incomplete

sentence-transformers uses the ktx-managed Python runtime. Choose only one embedding credential source.

Runtime

Setup prepares the managed Python runtime when your selected configuration needs it. In the full setup flow, the runtime step runs after database and context-source setup and before the initial context build.

ktx prepares the core runtime feature when query-history ingest, Looker context-source ingest, database introspection fallback, or daemon-backed context build paths need it. ktx prepares the local-embeddings runtime feature when you choose managed local sentence-transformers embeddings. Existing external daemon URLs, such as KTX_DAEMON_URL or KTX_SQL_ANALYSIS_URL, satisfy the matching dependency and skip managed runtime installation for that dependency.

ktx setup --agents doesn't prepare runtime features or build context. It only installs agent configuration and rules. Start MCP with ktx mcp start before using HTTP-based agents; MCP startup prepares the runtime it needs.

Interactive setup prompts before installing runtime features. Use --yes to install them without prompting. Use --no-input to fail fast when required runtime features are missing.

Databases

FlagDescription
--database <driver>Database driver to configure; repeatable. Choices: sqlite, postgres, mysql, sqlserver, bigquery, snowflake
--database-connection-id <id>Existing selected connection id; repeatable. With --database or --database-url, connection id for the new connection.
--database-url <url>URL, env:NAME, or file:/path for one new URL-style database connection; also used as the SQLite path
--database-schema <schema>Database schema or dataset to include; repeatable
--skip-databasesLeave database setup incomplete

ktx needs at least one database connection before it can build database context. Use --skip-databases only when intentionally leaving the project incomplete.

Query History

FlagDescription
--enable-query-historyEnable query-history ingest when the selected database supports it
--disable-query-historyDisable query-history ingest for the selected database
--query-history-window-days <number>BigQuery/Snowflake query-history lookback window
--query-history-min-executions <number>Minimum executions for a query-history template
--query-history-service-account-pattern <pattern>Query-history service-account regex; repeatable
--query-history-redaction-pattern <pattern>Query-history SQL-literal redaction regex; repeatable

Query history setup is supported for Postgres, BigQuery, and Snowflake. The window flag applies to BigQuery and Snowflake; Postgres reads the current pg_stat_statements aggregate data instead of a time-windowed history table. Enabling query history makes deep ingest readiness matter for later ktx ingest runs.

Context Sources

FlagDescription
--source <type>Context-source connector type: dbt, metricflow, metabase, looker, lookml, or notion
--source-connection-id <id>Connection id for context-source setup
--source-path <path>Local source path for dbt, MetricFlow, or LookML
--source-git-url <url>Git URL for dbt, MetricFlow, or LookML
--source-branch <branch>Git branch for context-source setup
--source-subpath <path>Repo subpath for context-source setup
--source-auth-token-ref <ref>env: or file: credential reference for source repo auth
--source-url <url>Source service URL for Metabase or Looker
--source-api-key-ref <ref>env: or file: API key reference for Metabase or Notion
--source-client-id <id>Looker client id
--source-client-secret-ref <ref>env: or file: Looker client secret reference
--source-warehouse-connection-id <id>Warehouse connection id used for context-source mapping
--source-project-name <name>dbt project name override
--source-profiles-path <path>dbt profiles path
--source-target <target>dbt target or context-source-specific mapping target
--metabase-database-id <id>Metabase database id to map
--notion-crawl-mode <mode>Notion crawl mode: all_accessible or selected_roots
--notion-root-page-id <id>Notion root page id; repeatable
--skip-sourcesMark optional context-source setup complete with no sources

Choose only one source location: --source-path or --source-git-url.

Examples

# Run the interactive setup wizard
ktx setup

# Run setup for a specific project directory
ktx setup --project-dir ./analytics

# Use Claude Code with Opus for ktx LLM calls
ktx setup \
  --project-dir ./analytics \
  --llm-backend claude-code \
  --llm-model opus

# Script a Postgres connection that reads its URL from the environment
ktx setup \
  --project-dir ./analytics \
  --no-input \
  --yes \
  --skip-llm \
  --skip-embeddings \
  --database postgres \
  --database-connection-id warehouse \
  --database-url env:DATABASE_URL \
  --database-schema public

# Enable Postgres query history while setting up a database
ktx setup \
  --project-dir ./analytics \
  --database postgres \
  --database-connection-id warehouse \
  --database-url env:DATABASE_URL \
  --enable-query-history \
  --query-history-min-executions 5

# Add a Metabase source mapped to an existing warehouse connection
ktx setup \
  --source metabase \
  --source-connection-id prod_metabase \
  --source-url https://metabase.example.com \
  --source-api-key-ref env:METABASE_API_KEY \
  --source-warehouse-connection-id warehouse \
  --metabase-database-id 1

# Install project-scoped agent integration for Codex
ktx setup --agents --target codex

Output

Interactive setup renders prompts and progress messages. Use ktx status to check setup and context readiness after setup exits.

output
ktx project: /home/user/analytics
Project ready: yes
LLM ready: yes (claude-sonnet-4-6)
Embeddings ready: yes (text-embedding-3-small)
Databases configured: yes (postgres-warehouse)
Context sources configured: yes (dbt-main)
Runtime ready: yes (core)
ktx context built: yes
Agent integration ready: yes (codex:project)

Use ktx status for repeatable readiness checks after setup exits.

Common errors

ErrorCauseRecovery
Setup resumes an unexpected projectKTX_PROJECT_DIR or nearest ktx.yaml points to another directoryPass --project-dir <path> explicitly
Setup cannot run in CIRequired values are missing and --no-input disables promptsProvide the relevant automation flags or create a fixture ktx.yaml
Provider health check failsProvider key, model id, Vertex project, or Vertex location is invalidFix the env: or file: reference and rerun setup
Python runtime is missingThe selected setup needs runtime-backed agent, query-history, Looker, or local embedding featuresAccept the interactive prompt, rerun with --yes, or run the suggested ktx admin runtime install command
--enable-query-history is rejectedThe selected database driver does not support query historyUse Postgres, BigQuery, or Snowflake, or rerun without query-history flags
Source setup rejects location flagsBoth --source-path and --source-git-url were suppliedChoose the local path or the Git URL, not both
Agent integration missingSetup skipped the agents stepRun ktx setup --agents --target <target>
Agent setup cannot prompt for a targetNon-TTY ktx setup --agents needs a targetRun ktx setup --agents --target <target> or rerun in a TTY
Global agent install is rejected--global was used with a target other than claude-code or codexOmit --global, or choose --target claude-code or --target codex