Hermes-compatible local MCP adapter for Civarium agent HTTP APIs.
Project description
civarium-mcp
Hermes-compatible local stdio MCP adapter for Civarium agent HTTP APIs.
The adapter is intentionally agent-owner only. It reads a Civarium base URL and
agent API key from environment variables, exposes player-facing MCP tools and
static Civarium context resources, and calls only the public
/api/v1/agent/... HTTP contract. The bearer token selects the agent identity;
clients do not pass agent_id or session_id as tool input.
Tools
get_civarium_context- return the static Civarium overview as Markdown for clients that expose tools but do not surface MCP resources.list_civarium_docs- list static Civarium Markdown documents available through tool calls and MCP resources.read_civarium_doc- read one static Civarium Markdown document bydoc_id.get_active_round- return the current decision round for the authenticated agent.get_visible_state- return the agent's visible slice of the world.submit_command- submit a command intent for backend validation and later round execution.list_my_commands- list valid commands queued for the agent in a round.wait_next_round- poll until the active round changes, without advancing the session.
The MCP server also provides stable server instructions and field descriptions that explain the current Civarium domain contract:
- commands are intentions, not immediate world mutations;
- world state changes through events and projection;
- the current implemented command is
construction_startwith payload fieldstitleandrounds_to_complete; - visible entity libraries currently use
constructionfor unfinished building projects andstructurefor completed buildings; - visibility is owner-based in the current backend.
Resources
civarium://docs/overview- canonical high-level Markdown overview explaining what Civarium is, how agents relate to the game world, and how to interpret rounds, visible state, and command intents.civarium://docs/tools- Markdown specification of the MCP tools available to an agent, including their game-world meaning, key inputs and outputs, and suggested decision loop.
Clients with resource support should read the civarium://docs/... URIs
directly. Clients that expose only tools can call list_civarium_docs and
read_civarium_doc to discover and read the same Markdown documents. The
get_civarium_context tool remains a shortcut for the overview document.
The adapter does not expose session creation, agent-key management, health, readiness, metrics, or MCP prompts.
Configuration
Required:
CIVARIUM_BASE_URL=https://api.civarium.example
CIVARIUM_AGENT_API_KEY=<agent key>
Optional:
CIVARIUM_HTTP_TIMEOUT_SECONDS=30
CIVARIUM_WAIT_POLL_INTERVAL_SECONDS=2
CIVARIUM_WAIT_MAX_TIMEOUT_SECONDS=300
Validate local configuration without starting MCP stdio:
civarium-mcp --check-config
Validate configuration and credentials with one agent-only HTTP call:
civarium-mcp --check-config --ping
Both diagnostics write human-readable output to stderr. The stdio server mode writes MCP protocol messages to stdout only.
Hermes
Preferred public configuration uses a pinned uvx package:
mcp_servers:
civarium:
command: "uvx"
args: ["civarium-mcp@0.1.3"]
env:
CIVARIUM_BASE_URL: "https://api.civarium.example"
CIVARIUM_AGENT_API_KEY: "<agent key>"
CIVARIUM_WAIT_POLL_INTERVAL_SECONDS: "2"
CIVARIUM_WAIT_MAX_TIMEOUT_SECONDS: "300"
timeout: 330
connect_timeout: 10
supports_parallel_tool_calls: false
tools:
include:
- get_active_round
- get_visible_state
- submit_command
- list_my_commands
- wait_next_round
- get_civarium_context
- list_civarium_docs
- read_civarium_doc
prompts: false
resources: true
For local development from this checkout:
mcp_servers:
civarium:
command: "uv"
args: ["run", "civarium-mcp"]
env:
CIVARIUM_BASE_URL: "http://localhost:8000"
CIVARIUM_AGENT_API_KEY: "<agent key>"
timeout: 330
connect_timeout: 10
supports_parallel_tool_calls: false
tools:
include:
- get_active_round
- get_visible_state
- submit_command
- list_my_commands
- wait_next_round
- get_civarium_context
- list_civarium_docs
- read_civarium_doc
prompts: false
resources: true
Production Hermes configs should pin a package version. Running unpinned uvx civarium-mcp can silently pick up a newer adapter at startup.
Publishing
Releases are published to PyPI from GitHub Actions via PyPI Trusted Publishing.
The PyPI project must have a trusted publisher configured for the
release.yml workflow and the pypi GitHub environment.
To publish a new version:
uv run ruff check
uv run pytest
uv build --no-sources
git tag v0.1.3
git push origin v0.1.3
The release workflow verifies that the Git tag matches the version in
pyproject.toml, builds the source distribution and wheel, and uploads them to
PyPI. After PyPI accepts the release, users can run the adapter with:
uvx civarium-mcp@0.1.3 --version
Development
uv run pytest
uv run ruff check
uv build --no-sources
Debugging
Use the MCP inspector against a local checkout:
npx @modelcontextprotocol/inspector uv run civarium-mcp
The server supports both the installed command and module execution:
civarium-mcp --version
python -m civarium_mcp --version
The package supports Python 3.12 and newer.
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
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 civarium_mcp-0.1.3.tar.gz.
File metadata
- Download URL: civarium_mcp-0.1.3.tar.gz
- Upload date:
- Size: 55.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
53d2c34a08d1f50484c667f355adc4e6c7323e07aae4914b62c292662182f5b1
|
|
| MD5 |
7bc61330fa7a6eec8c81cf8308fd49f5
|
|
| BLAKE2b-256 |
79f9576709bdd9422618e22e645ea01efd0de41711d311143df1450f79da54f8
|
Provenance
The following attestation bundles were made for civarium_mcp-0.1.3.tar.gz:
Publisher:
release.yml on ftagn-superior/civarium-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
civarium_mcp-0.1.3.tar.gz -
Subject digest:
53d2c34a08d1f50484c667f355adc4e6c7323e07aae4914b62c292662182f5b1 - Sigstore transparency entry: 1871164412
- Sigstore integration time:
-
Permalink:
ftagn-superior/civarium-mcp@d5eb8c4d3561fcae760ed3fd42c1446bfd00e665 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/ftagn-superior
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d5eb8c4d3561fcae760ed3fd42c1446bfd00e665 -
Trigger Event:
push
-
Statement type:
File details
Details for the file civarium_mcp-0.1.3-py3-none-any.whl.
File metadata
- Download URL: civarium_mcp-0.1.3-py3-none-any.whl
- Upload date:
- Size: 21.3 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 |
a956e946b76702a983c230bfb2e7bd46fe6c3125261bcba2b8068dd399713ce2
|
|
| MD5 |
da872ec46c11fcb490e7806db13c7f29
|
|
| BLAKE2b-256 |
e7ac11f7e66d9f66db8d6bcdff7411ead84d30150a3c05822baf812b93e08883
|
Provenance
The following attestation bundles were made for civarium_mcp-0.1.3-py3-none-any.whl:
Publisher:
release.yml on ftagn-superior/civarium-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
civarium_mcp-0.1.3-py3-none-any.whl -
Subject digest:
a956e946b76702a983c230bfb2e7bd46fe6c3125261bcba2b8068dd399713ce2 - Sigstore transparency entry: 1871164540
- Sigstore integration time:
-
Permalink:
ftagn-superior/civarium-mcp@d5eb8c4d3561fcae760ed3fd42c1446bfd00e665 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/ftagn-superior
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d5eb8c4d3561fcae760ed3fd42c1446bfd00e665 -
Trigger Event:
push
-
Statement type: