1.7 KiB
1.7 KiB
Public Contract
This document defines the supported public interface for pyro-mcp 1.x.
Package Identity
- Distribution name:
pyro-mcp - Public executable:
pyro - Public Python import:
from pyro_mcp import Pyro
CLI Contract
Top-level commands:
pyro env listpyro env pullpyro env inspectpyro env prunepyro mcp servepyro runpyro doctorpyro demopyro demo ollama
Stable pyro run interface:
- positional environment name
--vcpu-count--mem-mib--timeout-seconds--ttl-seconds--network
Behavioral guarantees:
pyro run <environment> -- <command>returns structured JSON.pyro env list,pyro env pull,pyro env inspect, andpyro env prunereturn structured JSON.pyro doctorreturns structured JSON diagnostics.pyro demo ollamaprints log lines plus a final summary line.
Python SDK Contract
Primary facade:
Pyro
Supported public methods:
create_server()list_environments()pull_environment(environment)inspect_environment(environment)prune_environments()create_vm(...)start_vm(vm_id)exec_vm(vm_id, *, command, timeout_seconds=30)stop_vm(vm_id)delete_vm(vm_id)status_vm(vm_id)network_info_vm(vm_id)reap_expired()run_in_vm(...)
MCP Contract
Primary tool:
vm_run
Advanced lifecycle tools:
vm_list_environmentsvm_createvm_startvm_execvm_stopvm_deletevm_statusvm_network_infovm_reap_expired
Versioning Rule
pyro-mcpuses SemVer.- Environment names are stable identifiers in the shipped catalog.
- Changing a public command name, public flag, public method name, public MCP tool name, or required request field is a breaking change.