home / skills / upstash / context7 / find-docs

find-docs skill

/skills/find-docs

This skill retrieves up-to-date documentation and code examples for libraries or tools to ensure accurate, referenceable answers.

npx playbooks add skill upstash/context7 --skill find-docs

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
6.2 KB
---
name: find-docs
description: >-
  Retrieves authoritative, up-to-date technical documentation, API references,
  configuration details, and code examples for any developer technology.

  Use this skill whenever answering technical questions or writing code that
  interacts with external technologies. This includes libraries, frameworks,
  programming languages, SDKs, APIs, CLI tools, cloud services, infrastructure
  tools, and developer platforms.

  Common scenarios:
  - looking up API endpoints, classes, functions, or method parameters
  - checking configuration options or CLI commands
  - answering "how do I" technical questions
  - generating code that uses a specific library or service
  - debugging issues related to frameworks, SDKs, or APIs
  - retrieving setup instructions, examples, or migration guides
  - verifying version-specific behavior or breaking changes

  Prefer this skill whenever documentation accuracy matters or when model
  knowledge may be outdated.
---

# Documentation Lookup

Retrieve current documentation and code examples for any library using the Context7 CLI.

Make sure the CLI is up to date before running commands:

```bash
npm install -g ctx7@latest
```

Or run directly without installing:

```bash
npx ctx7@latest <command>
```

## Workflow

Two-step process: resolve the library name to an ID, then query docs with that ID.

```bash
# Step 1: Resolve library ID
ctx7 library <name> <query>

# Step 2: Query documentation
ctx7 docs <libraryId> <query>
```

You MUST call `ctx7 library` first to obtain a valid library ID UNLESS the user explicitly provides a library ID in the format `/org/project` or `/org/project/version`.

IMPORTANT: Do not run these commands more than 3 times per question. If you cannot find what you need after 3 attempts, use the best result you have.

## Step 1: Resolve a Library

Resolves a package/product name to a Context7-compatible library ID and returns matching libraries.

```bash
ctx7 library react "How to clean up useEffect with async operations"
ctx7 library nextjs "How to set up app router with middleware"
ctx7 library prisma "How to define one-to-many relations with cascade delete"
```

Always pass a `query` argument — it is required and directly affects result ranking. Use the user's intent to form the query, which helps disambiguate when multiple libraries share a similar name. Do not include any sensitive or confidential information such as API keys, passwords, credentials, personal data, or proprietary code in your query.

### Result fields

Each result includes:

- **Library ID** — Context7-compatible identifier (format: `/org/project`)
- **Name** — Library or package name
- **Description** — Short summary
- **Code Snippets** — Number of available code examples
- **Source Reputation** — Authority indicator (High, Medium, Low, or Unknown)
- **Benchmark Score** — Quality indicator (100 is the highest score)
- **Versions** — List of versions if available. Use one of those versions if the user provides a version in their query. The format is `/org/project/version`.

### Selection process

1. Analyze the query to understand what library/package the user is looking for
2. Select the most relevant match based on:
   - Name similarity to the query (exact matches prioritized)
   - Description relevance to the query's intent
   - Documentation coverage (prioritize libraries with higher Code Snippet counts)
   - Source reputation (consider libraries with High or Medium reputation more authoritative)
   - Benchmark score (higher is better, 100 is the maximum)
3. If multiple good matches exist, acknowledge this but proceed with the most relevant one
4. If no good matches exist, clearly state this and suggest query refinements
5. For ambiguous queries, request clarification before proceeding with a best-guess match

### Version-specific IDs

If the user mentions a specific version, use a version-specific library ID:

```bash
# General (latest indexed)
ctx7 docs /vercel/next.js "How to set up app router"

# Version-specific
ctx7 docs /vercel/next.js/v14.3.0-canary.87 "How to set up app router"
```

The available versions are listed in the `ctx7 library` output. Use the closest match to what the user specified.

## Step 2: Query Documentation

Retrieves up-to-date documentation and code examples for the resolved library.

```bash
ctx7 docs /facebook/react "How to clean up useEffect with async operations"
ctx7 docs /vercel/next.js "How to add authentication middleware to app router"
ctx7 docs /prisma/prisma "How to define one-to-many relations with cascade delete"
```

### Writing good queries

The query directly affects the quality of results. Be specific and include relevant details. Do not include any sensitive or confidential information such as API keys, passwords, credentials, personal data, or proprietary code in your query.

| Quality | Example |
|---------|---------|
| Good | `"How to set up authentication with JWT in Express.js"` |
| Good | `"React useEffect cleanup function with async operations"` |
| Bad | `"auth"` |
| Bad | `"hooks"` |

Use the user's full question as the query when possible, vague one-word queries return generic results.

The output contains two types of content: **code snippets** (titled, with language-tagged blocks) and **info snippets** (prose explanations with breadcrumb context).

## Authentication

Works without authentication. For higher rate limits:

```bash
# Option A: environment variable
export CONTEXT7_API_KEY=your_key

# Option B: OAuth login
ctx7 login
```

## Error Handling

If a command fails with a quota error ("Monthly quota reached" or "quota exceeded"):
1. Inform the user their Context7 quota is exhausted
2. Suggest they authenticate for higher limits: `ctx7 login`
3. If they cannot or choose not to authenticate, answer from training knowledge and clearly note it may be outdated

Do not silently fall back to training data — always tell the user why Context7 was not used.

## Common Mistakes

- Library IDs require a `/` prefix — `/facebook/react` not `facebook/react`
- Always run `ctx7 library` first — `ctx7 docs react "hooks"` will fail without a valid ID
- Use descriptive queries, not single words — `"React useEffect cleanup function"` not `"hooks"`
- Do not include sensitive information (API keys, passwords, credentials) in queries

Overview

This skill retrieves authoritative, up-to-date technical documentation, API references, configuration details, and code examples for any developer technology. It uses the Context7 CLI workflow to resolve library identifiers and then fetch precise docs and runnable code snippets. Use it when documentation accuracy matters or when model knowledge may be outdated.

How this skill works

The workflow is two-step: first resolve a package or product name to a Context7 library ID with ctx7 library <name> <query>, then fetch documentation with ctx7 docs <libraryId> <query>. Always call ctx7 library unless the user supplies a valid library ID (/org/project or /org/project/version). The query text directly affects result ranking, so use the user’s full technical question for best results.

When to use it

  • Looking up API endpoints, method signatures, or parameter details
  • Generating code that integrates a specific library, SDK, or cloud service
  • Verifying version-specific behavior, changelogs, or breaking changes
  • Checking CLI commands, configuration options, or deployment steps
  • Debugging framework or SDK issues where authoritative examples are needed

Best practices

  • Always run ctx7 library first unless you already have a valid library ID (/org/project or /org/project/version).
  • Use the user’s full question or a precise, contextual query to improve result relevance (avoid one-word queries).
  • Limit CLI queries to three attempts per user question; if results remain insufficient, use the best result and inform the user.
  • Prefer version-specific library IDs when the user mentions a version; choose the closest available version if exact match is missing.
  • Do not include sensitive data (API keys, passwords, secrets, or proprietary code) in queries.

Example use cases

  • Find React useEffect cleanup examples for async operations and copy-ready code snippets.
  • Resolve /vercel/next.js docs to implement app router middleware with authentication examples.
  • Fetch Prisma schema examples for one-to-many relations with cascade delete and migration notes.
  • Lookup CLI commands and configuration options for a cloud SDK during a deployment guide.
  • Verify breaking changes between two library versions and get migration recommendations.

FAQ

What if ctx7 returns no good matches for my library name?

If no good matches appear, refine the query with more context (framework, org, exact package name, or a short description). If ambiguity remains, I’ll ask clarifying questions before proceeding.

What happens if the Context7 quota is exhausted?

You’ll be informed that the Context7 quota is exhausted and offered steps to authenticate (ctx7 login) for higher limits. If authentication isn’t possible, I will answer from training data and clearly label the response as potentially outdated.