Skip to main content

Temporal Knowledge Substrate MCP Server — domain-scoped knowledge accumulation with tool-enforced temporal integrity

Project description

Temporal Knowledge Substrate

An MCP server that lets LLM agents accumulate organizational knowledge across sessions, scoped by domain, backed by Neo4j. Tools enforce structural invariants so the graph can't corrupt itself — no raw Cypher writes.

Two-layer architecture:

  • Process layer (immutable) — Domains own Runs, Runs chain forward in time via NEXT_RUN. The arrow of time is enforced by the tool, not by instructions.
  • Knowledge layer (append-only) — 10 entity types (System, Process, Configuration, Gotcha, Rationale, etc.) connected by 7 relationship types. Knowledge evolves via EVOLVED_FROM chains — old versions are preserved, never overwritten.

Prerequisites

  • Python 3.10+
  • uv package manager
  • Neo4j 5.x instance (local or remote)

Quick Start

# Install
uv sync

# Run (stdio transport, default for MCP clients)
mcp-temporal-knowledge --db-url bolt://localhost:7687

Configuration

All options can be set via CLI flags or environment variables. CLI takes precedence.

CLI Flag Env Var Default Description
--db-url NEO4J_URI or NEO4J_URL bolt://localhost:7687 Neo4j connection URL
--username NEO4J_USERNAME neo4j Neo4j username
--password NEO4J_PASSWORD password Neo4j password
--database NEO4J_DATABASE neo4j Neo4j database name
--transport NEO4J_TRANSPORT stdio Transport: stdio, sse, or streamable-http
--namespace NEO4J_NAMESPACE (none) Tool name prefix (e.g. myapp -> myapp-begin_session)
--server-host NEO4J_MCP_SERVER_HOST 127.0.0.1 HTTP host (non-stdio transports)
--server-port NEO4J_MCP_SERVER_PORT 8000 HTTP port (non-stdio transports)
--server-path NEO4J_MCP_SERVER_PATH /mcp/ HTTP path (non-stdio transports)

MCP Client Configuration

Claude Desktop / Claude Code

Add to your MCP config:

{
  "mcpServers": {
    "temporal-knowledge": {
      "command": "mcp-temporal-knowledge",
      "args": ["--db-url", "bolt://localhost:7687"]
    }
  }
}

HTTP transport

mcp-temporal-knowledge \
  --db-url bolt://localhost:7687 \
  --transport streamable-http \
  --server-host 0.0.0.0 \
  --server-port 8000 \
  --allow-origins "http://localhost:3000" \
  --allowed-hosts "localhost,127.0.0.1"

Tool Surface (20 tools)

Session workflow

Every session follows: create_domain (once) -> begin_session -> create/evolve/confirm knowledge -> end_session

Tool Description
list_domains List all domains with run counts and last activity
create_domain Create a knowledge domain (idempotent)
begin_session Start a session — returns run_id needed by all knowledge tools
end_session Close a session with a summary of what was learned

Knowledge mutation

Tool Description
create_knowledge Create entities (System, Gotcha, Rationale, etc.) linked to the current session
evolve_knowledge Create a new version of an entity — old version preserved via EVOLVED_FROM
confirm_knowledge Record that entities were reviewed and found unchanged
create_connections Link entities (ENABLING, REQUIRING, CAUSING, etc.)

Querying

Tool Description
search_knowledge Fulltext search across names and descriptions
get_domain_state All current (head-of-chain) entities for a domain
get_run_history Session history — who worked on what, when
read_cypher Read-only Cypher escape hatch (writes rejected)

Taxonomy & Analytics

Tool Description
list_knowledge_types The 10 entity types with descriptions
list_connection_types The 7 knowledge + 4 process edge types
gds_create_projection Create a GDS graph projection for analytics
gds_drop_projection Drop a GDS projection
gds_pagerank PageRank centrality
gds_betweenness Betweenness centrality (bridge nodes)
gds_louvain Louvain community detection
gds_wcc Weakly connected components

Development

# Install with dev dependencies
uv sync --dev

# Run tests
uv run pytest

# Type checking
uv run pyright

See HOWTO.xml for the ontological commitments and the tools' behavior. Provide this to the LLM as invariant scaffolding.

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

mcp_temporal_knowledge-0.6.1.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

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

mcp_temporal_knowledge-0.6.1-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file mcp_temporal_knowledge-0.6.1.tar.gz.

File metadata

  • Download URL: mcp_temporal_knowledge-0.6.1.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_temporal_knowledge-0.6.1.tar.gz
Algorithm Hash digest
SHA256 7b0deda544c13fb57ab838e691d7d636a4d9c2e9fdc37424ef7544c4f3d9beb0
MD5 0f92147000ccff4ad580a9066c77a2c9
BLAKE2b-256 756d3f1cca158bb4efb4ab84eee3eefc371bfa117965045da3d9dd3800a29b4c

See more details on using hashes here.

File details

Details for the file mcp_temporal_knowledge-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: mcp_temporal_knowledge-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 29.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_temporal_knowledge-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b4ab58879984aff72d1f7c7ea2a33d7b4118805ccf936ad0806b993f55d91b6e
MD5 d270a718043f95457599deface670905
BLAKE2b-256 85f8cd19dc8b14e9845611a91b9d92f2cc50991edc0749b356130eb6916cd1f6

See more details on using hashes here.

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