Bundled plugin guides
Plugin workshop kỹ năng
Skill Workshop là thử nghiệm. Tính năng này bị tắt theo mặc định, các heuristic capture và prompt reviewer có thể thay đổi giữa các bản phát hành, và việc ghi tự động chỉ nên được dùng trong các workspace đáng tin cậy sau khi xem trước đầu ra ở chế độ pending.
Skill Workshop là bộ nhớ quy trình cho các skill trong workspace. Nó cho phép một agent chuyển
các quy trình có thể tái sử dụng, chỉnh sửa của người dùng, bản sửa khó đạt được, và các lỗi lặp lại
thành các tệp SKILL.md trong:
<workspace>/skills/<skill-name>/SKILL.mdĐiều này khác với bộ nhớ dài hạn:
- Memory lưu trữ dữ kiện, tùy chọn, thực thể, và ngữ cảnh trước đây.
- Skills lưu trữ các quy trình có thể tái sử dụng mà agent nên làm theo trong các tác vụ tương lai.
- Skill Workshop là cầu nối từ một lượt hữu ích đến một skill bền vững trong workspace với các kiểm tra an toàn và tùy chọn phê duyệt.
Skill Workshop hữu ích khi agent học được một quy trình như:
- cách xác thực tài nguyên GIF động có nguồn từ bên ngoài
- cách thay thế tài nguyên ảnh chụp màn hình và xác minh kích thước
- cách chạy một kịch bản QA riêng của repo
- cách gỡ lỗi một lỗi provider lặp lại
- cách sửa một ghi chú quy trình cục bộ đã lỗi thời
Nó không dành cho:
- dữ kiện như "người dùng thích màu xanh"
- bộ nhớ tự truyện rộng
- lưu trữ transcript thô
- bí mật, thông tin xác thực, hoặc văn bản prompt ẩn
- hướng dẫn dùng một lần sẽ không lặp lại
Trạng thái mặc định
Plugin đi kèm là thử nghiệm và bị tắt theo mặc định trừ khi được
bật rõ ràng trong plugins.entries.skill-workshop.
Manifest của plugin không đặt enabledByDefault: true. Mặc định enabled: true
bên trong schema cấu hình plugin chỉ áp dụng sau khi mục plugin đã
được chọn và tải.
Thử nghiệm nghĩa là:
- plugin được hỗ trợ đủ để kiểm thử opt-in và dogfooding
- lưu trữ đề xuất, ngưỡng reviewer, và heuristic capture có thể phát triển
- phê duyệt pending là chế độ khởi đầu được khuyến nghị
- auto apply dành cho thiết lập cá nhân/workspace đáng tin cậy, không dành cho môi trường chia sẻ hoặc thù địch có nhiều đầu vào
Bật
Cấu hình an toàn tối thiểu:
{ plugins: { entries: { "skill-workshop": { enabled: true, config: { autoCapture: true, approvalPolicy: "pending", reviewMode: "hybrid", }, }, }, },}Với cấu hình này:
- công cụ
skill_workshopkhả dụng - các chỉnh sửa có thể tái sử dụng rõ ràng được xếp hàng thành đề xuất pending
- các lượt reviewer dựa trên ngưỡng có thể đề xuất cập nhật skill
- không tệp skill nào được ghi cho đến khi một đề xuất pending được áp dụng
Chỉ dùng ghi tự động trong các workspace đáng tin cậy:
{ plugins: { entries: { "skill-workshop": { enabled: true, config: { autoCapture: true, approvalPolicy: "auto", reviewMode: "hybrid", }, }, }, },}approvalPolicy: "auto" vẫn dùng cùng scanner và đường dẫn cách ly. Nó
không áp dụng các đề xuất có phát hiện nghiêm trọng.
Cấu hình
| Khóa | Mặc định | Phạm vi / giá trị | Ý nghĩa |
|---|---|---|---|
enabled |
true |
boolean | Bật plugin sau khi mục plugin được tải. |
autoCapture |
true |
boolean | Bật capture/review sau lượt trên các lượt agent thành công. |
approvalPolicy |
"pending" |
"pending", "auto" |
Xếp hàng đề xuất hoặc tự động ghi các đề xuất an toàn. |
reviewMode |
"hybrid" |
"off", "heuristic", "llm", "hybrid" |
Chọn capture chỉnh sửa rõ ràng, reviewer LLM, cả hai, hoặc không cái nào. |
reviewInterval |
15 |
1..200 |
Chạy reviewer sau số lượt thành công này. |
reviewMinToolCalls |
8 |
1..500 |
Chạy reviewer sau số lệnh gọi công cụ đã quan sát này. |
reviewTimeoutMs |
45000 |
5000..180000 |
Thời gian chờ cho lượt reviewer nhúng. |
maxPending |
50 |
1..200 |
Số đề xuất pending/cách ly tối đa được giữ trên mỗi workspace. |
maxSkillBytes |
40000 |
1024..200000 |
Kích thước tối đa của tệp skill/hỗ trợ được tạo. |
Hồ sơ được khuyến nghị:
// Conservative: explicit tool use only, no automatic capture.{ autoCapture: false, approvalPolicy: "pending", reviewMode: "off",}// Review-first: capture automatically, but require approval.{ autoCapture: true, approvalPolicy: "pending", reviewMode: "hybrid",}// Trusted automation: write safe proposals immediately.{ autoCapture: true, approvalPolicy: "auto", reviewMode: "hybrid",}// Low-cost: no reviewer LLM call, only explicit correction phrases.{ autoCapture: true, approvalPolicy: "pending", reviewMode: "heuristic",}Đường dẫn capture
Skill Workshop có ba đường dẫn capture.
Đề xuất công cụ
Mô hình có thể gọi trực tiếp skill_workshop khi thấy một quy trình có thể tái sử dụng
hoặc khi người dùng yêu cầu lưu/cập nhật một skill.
Đây là đường dẫn rõ ràng nhất và hoạt động ngay cả với autoCapture: false.
Capture bằng heuristic
Khi autoCapture được bật và reviewMode là heuristic hoặc hybrid,
plugin quét các lượt thành công để tìm các cụm chỉnh sửa rõ ràng từ người dùng:
next timefrom now onremember tomake sure toalways ... use/check/verify/record/save/preferprefer ... when/for/instead/usewhen asked
Heuristic tạo một đề xuất từ hướng dẫn người dùng mới nhất khớp. Nó dùng gợi ý chủ đề để chọn tên skill cho các quy trình phổ biến:
- tác vụ GIF động ->
animated-gif-workflow - tác vụ ảnh chụp màn hình hoặc tài nguyên ->
screenshot-asset-workflow - tác vụ QA hoặc kịch bản ->
qa-scenario-workflow - tác vụ GitHub PR ->
github-pr-workflow - dự phòng ->
learned-workflows
Capture bằng heuristic được cố ý giữ hẹp. Nó dành cho các chỉnh sửa rõ ràng và ghi chú quy trình có thể lặp lại, không dành cho tóm tắt transcript chung.
Reviewer LLM
Khi autoCapture được bật và reviewMode là llm hoặc hybrid, plugin
chạy một reviewer nhúng gọn nhẹ sau khi đạt ngưỡng.
Reviewer nhận:
- văn bản transcript gần đây, giới hạn ở 12.000 ký tự cuối
- tối đa 12 skill workspace hiện có
- tối đa 2.000 ký tự từ mỗi skill hiện có
- hướng dẫn chỉ JSON
Reviewer không có công cụ:
disableTools: truetoolsAllow: []disableMessageTool: true
Reviewer trả về { "action": "none" } hoặc một đề xuất. Trường action là create, append, hoặc replace - ưu tiên append/replace khi đã có skill liên quan; chỉ dùng create khi không có skill hiện có nào phù hợp.
Ví dụ create:
{ "action": "create", "skillName": "media-asset-qa", "title": "Media Asset QA", "reason": "Reusable animated media acceptance workflow", "description": "Validate externally sourced animated media before product use.", "body": "## Workflow\n\n- Verify true animation.\n- Record attribution.\n- Store a local approved copy.\n- Verify in product UI before final reply."}append thêm section + body. replace thay oldText bằng newText trong skill được đặt tên.
Vòng đời đề xuất
Mỗi cập nhật được tạo trở thành một đề xuất với:
idcreatedAtupdatedAtworkspaceDiragentIdtùy chọnsessionIdtùy chọnskillNametitlereasonsource:tool,agent_end, hoặcreviewerstatuschangescanFindingstùy chọnquarantineReasontùy chọn
Trạng thái đề xuất:
pending- đang chờ phê duyệtapplied- đã ghi vào<workspace>/skillsrejected- bị operator/model từ chốiquarantined- bị chặn bởi các phát hiện nghiêm trọng của scanner
Trạng thái được lưu trữ theo từng không gian làm việc trong thư mục trạng thái Gateway:
<stateDir>/skill-workshop/<workspace-hash>.jsonCác đề xuất đang chờ xử lý và bị cách ly được khử trùng lặp theo tên skill và payload
thay đổi. Kho lưu trữ giữ các đề xuất đang chờ xử lý/bị cách ly mới nhất tối đa
maxPending.
Tham chiếu công cụ
Plugin đăng ký một công cụ agent:
skill_workshopstatus
Đếm đề xuất theo trạng thái cho không gian làm việc đang hoạt động.
{ "action": "status" }Hình dạng kết quả:
{ "workspaceDir": "/path/to/workspace", "pending": 1, "quarantined": 0, "applied": 3, "rejected": 0}list_pending
Liệt kê các đề xuất đang chờ xử lý.
{ "action": "list_pending" }Để liệt kê một trạng thái khác:
{ "action": "list_pending", "status": "applied" }Các giá trị status hợp lệ:
pendingappliedrejectedquarantined
list_quarantine
Liệt kê các đề xuất bị cách ly.
{ "action": "list_quarantine" }Dùng thao tác này khi tính năng ghi nhận tự động dường như không làm gì và nhật ký nhắc đến
skill-workshop: quarantined <skill>.
inspect
Lấy một đề xuất theo id.
{ "action": "inspect", "id": "proposal-id"}suggest
Tạo một đề xuất. Với approvalPolicy: "pending" (mặc định), thao tác này đưa vào hàng đợi thay vì ghi.
{ "action": "suggest", "skillName": "animated-gif-workflow", "title": "Animated GIF Workflow", "reason": "User established reusable GIF validation rules.", "description": "Validate animated GIF assets before using them.", "body": "## Workflow\n\n- Verify the URL resolves to image/gif.\n- Confirm it has multiple frames.\n- Record attribution and license.\n- Avoid hotlinking when a local asset is needed."}Request immediate write in auto mode (apply: true)
{"action": "suggest","apply": true,"skillName": "animated-gif-workflow","description": "Validate animated GIF assets before using them.","body": "## Workflow\n\n- Verify true animation.\n- Record attribution."}Với approvalPolicy: "pending", apply: true vẫn đưa đề xuất vào hàng đợi. Hãy xem xét đề xuất đó, rồi dùng
hành động apply sau khi phê duyệt.
Force pending under auto policy (apply: false)
{"action": "suggest","apply": false,"skillName": "screenshot-asset-workflow","description": "Screenshot replacement workflow.","body": "## Workflow\n\n- Verify dimensions.\n- Optimize the PNG.\n- Run the relevant gate."}Append to a named section
{"action": "suggest","skillName": "qa-scenario-workflow","section": "Workflow","description": "QA scenario workflow.","body": "- For media QA, verify generated assets render and pass final assertions."}Replace exact text
{"action": "suggest","skillName": "github-pr-workflow","oldText": "- Check the PR.","newText": "- Check unresolved review threads, CI status, linked issues, and changed files before deciding."}apply
Áp dụng một đề xuất đang chờ xử lý.
Với approvalPolicy: "pending", hành động này yêu cầu người vận hành phê duyệt trước khi ghi
skill của không gian làm việc.
{ "action": "apply", "id": "proposal-id"}apply từ chối các đề xuất bị cách ly:
quarantined proposal cannot be appliedreject
Đánh dấu một đề xuất là bị từ chối.
{ "action": "reject", "id": "proposal-id"}write_support_file
Ghi một tệp hỗ trợ bên trong thư mục skill hiện có hoặc được đề xuất.
Các thư mục hỗ trợ cấp cao nhất được phép:
references/templates/scripts/assets/
Ví dụ:
{ "action": "write_support_file", "skillName": "release-workflow", "relativePath": "references/checklist.md", "body": "# Release Checklist\n\n- Run release docs.\n- Verify changelog.\n"}Các tệp hỗ trợ có phạm vi theo workspace, được kiểm tra đường dẫn, giới hạn byte bởi
maxSkillBytes, được quét và được ghi theo cách nguyên tử.
Ghi skill
Skill Workshop chỉ ghi bên dưới:
<workspace>/skills/<normalized-skill-name>/Tên skill được chuẩn hóa:
- chuyển thành chữ thường
- các chuỗi không phải
[a-z0-9_-]trở thành- - các ký tự không phải chữ và số ở đầu/cuối bị loại bỏ
- độ dài tối đa là 80 ký tự
- tên cuối cùng phải khớp với
[a-z0-9][a-z0-9_-]{1,79}
Đối với create:
- nếu skill chưa tồn tại, Skill Workshop ghi một
SKILL.mdmới - nếu đã tồn tại, Skill Workshop nối phần body vào
## Workflow
Đối với append:
- nếu skill tồn tại, Skill Workshop nối vào mục được yêu cầu
- nếu skill không tồn tại, Skill Workshop tạo một skill tối thiểu rồi nối vào
Đối với replace:
- skill phải đã tồn tại
oldTextphải hiện diện chính xác- chỉ kết quả khớp chính xác đầu tiên được thay thế
Tất cả thao tác ghi đều nguyên tử và làm mới ngay ảnh chụp Skills trong bộ nhớ, vì vậy skill mới hoặc được cập nhật có thể hiển thị mà không cần khởi động lại Gateway.
Mô hình an toàn
Skill Workshop có bộ quét an toàn trên nội dung SKILL.md được tạo và các tệp hỗ trợ.
Các phát hiện nghiêm trọng sẽ cách ly đề xuất:
| ID quy tắc | Chặn nội dung... |
|---|---|
prompt-injection-ignore-instructions |
bảo agent bỏ qua các chỉ dẫn trước đó/cao hơn |
prompt-injection-system |
tham chiếu prompt hệ thống, thông điệp developer hoặc chỉ dẫn ẩn |
prompt-injection-tool |
khuyến khích vượt quyền/phê duyệt của công cụ |
shell-pipe-to-shell |
bao gồm curl/wget được pipe vào sh, bash hoặc zsh |
secret-exfiltration |
có vẻ gửi dữ liệu env/process env qua mạng |
Các phát hiện cảnh báo được giữ lại nhưng tự chúng không chặn:
| ID quy tắc | Cảnh báo về... |
|---|---|
destructive-delete |
các lệnh kiểu rm -rf phạm vi rộng |
unsafe-permissions |
cách dùng quyền kiểu chmod 777 |
Các đề xuất bị cách ly:
- giữ
scanFindings - giữ
quarantineReason - xuất hiện trong
list_quarantine - không thể được áp dụng qua
apply
Để khôi phục từ một đề xuất bị cách ly, hãy tạo một đề xuất an toàn mới với nội dung không an toàn đã bị loại bỏ. Không chỉnh sửa JSON lưu trữ bằng tay.
Hướng dẫn prompt
Khi được bật, Skill Workshop chèn một mục prompt ngắn cho agent biết
hãy dùng skill_workshop cho bộ nhớ quy trình bền vững.
Hướng dẫn nhấn mạnh:
- quy trình, không phải sự kiện/tùy chọn
- các chỉnh sửa của người dùng
- các quy trình thành công không hiển nhiên
- các lỗi thường gặp lặp lại
- sửa skill cũ/mỏng/sai bằng append/replace
- lưu quy trình có thể tái sử dụng sau các vòng lặp công cụ dài hoặc bản sửa khó
- văn bản skill ngắn gọn theo lối mệnh lệnh
- không dump transcript
Văn bản chế độ ghi thay đổi theo approvalPolicy:
- chế độ pending: xếp hàng gợi ý; dùng
applysau khi có phê duyệt rõ ràng - chế độ auto: áp dụng các cập nhật workspace-skill an toàn trừ khi
apply: falsechuyển sang xếp hàng
Chi phí và hành vi runtime
Thu thập heuristic không gọi model.
Đánh giá LLM dùng một lượt chạy nhúng trên model agent active/default. Cơ chế này dựa trên ngưỡng nên mặc định không chạy ở mọi lượt.
Reviewer:
- dùng cùng ngữ cảnh provider/model đã cấu hình khi có sẵn
- fallback về mặc định agent runtime
- có
reviewTimeoutMs - dùng ngữ cảnh bootstrap nhẹ
- không có công cụ
- không ghi trực tiếp gì
- chỉ có thể phát ra một đề xuất đi qua bộ quét bình thường và đường dẫn phê duyệt/cách ly
Nếu reviewer thất bại, hết thời gian hoặc trả về JSON không hợp lệ, Plugin ghi thông điệp warning/debug và bỏ qua lượt đánh giá đó.
Mẫu vận hành
Dùng Skill Workshop khi người dùng nói:
- "lần sau, hãy làm X"
- "từ giờ trở đi, ưu tiên Y"
- "đảm bảo xác minh Z"
- "lưu điều này thành một workflow"
- "việc này mất một lúc; hãy nhớ quy trình"
- "cập nhật skill cục bộ cho việc này"
Văn bản skill tốt:
## Workflow - Verify the GIF URL resolves to `image/gif`.- Confirm the file has multiple frames.- Record source URL, license, and attribution.- Store a local copy when the asset will ship with the product.- Verify the local asset renders in the target UI before final reply.Văn bản skill kém:
The user asked about a GIF and I searched two websites. Then one was blocked byCloudflare. The final answer said to check attribution.Lý do phiên bản kém không nên được lưu:
- có dạng transcript
- không mang tính mệnh lệnh
- bao gồm chi tiết một lần gây nhiễu
- không cho agent tiếp theo biết phải làm gì
Gỡ lỗi
Kiểm tra Plugin có được tải hay không:
openclaw plugins list --enabledKiểm tra số lượng đề xuất từ ngữ cảnh agent/công cụ:
{ "action": "status" }Kiểm tra các đề xuất đang chờ:
{ "action": "list_pending" }Kiểm tra các đề xuất bị cách ly:
{ "action": "list_quarantine" }Các triệu chứng thường gặp:
| Triệu chứng | Nguyên nhân có khả năng | Kiểm tra |
|---|---|---|
| Công cụ không khả dụng | Mục Plugin chưa được bật | plugins.entries.skill-workshop.enabled và openclaw plugins list |
| Không có đề xuất tự động xuất hiện | autoCapture: false, reviewMode: "off" hoặc chưa đạt ngưỡng |
Cấu hình, trạng thái đề xuất, log Gateway |
| Heuristic không thu thập | Cách diễn đạt của người dùng không khớp các mẫu chỉnh sửa | Dùng rõ ràng skill_workshop.suggest hoặc bật reviewer LLM |
| Reviewer không tạo đề xuất | Reviewer trả về none, JSON không hợp lệ hoặc hết thời gian |
Log Gateway, reviewTimeoutMs, ngưỡng |
| Đề xuất không được áp dụng | approvalPolicy: "pending" |
list_pending, rồi apply |
| Đề xuất biến mất khỏi pending | Đề xuất trùng lặp được dùng lại, cắt tỉa pending tối đa, hoặc đã được áp dụng/từ chối/cách ly | status, list_pending với bộ lọc trạng thái, list_quarantine |
| Tệp skill tồn tại nhưng model bỏ lỡ | Ảnh chụp skill chưa được làm mới hoặc cổng kiểm soát skill loại trừ nó | trạng thái openclaw skills và điều kiện hợp lệ của skill workspace |
Log liên quan:
skill-workshop: queued <skill>skill-workshop: applied <skill>skill-workshop: quarantined <skill>skill-workshop: heuristic capture skipped: ...skill-workshop: reviewer skipped: ...skill-workshop: reviewer found no update
Kịch bản QA
Các kịch bản QA dựa trên repo:
qa/scenarios/plugins/skill-workshop-animated-gif-autocreate.mdqa/scenarios/plugins/skill-workshop-pending-approval.mdqa/scenarios/plugins/skill-workshop-reviewer-autonomous.md
Chạy coverage xác định:
pnpm openclaw qa suite \ --scenario skill-workshop-animated-gif-autocreate \ --scenario skill-workshop-pending-approval \ --concurrency 1Chạy coverage reviewer:
pnpm openclaw qa suite \ --scenario skill-workshop-reviewer-autonomous \ --concurrency 1Kịch bản reviewer được tách riêng có chủ ý vì nó bật
reviewMode: "llm" và thực thi lượt reviewer nhúng.
Khi không nên bật tự động áp dụng
Tránh approvalPolicy: "auto" khi:
- workspace chứa các quy trình nhạy cảm
- agent đang làm việc trên đầu vào không đáng tin cậy
- skills được chia sẻ trên một nhóm rộng
- bạn vẫn đang tinh chỉnh prompt hoặc quy tắc quét
- model thường xuyên xử lý nội dung web/email đối địch
Hãy dùng chế độ pending trước. Chỉ chuyển sang chế độ auto sau khi đánh giá loại skills mà agent đề xuất trong workspace đó.