paperclip/skills/paperclip-dev/SKILL.md
Devin Foley 91333ec86f
feat: add paperclip-dev skill with optional bundled skill support (#3854)
## Thinking Path

> - Paperclip orchestrates AI agents for zero-human companies
> - Agents working on the Paperclip codebase itself need guidance on dev
workflows: server lifecycle, worktrees, builds, database ops,
diagnostics
> - There was no bundled skill covering these workflows — agents had to
figure it out from scratch each time
> - Additionally, not every skill should be force-installed on every
agent — a dev-focused skill should be opt-in
> - This PR adds a `paperclip-dev` skill with `required: false`
frontmatter so it ships with Paperclip but isn't auto-installed
> - The skill's PR section references canonical files
(`.github/PULL_REQUEST_TEMPLATE.md`, `CONTRIBUTING.md`) instead of
duplicating their content, with gated instructions that force agents to
read those files before creating any PR
> - The benefit is that developers (human or agent) can opt in to
structured dev guidance without polluting the default agent skill set or
creating drift between duplicated docs

## What Changed

- Added `skills/paperclip-dev/SKILL.md` covering server management,
worktree lifecycle, builds, database ops, diagnostics, agent operations,
and common mistakes
- The Pull Requests section uses gated, reference-based instructions —
agents MUST read `.github/PULL_REQUEST_TEMPLATE.md` and
`CONTRIBUTING.md` before running `gh pr create`, with a brief checklist
of required section names (no content duplication)
- Updated `packages/adapter-utils/src/server-utils.ts` to respect
`required: false` frontmatter — optional skills are bundled but not
auto-installed on agents
- Added test in `server/src/__tests__/paperclip-skill-utils.test.ts`
verifying that optional skills are excluded from the default install set

## Verification

```bash
# Run tests
pnpm test

# Manual verification: create a fresh worktree without seeding
npx paperclipai worktree:make test-optional-skill --no-seed
cd ~/paperclip-test-optional-skill
eval "$(npx paperclipai worktree env)"
npx paperclipai run

# Verify paperclip-dev appears in company skill library but is NOT auto-assigned
# Call listPaperclipSkillEntries() — paperclip-dev should show required: false
# Call resolvePaperclipDesiredSkillNames() — paperclip-dev should NOT be in the default set

# Cleanup
npx paperclipai worktree:cleanup test-optional-skill
```

## Risks

- Low risk. The `required` field defaults to `true` when absent, so all
existing skills behave identically. Only the new `paperclip-dev` skill
sets `required: false`.

## Model Used

Claude Opus 4.6 (`claude-opus-4-6`) via Claude Code, with tool use and
extended context.

## Checklist

- [x] I have included a thinking path that traces from project context
to this change
- [x] I have specified the model used (with version and capability
details)
- [x] I have run tests locally and they pass
- [x] I have added or updated tests where applicable
- [ ] If this change affects the UI, I have included before/after
screenshots
- [x] I have updated relevant documentation to reflect my changes
- [x] I have considered and documented any risks above
- [x] I will address all Greptile and reviewer comments before
requesting merge

---------

Co-authored-by: Paperclip <noreply@paperclip.ing>
2026-04-26 11:06:13 -07:00

10 KiB

name required description
paperclip-dev false Develop and operate a local Paperclip instance — start and stop servers, pull updates from master, run builds and tests, manage worktrees, back up databases, and diagnose problems. Use whenever you need to work on the Paperclip codebase itself or keep a running instance healthy.

Paperclip Dev

This skill covers the day-to-day workflows for developing and operating a local Paperclip instance. It assumes you are working inside the Paperclip repo checkout with origin pointing to git@github.com:paperclipai/paperclip.git.

MANDATORY: Before running any CLI command, building, testing, or managing worktrees, you MUST read doc/DEVELOPING.md in the Paperclip repo. It is the canonical reference for all paperclipai CLI commands, their options, build/test workflows, database operations, worktree management, and diagnostics. Do NOT guess at flags or options — read the doc first.

Quick Command Reference

These are the most common commands. For full option tables and details, see doc/DEVELOPING.md.

Task Command
Start server (first time or normal) npx paperclipai run
Dev mode with hot reload pnpm dev
Stop dev server pnpm dev:stop
Build pnpm build
Type-check pnpm typecheck
Run tests pnpm test
Run migrations pnpm db:migrate
Regenerate Drizzle client pnpm db:generate
Back up database npx paperclipai db:backup
Health check npx paperclipai doctor --repair
Print env vars npx paperclipai env
Trigger agent heartbeat npx paperclipai heartbeat run --agent-id <id>
Install agent skills locally npx paperclipai agent local-cli <agent> --company-id <id>

Pulling from Master

git fetch origin && git pull origin master
pnpm install && pnpm build

If schema changes landed, also run pnpm db:generate && pnpm db:migrate.

Worktrees

Paperclip worktrees combine git worktrees with isolated Paperclip instances — each gets its own database, server port, and environment seeded from the primary instance.

MANDATORY: Before creating or managing worktrees, you MUST read the "Worktree-local Instances" and "Worktree CLI Reference" sections in doc/DEVELOPING.md. That is the canonical reference for all worktree commands, their options, seed modes, and environment variables.

When to Use Worktrees

  • Starting a feature branch that needs its own Paperclip environment
  • Running parallel agent work without cross-contaminating the primary instance
  • Testing Paperclip changes in isolation before merging

Command Overview

The CLI has two tiers (see doc/DEVELOPING.md for full option tables):

Command Purpose
worktree:make <name> Create worktree + isolated instance in one step
worktree:list List worktrees and their Paperclip status
worktree:merge-history Preview/import issue history between worktrees
worktree:cleanup <name> Remove worktree, branch, and instance data
worktree init Bootstrap instance inside existing worktree
worktree env Print shell exports for worktree instance
worktree reseed Refresh worktree DB from another instance
worktree repair Fix broken/missing worktree instance metadata

Typical Workflow

# 1. Create a worktree for a feature
npx paperclipai worktree:make my-feature --start-point origin/main

# 2. Move into the worktree (path printed by worktree:make) and source the environment
cd <worktree-path>
eval "$(npx paperclipai worktree env)"

# 3. Start the isolated Paperclip server
npx paperclipai run

# 4. Do your work

# 5. When done, merge history back if needed
npx paperclipai worktree:merge-history --from paperclip-my-feature --to current --apply

# 6. Clean up
npx paperclipai worktree:cleanup my-feature

Pull Requests

MANDATORY PRE-FLIGHT: Before creating ANY pull request, you MUST read the canonical source files listed below. Do NOT run gh pr create until you have read these files and verified your PR body matches every required section.

Step 1 — Read the canonical files

You MUST read all three of these files before creating a PR:

  1. .github/PULL_REQUEST_TEMPLATE.md — the required PR body structure
  2. CONTRIBUTING.md — contribution conventions, PR requirements, and thinking-path examples
  3. .github/workflows/pr.yml — CI checks that gate merge

Step 2 — Validate your PR body against this checklist

After reading the template, verify your --body includes every one of these sections (names must match exactly):

  • ## Thinking Path — blockquote style, 5-8 reasoning steps
  • ## What Changed — bullet list of concrete changes
  • ## Verification — how a reviewer confirms this works
  • ## Risks — what could go wrong
  • ## Model Used — provider, model ID, version, capabilities
  • ## Checklist — copied from the template, items checked off

If any section is missing or empty, do NOT submit the PR. Go back and fill it in.

Step 3 — Create the PR

Only after completing Steps 1 and 2, run gh pr create. Use the template contents as the structure for --body — do not write a freeform summary.

Hard Rules — Do NOT Bypass

These rules exist because agents have caused real damage by improvising around CLI failures. Follow them exactly.

  1. CLI is the only interface to worktrees and databases. All worktree and database operations MUST go through npx paperclipai / pnpm paperclipai commands. You MUST NOT:

    • Run pg_dump, pg_restore, psql, createdb, dropdb, or any raw postgres commands
    • Manually set DATABASE_URL to point a worktree server at another instance's database
    • Run rm -rf on any .paperclip/, .paperclip-worktrees/, or db/ directory
    • Directly manipulate embedded postgres data directories
    • Kill postgres processes by PID
  2. If a CLI command fails, stop and report. Do NOT attempt workarounds. If worktree:make, worktree reseed, worktree init, worktree:cleanup, or any other paperclipai command fails:

    • Report the exact error message in your task comment
    • Set the task to blocked
    • Suggest running npx paperclipai doctor --repair or recreating the worktree from scratch
    • Do NOT try to manually replicate what the CLI does
  3. Never share databases between instances. Each worktree instance gets its own isolated database. Never override DATABASE_URL to point one instance at another's database. This destroys isolation and can corrupt production data.

  4. Starting a dev server in a worktree requires setup first. The correct sequence is:

    # If the worktree already exists but has no running instance:
    cd <worktree-path>
    eval "$(npx paperclipai worktree env)"
    pnpm install && pnpm build
    npx paperclipai run          # or pnpm dev
    
    # If the worktree needs a fresh database:
    npx paperclipai worktree reseed --seed-mode full
    
    # If the worktree is broken beyond repair:
    npx paperclipai worktree:cleanup <name>
    npx paperclipai worktree:make <name> --seed-mode full
    

    If any step fails, follow rule 2 — stop and report.

  5. Seeding is a CLI operation. When asked to seed a worktree database from the main instance, use worktree reseed or recreate with worktree:make --seed-mode full. Read doc/DEVELOPING.md for the full option tables. Never attempt manual database copying.

Persistent Dev Servers (for Manual Testing)

When an agent needs to start a dev server that outlives the current heartbeat — for example, so a human or QA agent can manually test against it — the server process must be launched in a detached session. A process started directly from a heartbeat shell is killed when the heartbeat exits.

Use tmux for persistent servers

# 1. cd into the worktree (or main repo) and source the environment
cd <worktree-path>
eval "$(npx paperclipai worktree env)"   # skip if using the primary instance

# 2. Start the dev server in a named, detached tmux session
tmux new-session -d -s <session-name> 'pnpm dev'

# Example with a descriptive name:
tmux new-session -d -s auth-fix-3102 'pnpm dev'

Managing the session

Task Command
Check if the session is alive tmux has-session -t <session-name> 2>/dev/null && echo running
View server output tmux capture-pane -t <session-name> -p
Kill the session tmux kill-session -t <session-name>
List all tmux sessions tmux list-sessions

Verifying the server is reachable

After launching, confirm the port is listening before reporting success:

# Wait briefly for startup, then verify
sleep 3
curl -sf http://127.0.0.1:<port>/api/health && echo "Server is up"
lsof -nP -iTCP:<port> -sTCP:LISTEN

Key rules

  1. Always use tmux (or equivalent) when a dev server needs to stay running after the heartbeat ends. A server started directly from the agent shell will die when the heartbeat exits, even if it appeared healthy moments before.
  2. Name the session descriptively — include the worktree name and port (e.g., auth-fix-3102).
  3. Verify the server is listening before reporting the URL to anyone.
  4. Do not use nohup or & alone — these are unreliable for agent shells that may have their entire process group killed.
  5. Clean up when done — kill the tmux session when the testing is complete.

Common Mistakes

Mistake Fix
Server won't start Run npx paperclipai doctor --repair to diagnose and auto-fix
Forgetting to source worktree env Run eval "$(npx paperclipai worktree env)" after cd-ing into the worktree
Stale dependencies after pull Run pnpm install && pnpm build after pulling
Schema out of date after pull Run pnpm db:generate && pnpm db:migrate
Reseeding while target DB is running Stop the target server first, or use --allow-live-target
Cleaning up with unmerged commits Merge or push first, or use --force if intentionally discarding
Running agents against wrong instance Verify PAPERCLIP_API_URL points to the correct port
CLI command fails Do NOT work around it — report the error and block (see Hard Rules above)
Agent tries manual postgres operations NEVER do this — all DB ops go through the CLI (see Hard Rules above)
Dev server dies between heartbeats Launch in a detached tmux session — see "Persistent Dev Servers" above