OpenClaw Mac Release
Use with $openclaw-release-maintainer, $openclaw-release-ci, and $one-password when stable macOS assets, private mac preflight, notarization, appcast promotion, or mac release recovery is involved.
Credentials
- Canonical ASC item: vault
Molty, titleAPI Key - App Store Connect - Personal - Release. - Fields:
private_key_p8,key_id,issuer_id. - Current known good key id:
AKVLXW849T. - Legacy mirror: vault
Private, titleAPI Key - App Store Connect - Personal; keep it synced for older refs. - Stale/revoked key symptom:
xcrun notarytool submitfails withHTTP status code: 401. Unauthenticated. - Validate candidate ASC credentials with
xcrun notarytool historybefore setting GitHub secrets.
1Password
- Use
$one-password: allopwork inside one persistent tmux session, no secret output. - Prefer
OP_SERVICE_ACCOUNT_TOKENfrom~/.profilefor Molty reads. - Do not assume
MOLTY_OP_SERVICE_ACCOUNT_TOKENis alive; it has previously pointed at a deleted service account. - If a service token fails, run status-only checks: token present/length and
op whoami; never print token values. - If desktop app auth is needed but Touch ID is unavailable, set
OP_BIOMETRIC_UNLOCK_ENABLED=falsefor the manualop account add --signinpath.
GitHub Secrets
Target private repo environment: openclaw/releases-private, env mac-release.
Set only after local notary auth validation:
APP_STORE_CONNECT_API_KEY_P8APP_STORE_CONNECT_KEY_IDAPP_STORE_CONNECT_ISSUER_ID
Do not update these from mixed sources. All three ASC fields must come from the same 1Password item.
Workflow Shape
- Public release branch may carry mac-only packaging fixes after the stable tag/npm are already live.
- Use
source_ref=release/YYYY.M.Dfor private mac preflight/validation when building that branch variation. - Keep
tag=vYYYY.M.Dpointing at the original stable release commit. - Real mac publish must reuse:
- a successful private mac preflight run for the same tag/source SHA
- a successful private mac validation run for the same tag/source SHA
- If preflight source SHA differs from tag SHA, validation must also use the same
source_ref; promotion rejects mismatched proof.
Notarization
- OpenClaw uses
scripts/notarize-mac-artifact.sh. xcrun notarytool submitshould use--no-s3-acceleration; accelerated upload can surface misleading 401s even whennotarytool historysucceeds.- If signing succeeds but notarization fails immediately with 401, check ASC key freshness first.
- If notarization stays in progress for several minutes after key-file write, that is normal Apple wait time; do not edit blindly.
Dispatch
Private preflight:
gh workflow run openclaw-macos-publish.yml --repo openclaw/releases-private --ref main \
-f tag=vYYYY.M.D \
-f source_ref=release/YYYY.M.D \
-f preflight_only=true \
-f smoke_test_only=false \
-f allow_late_calver_recovery=false \
-f public_release_branch=release/YYYY.M.D
Private validation for a branch-variation preflight:
gh workflow run openclaw-macos-validate.yml --repo openclaw/releases-private --ref main \
-f tag=vYYYY.M.D \
-f source_ref=release/YYYY.M.D
Real publish:
gh workflow run openclaw-macos-publish.yml --repo openclaw/releases-private --ref main \
-f tag=vYYYY.M.D \
-f preflight_only=false \
-f smoke_test_only=false \
-f preflight_run_id=<successful-preflight-run> \
-f validate_run_id=<successful-validation-run> \
-f allow_late_calver_recovery=false \
-f public_release_branch=release/YYYY.M.D
Verify
gh release view vYYYY.M.D --repo openclaw/openclawshows zip, dmg, dSYM zip, not draft, not prerelease.- Public
mainappcast.xmlpoints atOpenClaw-YYYY.M.D.zip. - Appcast entry has
sparkle:version,sparkle:shortVersionString, length, andsparkle:edSignature.