Skip to main content

Local MCP server exposing Stackless app APIs to terminal agents

Project description

Stackless MCP

stackless-mcp is a local stdio MCP server for Claude Code, Codex, and other terminal agents. It exposes Stackless app capabilities as MCP tools by calling a deployed Stackless instance over /api/v1.

The MCP process is intentionally thin. It does not import middleware-service, does not need Snowflake or dbt credentials, and does not read local app data. Stackless remains the source of truth for auth, RBAC, ownership, and mutations.

Use this guide when connecting a terminal agent to your own Stackless instance from the published stackless-mcp package. Development from a monorepo checkout is covered separately at the end.

Prerequisite

Install uv. The agent configuration uses uvx, which is included with uv and fetches the pinned stackless-mcp package on first run.

Install

Pin the beta version exactly in your agent configuration: stackless-mcp==<version>. The MCP server also needs the base URL for your Stackless instance.

Codex

Add this block to ~/.codex/config.toml:

[mcp_servers.stackless]
command = "uvx"
args = [
  "stackless-mcp==<version>",
  "--base-url",
  "https://your-stackless-instance.example.com",
]

Claude Code

Add this block to .mcp.json:

{
  "mcpServers": {
    "stackless": {
      "command": "uvx",
      "args": [
        "stackless-mcp==<version>",
        "--base-url",
        "https://your-stackless-instance.example.com"
      ]
    }
  }
}

Login

Run login once before starting Codex or Claude Code:

uvx stackless-mcp==<version> login \
  --base-url https://your-stackless-instance.example.com

login opens the Stackless browser auth flow, receives a local callback from the authenticated browser session, exchanges it for a scoped slmcp_ MCP session, and stores that session locally. The server-side session defaults to a 30-day TTL. Your Stackless instance can lower that lifetime with MCP_SESSION_TTL_SECONDS.

Credentials are stored in the OS keyring by default. If keyring support is not available, use file storage:

uvx stackless-mcp==<version> login \
  --base-url https://your-stackless-instance.example.com \
  --auth-storage file

With --auth-storage file, credentials are stored as a 0600 credentials.json file in the platform user config directory for stackless-mcp. If you use file storage for login, add "--auth-storage", "file" to the agent configuration too.

Verify

uvx stackless-mcp==<version> --version
uvx stackless-mcp==<version> doctor \
  --base-url https://your-stackless-instance.example.com

Run doctor first when setup does not work. It checks local configuration, stored auth, Stackless API connectivity, and server capability discovery.

Example successful output:

{
  "auth": {
    "credential_present": true,
    "expires_at": "2026-07-10T12:00:00Z",
    "expiry_status": "unexpired",
    "mode": "stored_token",
    "storage_backend": "keyring",
    "token_present": true,
    "user_id": "user_123"
  },
  "auth_storage": "keyring",
  "base_url": "https://your-stackless-instance.example.com",
  "capabilities": {
    "checked": true,
    "client_known_unsupported_by_server": [],
    "error": null,
    "ok": true,
    "server_supported_unknown_to_client": [],
    "server_version": "2026.06.10"
  },
  "client_version": "<version>",
  "connectivity": {
    "checked": true,
    "ok": true
  },
  "errors": [],
  "ok": true,
  "toolsets": [
    "all"
  ]
}

doctor exits 0 when required checks pass and exits 1 for local configuration, auth, or connectivity failures. Missing command arguments and invalid CLI options exit 2.

Troubleshooting

  • Missing base URL: pass --base-url https://... in the agent config and login command, or set STACKLESS_BASE_URL.
  • Expired or missing token: run uvx stackless-mcp==<version> login --base-url https://your-stackless-instance.example.com again.
  • Server capability delta: doctor reports tools known by the client but not supported by the server under client_known_unsupported_by_server. Upgrade the Stackless instance when you need those tools; otherwise the client simply advertises the supported subset.
  • Connectivity failure: confirm the base URL is reachable from your machine, uses the correct scheme, and includes no /api/v1 suffix.
  • Keyring failure: rerun login and your agent command with --auth-storage file.

For a one-shot connectivity check without starting MCP stdio, run:

uvx stackless-mcp==<version> \
  --base-url https://your-stackless-instance.example.com \
  --check

--check uses the stored MCP session when present and exits. Expired sessions prompt a fresh stackless-mcp login instead of failing with an opaque MCP startup error.

Upgrade

Upgrade by changing the pinned package version in your Codex or Claude Code configuration, then restart the agent. Pre-release versions follow PEP 440: beta releases must be pinned exactly. For example, change stackless-mcp==<old-version> to stackless-mcp==<new-version> when the new beta is published.

Revoke or Reset Auth

uvx stackless-mcp==<version> logout \
  --base-url https://your-stackless-instance.example.com
uvx stackless-mcp==<version> reset-auth \
  --base-url https://your-stackless-instance.example.com

logout calls /mcp/auth/revoke and then deletes the local credential. reset-auth only deletes the local credential, which is useful for stale or corrupt local state; the server-side session remains valid until it is revoked or expires.

To rotate a file-backed credential, run logout with --auth-storage file, then run login --auth-storage file again. Delete any copied backups of the old file credential as part of rotation.

Advanced: Toolsets

This is not part of basic setup. By default, the full supported tool set loads and the agent decides which tool to call at runtime. Tool selection is automatic and is not a setup choice.

Use --toolsets only when you intentionally want to reduce the loaded tool-schema surface and agent context:

[mcp_servers.stackless]
command = "uvx"
args = [
  "stackless-mcp==<version>",
  "--base-url",
  "https://your-stackless-instance.example.com",
  "--toolsets",
  "catalog,runs",
]

Valid toolsets are all, core, catalog, runs, transformations, semantic, dashboards, and lifecycle. all is the default. Core tools for auth checks and operation status are always registered; selecting core registers only those tools. Toolsets are a runtime ergonomics feature, not a security boundary. Stackless backend RBAC and tool permissions still enforce access.

Development

Use this path only when developing stackless-mcp from a monorepo checkout:

cd stackless-mcp
poetry install --with dev
poetry run stackless-mcp login \
  --base-url https://your-stackless-instance.example.com
poetry run stackless-mcp \
  --base-url https://your-stackless-instance.example.com

Manual token/cookie setup remains for development and compatibility only:

export STACKLESS_BASE_URL=https://your-stackless-instance.example.com
export STACKLESS_TOKEN='<valid Stackless/Cognito JWT or slmcp token>'
# or, for browser-cookie development auth:
# export STACKLESS_COOKIE='AWSALB=...; AWSELBAuthSessionCookie-0=...'
poetry run stackless-mcp

Tool Surface

Prefer these workflow-style tools for new agents:

Tool Description
check_stackless_connection Check configured Stackless auth/API connectivity.
find_relevant_data Find catalog assets relevant to a business question.
explain_stackless_asset Explain one catalog asset, columns, and lineage handles.
list_stackless_assets List visible catalog assets by type, domain, or tag.
trace_stackless_lineage Trace upstream or downstream catalog lineage.
get_stackless_column_details Get column metadata for a catalog asset.
refresh_stackless_catalog Refresh the catalog snapshot in light or full mode.
get_stackless_connector_status Get connector sync status from the catalog snapshot.
get_stackless_asset_freshness Summarize upstream freshness for a catalog asset.
list_stackless_snowflake_schemas List visible Snowflake schemas from the catalog.
describe_snowflake_object Describe a visible Snowflake table or view with typed column metadata.
validate_snowflake_access Check RBAC plus Snowflake metadata or zero-row object access.
explain_schema_permissions Explain Stackless catalog/RBAC visibility for a Snowflake schema.
query_snowflake Run direct read-only Snowflake SQL with Stackless guardrails.
list_stackless_runs List recent scheduler runs with stable run refs.
diagnose_stackless_run Diagnose one run or job with redacted logs.
get_stackless_run_logs Fetch filtered, redacted logs for a scheduler run.
cancel_stackless_run Cancel a pending or running scheduler run.
draft_transformation_model Scaffold or create a Transformation Model draft.
get_stackless_transformation_model Read Transformation Model source-of-truth state from middleware.
validate_transformation_model_draft Validate a Transformation Model draft.
preview_transformation_model_draft Queue a guarded preview for a Transformation Model draft.
draft_semantic_model Scaffold or create a Semantic Model draft.
list_stackless_semantic_models List visible Semantic Models.
explain_stackless_semantic_model Explain a Semantic Model and queryable members.
validate_semantic_model_draft Validate a Semantic Model draft or payload.
preview_semantic_model_query Run a guarded Semantic Model preview query.
list_stackless_dashboards List visible Stackless dashboards.
list_dashboard_members List Cube members available for custom dashboard widgets.
get_stackless_dashboard Get dashboard metadata, custom spec, and workflow hints.
diagnose_stackless_dashboard Diagnose custom dashboard widget hydration failures.
describe_gooddata_dashboard Describe a visible legacy GoodData dashboard structure and dependencies.
trace_gooddata_dashboard_metrics Trace legacy GoodData dashboard visualizations to metrics.
validate_gooddata_filters Validate legacy GoodData dashboard filter references against the LDM.
draft_dashboard_from_goal Scaffold or create a custom dashboard draft.
clone_stackless_dashboard Clone a custom dashboard into an independent private draft.
fork_stackless_dashboard Fork a published custom dashboard into a private draft.
update_stackless_dashboard_draft Update a private custom dashboard draft.
hydrate_dashboard Hydrate custom dashboard widgets through Stackless/Cube.
validate_dashboard_draft Validate a custom dashboard draft or spec.
preview_dashboard Hydrate a custom dashboard preview through Stackless/Cube.
diff_stackless_draft Inspect draft diff/review output and publish fingerprints before publication.
publish_stackless_draft Publish a Stackless draft after confirmation and matching review context.
estimate_stackless_refresh Prepare a refresh estimate before refreshing a published resource.
refresh_stackless_resource Refresh a published Stackless resource after confirmation.
unpublish_stackless_resource Unpublish a Stackless resource after confirmation.
delete_stackless_draft Delete a draft resource after confirmation.
get_stackless_operation Get status for an MCP operation ID.
get_stackless_invocation Recover status for a tool/idempotency key.

Mutating tools require an idempotency_key. Publish, refresh, unpublish, cancel, and delete also require confirmation={"confirmed": true, "evidence": "..."}. For dashboard drafts, first call diff_stackless_draft("dashboard:<id>"), using its optional request argument for non-default preview filters or table overrides, and pass the returned review object as publish_context={"review": review} to publish_stackless_draft. Stackless rejects stale dashboard fingerprints if the draft changes between review and publish. For draft_transformation_model, an idempotency_key is required only when a spec is supplied and a draft is created.

Managed Transformation Workflow

For managed Transformation Models, use middleware-backed tools for lifecycle state and catalog-backed tools for discoverability:

  1. Create or update a draft with draft_transformation_model.
  2. Validate and preview it with validate_transformation_model_draft and preview_transformation_model_draft, polling returned operations with get_stackless_operation.
  3. Review the publish diff with diff_stackless_draft, then publish with publish_stackless_draft and explicit confirmation.
  4. Verify middleware source-of-truth state with get_stackless_transformation_model. This is the tool for published version, materialization, identity, incremental config, relation metadata, refresh policy, and timestamps.
  5. Use explain_stackless_asset after catalog refresh when you need catalog visibility, lineage, columns, or downstream dependency context.
  6. Estimate refresh scope first with estimate_stackless_refresh. Use the returned refresh estimate, fingerprint, confirmation requirement, and operation ref before queueing a refresh.
  7. Queue the refresh with refresh_stackless_resource, passing the estimate identifiers, explicit confirmation, and an idempotency_key. Poll the returned operation ref and use diagnose_stackless_run for run details.

Endpoint-shaped compatibility tools are no longer registered. Use the workflow-style tools above for all new MCP agent flows.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stackless_mcp-1.0.0b4.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stackless_mcp-1.0.0b4-py3-none-any.whl (25.4 kB view details)

Uploaded Python 3

File details

Details for the file stackless_mcp-1.0.0b4.tar.gz.

File metadata

  • Download URL: stackless_mcp-1.0.0b4.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for stackless_mcp-1.0.0b4.tar.gz
Algorithm Hash digest
SHA256 5d7dfb89f596b1cca38e2ed4f0e107b09961d3c96deaf67ec36a139fc8ff999d
MD5 7094a2b2b12a49546aa2d8ab6a8e0073
BLAKE2b-256 196e3af4d8f33ced734b9b3624f555beb6bee4a6a0d9f66aed8b46eee52f0130

See more details on using hashes here.

Provenance

The following attestation bundles were made for stackless_mcp-1.0.0b4.tar.gz:

Publisher: stackless-mcp-release.yml on OxWorks/stackless

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file stackless_mcp-1.0.0b4-py3-none-any.whl.

File metadata

  • Download URL: stackless_mcp-1.0.0b4-py3-none-any.whl
  • Upload date:
  • Size: 25.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for stackless_mcp-1.0.0b4-py3-none-any.whl
Algorithm Hash digest
SHA256 2f369a7b6a26d9b735949f398ede23225d3d1f0de536c04d927409471d645443
MD5 398793df9f59a0db549acce6f7563cdc
BLAKE2b-256 f2cad77fdc6b7f6eeef243d05d0357f561be2a999eac44680940f1c04be67548

See more details on using hashes here.

Provenance

The following attestation bundles were made for stackless_mcp-1.0.0b4-py3-none-any.whl:

Publisher: stackless-mcp-release.yml on OxWorks/stackless

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page