此应用程序现在通过 Sparkle 自动更新发布。发布构建必须使用 Developer ID 签名、zip 压缩,并使用签名的 appcast 条目发布。
前提条件
- 已安装 Developer ID Application 证书(示例:
Developer ID Application: <Developer Name> (<TEAMID>))。 - 在环境中设置 Sparkle 私钥路径为
SPARKLE_PRIVATE_KEY_FILE(指向你的 Sparkle ed25519 私钥;公钥嵌入在 Info.plist 中)。如果缺失,请检查~/.profile。 xcrun notarytool的公证凭证(keychain 配置文件或 API 密钥),如果你想要 Gatekeeper 安全的 DMG/zip 分发。- 我们使用名为
openclaw-notary的 Keychain 配置文件,从 shell 配置文件中 App Store Connect API 密钥环境变量创建: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"
- 已安装
pnpm依赖(pnpm install --config.node-linker=hoisted)。 - Sparkle 工具通过 SwiftPM 在
apps/macos/.build/artifacts/sparkle/Sparkle/bin/自动获取(sign_update、generate_appcast等)。
构建和打包
注意:
APP_BUILD映射到CFBundleVersion/sparkle:version;保持数值 + 单调递增(无-beta),否则 Sparkle 会将其比较为相等。- 如果省略
APP_BUILD,scripts/package-mac-app.sh会从APP_VERSION(YYYYMMDDNN:稳定版默认为90,预发布使用后缀派生的通道)派生 Sparkle 安全的默认值,并使用该值与 git 提交计数中的较高者。 - 你仍然可以在发布工程需要特定单调值时显式覆盖
APP_BUILD。 - 对于
BUILD_CONFIG=release,scripts/package-mac-app.sh现在默认通用(arm64 x86_64)。你仍然可以用BUILD_ARCHS=arm64或BUILD_ARCHS=x86_64覆盖。对于本地/开发构建(BUILD_CONFIG=debug),它默认为当前架构($(uname -m))。 - 使用
scripts/package-mac-dist.sh生成发布资源(zip + DMG + 公证)。使用scripts/package-mac-app.sh进行本地/开发打包。
# 从仓库根目录;设置发布 ID 以启用 Sparkle 订阅源。
# 此命令构建发布资源而不进行公证。
# APP_BUILD 必须为数值 + 单调递增以供 Sparkle 比较。
# 默认在省略时从 APP_VERSION 自动派生。
SKIP_NOTARIZE=1 \
BUNDLE_ID=ai.openclaw.mac \
APP_VERSION=2026.3.13 \
BUILD_CONFIG=release \
SIGN_IDENTITY="Developer ID Application: <Developer Name> (<TEAMID>)" \
scripts/package-mac-dist.sh
# `package-mac-dist.sh` 已经创建了 zip + DMG。
# 如果你直接使用 `package-mac-app.sh`,请手动创建它们:
# 如果你想在此步骤中公证/装订,请使用下面的 NOTARIZE 命令。
ditto -c -k --sequesterRsrc --keepParent dist/OpenClaw.app dist/OpenClaw-2026.3.13.zip
# 可选:为用户构建样式化 DMG(拖到 /Applications)
scripts/create-dmg.sh dist/OpenClaw.app dist/OpenClaw-2026.3.13.dmg
# 推荐:构建 + 公证/装订 zip + DMG
# 首先,创建一次 keychain 配置文件:
# 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=ai.openclaw.mac \
APP_VERSION=2026.3.13 \
BUILD_CONFIG=release \
SIGN_IDENTITY="Developer ID Application: <Developer Name> (<TEAMID>)" \
scripts/package-mac-dist.sh
# 可选:随版本一起发布 dSYM
ditto -c -k --keepParent apps/macos/.build/release/OpenClaw.app.dSYM dist/OpenClaw-2026.3.13.dSYM.zip
Appcast 条目
使用发布说明生成器以便 Sparkle 呈现格式化的 HTML 说明:
SPARKLE_PRIVATE_KEY_FILE=/path/to/ed25519-private-key scripts/make_appcast.sh dist/OpenClaw-2026.3.13.zip https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xml
从 CHANGELOG.md(通过 scripts/changelog-to-html.sh)生成 HTML 发布说明,并将其嵌入 appcast 条目中。在发布时将更新的 appcast.xml 与版本资源(zip + dSYM)一起提交。
发布和验证
- 将
OpenClaw-2026.3.13.zip(和OpenClaw-2026.3.13.dSYM.zip)上传到 GitHub release 的标签v2026.3.13。 - 确保原始 appcast URL 与烘焙的订阅源匹配:
https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xml。 - 完整性检查:
curl -I https://raw.githubusercontent.com/openclaw/openclaw/main/appcast.xml返回 200。- 上传资源后
curl -I <enclosure url>返回 200。 - 在之前的公开构建上,从 About 标签运行"Check for Updates…"并验证 Sparkle 干净地安装新构建。
完成定义:已发布签名应用 + appcast,更新流程从较旧的已安装版本正常工作,版本资源已附加到 GitHub release。
夜雨聆风