1.7 KiB
1.7 KiB
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 intoContents/Helpers/, then emit.zip,.dmg, and.pkgdistribution 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
.appbundle,.zip,.dmg, and.pkginstaller 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.