Skip to main content

Agent-agnostic registry for skill discovery and contribution

Project description

I Know Kung Fu — a package manager for Agent Skills

AI Agents' shared knowledge library — maintained by Agents, supervised by Humans.

CI License: MIT Python 3.10+ PyPI


I Know Kung Fu is a package manager for Agent Skills. Any compatible agent can discover, install, and verify skills from one reviewed registry — without coupling to a single host's ecosystem.

  • Publish once, install anywhere. Contributors submit to one registry; agents retrieve through a thin per-host adapter.
  • Content-hash anchored. Every install is verified against the registry manifest; yanked versions are hard-refused.
  • No lock-in. Skills are plain Markdown + JSON directories — no runtime dependencies, no proprietary formats.

The experience we're aiming for is the I Know Kung Fu moment — Neo flatlining a new skill straight into working memory. An agent hits a capability gap mid-task, pulls the exact skill it needs, and keeps going: no context switch, no human in the loop to install it.

Architecture

flowchart LR
    A["Author writes<br/>SKILL.md + meta.json"] -->|kfu submit| CI{"CI review:<br/>validate + scan"}
    CI -->|merge| R[("registry.json<br/>content-hash anchored")]
    R -->|kfu install| AD{"per-host adapter"}
    AD --> H1["Claude Code"]
    AD --> H2["Hermes Agent"]
    AD --> H3["Codex / Cursor / OpenClaw<br/>opencode / pi"]

Names you'll see

Where Name
Brand (docs, marketing) I Know Kung Fu
PyPI package iknowkungfu
CLI command kfu
MCP server binary iknowkungfu-mcp

All four resolve to the same project.


Install

pip install iknowkungfu    # or: uv tool install iknowkungfu

Or, to develop against main:

git clone https://github.com/samuelgudi/iknowkungfu
pip install -e iknowkungfu/

Quickstart

kfu update                          # refresh registry cache
kfu search                          # browse the whole registry
kfu search <query>                  # find skills
kfu install <author>/<skill>        # install for detected host
kfu list                            # show installed skills
kfu verify <author>/<skill>         # check installed skill against registry

For contributors

kfu init <local-dir>     # scaffold meta.json interactively
kfu submit <local-dir>   # validate, sanitize, scan, open PR

Full contribution guidelines, frontmatter contract, and review template are in CONTRIBUTING.md.


How it works

  • Skills live as <author>/<slug>/ directories with SKILL.md (the instructions body) and meta.json (machine metadata). The generated registry.json is the content-hash-anchored manifest that clients query.
  • Per-host adapters translate the registry layout to each agent's convention: claude-code installs to ~/.claude/skills/<author>-<slug>/; hermes installs to ~/.hermes/skills/<category>/<slug>/. Adapters are thin — all logic lives in the registry client.
  • verify computes the local skill tree hash and compares it against the registry manifest. Yanked versions are hard-refused at install time with no override.

MCP server — for AI agents

iknowkungfu-mcp exposes the registry as Model Context Protocol tools so an agent runtime (Claude Code, OpenClaw, Codex, Cursor, etc.) can search and install skills mid-task without leaving the agent loop.

Eight tools: search, get_skill, get_skill_file, install_skill, list_categories, list_tags, list_agents, update_registry. The install_skill tool is the differentiator — no competing skill registry offers cross-host install via MCP.

Register it with Claude Code (recommended — handles the config file for you):

claude mcp add iknowkungfu iknowkungfu-mcp

Or edit ~/.claude.json (user scope) directly:

{
  "mcpServers": {
    "iknowkungfu": { "command": "iknowkungfu-mcp" }
  }
}

For the Hermes Agent, add to ~/.hermes/config.yaml:

mcp_servers:
  iknowkungfu:
    command: iknowkungfu-mcp
    args: []
    env: {}
    enabled: true

Other hosts (Codex, OpenClaw, Cursor, generic MCP clients): see docs/mcp-integration.md.

Then in a session:

> Find a rust serialization skill compatible with claude-code, and install it.

The agent will call search, inspect candidates with get_skill, then install_skill to write the chosen skill into the host's canonical skills directory.

Query language

The search tool (and the CLI's kfu search) accepts a Lucene-style DSL:

rust serialization tag:rust agent:claude-code
"binary parsing" -status:deprecated
(tag:rust OR tag:go) version:>=1.0
NOT requires:env_var:*

Determinism contract: identical (query, registry version) → identical result order. BM25 ranked, deterministically tie-broken, SQLite FTS5 backed.

Full reference: docs/query-language.md. MCP integration per-host: docs/mcp-integration.md.


Project layout

iknowkungfu/
├── registry.json            # generated manifest (never hand-edit)
├── yanks.json               # append-only yank log
├── skills/                  # approved skills (<author>/<slug>/)
├── archive/                 # (on-demand) deprecated skills with superseded_by pointers
├── submitted/               # (on-demand) open contribution PRs
├── scripts/                 # registry tooling (validate, security_scan, generate_manifest)
├── adapters/                # per-host install logic (claude-code, codex, hermes, openclaw, opencode, pi)
├── clients/                 # discovery + contribution clients
└── agent_skills/            # CLI package

The archive/ and submitted/ directories are created on demand by the kfu deprecate and kfu submit verbs; they are not present in a fresh clone.


Documentation


License

MIT


Acknowledgments

The design spec is at v4, incorporating review rounds from Hermes Agent, Gemini, and a real-skill walkthrough that hardened the submission pipeline, yank semantics, and frontmatter contract.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iknowkungfu-0.1.8.tar.gz (122.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

iknowkungfu-0.1.8-py3-none-any.whl (77.5 kB view details)

Uploaded Python 3

File details

Details for the file iknowkungfu-0.1.8.tar.gz.

File metadata

  • Download URL: iknowkungfu-0.1.8.tar.gz
  • Upload date:
  • Size: 122.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for iknowkungfu-0.1.8.tar.gz
Algorithm Hash digest
SHA256 6f39ce06b48557f32b134d5382563103c10837e18e81246d4e75f2098da1e873
MD5 473d28cd8187970c94fa40ac489d87d6
BLAKE2b-256 8be34c76f05182b3f3f0ed881b71e1273eb5f0708ce4e39d21f07e104f7585e2

See more details on using hashes here.

File details

Details for the file iknowkungfu-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: iknowkungfu-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 77.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for iknowkungfu-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 aac9c627058468fef80316782b36fa8a4f00b27ad4ef0fe5a9042b88471ed4d0
MD5 e16c9f8077479ac0ced41cb9029e7b2b
BLAKE2b-256 f7bda3c56ec1472fa3be05a32a9555f6254dfd6fadfa845473e2a4c9311485ea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page