Files
CleanMM/Docs/ADR/ADR-004-Helper-Executable-and-Native-Packaging.md
2026-03-10 17:09:35 +08:00

30 lines
1.7 KiB
Markdown

# ADR-004: Helper Executable and Native Packaging Pipeline
## Status
Accepted
## Context
Atlas for Mac needed to move beyond a print-only helper stub and legacy CLI release workflows. The MVP required a structured helper execution path for destructive actions plus a native build/package pipeline that could produce a distributable macOS app bundle.
## Decision
- Implement the helper as a JSON-driven executable that validates allowlisted target paths before acting.
- Invoke the helper from the worker through a structured client rather than direct UI mutations.
- Build the app with `xcodegen + xcodebuild`, embed the helper binary into `Contents/Helpers/`, then emit `.zip`, `.dmg`, and `.pkg` distribution artifacts during packaging.
- Add a native GitHub Actions workflow that packages the app artifact and can optionally extend to signing/notarization when release credentials are available.
## Consequences
- The worker/helper boundary is now implemented as code, not just documentation.
- Local and CI environments can produce a real `.app` bundle, `.zip`, `.dmg`, and `.pkg` installer artifacts for MVP verification, with DMG installation validated into the user Applications folder.
- The helper is still not a fully blessed privileged service, so future release hardening may deepen this path.
- Packaging now depends on Xcode project generation remaining synchronized with `project.yml`.
## Alternatives Considered
- Keep the helper as a stub — rejected because uninstall and destructive flows would remain architecturally incomplete.
- Bundle no helper and let the worker mutate files directly — rejected because it weakens privilege boundaries.
- Delay native packaging until release week — rejected because it postpones critical integration risk discovery.