Skip to content

pivoshenko/kasetto

Kasetto logo

CI Release Rust License Stand with Ukraine

Listed on BacklinkLog

A declarative AI agent environment manager, written in Rust.

kasetto sync output

About the name

Name comes from the Japanese word γ‚«γ‚»γƒƒγƒˆ (kasetto) - cassette. Think of Skills, MCPs, commands as cassettes you plug in, swap out, and share across machines.

Why Kasetto

There are good tools in this space already - Vercel Skills installs skills from a curated catalog, and Claude Plugins offer runtime integrations. Both work well for one-off installs, but neither gives you a declarative, version-controlled config.

Kasetto is a community-first project that solves a different problem: declarative, reproducible skill management across machines and agents.

  • Declarative β€” one YAML file, your whole setup: skills, commands, MCPs, and agents. Apply globally or scope to a project; configs compose with extends, so org, team, and project stay in sync.
  • Enterprise & private repositories β€” pull from anywhere: GitHub, GitLab, Bitbucket, Codeberg, Gitea, and self-hosted instances, public or private. Onboard a new engineer with one command; everyone gets the same environment, zero drift.
  • Multi-agent β€” write once, ship everywhere. Claude Code, Cursor, Codex, Windsurf, Copilot, Gemini CLI, and many more β€” one sync keeps them all current.
  • Skills, Commands & MCPs β€” all three asset kinds, one source: skills, commands, and MCPs. Everything is transformed into each agent's native format, and auto-merged. Distribute rules, tools, and prompts as easily as sharing a repository link.
  • Speed β€” instant by design. Built in Rust, it hashes content and diffs a lock file so only what changed gets touched β€” full syncs finish in seconds.
  • Universal β€” one static binary for macOS, Linux, and Windows. Install as kasetto, run as kst. CI-friendly with --json output and real exit codes.

Inspired by cargo and uv β€” the same lock-first, declarative, CLI-only ergonomics, applied to AI agent skills.

Install

Standalone Installer

macOS and Linux:

curl -fsSL kasetto.dev/install | sh

Windows:

powershell -ExecutionPolicy Bypass -c "irm kasetto.dev/install.ps1 | iex"

Homebrew

brew install pivoshenko/tap/kasetto

Scoop (Windows)

scoop bucket add kasetto https://github.com/pivoshenko/scoop-bucket
scoop install kasetto

Cargo

cargo install kasetto

Getting Started

1. Scaffold a config:

kst init            # creates ./kasetto.yaml in the current directory
kst init --global   # or a global one at ~/.config/kasetto/kasetto.yaml

Edit the generated kasetto.yaml β€” pick an agent, add a skills: source, and you're ready to sync. Or let Kasetto edit the config for you:

kst add https://github.com/anthropics/skills              # add every skill in the pack
kst add https://github.com/anthropics/skills@v1.2.0       # `@<ref>` shorthand (cargo/uv-style)
kst add https://github.com/anthropics/skills --skill pptx # or just named ones
kst add https://github.com/example/repo --skill find --mcp github --command review

kst add appends the source (keeping your comments) and syncs it in one step; kst remove <source> reverses it. See cargo/uv-style editing below.

2. Sync skills into your agents:

# uses ./kasetto.yaml in the current directory
kst sync

# or point at a shared team config over HTTPS
kst sync --config https://example.com/team-skills.yaml

Want bare kst sync to always pull from a remote URL? Persist it in ~/.config/kasetto/config.yaml:

source: https://github.com/pivoshenko/pivoshenko.ai/blob/main/kasetto.yaml

After that, kst sync resolves the URL automatically β€” no --config flag needed.

That's it. Kasetto pulls the skills, installs them into the right agent directory, and records exactly what it installed in kasetto.lock. Commit kasetto.yaml and kasetto.lock together (like Cargo.lock or package-lock.json) and every teammate gets identical versions. A plain kst sync honors the lock without re-resolving moving refs; kst sync --update rolls versions forward; kst sync --locked enforces the lock in CI.

See pivoshenko/pivoshenko.ai for a community example pulling skills from multiple packs for Claude Code and OpenCode.

3. See what's installed:

kst list                    # table of installed skills, MCPs, commands
kst list --type skills      # filter to one asset kind
kst doctor                  # version, paths, last sync status

Commands

One-line synopsis below. Full flags and examples in the commands reference.

  • kst init β€” generate a starter kasetto.yaml (local or --global).
  • kst add <source> β€” append a source to the config (comments preserved) and sync it in. Kind-tagged repeatable flags --skill/--mcp/--command name entries (a lone * is a wildcard; no flags β‡’ skills: "*"), so one add can touch several lists. Accepts a cargo/uv-style <source>@<ref> shorthand and deep blob/tree browse URLs β€” the latter decomposed into source + ref/branch + sub-dir (+ skill name for a SKILL.md link); --ref/--branch/--sub-dir override. --dry-run previews the edit; --no-sync edits without installing; --locked keeps the follow-up sync offline; --json for scripting.
  • kst remove <source> (alias rm) β€” drop entries from the config and prune the now-unconfigured assets. Mirrors add: --skill/--mcp/--command (repeatable) subtract named entries (last one drops the whole entry; a lone * drops it outright); no kind flags removes the source from every list. --ref/--branch (or the @<ref> shorthand) disambiguate a repeated URL. --dry-run previews; --no-sync edits only; --locked and --json mirror add.
  • kst lock β€” re-resolve every source and pin it into kasetto.lock without installing; skills become offline-ready for sync --locked, MCP/command revision pins refresh. --check (alias --locked/--frozen) verifies the lock matches the config without writing (CI-friendly); -P/--upgrade-package <name>... re-resolves only the named skills' sources.
  • kst sync β€” read config, install skills + MCPs into agent dirs honoring kasetto.lock; --update rolls pins forward, --locked/--frozen enforce the lock without fetching.
  • kst list β€” print a uv-style table of installed skills, MCPs, and commands from the lock file; --type skills|mcps|commands filters; --json for scripting.
  • kst doctor β€” local diagnostics: version, paths, last sync status, broken skills.
  • kst clean β€” remove tracked skills and MCP configs for the given scope.
  • kst self update β€” fetch latest release, verify SHA256, replace binary in place.
  • kst self uninstall β€” remove installed assets, data, and the binary.
  • kst completions <shell> β€” emit shell completion script (bash/zsh/fish/powershell).

Most commands accept --json, --color <auto|always|never>, -q/--quiet (repeat for stricter silence), and --project | --global. --plain is still accepted as a deprecated alias for --color never.

Configuration

When --config is omitted, Kasetto looks for config in this order:

  1. $KASETTO_CONFIG env var
  2. ./kasetto.yaml
  3. source: key in $XDG_CONFIG_HOME/kasetto/config.yaml
  4. $XDG_CONFIG_HOME/kasetto/kasetto.yaml (or ~/.config/kasetto/kasetto.yaml)

Run kst init to scaffold a local config, or kst init --global for the global one.

# Option A: preset destination by agent (see README for supported agent values)
agent:
  - codex
  - claude-code

# Option B: manual destination (takes precedence if both are set)
# destination: ./.agents/skills

skills:
  # "*" syncs every skill in the source β€” each is a directory with a SKILL.md,
  # discovered in the source root or its skills/ subdirectory
  - source: https://github.com/vercel-labs/next-skills
    # ref: v1.0.0   # pin to a tag or commit; omit to track the default branch
    skills: "*"

  # or list skills by name
  - source: https://github.com/anthropics/skills
    skills:
      - doc-coauthoring
      - frontend-design
      - pptx

  # sub-dir: resolve the named skills under this path, e.g. skills/productivity/grill-me/
  - source: https://github.com/mattpocock/skills
    sub-dir: skills/productivity
    skills:
      - grill-me
      - caveman

  # path: a skill in a non-standard location β†’ <path>/<name>/, here skills/engineering/improve-codebase-architecture/
  - source: https://github.com/mattpocock/skills
    skills:
      - name: improve-codebase-architecture
        path: skills/engineering

commands:
  # names resolve to commands/<name>.md in the source (nested dirs namespace, e.g. git:commit)
  - source: https://github.com/gsd-build/get-shit-done
    commands:
      - gsd:explore
      - gsd:fast

mcps:
  # names resolve to mcps/<name>.json in the source
  - source: https://github.com/pivoshenko/pivoshenko.ai
    branch: main   # track a specific branch (use ref: to pin a tag or commit)
    mcps:
      - github
      - vercel
      - kaggle

Full key reference, merge rules, and extends: inheritance live in the configuration docs.

Supported Agents

Set the agent field and Kasetto figures out where to put things.

Full list of supported agents
Agent Config value Install path
Amp amp ~/.config/agents/skills/
Antigravity antigravity ~/.gemini/antigravity/skills/
Augment augment ~/.augment/skills/
Claude Code claude-code ~/.claude/skills/
Cline cline ~/.agents/skills/
Codex codex ~/.codex/skills/
Continue continue ~/.continue/skills/
Cursor cursor ~/.cursor/skills/
Gemini CLI gemini-cli ~/.gemini/skills/
GitHub Copilot github-copilot ~/.copilot/skills/
Goose goose ~/.config/goose/skills/
Junie junie ~/.junie/skills/
Kiro CLI kiro-cli ~/.kiro/skills/
OpenClaw openclaw ~/.openclaw/skills/
OpenCode opencode ~/.config/opencode/skills/
OpenHands openhands ~/.openhands/skills/
Replit replit ~/.config/agents/skills/
Roo Code roo ~/.roo/skills/
Trae trae ~/.trae/skills/
Warp warp ~/.agents/skills/
Windsurf windsurf ~/.codeium/windsurf/skills/

Don't see your agent? Use the destination field to point at any path.

Private Repositories & Enterprise

Private GitHub, GitLab, Bitbucket, Codeberg, Gitea, and self-hosted instances work via env-var tokens (GITHUB_TOKEN, GITLAB_TOKEN, BITBUCKET_TOKEN, GITEA_TOKEN, etc.) β€” no login command, no credentials file. The same tokens apply to remote --config URLs.

Full host table and auth resolution rules in the authentication docs.

Contributing

See CONTRIBUTING.md for development setup and guidelines.

License

Licensed under either MIT or Apache-2.0, at your option.