Skip to main content

Visualization and sample domains built on ActionMachine.

Project description

AOA

Python 3.12+ MIT CI 19 tests Maxitor client Node 22 1.0.0

aoa-maxitor: A System You Can See

Most architecture diagrams live in Confluence or Miro and go stale faster than they are drawn. A month after release the schema no longer matches reality: new domains appear, operation steps are renamed, dependencies change. The gap between what is written and what runs is a familiar problem.

Maxitor breaks that cycle: diagrams are not drawn by hand. They are generated from the same code that actually runs. Code changes — the diagram changes. Open a browser — see the current system. Diagrams stay current because they are built from the same intents that execute in code. Intent changes — the diagram reflects it.

What Is Maxitor

Maxitor is a React SPA that turns AOA project code into live interactive diagrams. The data source is not YAML or Confluence annotations — it is the code itself: domains, actions, dependencies, entities, lifecycle state machines. Everything declared in code via intents automatically appears in the graph.

Maxitor can show four views of the system:

View Shows
Full graph Everything: domains, Actions, pipeline steps, resources, dependencies, links
ERD Entities, fields, relations, and cardinality by domain
Use case Roles and Actions each role can access
Lifecycle Finite state machine for a specific entity

1. Full Graph: The Whole System as One Map

The full graph is an interactive network of all elements in an AOA system. One view shows what used to take days of onboarding.

Full graph of an AOA system

The graph shows nodes of different types, each with a color label:

  • Domain — groups Actions by business area
  • Action — business operation with name and description
  • RegularAspect / SummaryAspect — pipeline steps inside an Action
  • Compensator — rollback steps (saga)
  • ErrorHandler — error handlers
  • Resource — dependencies via @depends
  • Entity / EntityField — data model
  • Lifecycle — state machine
  • Role — access roles
  • Params / Result / Field — contract of each Action

The left panel filters by groups: Applications, Domains, Roles, Actions, Entities, Resources. The graph is interactive — zoom, pan, isolate a cluster.

Key effect: a new developer understands system structure in five minutes without reading code. A reviewer sees what changed without diffs across dozens of files.


2. ERD: Data Model From Code

The ERD tab shows entity schemas by domain: fields, types, relations, cardinality.

ERD — entity schema by domain

The left panel navigates domains. For each domain:

  • Entity domain view — ERD for that domain only
  • Use case view — roles and Actions in the domain

On the diagram you see:

  • Which entities belong to the domain
  • Their fields and types
  • How entities are linked (AssociationOne/Many, AggregateOne/Many, CompositeOne/Many)
  • Bold lines — relation direction
  • Header color — domain membership

The ERD is built from BaseEntity classes and Relation fields. No YAML schema, no separate description. Write code — get a diagram.


3. Use Case: Who Can Do What

The use case view shows roles and Actions they can access via @check_roles. This is not hand-written documentation — it is read directly from @check_roles annotations in code.

Use case diagram — roles and Actions

Useful for:

  • Access audits — see who can run which operations
  • Business discussions — answer “can a manager do this?” without opening code
  • Reviewing role changes

4. Lifecycle: State Machine

For each entity with a Lifecycle field, Maxitor builds a finite automaton graph: states, transitions, initial and final vertices.

Lifecycle finite state machine for an entity

Especially valuable when an entity lifecycle is non-trivial — e.g. an order with a dozen states. Instead of reading automaton code line by line, you see the full transition graph.

Endpoint: GET /api/v1/lifecycle-finite-automaton?entity_qualname=...


5. How It Works Inside

Maxitor itself is an AOA application. Its backend is written with Actions, wired through FastApiAdapter, and uses DuckDB to store a graph snapshot.

AOA code (domains, Actions, entities)
        ↓
NodeGraphCoordinator — walks all elements
        ↓
DuckDB snapshot — graph in memory
        ↓
FastAPI Actions → JSON endpoints
        ↓
React SPA (G6 + Graphviz WASM)

On backend startup, NodeGraphCoordinator scans all registered AOA code and builds the graph. DuckDB stores it as nodes / edges tables. Each HTTP request for a diagram queries DuckDB and returns JSON for the client.

Important: the React SPA is fully separate from the backend. Two independent processes. In production you can build static SPA assets and serve them from a CDN, with the API hosted separately.


6. API Endpoints

All diagram endpoints are AOA Actions exposed via FastApiAdapter:

GET /api/health                          — health check
GET /api/sidebar                         — navigation: domains, entities

GET /api/v1/full-graph                   — full graph (G6 payload)
GET /api/v1/list-domains                 — domain list with colors
GET /api/v1/list-entities                — ERD slice by domain
GET /api/v1/list-node-types              — graph node types
GET /api/v1/domain-use-case-diagram      — use case by domain and roles
GET /api/v1/lifecycle-finite-automaton   — entity state machine

Swagger UI: http://127.0.0.1:8000/docs

JSON from endpoints can be embedded in your portal, CI pipeline, or documentation tooling.


7. How to Run

Backend

uv run task maxitor-api

Starts FastAPI at http://127.0.0.1:8000. Environment: MAXITOR_API_HOST (default 127.0.0.1), MAXITOR_API_PORT (default 8000).

Frontend (dev)

cd packages/aoa-maxitor/client
npm install
npm run dev

SPA at http://127.0.0.1:5173. Vite proxies /api to http://127.0.0.1:8000.

Production

VITE_MAXITOR_API_BASE_URL=https://api.example.com npm run build

Builds static SPA assets. Deploy: SPA on CDN or nginx, API in a separate container.


8. Client Architecture (client/src)

The React SPA is layered:

Layer Contents
app/ Entry: App.tsx, AppProviders.tsx. No business logic
components/ All UI: layout/, pages/, navigation/, diagrams/
components/diagrams/ FullGraphViewer/ (G6), ErdViewer/ (Graphviz WASM)
api/ HTTP clients mirroring FastAPI routes
model/ TypeScript contracts between UI and API
lib/ Pure helpers, layout constants
styles/ MUI theme

Graph rendering:

  • G6 (@antv/g6) — full graph, force-directed layout
  • @hpcc-js/wasm-graphviz — ERD, deterministic Graphviz layout

9. Installation

pip install aoa-maxitor
# or in the monorepo
uv sync

Dependencies: aoa-action-machine, fastapi, uvicorn, duckdb.

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

aoa_maxitor-1.0.1.tar.gz (135.2 kB view details)

Uploaded Source

Built Distribution

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

aoa_maxitor-1.0.1-py3-none-any.whl (52.5 kB view details)

Uploaded Python 3

File details

Details for the file aoa_maxitor-1.0.1.tar.gz.

File metadata

  • Download URL: aoa_maxitor-1.0.1.tar.gz
  • Upload date:
  • Size: 135.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.24 {"installer":{"name":"uv","version":"0.11.24","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for aoa_maxitor-1.0.1.tar.gz
Algorithm Hash digest
SHA256 2e3affdd0a508e509cbde2be2022093abc622e525f5889d64becbbc9552ad394
MD5 0e4bf3893c146502d8a4341e9d39eb9e
BLAKE2b-256 70f04877315bd056095b1f3d4c94333d3181d1e8ef55fc84c7ef58ba1d1acf5c

See more details on using hashes here.

File details

Details for the file aoa_maxitor-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: aoa_maxitor-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 52.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.24 {"installer":{"name":"uv","version":"0.11.24","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for aoa_maxitor-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4342e0b178ddc4c4766366a8f8d660d4b4ad345e3edc39b9bc43dce00e97985b
MD5 7de29b60a79e255f921d11a718bedf82
BLAKE2b-256 0825af6ccbe9bcc9efb22ca7f77e03fbeccebac0d06e2e5e9603b6040656efed

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