---
summary: "Hanzo Skills Hub guide: public skills registry + CLI workflows"
read_when:
  - Introducing Hanzo Skills Hub to new users
  - Installing, searching, or publishing skills
  - Explaining Hanzo Skills Hub CLI flags and sync behavior
title: "Hanzo Skills Hub"
---

# Hanzo Skills Hub

Hanzo Skills Hub is the **public skill registry for Hanzo Bot**. It is a free service: all skills are public, open, and visible to everyone for sharing and reuse. A skill is just a folder with a `SKILL.md` file (plus supporting text files). You can browse skills in the web app or use the CLI to search, install, update, and publish skills.

Site: [skills-hub.ai](https://skills-hub.ai)

## What Hanzo Skills Hub is

- A public registry for Hanzo Bot skills.
- A versioned store of skill bundles and metadata.
- A discovery surface for search, tags, and usage signals.

## How it works

1. A user publishes a skill bundle (files + metadata).
2. Hanzo Skills Hub stores the bundle, parses metadata, and assigns a version.
3. The registry indexes the skill for search and discovery.
4. Users browse, download, and install skills in Hanzo Bot.

## What you can do

- Publish new skills and new versions of existing skills.
- Discover skills by name, tags, or search.
- Download skill bundles and inspect their files.
- Report skills that are abusive or unsafe.
- If you are a moderator, hide, unhide, delete, or ban.

## Who this is for (beginner-friendly)

If you want to add new capabilities to your Hanzo Bot agent, Hanzo Skills Hub is the easiest way to find and install skills. You do not need to know how the backend works. You can:

- Search for skills by plain language.
- Install a skill into your workspace.
- Update skills later with one command.
- Back up your own skills by publishing them.

## Quick start (non-technical)

1. Install the CLI (see next section).
2. Search for something you need:
   - `skills-hub search "calendar"`
3. Install a skill:
   - `skills-hub install <skill-slug>`
4. Start a new Hanzo Bot session so it picks up the new skill.

## Install the CLI

Pick one:

```bash
npm i -g skills-hub
```

```bash
pnpm add -g skills-hub
```

## How it fits into Hanzo Bot

By default, the CLI installs skills into `./skills` under your current working directory. If a Hanzo Bot workspace is configured, `skills-hub` falls back to that workspace unless you override `--workdir` (or `SKILLS_HUB_WORKDIR`). Hanzo Bot loads workspace skills from `<workspace>/skills` and will pick them up in the **next** session. If you already use `~/.hanzo/bot/skills` or bundled skills, workspace skills take precedence.

For more detail on how skills are loaded, shared, and gated, see
[Skills](/tools/skills).

## Skill system overview

A skill is a versioned bundle of files that teaches Hanzo Bot how to perform a
specific task. Each publish creates a new version, and the registry keeps a
history of versions so users can audit changes.

A typical skill includes:

- A `SKILL.md` file with the primary description and usage.
- Optional configs, scripts, or supporting files used by the skill.
- Metadata such as tags, summary, and install requirements.

Hanzo Skills Hub uses metadata to power discovery and safely expose skill capabilities.
The registry also tracks usage signals (such as stars and downloads) to improve
ranking and visibility.

## What the service provides (features)

- **Public browsing** of skills and their `SKILL.md` content.
- **Search** powered by embeddings (vector search), not just keywords.
- **Versioning** with semver, changelogs, and tags (including `latest`).
- **Downloads** as a zip per version.
- **Stars and comments** for community feedback.
- **Moderation** hooks for approvals and audits.
- **CLI-friendly API** for automation and scripting.

## Security and moderation

Hanzo Skills Hub is open by default. Anyone can upload skills, but a GitHub account must
be at least one week old to publish. This helps slow down abuse without blocking
legitimate contributors.

Reporting and moderation:

- Any signed in user can report a skill.
- Report reasons are required and recorded.
- Each user can have up to 20 active reports at a time.
- Skills with more than 3 unique reports are auto hidden by default.
- Moderators can view hidden skills, unhide them, delete them, or ban users.
- Abusing the report feature can result in account bans.

Interested in becoming a moderator? Ask in the Hanzo Bot Discord and contact a
moderator or maintainer.

## CLI commands and parameters

Global options (apply to all commands):

- `--workdir <dir>`: Working directory (default: current dir; falls back to Hanzo Bot workspace).
- `--dir <dir>`: Skills directory, relative to workdir (default: `skills`).
- `--site <url>`: Site base URL (browser login).
- `--registry <url>`: Registry API base URL.
- `--no-input`: Disable prompts (non-interactive).
- `-V, --cli-version`: Print CLI version.

Auth:

- `skills-hub login` (browser flow) or `skills-hub login --token <token>`
- `skills-hub logout`
- `skills-hub whoami`

Options:

- `--token <token>`: Paste an API token.
- `--label <label>`: Label stored for browser login tokens (default: `CLI token`).
- `--no-browser`: Do not open a browser (requires `--token`).

Search:

- `skills-hub search "query"`
- `--limit <n>`: Max results.

Install:

- `skills-hub install <slug>`
- `--version <version>`: Install a specific version.
- `--force`: Overwrite if the folder already exists.

Update:

- `skills-hub update <slug>`
- `skills-hub update --all`
- `--version <version>`: Update to a specific version (single slug only).
- `--force`: Overwrite when local files do not match any published version.

List:

- `skills-hub list` (reads `.skills-hub/lock.json`)

Publish:

- `skills-hub publish <path>`
- `--slug <slug>`: Skill slug.
- `--name <name>`: Display name.
- `--version <version>`: Semver version.
- `--changelog <text>`: Changelog text (can be empty).
- `--tags <tags>`: Comma-separated tags (default: `latest`).

Delete/undelete (owner/admin only):

- `skills-hub delete <slug> --yes`
- `skills-hub undelete <slug> --yes`

Sync (scan local skills + publish new/updated):

- `skills-hub sync`
- `--root <dir...>`: Extra scan roots.
- `--all`: Upload everything without prompts.
- `--dry-run`: Show what would be uploaded.
- `--bump <type>`: `patch|minor|major` for updates (default: `patch`).
- `--changelog <text>`: Changelog for non-interactive updates.
- `--tags <tags>`: Comma-separated tags (default: `latest`).
- `--concurrency <n>`: Registry checks (default: 4).

## Common workflows for agents

### Search for skills

```bash
skills-hub search "postgres backups"
```

### Download new skills

```bash
skills-hub install my-skill-pack
```

### Update installed skills

```bash
skills-hub update --all
```

### Back up your skills (publish or sync)

For a single skill folder:

```bash
skills-hub publish ./my-skill --slug my-skill --name "My Skill" --version 1.0.0 --tags latest
```

To scan and back up many skills at once:

```bash
skills-hub sync --all
```

## Advanced details (technical)

### Versioning and tags

- Each publish creates a new **semver** `SkillVersion`.
- Tags (like `latest`) point to a version; moving tags lets you roll back.
- Changelogs are attached per version and can be empty when syncing or publishing updates.

### Local changes vs registry versions

Updates compare the local skill contents to registry versions using a content hash. If local files do not match any published version, the CLI asks before overwriting (or requires `--force` in non-interactive runs).

### Sync scanning and fallback roots

`skills-hub sync` scans your current workdir first. If no skills are found, it falls back to known legacy locations (for example `~/bot/skills` and `~/.hanzo/bot/skills`). This is designed to find older skill installs without extra flags.

### Storage and lockfile

- Installed skills are recorded in `.skills-hub/lock.json` under your workdir.
- Auth tokens are stored in the Hanzo Skills Hub CLI config file (override via `SKILLS_HUB_CONFIG_PATH`).

### Telemetry (install counts)

When you run `skills-hub sync` while logged in, the CLI sends a minimal snapshot to compute install counts. You can disable this entirely:

```bash
export SKILLS_HUB_DISABLE_TELEMETRY=1
```

## Environment variables

- `SKILLS_HUB_SITE`: Override the site URL.
- `SKILLS_HUB_REGISTRY`: Override the registry API URL.
- `SKILLS_HUB_CONFIG_PATH`: Override where the CLI stores the token/config.
- `SKILLS_HUB_WORKDIR`: Override the default workdir.
- `SKILLS_HUB_DISABLE_TELEMETRY=1`: Disable telemetry on `sync`.
