Skip to main content

DomainTome — the living knowledge graph for your software project. A programmatic MCP-backed graph of business logic, flows, events and rules.

Project description

DomainTome

The living knowledge graph for your software project.

Status: pre-1.0, solo-maintained. DomainTome is functional and used in production projects, but the API, the schema and the MCP surface may still break between minor versions. Bug reports are welcome; feature PRs may not be merged while the design stabilizes. The repository will open up to broader collaboration once the API is stable (target: 1.0).

DomainTome captures the business logic of a project — modules, capabilities, flows, events, rules, forms, entities and decisions — as a typed graph backed by SQLite, and exposes it over MCP so AI coding assistants (Claude Code, Claude Desktop) can query and maintain it as part of normal work.

It answers questions like "how many ways of registering a payment exist?", "what breaks if I touch flow-checkout?" or "which rules protect this entity?" in a single tool call, with provenance, without re-exploring the codebase each time.

Why

  • Persistent memory across sessions — the graph survives context resets.
  • Zero documentation overhead — the assistant writes as concepts get decided, not as a separate chore.
  • Auditable — every node carries source, confidence, source_context. Every MCP call is logged.
  • Token-efficient — summary-only listings, batch ops, cheap sub-agents for exploration, WAL-mode SQLite.

Token economics (measured)

Bytes-on-the-wire to the model when answering structural questions, with vs. without DomainTome. Reproduce on your machine via examples/booking-api/ (full protocol in examples/booking-api/README.md).

Project Files Question Without With Ratio
booking-api 5 How many ways can a Reservation be cancelled? 6,213 B 1,485 B 4.2×
booking-api 5 What rules apply to a Reservation? 4,032 B 291 B 13.9×
booking-api 5 What does deactivating a Resource affect? 4,654 B 543 B 8.6×
domaintome (this repo) 62 What capabilities does DomainTome expose? 49,726 B 729 B 68.2×
domaintome (this repo) 62 Where do graph writes happen? 14,566 B 314 B 46.4×

Median 13.9×, range 4–68×. The "without" column is a floor — minimum file set, no Grep/Glob overhead. Real sessions read more. The pattern is clear: ratios grow with project size and how scattered the answer is across the codebase.

Maintenance cost (what Claude pays to keep the graph in sync): a typical "new flow + 3 edges" write costs ~720 B total. Break-even is <1 query per new feature. Reads dominate writes by orders of magnitude.

Caveats: input-payload only (output answer not measured); does not include the one-time /dt:bootstrap cost; ratios are descriptive of the questions tested, not a guarantee for arbitrary questions.

Install (Claude Code plugin — recommended)

DomainTome ships as two pieces: a Python package (the dt binary, which runs the MCP server) and a Claude Code plugin (the marketplace metadata: skills, slash commands, hooks, MCP manifest). The plugin's .mcp.json invokes dt mcp, so the binary must be on $PATH before the plugin can talk to the graph.

Until DomainTome is published to PyPI, install the binary directly from the repo, then add the plugin:

# 1) Install the dt binary (one-time, places it on $PATH)
uv tool install git+https://github.com/YACB2/domaintome   # or: pipx install git+https://github.com/YACB2/domaintome
dt --version
# 2) Register and install the plugin in Claude Code
/plugin marketplace add YACB2/domaintome
/plugin install domaintome@domaintome
/reload-plugins

Once PyPI publishing lands, the install will collapse to a single /plugin install step (the .mcp.json will switch to uvx --from domaintome dt mcp, which auto-fetches the package on first run).

Reload, then from the project you want to model run dt init (or /dt:bootstrap for a guided onboarding that scans the code with Haiku). "Project" can be a single repo or a workspace that contains several repos — DomainTome has no opinion, .dt/graph.db is created relative to whatever directory you launched Claude Code from.

The plugin bundles:

  • MCP server exposing dt_add_node, dt_add_nodes, dt_update_node, dt_delete_node, dt_get_node, dt_add_edge, dt_add_edges, dt_remove_edge, dt_query, dt_traverse, dt_list, dt_find_variants, dt_audit, dt_history, dt_stats, dt_export_markdown.
  • Auto-invoked skill (dt-usage) that tells Claude to read before acting and write on decision, with provenance rules and lifecycle conventions.
  • Sub-agent dt-explorer (Haiku, read-only) for broad exploration without burning expensive tokens.
  • Slash commands: /dt:init, /dt:bootstrap, /dt:audit, /dt:show <id>, /dt:recent, /dt:impact <id>, /dt:probe <path> (audit another project's graph without switching directory).

Install (standalone CLI / other MCP hosts)

# Until PyPI publish: install from git
uv tool install git+https://github.com/YACB2/domaintome
# After PyPI publish: pipx install domaintome  (or: uv tool install domaintome)
dt init

For Claude Desktop / other MCP hosts:

{
  "mcpServers": {
    "dt": {
      "command": "dt",
      "args": ["mcp", "--db", ".dt/graph.db"]
    }
  }
}

CLI reference

dt init                      # create .dt/graph.db
dt list [--type flow]        # summary listing (id, type, title, status)
dt show <id>                 # full detail + edges
dt query "payment"           # exact id → title substring → tag fallback
dt variants <capability-id>  # flows implementing a capability
dt audit                     # orphans, cycles, id hygiene
dt stats [--since ISO]       # token/usage analytics from the audit log
dt export --out .dt/export   # one markdown file per node

Schema

Eight node types (stack-agnostic): module, capability, flow, event, rule, form, entity, decision.

Nine relations: part_of, implements, depends_on, triggers, validates, enforces, supersedes, references, conflicts_with. Type pairs are restricted (see schema.py).

Statuses: active | draft | deprecated | superseded | archived. Soft-delete is the default; dt_delete_node is reserved for typos and warns about edge loss.

The central abstraction is capability — a thing the system knows how to do, independent of how. Multiple flow nodes can implements the same capability, surfacing UX/logic divergences.

Model routing

Operations are split by cost:

  • Reads (broad scans, traversals, audits): delegated to Haiku via the dt-explorer sub-agent or model: haiku frontmatter on slash commands.
  • Writes & modeling decisions: caller's model (Sonnet/Opus). A sub-agent proposes JSON; the caller reviews and persists.

Override per-project in .dt/config.json:

{
  "language": "es",
  "app_name": "my-app",
  "models": { "exploration": "haiku", "write": "sonnet" }
}

Provenance & history

Every node carries metadata.{source, confidence, source_context} and, when relevant, source_ref (path:line), last_verified_at, deprecated_at, deprecated_reason, replaced_by.

dt_update_node(metadata_patch=…) merges without destroying provenance; metadata still exists for rare full replacements.

dt_history(id) returns every MCP event for a node (newest first) from the append-only audit log. dt_stats aggregates by tool/op and reports input/output bytes.

Status

Pre-MVP, alpha. Schema and MCP tool surface may change before 0.1.0.

Development

uv sync --all-groups
uv run pytest -q
uv run ruff check src tests

Tests live in tests/. The plugin layout is validated by test_plugin_structure.py.

License

MIT.

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

domaintome-0.3.2.tar.gz (105.0 kB view details)

Uploaded Source

Built Distribution

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

domaintome-0.3.2-py3-none-any.whl (47.3 kB view details)

Uploaded Python 3

File details

Details for the file domaintome-0.3.2.tar.gz.

File metadata

  • Download URL: domaintome-0.3.2.tar.gz
  • Upload date:
  • Size: 105.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.14

File hashes

Hashes for domaintome-0.3.2.tar.gz
Algorithm Hash digest
SHA256 9d5e5aab085bab361f7bb3e323ac0df9b32c1dfb638103c2d7fdf6f91217b087
MD5 0d3c531a86cc0e0060b16439ba78f670
BLAKE2b-256 1646b25a049835d808cec6f81cb42b6b12aaa705445cf3165942f3a0ebe5602b

See more details on using hashes here.

File details

Details for the file domaintome-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: domaintome-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 47.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.14

File hashes

Hashes for domaintome-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3a8a39121d98b9b105dab028337185d0eab5b04589976f51ca3765d25173ef5e
MD5 242ec974355a9b056e0380c66125799a
BLAKE2b-256 afc48bc61fe159e4d79b76e3554904c70209085f278cadd1c154dd17042d5db2

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