configure-plugin/skills/configure-repo/SKILL.md
Repo onboarding driver: .claude/ directory, SessionStart hook, install_pkgs.sh. Use when onboarding any repo to Claude Code with the claude-plugins marketplace.
npx skillsauth add laurigates/claude-plugins configure-repoInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
End-to-end driver that brings any repo's Claude Code configuration to a healthy baseline in one command. Produces committed-ready files: .claude/settings.json (permissions + marketplace enrollment), a SessionStart hook, and scripts/install_pkgs.sh.
| Use this skill when... | Use another approach when... |
|------------------------|------------------------------|
| Onboarding a new repo to Claude Code from scratch | Changing a single setting — use /configure:claude-plugins or /configure:web-session directly |
| Updating an existing repo to the latest baseline config | Diagnosing a specific hook or plugin issue — use /health:check directly |
| Checking what would change before committing | Running a health-only audit — use /health:check |
| Setting up a repo for ephemeral web sessions (claude.ai/code) | Managing plugins on an already-configured repo |
Detect current state and project stack:
find .claude -maxdepth 1 -name 'settings.json' -type ffind . -name 'install_pkgs.sh' -path '*/scripts/*'find .github/workflows -maxdepth 1 -name 'claude*.yml'find . -maxdepth 1 \( -name 'package.json' -o -name 'pyproject.toml' -o -name 'Cargo.toml' -o -name 'go.mod' -o -name 'justfile' -o -name 'Justfile' \)find . -maxdepth 2 \( -name 'idf_component.yml' -o -name 'sdkconfig' \)find . -maxdepth 1 -name '.pre-commit-config.yaml'git remote -v| Parameter | Description |
|-----------|-------------|
| --check-only | Report what would change without modifying any files |
| --skip-health | Skip the final /health:check validation step |
| --skip-migrations | Skip migration detection (don't offer mypy→ty etc.) |
Execute this end-to-end repository configuration workflow:
Identify the stack from the context above. Produce a brief summary:
Stack detected:
Language: Python (uv + ruff) | Node/TypeScript | Rust | Go | ESP-IDF | ESPHome | ...
Tools: pre-commit, just, docker, ...
Migrations: mypy→ty candidate | black→ruff-format candidate | flake8→ruff candidate | ESLint→Biome candidate
If --check-only, annotate all subsequent steps as "(would do)" rather than doing them.
Invoke /configure:claude-plugins --fix using the SlashCommand tool.
This step:
permissions.allow (common + stack-aware) to .claude/settings.jsonextraKnownMarketplaces + enabledPlugins to .claude/settings.json (critical for web sessions).github/workflows/claude.yml and claude-code-review.ymlInvoke /configure:web-session --fix using the SlashCommand tool.
This step generates scripts/install_pkgs.sh with idempotent tool installs gated on CLAUDE_CODE_REMOTE=true, and wires the SessionStart hook in .claude/settings.json.
If the project uses language-level deps (Python, Node, Rust, Go), also invoke /hooks:session-start-hook --remote-only using the SlashCommand tool to add dependency installation to the hook script.
Detect these migratable patterns and ask whether to run each migration via AskUserQuestion:
| Pattern detected | Migration to offer | Skill to invoke |
|------------------|--------------------|-----------------|
| .pre-commit-config.yaml contains mirrors-mypy or [tool.mypy] in pyproject.toml | mypy → ty | /migration-patterns:mypy-to-ty |
| .pre-commit-config.yaml contains psf/black | black → ruff-format | /migration-patterns:black-to-ruff-format |
| .pre-commit-config.yaml contains pycqa/flake8 or PyCQA/isort | flake8/isort → ruff | /migration-patterns:flake8-to-ruff |
| .eslintrc* or eslint.config.* present, no biome.json | ESLint → Biome | /migration-patterns:eslint-to-biome |
For each detected pattern, ask: "Found [pattern] — offer to migrate? (y/n)". Only run the migration skill if the user confirms.
Migrations are not part of the happy path. If the user declines all migrations, continue to Step 5.
Invoke /health:check using the SlashCommand tool.
Parse the health check output. If any checks fail:
Run git status to list all created/modified files. Stage the relevant files:
git add .claude/settings.json
git add scripts/install_pkgs.sh # if created
git add .github/workflows/claude.yml # if created
git add .github/workflows/claude-code-review.yml # if created
Print a summary:
configure-repo complete
=======================
Repository: <repo-name>
Files staged:
.claude/settings.json [CREATED | UPDATED]
scripts/install_pkgs.sh [CREATED | UPDATED | SKIPPED]
.github/workflows/claude.yml [CREATED | UPDATED | SKIPPED]
.github/workflows/claude-code-review.yml [CREATED | UPDATED | SKIPPED]
Marketplace enrollment:
.claude/settings.json → extraKnownMarketplaces.claude-plugins ✓
.github/workflows/claude.yml → plugin_marketplaces ✓
Health check: PASS | WARN (<N> warnings) | FAIL (<N> failures)
Next steps:
1. Review the staged diff: git diff --cached
2. Commit: git commit -m "chore(claude): configure repo for Claude Code"
3. Add CLAUDE_CODE_OAUTH_TOKEN to repository secrets
4. Push and test: mention @claude in a PR comment
If --check-only was set, prefix the summary with "DRY RUN — no files modified".
git diff --cached.AskUserQuestion is required for migration offers — this skill must not run on haiku model.extraKnownMarketplaces in .claude/settings.json is the key to surviving ephemeral web sessions.CLAUDE_CODE_REMOTE guard so it is a no-op in local sessions.| Context | Command |
|---------|---------|
| Full setup with health check | /configure:repo |
| Dry-run, no file changes | /configure:repo --check-only |
| Setup without migration prompts | /configure:repo --skip-migrations |
| Quick setup, skip health | /configure:repo --skip-health --skip-migrations |
| Stage and review | git diff --cached |
This skill orchestrates these dependencies. If any dependency's modified: date is newer than this skill's reviewed: date, run scripts/check-driver-freshness.sh and update this skill accordingly.
| Dependency | File |
|------------|------|
| /configure:claude-plugins | configure-plugin/skills/configure-claude-plugins/SKILL.md |
| /configure:web-session | configure-plugin/skills/configure-web-session/SKILL.md |
| /hooks:session-start-hook | hooks-plugin/skills/hooks-session-start-hook/SKILL.md |
| /health:check | health-plugin/skills/health-check/SKILL.md |
| /migration-patterns:mypy-to-ty | migration-patterns-plugin/skills/mypy-to-ty/SKILL.md |
| /migration-patterns:black-to-ruff-format | migration-patterns-plugin/skills/black-to-ruff-format/SKILL.md |
| /migration-patterns:flake8-to-ruff | migration-patterns-plugin/skills/flake8-to-ruff/SKILL.md |
| /migration-patterns:eslint-to-biome | migration-patterns-plugin/skills/eslint-to-biome/SKILL.md |
/configure:claude-plugins — Configure plugins, permissions, and marketplace enrollment/configure:web-session — SessionStart hook for infrastructure tools/health:check — Claude Code configuration health checkscripts/check-driver-freshness.sh — Detect when this driver is out of sync with its dependenciestools
Scaffold a new ComfyUI custom-node repo (pyproject, CI, release-please, vitest+pytest, JS extension skeleton) in the picker/gesture vein. Use when bootstrapping or init-ing a comfyui node pack.
tools
Orchestrate a ComfyUI node pack from idea to registry: scaffold, create + seed the repo, open the gitops adoption PR. Use when releasing or spinning up a new comfyui node pack.
testing
macOS EndpointSecurity/EDR high CPU & battery drain. Use when Kandji ESF / XProtect pegs a core; trace the exec storm via powermetrics + eslogger.
development
odiff pixel-by-pixel image diffing. Use when comparing screenshots, detecting visual regressions, diffing before/after PNGs, asserting golden images.