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.7.0.tar.gz (92.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.7.0-py3-none-any.whl (34.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mcp_temporal_knowledge-0.7.0.tar.gz
  • Upload date:
  • Size: 92.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.7.0.tar.gz
Algorithm Hash digest
SHA256 d0acf44ab1022d358f9a4adf72600c6437672ab844a1cf5cef82d5755ae73f7e
MD5 44a2c256c653effc888ebd513b4b0eab
BLAKE2b-256 ffd67b28a3a77ea408b260e96148a3b77a8a120547cf2d381e795cb2e36081df

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mcp_temporal_knowledge-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 34.4 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.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 667dffa13476abe842a2e1d690da60084a7caf12a1f8b1c7f0945250d9622c2c
MD5 ab2826a0a93945266e4b41ffdef3c9db
BLAKE2b-256 c4e6695216e493001bb558715babdba2178132f8ac725dd45baebccaa94ed23c

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