Skip to content

mavam/skeel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🛠️ skeel

Declarative agent skill management.

skeel reads a desired-state manifest and applies it through gh skill.

✨ Features

  • Desired state: declare skill sources in one YAML file
  • Inventory, dry run, and diff: list manifest skill status, preview commands, and compare managed skills against what's installed locally
  • Add, apply, and update: edit desired state, reconcile installed skills with live progress, and update declared installed skills
  • Target flags: choose local or global scope from the CLI
  • JSON output: pass --json for one machine-readable object on stdout

🚀 Quickstart

Run skeel directly with uvx:

uvx skeel

⚙️ Manifest

Default path: .agents/skills.yaml in project scope, ~/.agents/skills.yaml in user scope.

sources:
  anthropics/skills:
    - skill-creator
  mavam/quarto-brief:
  openclaw/gogcli:
    - gog
  tenzir/skills:
    pin: main
    skills:
      - tenzir-ecs

An empty value installs all skills from a source. A list is the common form for selected skills. Use a nested mapping only for source options, such as pin or custom install commands.

By default, skeel installs gh skill skills into .agents/skills in the current working directory. Use --scope user for global installs into ~/.agents/skills:

uvx skeel --scope user apply

Use --manifest (-m) for a non-default desired-state manifest:

uvx skeel --manifest ./skills.yaml apply --dry-run

Scope selects the base directory for the implicit manifest and managed skill directory: project scope uses the current working directory and user scope uses $HOME. If the implicit manifest does not exist, apply, diff, list, and update are no-ops; add creates the manifest. Use --manifest or SKEEL_MANIFEST to use a manifest from another path.

✨ Commands

By default, list, diff, apply, and update read both .agents/skills.yaml in the current working directory and ~/.agents/skills.yaml. Use --scope project or --scope user to operate on one scope. Human output uses the first column for the marker, the second column for the skill name, the third column for the source, and a muted suffix for versions or paths. User-scope skills include a muted suffix.

For scripts, pass --json to add, apply, diff, list, path, remove, or update to emit one machine-readable object on stdout.

list

Show manifest skills and whether they are installed. Sources declared without a skill list expand to the installed skills from that source instead of showing *.

uvx skeel list
✔︎ skill-creator anthropics/skills main@3cf9a8d ⌂
✔︎ wrangler cloudflare/skills main@45cc198 ⌂
✔︎ quarto-brief mavam/quarto-brief main@e89c555 ⌂
✔︎ tenzir-docs tenzir/skills main@a5d04ab
✘ gog openclaw/gogcli

diff

Compare desired state with installed skills. + rows would be installed by apply; - rows would be removed.

uvx skeel diff
+ wrangler cloudflare/skills
+ vectorize cloudflare/skills
- obsolete-skill installed
- old-experiment installed

apply

Reconcile installed skills with the manifest. Missing skills are installed and extra skills are removed. Use --reinstall to run every manifest installer without diffing first, or apply <source> [skill] to target one source. A selector that does not match the manifest exits with an error.

uvx skeel apply --dry-run
↳ gh skill install cloudflare/skills wrangler --allow-hidden-dirs --dir .agents/skills --force
↳ gh skill install cloudflare/skills vectorize --allow-hidden-dirs --dir .agents/skills --force
↳ rm -rf .agents/skills/obsolete-skill
uvx skeel apply
+ wrangler cloudflare/skills
+ vectorize cloudflare/skills
- obsolete-skill

update

Update installed skills that are represented by the manifest. Each installed skill is checked independently, and remote update checks run in parallel. Pass a source, or a source and skill, to update only that manifest selection. A selector that does not match the manifest exits with an error.

uvx skeel update
uvx skeel update tenzir/skills
uvx skeel update tenzir/skills tenzir-docs
✔︎ teach mattpocock/skills main@975430f
✔︎ tenzir-docs tenzir/skills main@f3842c1
✔︎ clacks downstairs-dawgs/clacks
✘ broken-skill broken/source

Pinned GitHub entries are updated by resolving the configured pin and refreshing installed files when the source changes. Skills installed by gh skill include provenance in SKILL.md frontmatter, so future updates can track them directly.

add

Upsert a source or source/skill entry into the manifest. Omit the skill to select all skills from the source. Pass --apply to reconcile immediately.

uvx skeel add tenzir/skills tenzir-docs@main
✔︎ tenzir-docs tenzir/skills .agents/skills.yaml
uvx skeel add mavam/quarto-brief --dry-run
↳ mavam/quarto-brief .agents/skills.yaml

remove

Remove an unambiguous skill name from the manifest. Pass --apply to reconcile immediately. A selector that does not match the manifest exits with an error.

add and remove are intentionally asymmetric: adding starts from a source because skeel needs to know where to install from, while removing starts from a skill because that is the common user intent. Use --source only to disambiguate or remove a whole source.

uvx skeel remove tenzir-docs
✔︎ tenzir-docs tenzir/skills .agents/skills.yaml

When multiple sources declare the same skill name, disambiguate with --source:

uvx skeel remove tenzir-docs --source tenzir/skills

Omit the skill to remove the whole source selected by --source:

uvx skeel remove --source mavam/quarto-brief --dry-run
↳ mavam/quarto-brief .agents/skills.yaml

path

Print the manifest path that skeel would use for the selected scope.

uvx skeel path
/Users/alice/project/.agents/skills.yaml

🧰 GitHub Skill Policy

When applying, skeel delegates placement to gh skill with:

gh skill install <repo> <skill> --dir .agents/skills --force

The target directory is derived from scope: project scope uses the current working directory and user scope uses $HOME. A bare GitHub source installs all skills from that repository:

sources:
  mavam/quarto-brief:

which runs:

gh skill install mavam/quarto-brief --all --dir .agents/skills --force

For installers that are not backed by gh skill, provide source-level install commands under the source key. Skeel runs those commands as the complete install command set:

sources:
  slack-clacks/clacks:
    skills:
      - clacks
    install:
      - uvx --from slack-clacks clacks skill --mode universal --force

To add a GitHub source from the CLI, use the same positional shape as gh skill install:

uvx skeel add tenzir/skills tenzir-docs@main
uvx skeel remove tenzir/skills tenzir-docs
uvx skeel add mavam/quarto-brief --apply

📄 License

MIT

About

Declarative agent skill management for GitOps workflows.

Topics

Resources

License

Stars

Watchers

Forks

Contributors

Languages