Skip to main content

Shipwright — AI-agent dev framework + import-light design/eval/security library

Project description

Shipwright

CI CodeQL Coverage Types License: MIT Python

Shipwright is two things that share one repo:

  • an installable, import-light Python library of shared dev-tooling runtime — shipwright_kit.design (severity tiers + accessible output), shipwright_kit.eval (detection-quality eval harness), shipwright_kit.security (a security pack);
  • an AI-agent-operated development framework — reusable CI/CD, a Copier scaffolder, quality gates, and bundled agent skills + personas — that dogfoods the library and the gates it hands to the projects built with it.

The library is consumed today by two real tools: barb and sift both import shipwright_kit.eval to run their detection-quality gates.

Install

The library is not on PyPI — the bare name shipwright belongs to an unrelated project, so the published distribution is shipwright-kit and the import name is shipwright_kit. For now, install from git:

uv pip install "git+https://github.com/duathron/shipwright@main"
# then: import shipwright_kit

[!NOTE] Pin a release tag instead of @main for reproducible builds once a tagged release of the shipwright-kit distribution is cut. Do not pip install shipwright from PyPI — that is a different, unrelated package.

The security pack needs no extra — it ships with the base install and registers through the shipwright_kit.packs entry point.

Library quickstart

Run an eval gate — score a classifier against a labeled corpus and fail if it misses a floor (the exact pattern barb and sift use):

from shipwright_kit.eval import Sample, evaluate, gate

corpus = [Sample("phish-login", "phishing"),
          Sample("example.com", "benign"),
          Sample("secure-phish", "phishing")]

result = evaluate(
    lambda text: "phishing" if "phish" in text else "benign",
    corpus,
    positive_pred=lambda pred: pred == "phishing",
    positive_expected=lambda label: label == "phishing",
)
print(result.precision, result.recall)        # 1.0 1.0
gate(result, min_precision=1.0, min_recall=0.9)  # raises EvalGateError if below

Use the shared severity tiers — one generic scale tools map their own verdicts onto, with accessible (Unicode-or-ASCII) labels:

from shipwright_kit.design import Severity, tier_label

Severity.OK, Severity.INFO, Severity.NOTICE, Severity.WARN, Severity.CRITICAL  # IntEnum 0..4
print(tier_label(Severity.CRITICAL))  # ✗ CRITICAL
print(tier_label(Severity.OK))        # ✓ OK

import shipwright_kit pulls in no rich or pyfiglet — the heavy deps load lazily only when you actually render. Full API: docs/library.md.

The framework

The repo contains no project code. Projects stay their own Git repositories and their own packages; locally you clone each into the gitignored projects/ directory, where a uv workspace ties them together for development:

shipwright/
├─ shipwright_kit/          # the importable library (design / eval / security)
├─ tooling/ruff-base.toml   # single source of truth for lint rules
├─ templates/               # Copier scaffolder (python-cli) + release config
├─ skills/ · personas/      # the agent operating layer (scaffold, onboard, review …)
├─ .github/workflows/       # reusable python-ci.yml + python-release.yml (SHA-pinned)
└─ projects/                # GITIGNORED, local-only — your projects plug in here

Work is promoted through gates; failing a rung blocks promotion:

commit → lint + unit (auto) → build → dogfood + eval (auto) →
QM gate (manual) → beta sign-off (manual) → release

The reusable CI/CD that wires these gates, the Copier scaffolder (templates/), and the agent skills (skills/) and personas (personas/) all ship now. This repo runs the exact gates it gives the projects built with it.

Framework quickstart

Requires Python 3.11+, uv, and just.

uv sync --dev              # create the dev environment
uv run pre-commit install  # install the local gate
just lint                  # ruff check + format-check
just test                  # pytest

The local pre-commit gate runs the same lint/format/secret checks as CI; add just test (and uv build) for the test and build rungs CI also enforces.

Docs

Security

Report vulnerabilities privately via GitHub's private vulnerability reporting (repo Security tab → Report a vulnerability). See SECURITY.md.

License

MIT © 2026 Christian Huhn

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

shipwright_kit-0.6.0.tar.gz (20.9 kB view details)

Uploaded Source

Built Distribution

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

shipwright_kit-0.6.0-py3-none-any.whl (19.8 kB view details)

Uploaded Python 3

File details

Details for the file shipwright_kit-0.6.0.tar.gz.

File metadata

  • Download URL: shipwright_kit-0.6.0.tar.gz
  • Upload date:
  • Size: 20.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for shipwright_kit-0.6.0.tar.gz
Algorithm Hash digest
SHA256 95c0e04dc490a95116649510a9e488901011166b55a2ccffec17d92429731d12
MD5 fb9127f6d83c7afbee12deb7afd2d021
BLAKE2b-256 eb043e1e405d9bbf1d5ed8fa06ce37735b0f0e9a5f3f1f975101466693ea8d8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for shipwright_kit-0.6.0.tar.gz:

Publisher: release.yml on duathron/shipwright

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file shipwright_kit-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: shipwright_kit-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 19.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for shipwright_kit-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8deca89448e789e2e201f6d5ab6f3ff4addfcde2f77d5c38ea5bdc0da6f30315
MD5 bf6cb185a469df7760e3cd7dc759acb9
BLAKE2b-256 93efc857ad2f3f54d25a7f3a88976c146d2b9f822263974bb922e8e8dcb024ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for shipwright_kit-0.6.0-py3-none-any.whl:

Publisher: release.yml on duathron/shipwright

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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