Penandatanganan macOS (build debug)
Aplikasi ini biasanya dibangun dariscripts/package-mac-app.sh, yang sekarang:
- menetapkan bundle identifier debug yang stabil:
ai.openclaw.mac.debug - menulis Info.plist dengan bundle id tersebut (timpa dengan
BUNDLE_ID=...) - memanggil
scripts/codesign-mac-app.shuntuk menandatangani biner utama dan app bundle agar macOS memperlakukan setiap build ulang sebagai bundle bertanda tangan yang sama dan mempertahankan izin TCC (notifikasi, aksesibilitas, perekaman layar, mikrofon, ucapan). Untuk izin yang stabil, gunakan identitas penandatanganan sungguhan; ad-hoc bersifat opt-in dan rapuh (lihat izin macOS). - menggunakan
CODESIGN_TIMESTAMP=autosecara default; ini mengaktifkan trusted timestamp untuk tanda tangan Developer ID. TetapkanCODESIGN_TIMESTAMP=offuntuk melewati timestamping (build debug offline). - menyuntikkan metadata build ke Info.plist:
OpenClawBuildTimestamp(UTC) danOpenClawGitCommit(hash pendek) agar panel About dapat menampilkan build, git, dan channel debug/rilis. - Packaging secara default menggunakan Node 24: script menjalankan build TS dan build Control UI. Node 22 LTS, saat ini
22.14+, tetap didukung untuk kompatibilitas. - membaca
SIGN_IDENTITYdari environment. Tambahkanexport SIGN_IDENTITY="Apple Development: Your Name (TEAMID)"(atau sertifikat Developer ID Application Anda) ke shell rc Anda agar selalu menandatangani dengan sertifikat Anda. Penandatanganan ad-hoc memerlukan opt-in eksplisit melaluiALLOW_ADHOC_SIGNING=1atauSIGN_IDENTITY="-"(tidak direkomendasikan untuk pengujian izin). - menjalankan audit Team ID setelah penandatanganan dan gagal jika ada Mach-O di dalam app bundle yang ditandatangani oleh Team ID yang berbeda. Tetapkan
SKIP_TEAM_ID_CHECK=1untuk melewati pemeriksaan.
Penggunaan
Catatan Penandatanganan Ad-hoc
Saat menandatangani denganSIGN_IDENTITY="-" (ad-hoc), script secara otomatis menonaktifkan Hardened Runtime (--options runtime). Ini diperlukan untuk mencegah crash saat aplikasi mencoba memuat embedded framework (seperti Sparkle) yang tidak menggunakan Team ID yang sama. Tanda tangan ad-hoc juga merusak persistensi izin TCC; lihat izin macOS untuk langkah pemulihan.
Metadata build untuk About
package-mac-app.sh memberi stempel pada bundle dengan:
OpenClawBuildTimestamp: UTC ISO8601 pada saat packagingOpenClawGitCommit: hash git pendek (atauunknownjika tidak tersedia)
#if DEBUG). Jalankan packager untuk menyegarkan nilai-nilai ini setelah perubahan kode.
Alasan
Izin TCC terikat pada bundle identifier dan code signature. Build debug tanpa tanda tangan dengan UUID yang berubah-ubah menyebabkan macOS melupakan izin yang telah diberikan setelah setiap build ulang. Menandatangani biner (ad-hoc secara default) dan mempertahankan bundle id/path tetap (dist/OpenClaw.app) mempertahankan izin antar-build, sesuai dengan pendekatan VibeTunnel.