Skip to main content

MCP server for populating and managing Sciple platform content

Project description

Sciple Platform MCP Server

MCP server that lets a local Claude populate and manage Sciple platform content — environments, services, observability dashboards, and runbooks — via the Sciple REST API. Engineers use it to bootstrap tenant structure, maintain the service catalog, build dashboards, and author runbooks without leaving their AI coding session.

Published on PyPI: https://pypi.org/project/sciple-mcp/ Source: https://github.com/navaganeshr/sciple-mcp

Install

The recommended install is via uv — it's a one-time setup that gives you uvx, which fetches and caches sciple-mcp on demand. No clone required.

# Install uv (one-time, only if you don't have it)
curl -LsSf https://astral.sh/uv/install.sh | sh

uvx sciple-mcp will resolve the latest version from PyPI on first run and cache it locally.

Configuration

The server reads three environment variables:

SCIPLE_API_URL=http://localhost:8000/api/v1
SCIPLE_API_TOKEN=sciple_pat_...
SCIPLE_TENANT_ID=<your tenant id>

SCIPLE_API_TOKEN is a personal access token minted under Profile → Access tokens in the Sciple dashboard, scoped to the permissions the server should have:

Domain Permissions
Environments environments.view, environments.manage
Services services.view, services.manage
Observability observability.view, observability.manage
Runbooks observability.view, observability.manage (runbooks live under the observability permission family)

The PAT is single-tenant — its bound tenant must equal SCIPLE_TENANT_ID. Calls against a different tenant return 403.

Wire into Claude Desktop / Claude Code

Add to ~/Library/Application Support/Claude/claude_desktop_config.json (Claude Desktop) or your Claude Code MCP config:

{
  "mcpServers": {
    "sciple-platform": {
      "command": "uvx",
      "args": ["sciple-mcp"],
      "env": {
        "SCIPLE_API_URL": "http://localhost:8000/api/v1",
        "SCIPLE_API_TOKEN": "sciple_pat_...",
        "SCIPLE_TENANT_ID": "..."
      }
    }
  }
}

Then restart Claude. You should see 26 platform tools available.

The Sciple dashboard also renders this exact JSON block — with SCIPLE_API_URL and SCIPLE_TENANT_ID pre-filled from the running environment — inside the "How to use this token with Claude" panel on Profile → Access tokens. Generate a token there and copy the snippet directly.

Tools

Environments

Tool Description
list_environments List all environments in the tenant (id, name, slug, group, default flag)
create_environment Create an environment with optional group assignment and default flag
update_environment Update an environment's name, description, group, or sort order
delete_environment Delete an environment by id (irreversible)
list_environment_groups List environment groups (id, name, slug, AWS account binding)
create_environment_group Create an environment group with optional AWS account binding

Services

Tool Description
list_services List all services in the tenant catalog (id, name, slug)
create_service Create a service in the catalog with kind, language, SCM provider, and repository
update_service Update a service's metadata, lifecycle, owner, tags, links, or environment associations
delete_service Delete a service from the catalog by id (irreversible)

Observability

Tool Description
list_dashboards List all observability dashboards in the tenant (id, name, panel count)
get_dashboard Get a dashboard's name, description, and panel list
create_dashboard Create a new dashboard with optional description
update_dashboard Replace a dashboard's name and description (full PUT; name required)
delete_dashboard Delete a dashboard and all its panels (irreversible)
add_panel Add a panel to a dashboard. Supports 5 shapes end-to-end (pick one): PromQL (promql), CloudWatch Metrics (cw_namespace+cw_metric_name+cw_stat + optional cw_dimensions/cw_period), ElasticSearch/OpenSearch logs (es_index + optional kql_filter), CloudWatch Logs (cw_log_group + optional cw_filter_pattern), or Text (text_content + optional text_background). Log panels also accept display options (log_columns, log_limit, log_wrap_message, log_expandable_rows, log_highlight_by_severity, log_live_tail). Always pass datasource_id for metric + log panels.
delete_panel Delete a panel from a dashboard (irreversible)

Runbooks

Tool Description
list_runbooks List all runbooks in the tenant with lifecycle status and cell count
get_runbook Get a runbook with its cells (name, status, content preview per cell)
create_runbook Create a new runbook in draft status
add_cell Add a markdown / shell / http cell to a runbook with optional k8s/ecs/ec2 target
update_cell Update a cell's content or execution target
delete_cell Remove a cell from a runbook
reorder_cells Set the execution order of all cells in a runbook
promote_runbook Advance the runbook lifecycle: draft → reviewed → standard
deprecate_runbook Mark a runbook as deprecated

Runbook lifecycle: draft → reviewed → standard. Deprecation is one-way from any state.

Security

The server can only do what the PAT's scope allows. Attempts to write without the relevant manage permission return a 403 from the API and are surfaced as an error in Claude's response. The PAT is revocable at any time from Profile → Access tokens in the Sciple dashboard — revoking it immediately cuts off the server's access without any config change.

Development

To work on the server itself:

git clone https://github.com/navaganeshr/sciple-mcp
cd sciple-mcp
uv sync --all-groups
uv run python -m pytest -q

Releases are tag-driven via a GitHub Actions workflow using PyPI Trusted Publishing (OIDC). To cut a release:

  1. Bump version in pyproject.toml.
  2. Commit, then git tag vX.Y.Z && git push origin vX.Y.Z.
  3. Approve the pypi environment deployment in the Actions UI.

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

sciple_mcp-0.4.0.tar.gz (51.3 kB view details)

Uploaded Source

Built Distribution

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

sciple_mcp-0.4.0-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file sciple_mcp-0.4.0.tar.gz.

File metadata

  • Download URL: sciple_mcp-0.4.0.tar.gz
  • Upload date:
  • Size: 51.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sciple_mcp-0.4.0.tar.gz
Algorithm Hash digest
SHA256 2eb0e81ece9007fa5a6fe7815c291d92057d0fbc352b4c02d9c1bec07efca955
MD5 0ccbaa21fe073c2a4ef56d3990f2b4e2
BLAKE2b-256 e19c002549b81185a56657c8fa41a8623c3d0aba95d094a083ea106b8173e889

See more details on using hashes here.

Provenance

The following attestation bundles were made for sciple_mcp-0.4.0.tar.gz:

Publisher: publish.yml on navaganeshr/sciple-mcp

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

File details

Details for the file sciple_mcp-0.4.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for sciple_mcp-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 20df732adb82c3100bc4802b78cdb9f120cac75474ac4dbdcc6e68a11352b042
MD5 d1e08c6303808e21f0479f389719b102
BLAKE2b-256 044a2cb0e812796a6c32a9f033a0d1e2f07cec07b16b7a3162dc6ba7d16b6fe6

See more details on using hashes here.

Provenance

The following attestation bundles were made for sciple_mcp-0.4.0-py3-none-any.whl:

Publisher: publish.yml on navaganeshr/sciple-mcp

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