Metadata-Version: 2.4
Name: core-runtime
Version: 2.7.0
Summary: CORE: executable constitutional governance for AI-assisted software development.
License-Expression: MIT
License-File: LICENSE
Keywords: governance,audit,ci,constitutional,software-factory,code-quality,intent-driven,ai-assisted,llm
Author: Dariusz Newecki
Author-email: d.newecki@gmail.com
Requires-Python: >=3.12,<4.0
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Information Technology
Classifier: Operating System :: POSIX :: Linux
Classifier: Operating System :: MacOS
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Software Development :: Quality Assurance
Classifier: Topic :: Software Development :: Testing
Classifier: Topic :: System :: Systems Administration
Provides-Extra: telemetry
Requires-Dist: alembic (>=1.13.0,<2.0.0)
Requires-Dist: asyncpg (>=0.31.0,<0.32.0)
Requires-Dist: black (>=26.3.1,<27.0.0)
Requires-Dist: cryptography (>=46.0.5,<47.0.0)
Requires-Dist: dependency-injector (>=4.42.0,<5.0.0)
Requires-Dist: fastapi (>=0.136.0,<0.137.0)
Requires-Dist: filelock (>=3.13.0,<4.0.0)
Requires-Dist: httpx (>=0.28.0,<0.29.0)
Requires-Dist: jsonschema (>=4,<5)
Requires-Dist: networkx (>=3.3,<4.0)
Requires-Dist: numpy (>=2.3.2,<3.0.0)
Requires-Dist: openai (>=2.26.0,<3.0.0)
Requires-Dist: opentelemetry-api (>=1.21.0,<2.0.0) ; extra == "telemetry"
Requires-Dist: opentelemetry-instrumentation-fastapi (>=0.42b0,<0.43) ; extra == "telemetry"
Requires-Dist: opentelemetry-instrumentation-sqlalchemy (>=0.42b0,<0.43) ; extra == "telemetry"
Requires-Dist: opentelemetry-sdk (>=1.21.0,<2.0.0) ; extra == "telemetry"
Requires-Dist: pathspec (>=1.1.0,<2.0.0)
Requires-Dist: pydantic (>=2.11,<3.0)
Requires-Dist: pydantic-settings (>=2.10.1,<3.0.0)
Requires-Dist: python-dotenv (>=1.0.0,<2.0.0)
Requires-Dist: pyyaml (>=6.0,<7.0)
Requires-Dist: qdrant-client (>=1.9.0,<2.0.0)
Requires-Dist: radon (>=6.0.1,<7.0.0)
Requires-Dist: rich (>=13,<16)
Requires-Dist: ruamel-yaml (>=0.19.0,<0.20.0)
Requires-Dist: scikit-learn (>=1.5.1,<2.0.0)
Requires-Dist: scipy (>=1.14.0,<2.0.0)
Requires-Dist: sqlalchemy[asyncio] (>=2.0.36,<3.0.0)
Requires-Dist: sqlparse (>=0.5.3,<0.6.0)
Requires-Dist: typer[rich] (>=0.16.1,<0.17.0)
Requires-Dist: uvicorn[standard] (>=0.38.0,<0.39.0)
Project-URL: Documentation, https://dariusznewecki.github.io/CORE/
Project-URL: Homepage, https://github.com/DariuszNewecki/CORE
Project-URL: Repository, https://github.com/DariuszNewecki/CORE
Description-Content-Type: text/markdown

# CORE

> **Executable constitutional governance for AI-assisted software development.**
>
> Designed for environments where AI action traceability is not optional.

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)
[![Release](https://img.shields.io/badge/Release-v2.7.0-blue)](https://github.com/DariuszNewecki/CORE/releases)
[![Docs](https://img.shields.io/badge/Docs-online-green)](https://dariusznewecki.github.io/CORE/)
[![Autonomy](https://img.shields.io/badge/Autonomy-A3-blue)](https://github.com/DariuszNewecki/CORE/issues/106)

*Versioning: SemVer with `2.x` denoting an API approaching stability (Beta on PyPI); see [ADR-088](.specs/decisions/ADR-088-pypi-version-alignment.md) for the policy.*

---

## The Problem

AI coding tools generate code fast. Too fast to stay sane.

Without enforcement, AI-assisted codebases accumulate invisible debt — layer violations, broken architectural contracts, files that grow unbounded. And agents, left unconstrained, will eventually do something like this:

```
Agent: "I'll delete the production database to fix this bug"
System: Executes.
You:    😱
```

CORE makes that *class* of violation impossible — structurally blocked before execution, not detected after the fact. (Which surfaces hard-block versus advisory-report is mapped under *Current proof status* below.)

```
Agent: "I'll delete the production database to fix this bug"
Constitution: BLOCKED — Violates data.ssot.database_primacy
System: Execution halted. Violation logged.
You:    😌
```

CORE is a governance runtime that constrains AI agents with machine-enforced constitutional law — enforcing architectural invariants, blocking invalid mutations automatically, and making autonomous workflows auditable and deterministic.

**LLMs operate inside CORE. Never above it.**

---

## 🎬 See it govern itself — one command

You don't have to take this on faith. On a clean machine with Docker:

```bash
git clone https://github.com/DariuszNewecki/CORE.git
cd CORE && ./install-core.sh
```

`install-core.sh` stands up CORE and finishes by running the consequence-chain demo **live** — no LLM key required. It:

- commits a function that violates `linkage.assign_ids` (a blocking rule)
- watches CORE's audit **block** it
- has CORE propose a fix, the governor approve it, and CORE execute it and commit the repair
- re-audits to confirm **clean**
- prints the full causal chain it recorded: finding → proposal → approval → execution → file change

Re-run it any time with `scripts/demo.sh`.

Governance is executable.

<!-- TODO: embed a fresh asciicast of ./install-core.sh once recorded -->

---

## 📋 Live Audit Trail

Every enforced action records its lineage. Two consequence chains, pulled live from the CORE database — same schema, two different authorities:

**Autonomous path** — risk-classified as safe, system self-approved

```
FINDING     → workflow.ruff_format_check       src/api/cli/client.py                2026-05-18 05:15:15 UTC
PROPOSAL    → 8845dacc…   fix.format                                                2026-05-18 05:16:15 UTC
APPROVAL    → risk_classification.safe_auto_approval                                2026-05-18 05:16:15 UTC
EXECUTION   → completed   (1.29s)                                                   2026-05-18 05:17:18 UTC
FILE CHANGE → +105 / -0   98da9038 → fca9a971  src/api/cli/client.py                2026-05-18 05:17:19 UTC
```

**Human-approval path** — governor in the loop

```
FINDING     → purity.docstrings.required       src/cli/commands/audit_reporter.py   2026-05-15 08:28:29 UTC
PROPOSAL    → a4363a81…   fix.docstrings                                            2026-05-16 13:39:34 UTC
APPROVAL    → principal.governor  (cli_admin)                                       2026-05-16 13:53:32 UTC
EXECUTION   → completed   (24.5s)                                                   2026-05-16 13:55:48 UTC
FILE CHANGE → +26 / -0    5a123426 → 71fde489  src/cli/commands/audit_reporter.py   2026-05-16 13:55:49 UTC
```

Both chains are queryable end-to-end from `proposal_consequences` and `blackboard_entries`. The constitution decides which authority applies; the schema is identical. Reproduce them yourself with the [Consequence-chain query](https://dariusznewecki.github.io/CORE/proof-index/#consequence-chain-query) in the Proof Index.

---

## Architectural Model

CORE separates responsibility across four repository layers — three enforced as constitutional law, and Specs (human intent). This separation is enforced as law — not convention.

### 📐 Specs — Human Intent (`.specs/`)

Where humans define what the system is for and why decisions were made. Contains architectural papers, northstar documents, user requirements, architectural decision records, and planning documents. This is the entry point for anyone trying to understand CORE before reading its implementation.

`.specs/` is read by humans and searchable by CORE's semantic layer. It is never written by CORE itself.

### 🧠 Mind — Law (`.intent/` + `src/mind/`)

Defines what is allowed, required, or forbidden. Contains machine-readable constitutional rules, enforcement mappings, phase-aware governance models, and the authority hierarchy (`Meta → Constitution → Policy → Code`).

Mind never executes. Mind never mutates. Mind defines law.

### ⚖️ Will — Judgment (`src/will/`)

Reads constitutional constraints, orchestrates autonomous reasoning, and records every decision with a traceable audit trail. Every operation follows a structured phase pipeline:

```
INTERPRET → PLAN → GENERATE → VALIDATE → STYLE CHECK → EXECUTE
```

Will never bypasses Body. Will never rewrites Mind.

### 🏗️ Body — Execution (`src/body/`)

Deterministic, atomic components: analyzers, evaluators, file operations, git services, test runners, CLI commands.

Body performs mutations. Body does not judge. Body does not govern.

---

## How CORE Works

Every autonomous operation is governed by the same constitutional loop:

```mermaid
flowchart TD
    A["🟢 GOAL\nHUMAN INTENT"] --> B["📂 CONTEXT\nRepo state • knowledge • history"]
    B --> C["🔒 CONSTRAINTS\nImmutable rules\n209 rules • 13 engines"]
    C --> D["🗺️ PLAN\nStep-by-step reasoning\nRule-aware plan"]
    D --> E["✨ GENERATE\nCode • changes • tool calls"]
    E --> F["✅ VALIDATE\nDeterministic checks\nAST • semantic • intent • style"]
    F -->|Pass| G["▶️ EXECUTE\nApply compliant changes"]
    F -->|Fail| H["🔄 REMEDIATE\nRepair violation\nAutonomy Ladder"]
    H --> E
    G --> I["✓ SUCCESS\nChanges committed"]

    subgraph "SAFETY HALT"
        direction TB
        J["🚨 CONSTITUTIONAL VIOLATION\n→ HARD HALT\n+ FULL AUDIT LOG"]
    end

    E -.->|Any violation| J
    F -.->|Any violation| J

    classDef phase      fill:#f8f9fa,stroke:#495057,stroke-width:2px
    classDef constraint fill:#d1e7ff,stroke:#0d6efd,stroke-width:2.5px
    classDef validate   fill:#fff3cd,stroke:#ffc107,stroke-width:2.5px
    classDef halt       fill:#ffebee,stroke:#dc3545,stroke-width:3px

    class A,B,D,E,G,I phase
    class C constraint
    class F validate
    class J halt
```

---

## System Guarantees

Within CORE:

- No file outside an autonomy lane can be modified
- No structural rule can be bypassed silently
- No atomic action can execute outside the governed executor (inline authorization is deferred to the audit→consequence loop)
- Decisions are phase-aware and logged with decision traces (audit persistence is best-effort — see *Current proof status*)
- No agent can amend constitutional law

If a *blocking* rule fails, execution halts with no partial state. Reporting and advisory rules surface findings and continue — what blocks versus what reports depends on the mode.

### Current proof status

CORE's guarantee semantics are split across modes by design. This is the honest map of what each surface does, so a single binary claim ("CORE blocks violations") is not mistaken for the whole picture:

| Surface | Mode | Behaviour |
|---|---|---|
| `.intent/` writes | hard invariant | blocked — the governance directory is immutable to all components |
| Constitutional rules | always-blocking | block a commit regardless of strict mode |
| Policy rules | strict vs. default | block only when `strict_mode=True`; otherwise report |
| Capability tier | advisory today | reports a "would-deny" signal; does not yet block (ADR-079) |
| Stateless CI (GitHub Action) | rule subset | skips `knowledge_gate` + `llm_gate` (they need DB / LLM state) and reports the skip |
| Action audit trail | best-effort | recorded when the DB write succeeds; a write-action failure is surfaced (`AUDIT_GAP`), not silent |

The hard invariants and constitutional rules block unconditionally; the policy, capability, and stateless tiers are weaker by design and labelled here so the boundary is legible rather than implied.

---

## Constitutional Primitives

| Primitive  | Purpose                        |
|------------|--------------------------------|
| Document   | Persisted, validated artifact  |
| Rule       | Atomic normative statement     |
| Phase      | When the rule is evaluated     |
| Authority  | Who may define or amend it     |

Enforcement strengths: **Blocking** · **Reporting** · **Advisory**

---

## Enforcement Engines

| Engine            | Method                                       |
|-------------------|----------------------------------------------|
| `ast_gate`        | Deterministic structural analysis (AST)      |
| `regex_gate`      | Pattern-based text enforcement               |
| `glob_gate`       | Path and boundary enforcement                |
| `cli_gate`        | CLI surface and command-shape enforcement    |
| `artifact_gate`   | Declared-vs-discovered artifact completeness |
| `workflow_gate`   | Phase-sequencing and coverage checks         |
| `knowledge_gate`  | Responsibility and ownership validation      |
| `action_gate`     | Atomic-action invariants                     |
| `passive_gate`    | Substrate-enforced rules (DB/runtime marker) |
| `taxonomy_gate`   | Capability-id ↔ atomic-action coherence (ADR-079 D9) |
| `contracts_gate`  | Cross-cutting data-contract coherence (context-level; ADR-102) |
| `llm_gate`        | LLM-assisted semantic checks                 |
| `IntentGuard`*    | Runtime write authorization (not audit)      |

*Runtime Gate per `.specs/papers/CORE-Gate.md`, kept here for visibility.

Deterministic when possible. LLM only when necessary.

209 rules across 49 rule documents. 204 are mapped to enforcement engines; 5 test-quality rules are still pending mappings. "Mapped" means engine-bound — not enforced in every mode: stateless CI skips `knowledge_gate` and `llm_gate`, which need the knowledge graph and an LLM provider.

---

## The Autonomy Ladder

CORE progresses through defined levels. Each adds capability while remaining constitutionally bounded.

```
A0 — Self-Awareness       ✅  Knows what it is and where it lives
A1 — Self-Healing         ✅  Fixes known structural issues automatically
A2 — Governed Generation  ✅  Natural language → constitutionally aligned code
A3 — Governed Autonomy    ✅  Daemon finds, proposes, and fixes violations unattended  ← current
A4 — Self-Replication     🔮  Writes CORE.NG from its own understanding of itself
```

---

## Requirements

| Dependency  | Version      |
|-------------|--------------|
| Python      | 3.12+        |
| PostgreSQL  | ≥ 14         |
| Qdrant      | latest       |
| Docker      | for services |
| Poetry      | for deps     |

---

## Quick Start

> **Honest status — what works today.** CORE governs *itself* end to end (the demo above), and audits any repo that **already has a `.intent/` constitution** — in CI via the [GitHub Action](https://dariusznewecki.github.io/CORE/cold-reviewer/), or locally with `core-admin code audit --offline` *inside that repo*. `pip install core-runtime` gives you the `core-admin` CLI. **Not yet self-serve:** pointing CORE at your *own* repo from scratch — scaffolding that first constitution (BYOR, [#640](https://github.com/DariuszNewecki/CORE/issues/640)). Until that lands, `core-admin code audit --offline` in a repo with no `.intent/` won't help you (it currently hangs — fix tracked in #640). We'd rather say so than let you hit a wall. **Fastest way to see CORE today: run it on itself, below.**

**Full local runtime** — one command. Clone, then run the installer:

```bash
git clone https://github.com/DariuszNewecki/CORE.git
cd CORE
./install-core.sh
```

`install-core.sh` checks prerequisites, installs dependencies, starts Postgres + Qdrant, applies the schema, and finishes by **showing CORE govern itself** — a violation found, proposed, approved, fixed, and verified, with the consequence chain recorded. No LLM API key needed for the demo.

<details>
<summary>Prefer to run the steps yourself?</summary>

```bash
poetry install
cp .env.example .env
docker compose up -d
docker compose exec -T postgres psql -U postgres -d core < infra/sql/db_schema_live.sql
poetry run core-admin code audit --offline   # offline mode needs no running services
```
</details>

Full setup — services, schema, vector sync, first audit — is in [Getting Started](https://dariusznewecki.github.io/CORE/getting-started/).

---

## Documentation

Full documentation, architecture deep-dive, and governance reference:
[dariusznewecki.github.io/CORE](https://dariusznewecki.github.io/CORE/)

To understand what CORE is for before reading its implementation, start here:
[`.specs/northstar/CORE-What-It-Does.md`](.specs/northstar/CORE%20-%20What%20It%20Does.md)

---

## Project Status

**Current Release:** v2.7.0 — Bounded Autonomy

Active work: A3 Governed Autonomy — the daemon runs continuously, finds constitutional violations in its own codebase, proposes fixes, executes approved fixes, and verifies the result. The governor's role is to define intent, review proposals that require architectural judgment, and approve constitutional changes.

All four A3 integrity gates are now closed. No enforcement logic or operational threshold lives in `src/` — governance is declared in `.intent/` and enforced from there. The autonomous loop is circuit-breaker protected; systematic errors surface as signals rather than unbounded churn.

| Gate | Meaning | Status |
|------|---------|--------|
| G1 — Loop closure | Round-trip autonomous fix demonstrated | ✅ |
| G2 — Convergence | Circuit-breaker; resolution rate > creation rate | ✅ |
| G3 — Consequence chain | Causality queryable end-to-end | ✅ |
| G4 — Governance in `.intent/` | No enforcement logic or thresholds in `src/` | ✅ |

---

## License

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)

---

<div align="center">

**Build fast with AI. Stay constitutionally aligned.**

</div>

