> ## Documentation Index
> Fetch the complete documentation index at: https://openclaw.veiseule.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Lanzamiento de macOS

# 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 notarytool` si 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_ID`
    * `echo "$APP_STORE_CONNECT_API_KEY_P8" | sed 's/\\n/\n/g' > /tmp/openclaw-notary.p8`
    * `xcrun notarytool store-credentials "openclaw-notary" --key /tmp/openclaw-notary.p8 --key-id "$APP_STORE_CONNECT_KEY_ID" --issuer "$APP_STORE_CONNECT_ISSUER_ID"`
* Dependencias de `pnpm` instaladas (`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_BUILD` se asigna a `CFBundleVersion`/`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, configure `BUILD_ARCHS="arm64 x86_64"` (o `BUILD_ARCHS=all`).
* Use `scripts/package-mac-dist.sh` para artefactos de lanzamiento (zip + DMG + notarización). Use `scripts/package-mac-app.sh` para empaquetado local/dev.

```bash theme={"theme":{"light":"min-light","dark":"min-dark"}}
# From repo root; set release IDs so Sparkle feed is enabled.
# APP_BUILD must be numeric + monotonic for Sparkle compare.
BUNDLE_ID=bot.molt.mac \
APP_VERSION=2026.2.9 \
APP_BUILD="$(git rev-list --count HEAD)" \
BUILD_CONFIG=release \
SIGN_IDENTITY="Developer ID Application: <Developer Name> (<TEAMID>)" \
scripts/package-mac-app.sh

# Zip for distribution (includes resource forks for Sparkle delta support)
ditto -c -k --sequesterRsrc --keepParent dist/OpenClaw.app dist/OpenClaw-2026.2.9.zip

# Optional: also build a styled DMG for humans (drag to /Applications)
scripts/create-dmg.sh dist/OpenClaw.app dist/OpenClaw-2026.2.9.dmg

# Recommended: build + notarize/staple zip + DMG
# First, create a keychain profile once:
#   xcrun notarytool store-credentials "openclaw-notary" \
#     --apple-id "<apple-id>" --team-id "<team-id>" --password "<app-specific-password>"
NOTARIZE=1 NOTARYTOOL_PROFILE=openclaw-notary \
BUNDLE_ID=bot.molt.mac \
APP_VERSION=2026.2.9 \
APP_BUILD="$(git rev-list --count HEAD)" \
BUILD_CONFIG=release \
SIGN_IDENTITY="Developer ID Application: <Developer Name> (<TEAMID>)" \
scripts/package-mac-dist.sh

# Optional: ship dSYM alongside the release
ditto -c -k --keepParent apps/macos/.build/release/OpenClaw.app.dSYM dist/OpenClaw-2026.2.9.dSYM.zip
```

## Entrada de appcast

Use el generador de notas de lanzamiento para que Sparkle renderice notas HTML con formato:

```bash theme={"theme":{"light":"min-light","dark":"min-dark"}}
SPARKLE_PRIVATE_KEY_FILE=/path/to/ed25519-private-key scripts/make_appcast.sh dist/OpenClaw-2026.2.9.zip https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xml
```

Genera notas de lanzamiento en HTML a partir de `CHANGELOG.md` (vía [`scripts/changelog-to-html.sh`](https://github.com/openclaw/openclaw/blob/main/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` (y `OpenClaw-2026.2.9.dSYM.zip`) a la release de GitHub para la etiqueta `v2026.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.xml` devuelve 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.

Definición de terminado: la app firmada y el appcast están publicados, el flujo de actualización funciona desde una versión instalada anterior y los activos del lanzamiento están adjuntos al lanzamiento de GitHub.
