npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

selftune

v0.2.32

Published

Skill-level observability and self-improvement for AI agents — monitors skill routing, detects missed triggers, and evolves descriptions automatically

Downloads

632

Readme

selftune

Skill-level observability and self-improvement for AI agents.

CI CodeQL OpenSSF Scorecard npm version License: MIT TypeScript Zero Dependencies Bun

Your agent skills learn how you work. Detect what's broken. Fix it automatically.

Website · Install · Use Cases · How It Works · Commands · Platforms · Docs


selftune is an open-source agent skill observability toolkit that watches how your AI agent uses its skills, detects when skills fail silently, and automatically rewrites skill descriptions to match how you actually talk. Think of it as observability + continuous improvement for your agent's skill routing layer.

Your skills don't understand how you talk. You say "make me a slide deck" and nothing happens — no error, no log, no signal. selftune watches your real sessions, learns how you actually speak, and rewrites skill descriptions to match. Automatically.

Works with Claude Code (primary), Codex, OpenCode, Cline, OpenClaw, and Pi. Zero runtime dependencies. MIT licensed.

Install

npx skills add selftune-dev/selftune

Then tell your agent: "initialize selftune"

Two minutes. No API keys. No external services. No configuration ceremony. Uses your existing agent subscription. You'll see which skills are undertriggering.

CLI only (no skill, just the CLI):

npx selftune@latest doctor

Updating

The skill and CLI ship together as one npm package. To update:

npx skills add selftune-dev/selftune

This reinstalls the latest version of both the skill (SKILL.md, workflows) and the CLI. selftune doctor will warn you when a newer version is available.

If you already have the local dashboard running, rerun:

selftune dashboard

The command now reuses a healthy dashboard already on the target port and automatically restarts an older standalone dashboard instance after upgrades so the new UI is picked up without manual process hunting. Use selftune dashboard --restart to force a restart.

If the browser is still holding an older client after a restart, the dashboard now shows an explicit reload prompt instead of silently staying stale.

Local dashboard development

For contributor HMR, use the repo dev server and open the dashboard port, not the Vite port:

cd oss/selftune
bun run dev

This starts Vite internally and serves the dashboard at http://localhost:7888 through dashboard-server, so API routes and the browser entrypoint stay on one origin.

Before / After

selftune learned that real users say "slides", "deck", "presentation for Monday" — none of which matched the original skill description. It rewrote the description to match how people actually talk. Validated against the eval set. Deployed with a backup. Done.

Built for How You Actually Work

I write and use my own skills — Your skill descriptions don't match how you actually talk. Tell your agent "improve my skills" and selftune learns your language from real sessions, evolves descriptions to match, and validates before deploying. No manual tuning.

I publish skills others install — Your skill works for you, but every user talks differently. selftune gives creators a real before-ship / after-ship loop: test the router before launch, bundle creator-directed contribution, inspect community signal after launch, then turn that signal into proposals and watched improvements.

I manage an agent setup with many skills — You have 15+ skills installed. Some work. Some don't. Some conflict. Tell your agent "how are my skills doing?" and selftune gives you a health dashboard and automatically improves the skills that aren't keeping up.

I use skills for non-coding work — Marketing workflows, research pipelines, compliance checks, slide decks. You say "make me a presentation" and nothing happens. selftune learns that "slides", "deck", and "presentation for Monday" all mean the same skill — and fixes the routing automatically.

Creator Lifecycle

If you publish skills, the loop is:

  1. structure the skill router, workflows, references, and tools clearly
  2. validate the skill package and test the router before launch
  3. deploy only after evals, unit tests, replay validation, and baseline are in place
  4. bundle selftune.contribute.json with selftune creator-contributions enable
  5. review community signal on the Community page after launch
  6. create proposals from contributor aggregate data only when thresholds are met
  7. apply and watch changes through the normal proposal flow

How to Test a Skill

The simplified lifecycle is:

selftune verify --skill-path path/to/SKILL.md
selftune publish --skill-path path/to/SKILL.md
selftune search-run --skill-path path/to/SKILL.md --surface both
selftune improve --skill my-skill --skill-path path/to/SKILL.md --dry-run --validation-mode replay
selftune run --dry-run

What each step gives you:

  • verify runs the draft-package readiness check first, then emits the benchmark-style package report once the draft is ready. If readiness is still incomplete, it surfaces the next missing low-level step instead of guessing.
  • publish delegates to the draft-package publish flow and starts watch by default. Use --no-watch if you want a manual monitoring handoff.
  • search-run evaluates a bounded minibatch of routing/body package variants against the accepted frontier and persists the measured winner plus provenance.
  • search-run is currently an explicit package-improvement surface. run / orchestrate do not auto-select bounded package search yet.
  • improve is the intention-level alias for evolve and evolve body. Use --scope description|routing|body when you already know the right mutation surface.
  • run is the intention-level alias for orchestrate, so you can preview or operate the whole closed loop without remembering the internal command name.

The advanced lifecycle primitives are still available when you need explicit control:

selftune create check --skill-path path/to/SKILL.md
selftune eval generate --skill my-skill
selftune eval unit-test --skill my-skill --generate --skill-path path/to/SKILL.md
selftune create replay --skill-path path/to/SKILL.md --mode package
selftune create baseline --skill-path path/to/SKILL.md --mode package
selftune create report --skill-path path/to/SKILL.md
selftune create publish --skill-path path/to/SKILL.md --watch
selftune evolve --skill my-skill --skill-path path/to/SKILL.md --dry-run --validation-mode replay
selftune grade baseline --skill my-skill --skill-path path/to/SKILL.md
selftune watch --skill my-skill

The local dashboard overview, per-skill report, and selftune status now all read from those artifacts to show whether a skill is blocked on testing, ready to deploy, or already under watch.

How It Works

A continuous feedback loop that makes your skills learn and adapt. Automatically. Your agent runs everything — you just install the skill and talk naturally.

Observe — Seven real-time hooks capture every query, every skill invocation, and every correction signal. Structured telemetry — not raw logs. On Claude Code, hooks install automatically during selftune init. Backfill existing transcripts with selftune ingest claude.

Detect — Finds the gap between how you talk and how your skills are described. You say "make me a slide deck" and your pptx skill stays silent — selftune catches that mismatch. Clusters missed queries by invocation type. Detects correction signals ("why didn't you use X?") and triggers immediate improvement.

Evolve — Generates multiple proposals biased toward different invocation types, validates each against your real eval set with majority voting, runs constitutional checks, then gates with an expensive model before deploying. Not guesswork — evidence. Automatic backup on every deploy.

Watch — After deploying changes, selftune monitors trigger rates, false negatives, and per-invocation-type scores. If anything regresses, it rolls back automatically. No manual monitoring needed.

Automate — Run selftune cron setup to install OS-level scheduling. selftune syncs, grades, evolves, and watches on a schedule — fully autonomous.

FAQ

What is selftune?

selftune is an open-source CLI and agent skill that provides skill-level observability for AI coding agents. It monitors how skills are triggered (or missed), grades execution quality, and automatically evolves skill descriptions so they match how users actually talk. It works locally with zero API keys — using your existing agent subscription for any LLM calls.

How is selftune different from LLM observability tools?

LLM observability tools (Langfuse, LangSmith, Arize) trace what happens inside model calls — token usage, latency, chain failures. selftune operates at a different layer: it monitors whether the right skill was triggered for the right query in the first place. They're complementary, not competitive.

How is this different from agents that "learn"?

Some agents claim self-improvement by saving notes about what worked. That's knowledge persistence — not a closed loop. There's no measurement, no validation, and no way to know if the saved notes are actually correct.

selftune is empirical. It observes real sessions, grades execution quality, detects missed triggers, proposes changes, validates them against eval sets, deploys with automatic backup, monitors for regressions, and rolls back on failure. Twelve interlocking mechanisms — not one background thread writing markdown.

| Approach | Measures quality? | Validates changes? | Detects regressions? | Rolls back? | | ------------------------- | ----------------- | --------------------------- | ---------------------- | ----------- | | Agent saves its own notes | No | No | No | No | | Manual skill rewrites | No | No | No | No | | selftune | 3-tier grading | Eval sets + majority voting | Post-deploy monitoring | Automatic |

Commands

Your agent runs these — you just say what you want ("improve my skills", "show the dashboard").

| Group | Command | What it does | | ---------- | ---------------------------------------------- | ------------------------------------------------------------------------------------------- | | | selftune status | Get a one-line health summary plus compact attention / improving highlights | | | selftune last | Quick insight from the most recent session | | | selftune verify --skill-path <path> | Check draft-package readiness, then emit benchmark-style verification evidence | | | selftune publish --skill-path <path> | Publish a verified draft package and start watch by default | | | selftune search-run --skill-path <path> | Run bounded package search over routing/body variants against the measured frontier | | | selftune improve --skill <name> | Route to the smallest matching evolution surface | | | selftune run | Run the full autonomous loop through the simplified lifecycle alias | | | selftune orchestrate | Advanced alias for run | | | selftune sync | Replay source-truth transcripts/rollouts into SQLite and refresh repair state | | | selftune dashboard | Open the visual skill health dashboard | | | selftune doctor | Health check: logs, hooks, config, permissions | | ingest | selftune ingest claude | Backfill from Claude Code transcripts | | | selftune ingest codex | Import Codex rollout logs (experimental) | | grade | selftune grade --skill <name> | Grade a skill session with evidence | | | selftune grade auto | Auto-grade recent sessions for ungraded skills | | | selftune grade baseline --skill <name> | Measure skill value vs no-skill baseline | | evolve | selftune evolve --skill <name> | Propose, validate, and deploy improved descriptions | | | selftune evolve body --skill <name> | Evolve full skill body or routing table | | | selftune evolve rollback --skill <name> | Rollback a previous evolution | | create | selftune create init --name <name> | Initialize a new draft skill package skeleton | | | selftune create status --skill-path <path> | Show the current draft-package readiness | | | selftune create scaffold --from-workflow 1 | Scaffold a draft skill package from an observed workflow | | | selftune create check --skill-path <path> | Advanced draft-package readiness primitive behind verify | | | selftune create replay --skill-path <path> | Replay-validate the current draft package | | | selftune create baseline --skill-path <path> | Measure draft-package lift vs a no-skill baseline | | | selftune create report --skill-path <path> | Render measured draft-package evidence as a benchmark-style report | | | selftune create publish --skill-path <path> | Advanced publish primitive behind publish | | eval | selftune eval generate --skill <name> | Generate eval sets (--synthetic for cold-start) | | | selftune eval unit-test --skill <name> | Run or generate skill-level unit tests | | | selftune eval composability --skill <name> | Detect conflicts between co-occurring skills | | | selftune eval family-overlap --prefix sc- | Detect sibling overlap and suggest when a skill family should be consolidated | | | selftune eval import | Import external eval corpus from SkillsBench | | hooks | selftune codex install | Install selftune hooks into Codex (--dry-run, --uninstall) | | | selftune opencode install | Install selftune hooks into OpenCode | | | selftune cline install | Install selftune hooks into Cline | | | selftune pi install | Install selftune hooks into Pi | | auto | selftune cron setup | Install OS-level scheduling (cron/launchd/systemd) | | | selftune watch --skill <name> | Monitor after deploy. Auto-rollback on regression. | | other | selftune workflows | Discover and manage multi-skill workflows | | | selftune contributions | Manage creator-directed sharing preferences | | | selftune creator-contributions | Create or remove bundled selftune.contribute.json configs for skill creators | | | selftune contribute | Export an anonymized community contribution bundle | | | selftune recover | Recover SQLite from legacy/exported JSONL during migration or disaster recovery | | | selftune badge --skill <name> | Generate a health badge for your skill's README | | | selftune telemetry | Manage anonymous usage analytics (status, enable, disable) | | | selftune alpha upload | Run a manual SQLite-backed alpha upload cycle and emit a JSON send summary |

Full command reference: selftune --help

Why Not Just Rewrite Skills Manually?

| Approach | Problem | | -------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- | | Rewrite the description yourself | No data on how users actually talk. No validation. No regression detection. | | Add "ALWAYS invoke when..." directives | Brittle. One agent rewrite away from breaking. | | Force-load skills on every prompt | Doesn't fix the description. Expensive band-aid. | | selftune | Learns from real usage, rewrites descriptions to match how you work, validates against eval sets, auto-rollbacks on regressions. |

Comparison with LLM Observability Tools

LLM observability tools trace API calls. Infrastructure tools monitor servers. Neither knows whether the right skill fired for the right person. selftune does — and fixes it automatically.

selftune is complementary to these tools, not competitive. They trace what happens inside the LLM. selftune makes sure the right skill is called in the first place.

| Dimension | selftune | Langfuse | LangSmith | OpenLIT | | ------------ | ------------------------------------------------- | -------------------- | -------------- | -------------- | | Layer | Skill-specific | LLM call | Agent trace | Infrastructure | | Detects | Missed triggers, false negatives, skill conflicts | Token usage, latency | Chain failures | System metrics | | Improves | Descriptions, body, and routing automatically | — | — | — | | Setup | Zero deps, zero API keys | Self-host or cloud | Cloud required | Helm chart | | Price | Free (MIT) | Freemium | Paid | Free | | Unique | Self-improving skills + auto-rollback | Prompt management | Evaluations | Dashboards |

Platforms

| Platform | Support | Session capture | LLM-backed judge / evolve | Optimizer agents | Config location | | --------------- | ------------ | ---------------------------------------------------------------------------------- | ------------------------- | --------------------------------------------- | ------------------------------------------------------- | | Claude Code | Full | Automatic hooks via selftune init + selftune ingest claude | Yes | Native claude --agent | ~/.claude/settings.json | | Codex | Experimental | selftune codex install, selftune ingest codex, or selftune ingest wrap-codex | Yes | Inlined into codex exec | ~/.codex/hooks.json | | OpenCode | Experimental | selftune opencode install + selftune ingest opencode | Yes | Native opencode run --agent | ./opencode.json or ~/.config/opencode/opencode.json | | Cline | Experimental | selftune cline install | No | No | ~/Documents/Cline/Hooks/ | | OpenClaw | Experimental | selftune ingest openclaw + selftune cron setup --platform openclaw | No | No | — | | Pi | Experimental | selftune pi install + selftune ingest pi | Yes | Inlined into pi -p with system-prompt setup | ~/.pi/extensions/selftune/ |

Codex, OpenCode, Claude Code, and Pi can run selftune's LLM-backed judge, eval, and optimizer workflows. Codex and OpenCode also participate in experimental runtime replay validation during selftune evolve, using codex exec --json and opencode run --format json respectively. OpenCode agents are registered in config during selftune opencode install; Codex still inlines bundled agent instructions into the prompt because it has no native --agent flag. OpenCode has weaker hook coverage than Claude Code because it lacks a prompt-submission event and cannot hard-block pre-tool writes. Pi has no native subagent flag, so selftune inlines bundled optimizer instructions into pi -p calls. Cline is telemetry-only today. OpenClaw remains ingest and cron only. All platforms write to the same shared log schema.

Requires Bun or Node.js 18+. No extra API keys.


Website · Docs · Blog · Architecture · Contributing · Security · Sponsor

MIT licensed. Free forever. Hooks for Claude Code, Codex, OpenCode, Cline, and Pi; batch ingest for OpenClaw.

For AI models: llms.txt