Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
ký mac (bản dựng debug)
Ứng dụng này thường được dựng từscripts/package-mac-app.sh, hiện sẽ:
- đặt mã định danh bundle debug ổn định:
ai.openclaw.mac.debug - ghi Info.plist với bundle id đó (ghi đè bằng
BUNDLE_ID=...) - gọi
scripts/codesign-mac-app.shđể ký binary chính và bundle ứng dụng, để macOS coi mỗi lần dựng lại là cùng một bundle đã ký và giữ các quyền TCC (thông báo, trợ năng, ghi màn hình, mic, giọng nói). Để quyền ổn định, hãy dùng một danh tính ký thật; ad-hoc là tùy chọn phải bật rõ ràng và dễ hỏng (xem quyền macOS). - dùng
CODESIGN_TIMESTAMP=autotheo mặc định; tùy chọn này bật timestamp đáng tin cậy cho chữ ký Developer ID. ĐặtCODESIGN_TIMESTAMP=offđể bỏ qua timestamping (bản dựng debug ngoại tuyến). - chèn metadata bản dựng vào Info.plist:
OpenClawBuildTimestamp(UTC) vàOpenClawGitCommit(hash ngắn) để khung About có thể hiển thị bản dựng, git, và kênh debug/release. - Đóng gói mặc định dùng Node 24: script chạy các bản dựng TS và bản dựng Control UI. Node 22 LTS, hiện là
22.14+, vẫn được hỗ trợ để tương thích. - đọc
SIGN_IDENTITYtừ môi trường. Thêmexport SIGN_IDENTITY="Apple Development: Your Name (TEAMID)"(hoặc chứng chỉ Developer ID Application của bạn) vào shell rc để luôn ký bằng chứng chỉ của bạn. Ký ad-hoc cần bật rõ ràng bằngALLOW_ADHOC_SIGNING=1hoặcSIGN_IDENTITY="-"(không khuyến nghị để kiểm thử quyền). - chạy kiểm tra Team ID sau khi ký và thất bại nếu bất kỳ Mach-O nào bên trong bundle ứng dụng được ký bởi Team ID khác. Đặt
SKIP_TEAM_ID_CHECK=1để bỏ qua.
Cách dùng
Ghi chú về ký ad-hoc
Khi ký bằngSIGN_IDENTITY="-" (ad-hoc), script tự động tắt Hardened Runtime (--options runtime). Điều này cần thiết để ngăn crash khi ứng dụng cố tải các framework nhúng (như Sparkle) không dùng chung Team ID. Chữ ký ad-hoc cũng làm hỏng khả năng duy trì quyền TCC; xem quyền macOS để biết các bước khôi phục.
Metadata bản dựng cho About
package-mac-app.sh đóng dấu bundle với:
OpenClawBuildTimestamp: UTC ISO8601 tại thời điểm đóng góiOpenClawGitCommit: hash git ngắn (hoặcunknownnếu không có)
#if DEBUG). Chạy packager để làm mới các giá trị này sau khi thay đổi mã.
Lý do
Quyền TCC được gắn với mã định danh bundle và chữ ký mã. Các bản dựng debug chưa ký với UUID thay đổi đã khiến macOS quên quyền đã cấp sau mỗi lần dựng lại. Việc ký các binary (mặc định là ad-hoc) và giữ bundle id/đường dẫn cố định (dist/OpenClaw.app) bảo toàn các quyền đã cấp giữa các bản dựng, khớp với cách tiếp cận của VibeTunnel.