Open, self-hosted, IFC-native AEC platform. A web BIM viewer + modeling, a 73-module GC portal (RFIs, pay apps, CPM schedule, TRIR), and a development proforma — one model, from acquisition to turnover. Generate a building from a zoning envelope, then coordinate, draw, schedule & underwrite it. Built on That Open + IfcOpenShell. $0 to run.
What it is — three pillars on one IFC-keyed model, switched by a Model / Construction / Finance bar:
- 🧊 BIM platform — stream + author IFC in the browser (That Open Fragments), QA, clash, IDS, BCF, 2D drawings; also opens meshes & point clouds (OBJ/STL/PLY/glTF · PCD/XYZ/LAS/LAZ) as reference overlays, with QR sharing
- 🏗 GC portal — config-driven modules: RFIs, submittals, change orders, pay apps (G702/G703), CPM schedule, safety/TRIR, closeout (COBie)
- 💵 Development proforma — sources & uses, S-curve draws, XIRR/NPV, JV waterfall — seeded straight from the model
▶ Live demo · ⬇ Download (Win/macOS/Linux) · 📚 Guides · 📄 Project page
docker compose --profile full up --build # web → http://localhost:8080 · api → http://localhost:8000
docker compose --profile full --profile seed run --rm seed # optional: a demo project across every moduleOr install the signed desktop app (single-project, auto-updating) from the latest release.
Built on That Open (Fragments + web-ifc, MIT) · IfcOpenShell (LGPL) · three.js · FastAPI · Tauri. IFC is the source of truth — no proprietary format, no per-seat license.
The market is a patchwork of point tools — feasibility in one, BIM in another, construction management in a third. This spans acquisition → turnover on a single IFC-keyed model, where competitors each cover only one slice:
| Capability | This | Procore | Autodesk Forma¹ | TestFit | ARGUS / proforma |
|---|---|---|---|---|---|
| Feasibility + underwriting (proforma, S&U, memo) | ✅ | – | partial | – | ✅ |
| Generative massing + Test Fit | ✅ | – | ✅ | ✅ | – |
| BIM authoring + clash/IDS | ✅ | view | ✅ | – | – |
| Construction mgmt (RFIs, COs, pay apps, 4D) | ✅ | ✅ | ✅ | – | – |
| Turnover (COBie, as-built, closeout) | ✅ | ✅ | ✅ | – | – |
| IFC-native / open / self-hostable | ✅ | – | – | – | – |
| Free desktop app · no per-seat license | ✅ | – | – | – | – |
¹ Autodesk Construction Cloud was rebranded Autodesk Forma in 2026. Comparison reflects typical product scope; competitors are strong within their slice — the difference is whole-lifecycle on one open model.
Full mapping in docs/capability-matrix.md. Highlights, all built and verified in this repo unless noted:
- Web viewer — Three.js + Fragments, streams large models, runs fully offline (local WASM).
- Navigation & review — select→properties, spatial tree, layers, isolate/hide, ghost, section planes, measure, color-by-data, set-origin/CRS.
- Coordination — model federation; clash detection (AABB broad phase + mesh boolean narrow phase, exact penetration volume) → BCF clash topics.
- Issues — BCF-modeled topics/RFIs/punch/clash, viewpoints, comments, attachments,
pins;
.bcfzipimport/export (round-trips with Solibri/ACC/BIMcollab). - QA — IDS validation (ifctester) with failing-element highlighting.
- 4D / 5D — schedule↔element mapping; quantity takeoff + cost mapping (geometry fallback).
- Data export — QTO, COBie, space schedules → XLSX.
- 2D documentation — dimensioned grid plans (grid derived from columns), sections, elevations (N/S/E/W) with level lines, and composed PDF sheets with title blocks.
- Authoring round-trip (in-viewer modeling) — a full toolbar of authoring ops, each a
server-side
ifcopenshellrecipe → background republish (reconvert + reindex). GUID-stable, so pins/RFIs/clashes survive. Create: walls, slabs, columns, beams, roofs (sketch on the model/grid). Openings: doors/windows void the host wall + fill it. Edit: delete, move, rotate, copy, per-element Pset edit. Drafting aids: grid + corner snap, a 6-face section box, a storey-levels overlay. Verified live end-to-end (upload IFC → add wall → republish → updated.frag+ reindex). Desktop GUI authoring is the Blender + Bonsai bridge. - Generative design — zoning → a fully-developed IFC building + proforma — the IFC-native answer to TestFit/Forma: enter a municipal zoning envelope (lot, FAR, coverage, setbacks, height limit, floor-to-floor) and the platform computes the buildable program (footprint, floors, GFA, units, binding constraint) and generates a real IFC4 model in one call — optionally with a concrete structural frame (columns + beams on a bay grid), per-apartment unit layout, a facade envelope (walls + ribbon windows at a WWR, feeding the energy model), and a service core (elevator + stair + MEP risers) — then publishes it and solves a starter acquisition proforma. Because the output is openBIM, the generated building flows straight into the viewer, drawings, energy, QTO, the assembly-based estimate (+ GFA benchmark) and underwriting — one chain from lot → deal → turnover. Driven end-to-end through a full lifecycle harness (63/63).
- Furnish & equip (starter IFC family library) — a curated 16-family catalog (furniture /
sanitary / appliances / plants) generated parametrically, placeable into any model (incl. a
generated massing) as real, GUID-stable, typed IFC occurrences via
type.assign_type. - Sign-in (SSO) + free tier, no admin — log in with Google / Microsoft / Procore (OAuth2);
SSO users are plain free-tier accounts and there's no admin tier for end users (project
owners manage their own teams; platform config is ops/env). A
tierseam (entitlements.py) makes the eventual paid plans a one-place change. - First-run onboarding + AI assistant — a skippable welcome + coach-mark tour for new users, and an "Ask AI" box that answers natural-language questions about a project (open RFIs, overdue, cost) grounded in a live snapshot (Claude when keyed; graceful no-key fallback).
- Field/mobile capture (offline-first) — a mobile bottom-sheet quick-capture: snap a photo → punchlist / safety observation / progress photo in a couple taps. Captures queue offline (photo included) and auto-sync on reconnect (queued-count badge); pairs with the PWA/Capacitor build.
- Turnover — a one-click closeout package (
/closeout/package.zip: as-built IFC + COBie/QTO/spaces + status PDF + closeout manifest), module-log PDFs (RFI/submittal/CO registers), multi-period pay apps (period advance + auto lien waivers), COBie tabs enriched with warranties/assets/commissioning, and warranty-expiry tracking.
A construction-management portal on top of the viewer — full writeup in docs/gc-portal.md. Highlights:
- Module engine — every process (RFIs, Submittals, PCO/Change-Order chain, Daily
Reports, …) is a
module.json→ its own auto-created table. 71 modules / 12 sections, no per-module code. Each gets CRUD, role-gated workflow, comments, CSV/PDF, pins, timeline. - Two role dimensions — capability roles (viewer→admin) + party roles (GC/Owner/OwnersRep/Consultant/Subcontractor) that gate workflow transitions.
- Change-order chain — PCO ▸ NOC ▸ Directive ▸ Proposal ▸ COR ▸ eTicket, linked and audit-logged; approved CORs flow into the contract sum.
- Financials — AIA G702/G703 pay apps (+ PDF), Cost Summary roll-up, eTicket T&M builder priced from rate tables.
- Schedule — Gantt + Empire-State Line-of-Balance charts.
- Role-tailored dashboard — per-party KPIs + "ball-in-your-court" action items.
- Model pins — any anchored record (RFI/PCO/COR/punchlist/inspection/…) shows on the 3D model; clicking selects the element and opens the record. Same GUID keys geometry, BCF, and GC records.
A developer/owner platform that goes lot → building → deal → investor package, all IFC-native.
Generative design & Test Fit (TestFit-style, but openBIM — every fit is a real IFC model):
- Generate from zoning — lot + zoning envelope (FAR, setbacks, height, coverage) → a buildable program + a from-scratch IFC4 model (structural frame, per-unit spaces, facade + windows, service core) + a solved acquisition proforma, one click. Real lot polygons (shoelace area).
- Test Fit — fit a unit mix on a double-loaded corridor (real units + corridor), a parking
solver (stalls/unit → count/area/cost), scheme compare (units/efficiency/NSF/parking ranked),
and generative optimize that sweeps unit-mix × parking and ranks by yield-on-cost ("find the
deal that pencils").
POST /test-fit/{compare,optimize}.
Developer cost portal — the institutional underwriting facets:
- Line-item hard/soft cost budgets (description × $/unit × qty + per-category contingency) that roll into the proforma cost tree.
- Sources & Uses — grouped uses vs sized senior debt (LTC capped by LTV/DSCR/debt-yield) + equity.
- Property & tax assumptions — parcel/areas/purchase + tax table → OPEX; per-SF ratios.
- Specialty assets — on-site energy (solar/wind/battery/rainwater → capex + energy offset) and vertical-farm/PFAL (tower count → produce revenue + lighting opex), flowing into the deal.
- Investment memo (PDF) — a confidential memorandum (exec summary, S&U, cost budget, returns, risk) generated from live project data: the "presentation with financials."
Underwriting engine:
- Sources & uses with construction-loan interest-reserve circularity solved to a fixed point.
- S-curve draws, XIRR / NPV / equity multiple / yield-on-cost, a JV waterfall (pref + promote tiers, American/European, clawback), debt sizing (LTC/LTV/DSCR/debt-yield), sensitivity tables and Monte Carlo risk.
- Underwriting realism — specialty/operating revenue is risk-adjusted (not booked as de-risked rent), and guardrails flag returns outside market bands (IRR / equity-multiple / dev-spread / DSCR) so the IRR is credible, surfaced on a sticky returns bar.
- Actuals/draws bridge → re-forecast IRR + AIA G702/G703 pay apps off the same cost tree.
- Multi-deal portfolio roll-up (true XIRR) and LP-shared read-only scenarios.
The Finance workspace is organized into sub-tabs — Feasibility · Budget & Capital · Underwriting · Deliverables — with a sticky live-solved returns bar.
- One relational model — schedule · budget · 5D · capital (latest) — the GC
schedule_activityrecords now drive the Gantt / Line-of-Balance / CPM and the 3D 4D scrub (per-activity dates, element/trade links), with lookahead + milestone views and editable P6.xerimport. A first-class Budget destination assembles the agreed GMP from every cost code & bid package- General Conditions / Requirements (incl. staffing projections) + overhead / fee / contingency — each budget vs committed vs actual vs EAC, with buyout savings, change-orders→revised-GMP, owner SOV from the budget, a cash-flow S-curve, and a baseline; it reconciles to the developer proforma's hard cost. The capital chain closes the loop: GMP↔hard-cost sync, an actuals loop (owner invoices → re-forecast IRR), construction-loan draws (equity-first, interest accrual, lender draw-request PDF), a cross-pillar Portfolio (GC status + developer returns), and on-schedule/on-budget executive bands. 5D: click an element → its activity + cost-code budget; colour the model by %-complete or cost variance; scrub the 4D timeline with live cost burn; QTO by floor & discipline. Plus multi-user (members → role-scoped persona views), bulk site-photo + camera capture, and an optional paid Revit (.rvt)→IFC bridge (APS, feature-flagged with a cost gate; IFC stays the source of truth). One click (lot→building→deal) seeds all three pillars. See the CHANGELOG (v0.1.53→v0.1.80).
- Rendering, families & computational design (M-theme) — a viewer render mode (directional
sun + soft shadows, ACES/PBR, IBL), a NOAA sun-&-shadow study (date · time · lat/long), and a
Matterport-style first-person walkthrough; Revit-style
IfcMaterialLayerSetassemblies on walls/slabs/roofs; the family library grown to 37 parametric types (Lighting/MEP/Structural/ Transport added) with type-variant sizing and import of external/manufacturer IFC families (project.append_asset); and Studio, a visual computational node graph (Dynamo/Hypar-style) that runs the server compute engine — wire zoning → structure → schedule → cost → yield with no code. - Hardening & ops — distributed Redis-backed rate limiting (multi-worker, fail-open), a
faster dashboard (GROUP-BY counts, JSON parsed only for active records), an accessibility
pass (tab roles/
aria-selected, labels, live region), a stored-XSS sweep of the admin modals, andmain.tsmodularization (the connections UI is now a lazily-loaded chunk). COBie handover gains model-derived areas / manufacturer / warranty / asset-id fields + an Attribute sheet; the pitch deck gains Market + Timeline slides. Library interop evaluated (IFClite / pyRevit / FreeCAD / Pascal) — seedocs/roadmap.md§L and the dependency/update ADR. - Built-world techniques (research-grounded) — direction from Carol Willis (Form Follows Finance, Building the Empire State), Salvadori (Why Buildings Stand Up), and CM/RE research: form-follows-finance massing (daylight-limited rentable depth + core efficiency), a structural-system advisor (flat-plate · shear-core · outrigger by height/span + member sizing), takt / line-of-balance scheduling with a JIT delivery plan, 4D sequencing with a viewer scrub, lean / Last-Planner PPC, and citable benchmarks + comparables.
- Underwriting realism + Finance revamp — specialty/operating revenue is now risk-adjusted before
it hits the deal, and
underwrite.guardrails()flags returns outside market bands (the vertical-farm scenario's once-inflated IRR is now credible). The Finance view is reorganized into sub-tabs with a sticky returns bar that carries a live guardrail badge. - Developer portal + Test Fit — line-item hard/soft cost budgets, Sources & Uses, property/tax assumptions, specialty assets (on-site energy + vertical-farm revenue), an investment-memo PDF, plus Test Fit (corridor unit-mix layout, parking solver, scheme compare, generative yield-on-cost optimize) and real lot polygons — see the "Real-Estate Development & Feasibility" section. Each backed by tests in the CI gate.
- AI assistant — natural-language "Ask AI" over a live project snapshot (Claude when keyed, graceful rules fallback) alongside AI risk summaries + AI-drafted RFIs.
- Accounts & onboarding — SSO (Google / Microsoft / Procore), a no-admin free-tier model, first-run welcome + skippable tour, and field capture (offline photo → punchlist/observation, syncs on reconnect) for the mobile/jobsite path.
- Generative massing + family library —
aec_data.massingturns a zoning envelope into a buildable program + a from-scratch IFC4 model (POST /projects/{id}/generate/massing, plus a stateless/generate/massing/preview) and seeds a solved acquisition proforma;aec_data.familiesgenerates a 37-family parametric type library (GET /families/catalog) placed via theadd_familyauthoring recipe. Both render in the viewer (fixed two web-ifc gotchas surfaced en route: generated models now use metre units, and everyIfcProfileDefcarries aPosition— without it web-ifc silently skips the geometry). Gated bytest_generatein the CI suite. - 4-zone UI (top chrome + Model/Construction/Finance workspaces + left icon rail + bottom settings bar) with a lazy-loaded 3D viewer — the ~6 MB three/@thatopen bundle loads only when the Model workspace opens, so portal/finance users get a ~16 KB-gzip first load.
- Module relations —
referencefields + reverse lookups + numeric rollups wire the domain chains across the portal (RFI/Submittal→Drawing, RFI→ChangeEvent→PCO→COR→Subcontract, budget/SOV/timesheet→CostCode cost-coding, Meeting→ActionItems, Inspection→NCR/Deficiency, bidding, daily/field, closeout, …) — 44 references + 16 rollups, all config-driven so the form record-picker, "related" panel, and rollups come for free. Plus a kanban board, cross-module search, bulk actions, inline list editing, saved views, and real-time SSE notifications — all engine-level, so every module gets them. - Background conversion — IFC convert/reindex runs off-thread; clients poll a publish status.
- In-viewer modeling — 18-tool authoring toolbar (walls/slabs/columns/beams/roofs,
doors/windows, delete/move/rotate/copy, Pset edit) + grid/corner snap, section box, levels
overlay — all server-authored via
ifcopenshelland proven live. - Interoperability — a data-source Connections framework: register external Postgres/Supabase (read-only table browse + a guarded SELECT console), Procore (two-way sync — import RFIs/submittals/change-events into the portal, push resolved RFI status/answers back, scheduled auto-sync), Autodesk Construction Cloud (project/issue read), and accounting/ERP — QuickBooks + generic-REST Sage/Viewpoint (read accounts / vendors / bills) — all behind one adapter pattern. An admin field-mapping editor remaps each external field → module field per connection; secrets are write-only and masked on read; admin-gated.
- Construction & financial depth — CPM scheduling (forward/backward pass, total+free float, critical path); model-based estimating & takeoff (IFC quantities × unit rates → priced estimate); model→proforma (areas seed hard cost + rent); bid leveling; a risk register + cross-project construction program portfolio with cost-overrun flagging; TRIR/DART safety analytics; reusable templates (save a module's records, apply to any project); and model version history + diff (GUID snapshot per publish). The GC portal + proforma run on a blank project — no IFC required; model-derived tools light up once an IFC is opened.
- Free single-project desktop app (.exe) — the whole platform in one process (FastAPI
serving the API + SPA, SQLite + local files, single-operator local mode, no login), packaged
self-contained with PyInstaller (
services/api/desktop.py,build-desktop.ps1) — a Bluebeam-style local app; data lives under%LOCALAPPDATA%\AEC-BIM, uninstall = delete the folder. Projects are portable.mmprojbundles (geometry + all data + attachments) via the Open/Save menu. The Tauri 2 shell spawns this backend as a sidecar for a native window; mobile (Capacitor/Tauri-mobile) is next. - UX — the ⚙ Tools panel is a collapsible, persona-ordered, state-aware accordion with
readable result modals (cost/energy/IDS/clash); the 73-module portal catalog gains ★
favorites + collapsible persona-aware sections + a filter; the viewer toolbar is grouped. The
project picker tags each project's model type (
.frag/.ifc). (Seedocs/ux-findings.md.) - Installable + offline — PWA (manifest + Workbox service worker; lean ~97 KB precache, viewer libs/WASM/tiles runtime-cached).
- Authentication — username/password accounts (PBKDF2-hashed) + signed bearer tokens
(stdlib, dependency-free) at
/auth/{register,login,me}. The token is the identity the RBAC layer trusts (replacing the devX-Userheader); per-project authorization stays inProjectMember. First account bootstraps as admin. Web app has a sign-in control + token store. Login also sets an httpOnly cookie so the SSE notification feed and direct-download links (which can't set a header) authenticate same-origin via the/apiproxy;/auth/logoutclears it. (Dev cross-origin:5173→:8000uses the header path; the cookie applies to the deployed same-origin stack.) - Identity & RBAC management — admin user management (create / list / set role / activate / deactivate / reset password) with a last-active-admin guard; self-service password reset via an admin-issued single-use token (no email infra); deactivation invalidates existing tokens immediately. The web UI gates per project role — authoring tools, the authoring panel, "+ RFI", and the portal "+ New" hide above the caller's role (the API still enforces).
- Risk + debt sizing (Proforma) — Monte Carlo simulation (sample drivers → P5–P95, P[IRR ≥ target], histogram) alongside the deterministic sensitivity table, and debt sized to the lesser of LTC / LTV / DSCR / debt-yield constraints.
- Drawings — element callouts with leader lines on plans (doors/windows by default),
complementing room tags (
plan.svg?callouts=true). - Ops & observability —
/metrics(Prometheus: request counts/latencies by route template, in-flight, uptime) + structured JSON access logs; email digests of per-member work queues (stdlib SMTP, no-op-but-logged when unconfigured); a backup/restore runbook + scripts (scripts/backup.sh/restore.sh: pg_dump + MinIO/IFC volumes). - Desktop release CI — tag-driven GitHub Actions builds signed Win/macOS/Linux Tauri
installers (
.github/workflows/desktop.yml); each runner first builds the Python backend sidecar (PyInstaller) so the installer ships the full app, not just the viewer. A viewer-only GitHub Pages demo deploys frompages.yml. - CI gate —
services/api/run_tests.pyruns all Python suites (incl. interop/bundle/desktop/ local-mode); GitHub Actions runs it + the web build (tsc + vitest + prod build).
Generative design — lot → IFC model → acquisition proforma (the TestFit/Forma differentiator, but openBIM): a zoning envelope generates a real IFC massing you can then furnish from a starter family library. (Vector renders of the redesigned UI; numbers are an actual solve.)
| Generate from zoning → IFC + proforma | Furnish & equip (starter IFC family library) |
|---|---|
Generated directly from the IFC by the data service (BIM), plus GC schedule charts:
| Dimensioned grid plan | Composed sheet (A3) | North elevation (HLR) | Room tags |
|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
The dimensioned plan derives the structural grid from column positions (no IfcGrid needed),
adds numbered/lettered bubbles and grid-spacing dimensions; the sheet composes per-storey
plans + a section under a title block (also exported as PDF).
GC portal schedule visuals (from the schedule_activity module):
| Gantt | Line of Balance |
|---|---|
![]() |
![]() |
Platform interface (vector renders of the redesigned UI — see the live demo for the running app):
| Tools panel + readable results | 73-module portal catalog |
|---|---|
The ⚙ Tools panel is a persona-ordered, collapsible, state-aware accordion (secondary tools fold under "More tools"; analysis opens in a readable modal); the GC-portal catalog tames 71 modules with ★ favorites, collapsible persona-aware sections, and a filter.
IFC (source of truth)
author ▲ │ convert + tile
│ ▼
Blender + Bonsai services/converter (Node) IFC → .frag tiles
(Bonsai-MCP) │
services/data (Python, ifcopenshell) props index · QTO/COBie/4D/5D ·
clash · IDS · drawings/sheets · authoring recipes exports · validation · 2D drawings
│ │
└──────► services/api (FastAPI) ◄──────► apps/web (Vite + TS, Three.js + Fragments)
BCF issues · pins · viewpoints · properties · exports · clash · validate ·
drawings/sheets · edit/publish (Postgres/SQLite + MinIO/local storage)
apps/web/ Vite + TS viewer (Three.js + @thatopen/*), integrated app shell
apps/editor-bridge/ Bonsai-MCP config + authoring recipes (desktop path)
services/converter/ IFC→.frag (Node) + optional RVT→IFC via APS (paid, flagged)
services/api/ FastAPI: BCF, properties, exports, clash/validate, drawings, edit/publish,
GC portal (modules, cost, schedule, dashboard)
services/api/modules/ 71 module.json definitions (GC portal — one table each)
services/data/ IfcOpenShell: index, QTO, COBie, spaces, schedule, clash, IDS, drawings, edit,
massing (zoning→IFC), families (starter IFC type library)
packages/ shared types
families/ IFC type libraries (versioned) — curated/manufacturer content drop-in
docs/ status, capability matrix, gc-portal, deploy, images
git clone https://github.com/ibuilder/ModelMaker.git && cd ModelMaker
cp .env.example .env # set secrets + AEC_RBAC=1 for anything but local dev
docker compose --profile full up --build # web → http://localhost:8080 (api → :8000)
# optional: fill a demo project across all relation chains
docker compose --profile full --profile seed run --rm seedThe web container reverse-proxies /api to the API (same-origin, no CORS), serves the
viewer with the cross-origin isolation web-ifc needs, and persists Postgres/MinIO/IFC volumes.
See .env.example for every knob and docs/roadmap.md
for the desktop (Tauri/Electron) and mobile (Capacitor) packaging plan.
# 1. web viewer (offline; copies WASM automatically)
cd apps/web && npm install && npm run dev # http://localhost:5173
# 2. backend API (prefer Python 3.11+; 3.10 works)
cd services/api && python -m venv .venv && .venv/Scripts/activate
pip install -r requirements.txt
PYTHONPATH=src uvicorn aec_api.main:app --reload # http://localhost:8000
# 3. convert an IFC to Fragments (Node converter)
node services/converter/src/cli.mjs model.ifc model.frag
# 4. data exports / drawings (CLI)
cd services/data && pip install -r requirements.txt
PYTHONPATH=src python -m aec_data.cli qto model.ifc qto.xlsxSeed a project, then the web app auto-connects: POST /projects with source_ifc, upload
the props index, and open the viewer. See docs/status.md for the verified flow.
POST /projects create project (name, source_ifc, origin)
GET /projects/{id}/elements[/{guid}] properties index (Phase 1 data)
GET/POST /projects/{id}/topics ... BCF topics/RFIs/pins, comments, viewpoints, attachments
GET/POST /projects/{id}/bcf/export|import .bcfzip round-trip
GET /projects/{id}/exports/{qto,cobie,spaces,schedule}.xlsx
POST /projects/{id}/clash clash detection (→ BCF clash topics)
POST /projects/{id}/validate IDS validation
GET /projects/{id}/drawings/{plan,section,elevation}.svg
GET /projects/{id}/drawings/sheet.{svg,pdf}
POST /projects/{id}/edit | /publish authoring round-trip (recipes incl. add_family)
POST /projects/{id}/generate/massing zoning → IFC massing model + acquisition proforma
POST /generate/massing/preview stateless zoning → program + proforma (no model written)
GET /families/catalog starter IFC family library (furnish & equip)
# GC portal (full list in docs/gc-portal.md)
GET /modules module catalog
GET/POST /projects/{id}/modules/{key}[/{rid}] config-driven CRUD (+ /transition /link /comments /pdf /export.csv)
GET /projects/{id}/module-pins anchored records → viewer overlay
GET /projects/{id}/cost/{g703,g702,summary} financials (+ g702.pdf, POST /cost/tm)
GET /projects/{id}/schedule/{gantt,lob}.svg Gantt + Line-of-Balance
GET /projects/{id}/dashboard role-tailored dashboard
# interoperability + portability
GET/POST /connections[/{id}] data-source connections (Postgres/Supabase/Procore/ACC)
GET /connections/{id}/tables | POST .../query read-only browse + SELECT (SQL sources)
GET/PUT /connections/{id}/mappings admin field-mapping editor (external → module fields)
POST /projects/{id}/sync/procore[/push] Procore import + two-way push (+ /sync/schedules)
GET /connections/{id}/acc/projects/{pid}/issues Autodesk Construction Cloud issue read
GET /projects/{id}/bundle | POST /projects/import-bundle portable .mmproj save / open
DELETE /projects/{id} delete a project (rows + geometry + attachments)
Every feature here was run against the sample model. The latest end-to-end proof: IDS flagged
299 slabs missing LoadBearing → the authoring round-trip edited them → republish → IDS
re-validated PASS (299/299) with the slab's pin GUID unchanged. Regressions: web tsc,
API smoke test, and Python compile all green.
Open stack (That Open MIT-style, IfcOpenShell LGPL). The Blender + Bonsai desktop editor is GPL — kept a separate process you use, not linked in. Optional Autodesk APS RVT→IFC is paid/flagged. See LICENSE-NOTES.md.
Created by Matthew M. Emma — built with Claude Code as AI assistant.







