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, runbooks, projects, and tickets — via the Sciple REST API. Engineers use it to bootstrap tenant structure, maintain the service catalog, build dashboards, author runbooks, and triage tickets without leaving their AI coding session.
Distribution channels:
| Channel | Use it from | How to install |
|---|---|---|
| PyPI | Claude Code, custom scripts, CI | uvx sciple-mcp |
| MCP Registry | Anywhere an MCP client speaks the registry protocol | Resolves automatically by io.github.navaganeshr/sciple-mcp |
Desktop Extension (.dxt) |
Claude Desktop | Double-click sciple-mcp-<version>.dxt from the GitHub release |
- PyPI: https://pypi.org/project/sciple-mcp/
- MCP Registry: https://registry.modelcontextprotocol.io/v0/servers/io.github.navaganeshr%2Fsciple-mcp
- Source: https://github.com/navaganeshr/sciple-mcp
Install
# Install uv (one-time, only if you don't have it)
curl -LsSf https://astral.sh/uv/install.sh | sh
uvx sciple-mcp resolves the latest version from PyPI and caches it.
Authentication — OAuth only (v0.7.0+)
sciple-mcp authenticates against the Sciple platform via OAuth 2.0
with PKCE. The CLI is a credential helper: log in once via the
browser, the access + refresh tokens land in ~/.sciple/credentials.json
(mode 0600), and the MCP server reads + auto-refreshes from there.
PAT support was removed in v0.7.0. Earlier versions accepted
SCIPLE_API_TOKEN=sciple_pat_…in the env (stdio mode). That path is gone — the only credential the MCP server understands is the OAuth JWT minted bysciple-mcp login. Personal Access Tokens on the platform are unchanged and still work for scripts / CI / direct REST calls against/api/v1/*.
1. Log in (one-time per platform)
sciple-mcp login --platform-url https://your.sciple.cloud
Opens your browser, you click Approve on the consent page, the CLI
captures the callback and writes the credential. No --tenant-id /
--scope needed — the JWT inherits your full role on whichever tenant
the dashboard is currently showing.
2. Wire into Claude
The Sciple platform now hosts /mcp itself, so the preferred shape is
Streamable HTTP straight to the platform:
# Claude Code (HTTP transport — preferred)
claude mcp add-json sciple-platform "$(cat <<EOF
{
"type": "http",
"url": "https://your.sciple.cloud/mcp",
"headers": { "Authorization": "Bearer $(sciple-mcp print-token)" }
}
EOF
)"
For Claude Desktop builds that only speak stdio MCP today, use the stdio mode — same credential, no PAT:
{
"mcpServers": {
"sciple-platform": {
"command": "uvx",
"args": ["sciple-mcp"],
"env": {
"SCIPLE_PLATFORM_URL": "https://your.sciple.cloud"
}
}
}
}
SCIPLE_PLATFORM_URL is optional — only needed if you have multiple
platforms cached. Stdio mode reads ~/.sciple/credentials.json
directly.
3. Manage / rotate
sciple-mcp print-token # current valid JWT (auto-refreshes near expiry)
sciple-mcp logout # forget local cache
sciple-mcp logout --revoke # also revoke the refresh token server-side
Revoke any time from Profile → Connected apps on the dashboard.
Legacy: sciple-mcp serve (local HTTP server)
For air-gapped deployments where the client can't reach the platform's
hosted /mcp endpoint, sciple-mcp serve still ships a local
Streamable HTTP MCP server that re-validates OAuth JWTs against the
platform's JWKS. Same credential, same flow — only the network shape
differs. See --help for serve / install / uninstall.
Tools
Cloud inventory (read-only)
| Tool | Description |
|---|---|
list_aws_accounts |
List AWS accounts connected to the tenant (account_id, name, AWS number, regions, payer flag) |
list_cloud_resource_types |
List synced resource types + row counts for one AWS service in an account |
query_cloud_resources |
Query cached rows from any synced AWS resource table (paginated, region filter) |
list_ec2_instances |
Summarize EC2 instances for one account or across all (state/type/id/name/ip) |
These read the platform's last AWS sync — they never call AWS directly and
never mutate anything. They require the credential to hold cloud.view.
Example — explore your AWS estate
Ask Claude in plain language; it chains the tools for you:
You: What EC2 instances are running across all our AWS accounts?
Claude calls list_ec2_instances (no account_id → sweeps every connected
account) and summarizes:
45 EC2 instances across 4 accounts.
### Production (account_id=LlDZzq) — 13 instances (12 running, 1 shutting-down)
[running] m5.2xlarge i-047323d5f680e822f portal-apps-ondemand (10.40.2.11)
[running] t2.micro i-00fcaed2de8131fd1 prod-nat-instance-1a (10.40.0.9)
...
To drill into a single account, or a different resource type, Claude discovers what's synced first, then queries it:
You: Show the RDS databases in the Production account.
1. list_aws_accounts → Production has account_id "LlDZzq"
2. list_cloud_resource_types( → aws_rds_db_instance: 4
account_id="LlDZzq", service="rds")
3. query_cloud_resources( → 4 rows (engine, class, status, endpoint…)
account_id="LlDZzq", service="rds",
resource_type="aws_rds_db_instance")
query_cloud_resources is the generic accessor for any of the 19 supported
services (ec2, rds, s3, vpc, iam, lambda, eks, ecs, ebs,
elasticache, route53, cloudfront, dynamodb, ecr, efs, and the
code* suite) — pass an unknown service and the tool returns the valid set.
Use region to filter ("global" for S3) and page / page_size (≤500) to
walk large tables.
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.
Projects
| Tool | Description |
|---|---|
list_projects |
List all projects in the tenant (id, key, name, classification) |
get_project |
Get a single project's details (owner, description, classification) |
create_project |
Create a new project (name + uppercase key like "PLAT", optional classification + owner) |
list_project_members |
List the user_ids and roles of a project's members (use to find an assignee) |
list_project_issue_types |
List a project's issue types (required before create_project_ticket) |
Tickets
| Tool | Description |
|---|---|
list_tickets |
List tickets across the tenant with optional filters (service, assignee, status, priority, type, tag, full-text q) |
get_ticket |
Get a single ticket's full details + activity counts (by internal id) |
create_ticket |
Create a service-level ticket (not bound to a project) — tickets.manage |
update_ticket |
PATCH a ticket — change status, priority, assignee, dates, tags, parent |
comment_on_ticket |
Add a comment to a ticket — tickets.comment |
link_tickets |
Relate two tickets (blocks / relates_to / duplicates) |
list_project_tickets |
List tickets in a project |
get_project_ticket |
Get a project ticket by sequence number (the NNN in KEY-NNN) |
create_project_ticket |
Create a ticket inside a project — returns a "KEY-NNN" display id. Recommended for most ticket creation. Supports custom_fields (JSON string of {field_id: value}). Requires tickets.create. |
Ticket statuses: open → in_progress → done (or cancelled from any state). Priorities: low / medium / high / urgent. Severities (optional): minor / major / critical. Types: epic / story / task / subtask / bug.
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:
- Bump
versioninpyproject.toml. - Commit, then
git tag vX.Y.Z && git push origin vX.Y.Z. - Approve the
pypienvironment deployment in the Actions UI.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sciple_mcp-0.9.0.tar.gz.
File metadata
- Download URL: sciple_mcp-0.9.0.tar.gz
- Upload date:
- Size: 78.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8fe2d83bf7688cecc2d218245e7e6b689acf238a0c8edf95d35905b7e87cc989
|
|
| MD5 |
d22c9fb7167c228763f927d74be91108
|
|
| BLAKE2b-256 |
aca262fcec9a7c90b437060f256e1d0481f0fd47b069b8caaa17c2c6af8deeeb
|
Provenance
The following attestation bundles were made for sciple_mcp-0.9.0.tar.gz:
Publisher:
publish.yml on sciple-idp/sciple-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sciple_mcp-0.9.0.tar.gz -
Subject digest:
8fe2d83bf7688cecc2d218245e7e6b689acf238a0c8edf95d35905b7e87cc989 - Sigstore transparency entry: 1935252116
- Sigstore integration time:
-
Permalink:
sciple-idp/sciple-mcp@f0ffbfeeed158630f5cc618919923ab0fbcceba5 -
Branch / Tag:
refs/tags/v0.9.0 - Owner: https://github.com/sciple-idp
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@f0ffbfeeed158630f5cc618919923ab0fbcceba5 -
Trigger Event:
push
-
Statement type:
File details
Details for the file sciple_mcp-0.9.0-py3-none-any.whl.
File metadata
- Download URL: sciple_mcp-0.9.0-py3-none-any.whl
- Upload date:
- Size: 45.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8464642f3633f4694f94e3d62c4f4e00fec7bf3653bbea3c901ded213ce316c1
|
|
| MD5 |
e4dbf46d2f8fc88db076dbe4087cd136
|
|
| BLAKE2b-256 |
bab7914e19347026953abc48e4193c8f205cfad1df5e7b06ef8302828e1c5ea9
|
Provenance
The following attestation bundles were made for sciple_mcp-0.9.0-py3-none-any.whl:
Publisher:
publish.yml on sciple-idp/sciple-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
sciple_mcp-0.9.0-py3-none-any.whl -
Subject digest:
8464642f3633f4694f94e3d62c4f4e00fec7bf3653bbea3c901ded213ce316c1 - Sigstore transparency entry: 1935252119
- Sigstore integration time:
-
Permalink:
sciple-idp/sciple-mcp@f0ffbfeeed158630f5cc618919923ab0fbcceba5 -
Branch / Tag:
refs/tags/v0.9.0 - Owner: https://github.com/sciple-idp
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@f0ffbfeeed158630f5cc618919923ab0fbcceba5 -
Trigger Event:
push
-
Statement type: