إصدار OpenClaw على macOS (Sparkle)
يشحن هذا التطبيق الآن تحديثات Sparkle التلقائية. يجب توقيع بنى الإصدار بمعرّف المطوّر (Developer ID)، وضغطها، ونشرها مع إدخال appcast موقّع.المسبق
- تثبيت شهادة Developer ID Application (مثال:
Developer ID Application: <Developer Name> (<TEAMID>)). - تعيين مسار المفتاح الخاص لـ Sparkle في متغيرات البيئة كـ
SPARKLE_PRIVATE_KEY_FILE(المسار إلى مفتاح Sparkle الخاص ed25519؛ المفتاح العام مضمّن في Info.plist). إذا كان مفقودًا، تحقّق من~/.profile. - بيانات اعتماد التوثيق (ملف تعريف سلسلة المفاتيح أو مفتاح API) لـ
xcrun notarytoolإذا كنت تريد توزيع DMG/zip آمنًا مع Gatekeeper.- نستخدم ملف تعريف لسلسلة المفاتيح باسم
openclaw-notary، تم إنشاؤه من متغيرات بيئة مفتاح API لـ App Store Connect في ملف تعريف الصدفة لديك: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 على أنه متساوٍ.- الإعداد الافتراضي هو المعمارية الحالية (
$(uname -m)). لبنى الإصدار/العالمية، عيّنBUILD_ARCHS="arm64 x86_64"(أوBUILD_ARCHS=all). - استخدم
scripts/package-mac-dist.shلأصول الإصدار (zip + DMG + التوثيق). استخدمscripts/package-mac-app.shللتغليف المحلي/التطويري.
إدخال Appcast
استخدم مولّد ملاحظات الإصدار لكي يعرض Sparkle ملاحظات HTML منسّقة:CHANGELOG.md (عبر scripts/changelog-to-html.sh) ويضمّنها في إدخال appcast.
قم بعمل commit للملف المحدّث appcast.xml إلى جانب أصول الإصدار (zip + dSYM) عند النشر.
النشر والتحقق
- ارفع
OpenClaw-2026.2.9.zip(وOpenClaw-2026.2.9.dSYM.zip) إلى إصدار GitHub للوسمv2026.2.9. - تأكّد من أن رابط appcast الخام يطابق الخلاصة المضمّنة:
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 بعد رفع الأصول.- على بنية عامة سابقة، شغّل «التحقق من وجود تحديثات…» من تبويب «حول» وتحقق من أن Sparkle يثبت البنية الجديدة بسلاسة.