Lanzamiento de OpenClaw para macOS (Sparkle)
Esta app ahora incluye actualizaciones automáticas con Sparkle. Las compilaciones de lanzamiento deben estar firmadas con Developer ID, comprimidas en zip y publicadas con una entrada de appcast firmada.Prereqs
- Certificado Developer ID Application instalado (ejemplo:
Developer ID Application: <Developer Name> (<TEAMID>)). - Ruta de la clave privada de Sparkle configurada en el entorno como
SPARKLE_PRIVATE_KEY_FILE(ruta a su clave privada ed25519 de Sparkle; la clave pública está integrada en Info.plist). Si falta, verifique~/.profile. - Credenciales de Notary (perfil del llavero o clave de API) para
xcrun notarytoolsi desea distribución de DMG/zip segura con Gatekeeper.- Usamos un perfil del llavero llamado
openclaw-notary, creado a partir de variables de entorno de la clave de API de App Store Connect en el perfil de su shell:APP_STORE_CONNECT_API_KEY_P8,APP_STORE_CONNECT_KEY_ID,APP_STORE_CONNECT_ISSUER_IDecho "$APP_STORE_CONNECT_API_KEY_P8" | sed 's/\\n/\n/g' > /tmp/openclaw-notary.p8xcrun notarytool store-credentials "openclaw-notary" --key /tmp/openclaw-notary.p8 --key-id "$APP_STORE_CONNECT_KEY_ID" --issuer "$APP_STORE_CONNECT_ISSUER_ID"
- Usamos un perfil del llavero llamado
- Dependencias de
pnpminstaladas (pnpm install --config.node-linker=hoisted). - Las herramientas de Sparkle se obtienen automáticamente vía SwiftPM en
apps/macos/.build/artifacts/sparkle/Sparkle/bin/(sign_update,generate_appcast, etc.).
Compilar y empaquetar
Notas:APP_BUILDse asigna aCFBundleVersion/sparkle:version; manténgalo numérico y monótono (sin-beta), o Sparkle lo compara como igual.- Por defecto usa la arquitectura actual (
$(uname -m)). Para compilaciones de lanzamiento/universales, configureBUILD_ARCHS="arm64 x86_64"(oBUILD_ARCHS=all). - Use
scripts/package-mac-dist.shpara artefactos de lanzamiento (zip + DMG + notarización). Usescripts/package-mac-app.shpara empaquetado local/dev.
Entrada de appcast
Use el generador de notas de lanzamiento para que Sparkle renderice notas HTML con formato:CHANGELOG.md (vía scripts/changelog-to-html.sh) y las incrusta en la entrada del appcast.
Confirme el appcast.xml actualizado junto con los activos del lanzamiento (zip + dSYM) al publicar.
Publicar y verificar
- Sube
OpenClaw-2026.2.9.zip(yOpenClaw-2026.2.9.dSYM.zip) a la release de GitHub para la etiquetav2026.2.9. - Asegúrese de que la URL raw del appcast coincida con el feed integrado:
https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xml. - Comprobaciones de sanidad:
curl -I https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xmldevuelve 200.curl -I <enclosure url>devuelve 200 después de cargar los activos.- En una compilación pública anterior, ejecute “Buscar actualizaciones…” desde la pestaña Acerca de y verifique que Sparkle instale la nueva compilación correctamente.