skill-extractor
Extracts reusable skills from work sessions. Use when: (1) a non-obvious problem was solved worth preserving, (2) a pattern was discovered that would help future sessions, (3) a workaround or debugging technique needs documentation. Manual invocation only via /skill-extractor command - no automatic triggers or hooks.
Best use case
skill-extractor is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Extracts reusable skills from work sessions. Use when: (1) a non-obvious problem was solved worth preserving, (2) a pattern was discovered that would help future sessions, (3) a workaround or debugging technique needs documentation. Manual invocation only via /skill-extractor command - no automatic triggers or hooks.
Teams using skill-extractor should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/skill-extractor/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How skill-extractor Compares
| Feature / Agent | skill-extractor | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Extracts reusable skills from work sessions. Use when: (1) a non-obvious problem was solved worth preserving, (2) a pattern was discovered that would help future sessions, (3) a workaround or debugging technique needs documentation. Manual invocation only via /skill-extractor command - no automatic triggers or hooks.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Skill Extractor Extracts reusable knowledge from work sessions and saves it as a Claude Code skill. ## When to Use - Just solved a non-obvious problem through investigation - Discovered a workaround that required trial-and-error - Found a debugging technique that would help in similar situations - Learned a project-specific pattern worth preserving - Fixed an error where the root cause wasn't immediately apparent ## When NOT to Use - Simple documentation lookups (just bookmark the docs) - Trivial fixes (typos, obvious errors) - One-off project-specific configurations - Knowledge that's already well-documented elsewhere - Unverified solutions (wait until it actually works) ## Finding Extraction Candidates Use these prompts to identify knowledge worth extracting: - "What did I just learn that wasn't obvious before starting?" - "If I faced this exact problem again, what would I wish I knew?" - "What error message or symptom led me here, and what was the actual cause?" - "Is this pattern specific to this project, or would it help in similar projects?" - "What would I tell a colleague who hits this same issue?" If you can't answer at least two of these with something non-trivial, it's probably not worth extracting. ## Command ``` /skill-extractor [--project] [context hint] ``` - Default: saves to `~/.claude/skills/[name]/SKILL.md` - `--project`: saves to `.claude/skills/[name]/SKILL.md` - Context hint helps focus extraction (e.g., `/skill-extractor the cyclic data DoS fix`) ## Extraction Process ### Step 0: Check for Existing Skills Before creating a new skill, search for existing ones that might cover the same ground: ```bash # Check user skills ls ~/.claude/skills/ # Check project skills ls .claude/skills/ # Search by keyword grep -r "keyword" ~/.claude/skills/ .claude/skills/ 2>/dev/null ``` If a related skill exists, consider **updating it** instead of creating a new one. See [skill-lifecycle.md](references/skill-lifecycle.md) for guidance on when to update vs create. ### Step 1: Identify the Learning If `$ARGUMENTS` contains a context hint (e.g., "the cyclic data DoS fix"), use it to focus the extraction on that specific topic. Analyze the conversation to identify: - What problem was solved? - What made the solution non-obvious? - What would someone need to know to solve this faster next time? - What are the exact trigger conditions (error messages, symptoms)? Present a brief summary to the user: ``` I identified this potential skill: **Problem:** [Brief description] **Key insight:** [What made it non-obvious] **Triggers:** [Error messages or symptoms] ``` ### Step 2: Quality Assessment Evaluate the candidate skill against these criteria: | Criterion | Pass? | Evidence | |-----------|-------|----------| | **Reusable** - Helps future tasks, not just this instance | | [Why] | | **Non-trivial** - Required discovery, not docs lookup | | [Why] | | **Verified** - Solution actually worked | | [Evidence] | | **Specific triggers** - Exact error messages or scenarios | | [What they are] | | **Explains WHY** - Trade-offs and judgment, not just steps | | [How] | | **Value-add** - Teaches judgment, not just facts Claude could look up | | [How] | Present assessment to user and ask: "Proceed with extraction? [yes/no]" The user decides whether to proceed regardless of how many criteria pass. Respect their judgment - if they say yes, extract; if no, skip. ### Step 3: Gather Details Ask the user: 1. **Skill name** - Suggest a kebab-case name based on context, let them override 2. **Scope** - User-level (default) or project-level (`--project`) ### Step 4: Optional Research If the topic involves a specific library or framework: - Use web search to find current best practices - Use Context7 MCP (if available) for official documentation - Include relevant sources in the References section Skip research for: - Project-specific internal patterns - Generic programming concepts - Time-sensitive extractions ### Step 5: Generate the Skill Use the template from [skill-template.md](references/skill-template.md). **Quality standards:** Follow [quality-guide.md](references/quality-guide.md) to ensure the skill provides lasting value. Key points: - Behavioral guidance over reference dumps - Explain WHY, not just WHAT - Specific triggers that compete well against other skills ### Step 6: Validate Before Saving Run through the validation checklist in [skill-template.md](references/skill-template.md). If validation fails, fix the issues before saving. ### Step 7: Save the Skill Create the directory and save: - User-level: `~/.claude/skills/[name]/SKILL.md` - Project-level: `.claude/skills/[name]/SKILL.md` Report success: ``` Skill saved to: [path] The skill will be available in future sessions when the context matches: "[first line of description]" ``` ## Memory Consolidation When extracting, consider how the new knowledge relates to existing skills: **Combine or separate?** - **Combine** if the new knowledge is a variation or edge case of an existing skill - **Separate** if it has distinct trigger conditions or solves a fundamentally different problem - When in doubt, start separate - you can always merge later **Update vs create:** - **Update** an existing skill when you've discovered additional edge cases, better solutions, or corrections - **Create** a new skill when the knowledge has different trigger conditions, even if the domain is related **Cross-referencing:** - If skills are related but separate, add a "See also" section linking them - Example: A skill for "debugging connection pool exhaustion" might link to "serverless cold start optimization" ## Skill Lifecycle Skills aren't permanent. See [skill-lifecycle.md](references/skill-lifecycle.md) for guidance on: - Updating skills with new discoveries - Deprecating skills when tools or patterns change - Archiving skills that are no longer relevant ## Rationalizations to Reject If you catch yourself thinking any of these, do NOT extract: - "This might be useful someday" - Only extract verified, reusable knowledge - "Let me just save everything" - Quality over quantity - "The user didn't confirm but it seems valuable" - Always get explicit confirmation - "I'll skip the 'When NOT to Use' section" - It's mandatory for good skills - "The description can be vague" - Specific triggers are essential for discovery ## Example Extraction **Scenario:** User discovered that an AST visitor crashes with RecursionError when analyzing serialized files containing cyclic references (e.g., a list that contains itself). **Identified learning:** - Cyclic data structures create cyclic ASTs - Visitor pattern without cycle tracking causes infinite recursion - Need to track visited nodes or enforce depth limits **Generated skill name:** `cyclic-ast-visitor-hardening` **Key sections:** - When to Use: "RecursionError in AST visitor", "analyzing untrusted serialized input" - When NOT to Use: "Recursion from deeply nested (but acyclic) structures" - Problem: Visitor doesn't track visited nodes, enters infinite loop on cycles - Solution: Add `visited: set` parameter, check before recursing - Verification: Cyclic test case completes without RecursionError
Related Skills
x-research
Searches X/Twitter for real-time perspectives, dev discussions, product feedback, breaking news, and expert opinions using the X API v2. Provides search with engagement sorting, user profiles, thread fetching, watchlists, and result caching. Use when: (1) user says "x research", "search x for", "search twitter for", "what are people saying about", "what's twitter saying", "check x for", "x search", (2) user needs recent X discourse on a topic (library releases, API changes, product launches, industry events), (3) user wants to find what devs/experts/community thinks about a topic. NOT for: posting tweets or account management.
wooyun-legacy
Provides web vulnerability testing methodology distilled from 88,636 real-world cases from the WooYun vulnerability database (2010-2016). Use when performing penetration testing, security audits, code reviews for security flaws, or vulnerability research. Covers SQL injection, XSS, command execution, file upload, path traversal, unauthorized access, information disclosure, and business logic flaws.
security-awareness
Teaches agents to recognize and avoid security threats during normal activity. Covers phishing detection, credential protection, domain verification, and social engineering defense. Use when building or operating agents that access email, credential vaults, web browsers, or sensitive data.
scv-scan
Audits Solidity codebases for smart contract vulnerabilities using a four-phase workflow (cheatsheet loading, codebase sweep, deep validation, reporting) covering 36 vulnerability classes. Use when auditing Solidity contracts for security issues, performing smart contract vulnerability scans, or reviewing Solidity code for common exploit patterns.
react-pdf
Generates PDF documents using the React-PDF library (@react-pdf/renderer) with TypeScript and JSX. Use when creating PDFs, generating reports, invoices, forms, resumes, or any document that needs flexbox layout, SVG graphics, custom fonts, or professional typesetting. Prefer over Python PDF libraries (ReportLab, fpdf2) when layout complexity matters.
planning-with-files
Implements file-based planning for complex multi-step tasks. Creates task_plan.md, findings.md, and progress.md as persistent working memory. Use when starting tasks requiring >5 tool calls, multi-phase projects, research, or any work where losing track of goals and progress would be costly.
openai-yeet
Use only when the user explicitly asks to stage, commit, push, and open a GitHub pull request in one flow using the GitHub CLI (`gh`). Originally from OpenAI's curated skills catalog.
openai-spreadsheet
Use when tasks involve creating, editing, analyzing, or formatting spreadsheets (`.xlsx`, `.csv`, `.tsv`) using Python (`openpyxl`, `pandas`), especially when formulas, references, and formatting need to be preserved and verified. Originally from OpenAI's curated skills catalog.
openai-sentry
Use when the user asks to inspect Sentry issues or events, summarize recent production errors, or pull basic Sentry health data via the Sentry API; perform read-only queries with the bundled script and require `SENTRY_AUTH_TOKEN`. Originally from OpenAI's curated skills catalog.
openai-security-threat-model
Repository-grounded threat modeling that enumerates trust boundaries, assets, attacker capabilities, abuse paths, and mitigations, and writes a concise Markdown threat model. Trigger only when the user explicitly asks to threat model a codebase or path, enumerate threats/abuse paths, or perform AppSec threat modeling. Do not trigger for general architecture summaries, code review, or non-security design work. Originally from OpenAI's curated skills catalog.
openai-security-ownership-map
Analyze git repositories to build a security ownership topology (people-to-file), compute bus factor and sensitive-code ownership, and export CSV/JSON for graph databases and visualization. Trigger only when the user explicitly wants a security-oriented ownership or bus-factor analysis grounded in git history (for example: orphaned sensitive code, security maintainers, CODEOWNERS reality checks for risk, sensitive hotspots, or ownership clusters). Do not trigger for general maintainer lists or non-security ownership questions. Originally from OpenAI's curated skills catalog.
openai-security-best-practices
Perform language and framework specific security best-practice reviews and suggest improvements. Trigger only when the user explicitly requests security best practices guidance, a security review/report, or secure-by-default coding help. Trigger only for supported languages (python, javascript/typescript, go). Do not trigger for general code review, debugging, or non-security tasks. Originally from OpenAI's curated skills catalog.