Publishing on ClawHub
先看人话
这页用于补齐 OpenClaw 官方最新文档里的新增内容。先按命令和字段原样理解;如果你只是普通用户,优先看本页的标题、小节和示例命令,不需要一口气读完所有维护者细节。
ClawHub publishing is owner-scoped: every publish targets a publisher, and the server decides whether the signed-in user is allowed to publish there.
Owners
An owner is a ClawHub publisher handle, such as @alice or @openclaw. Personal owners are created for users. Org owners can have multiple members.
When you publish, you either use your personal owner or choose an org owner where you have publisher access.
Skills
Skills are published from a skill folder. The public page is:
https://clawhub.ai/<owner>/<slug>Example:
https://clawhub.ai/alice/review-helperThe publish request includes the selected owner, slug, version, changelog, and files. The server verifies that the actor can publish as that owner before it creates the release.
Plugins
Plugins use npm-style package names. Scoped package names include the owner in the first part of the name:
@owner/package-nameThe scope must match the selected publish owner. If your package is named @openclaw/dronzer, it can only be published as @openclaw. If you publish as @vintageayu, rename the package to @vintageayu/dronzer.
This prevents a package from claiming an org namespace that the publisher does not control.
Release Flow
- The UI, CLI, or GitHub workflow gathers package metadata and files.
- The publish request is sent to ClawHub with the selected owner.
- The server validates owner permissions, package scope, package name, version, file limits, and source metadata.
- ClawHub stores the release and starts automated security checks.
- New releases are hidden from normal install/download surfaces until review and verification finish.
If validation fails, the release is not created.
FAQ
Package scope must match selected owner
If the package scope and selected owner do not match, ClawHub rejects the publish:
Package scope "@openclaw" must match selected owner "@vintageayu".
Publish as "@openclaw" or rename this package to "@vintageayu/dronzer".To fix it, either choose the owner named by the package scope, or rename the package so the scope matches the owner you can publish as.
If the package name already has the right scope but the package is owned by the wrong publisher, transfer ownership instead:
clawhub package transfer @opik/opik-openclaw --to opikUse package transfer only when you have admin access to both the current package owner and the destination publisher. It does not let you publish into a scope you cannot manage.
This protects org namespaces. A package named @openclaw/dronzer claims the @openclaw namespace, so only publishers with access to the @openclaw owner can publish it.
