chore: install openagent opencode
Signed-off-by: Dmytro Stanchiev <git@dmytros.dev>
This commit is contained in:
290
.opencode/skills/context7/library-registry.md
Normal file
290
.opencode/skills/context7/library-registry.md
Normal file
@@ -0,0 +1,290 @@
|
||||
# External Library Registry
|
||||
|
||||
## Purpose
|
||||
|
||||
This file lists external libraries/frameworks that should use **ExternalScout** (via Context7) for live documentation instead of relying on potentially outdated training data.
|
||||
|
||||
## When to Use This
|
||||
|
||||
**ContextScout** checks this list when:
|
||||
1. User asks about a library/framework
|
||||
2. No internal context exists in `.opencode/context/development/frameworks/`
|
||||
3. Query matches a library name below
|
||||
|
||||
**Action**: Recommend **ExternalScout** subagent
|
||||
|
||||
---
|
||||
|
||||
## Supported Libraries
|
||||
|
||||
### Database & ORM
|
||||
|
||||
#### Drizzle ORM
|
||||
- **Aliases**: `drizzle`, `drizzle-orm`, `drizzle orm`
|
||||
- **Docs**: https://orm.drizzle.team/
|
||||
- **Context7**: `use context7 for drizzle`
|
||||
- **Common topics**: schema organization, migrations, relational queries, transactions, TypeScript types
|
||||
|
||||
#### Prisma
|
||||
- **Aliases**: `prisma`
|
||||
- **Docs**: https://www.prisma.io/docs
|
||||
- **Context7**: `use context7 for prisma`
|
||||
- **Common topics**: schema, migrations, client, relations, TypeScript
|
||||
|
||||
---
|
||||
|
||||
### Authentication
|
||||
|
||||
#### Better Auth
|
||||
- **Aliases**: `better-auth`, `better auth`, `betterauth`
|
||||
- **Docs**: https://www.better-auth.com/docs
|
||||
- **Context7**: `use context7 for better-auth`
|
||||
- **Common topics**: Next.js integration, Drizzle adapter, social providers, session management, 2FA
|
||||
|
||||
#### NextAuth.js
|
||||
- **Aliases**: `nextauth`, `next-auth`, `nextauth.js`
|
||||
- **Docs**: https://next-auth.js.org/
|
||||
- **Context7**: `use context7 for nextauth`
|
||||
- **Common topics**: providers, callbacks, sessions, JWT
|
||||
|
||||
#### Clerk
|
||||
- **Aliases**: `clerk`
|
||||
- **Docs**: https://clerk.com/docs
|
||||
- **Context7**: `use context7 for clerk`
|
||||
- **Common topics**: authentication, user management, organizations
|
||||
|
||||
---
|
||||
|
||||
### Frontend Frameworks
|
||||
|
||||
#### Next.js
|
||||
- **Aliases**: `nextjs`, `next.js`, `next`
|
||||
- **Docs**: https://nextjs.org/docs
|
||||
- **Context7**: `use context7 for nextjs`
|
||||
- **Common topics**: App Router, Server Actions, Server Components, routing, middleware, API routes
|
||||
|
||||
#### React
|
||||
- **Aliases**: `react`, `reactjs`, `react.js`
|
||||
- **Docs**: https://react.dev/
|
||||
- **Context7**: `use context7 for react`
|
||||
- **Common topics**: hooks, components, state, effects, context
|
||||
|
||||
#### TanStack Query
|
||||
- **Aliases**: `tanstack query`, `react query`, `@tanstack/react-query`
|
||||
- **Docs**: https://tanstack.com/query/latest
|
||||
- **Context7**: `use context7 for tanstack query`
|
||||
- **Common topics**: useQuery, useMutation, prefetching, caching, Server Components
|
||||
|
||||
#### TanStack Router
|
||||
- **Aliases**: `tanstack router`, `@tanstack/react-router`
|
||||
- **Docs**: https://tanstack.com/router/latest
|
||||
- **Context7**: `use context7 for tanstack router`
|
||||
- **Common topics**: routing, type-safe routes, loaders, navigation
|
||||
|
||||
#### TanStack Start
|
||||
- **Aliases**: `tanstack start`, `@tanstack/start`
|
||||
- **Docs**: https://tanstack.com/start/latest
|
||||
- **Context7**: `use context7 for tanstack start`
|
||||
- **Common topics**: full-stack setup, server functions, file routing
|
||||
|
||||
---
|
||||
|
||||
### Infrastructure & Deployment
|
||||
|
||||
#### Cloudflare Workers
|
||||
- **Aliases**: `cloudflare workers`, `cloudflare`, `workers`, `cf workers`
|
||||
- **Docs**: https://developers.cloudflare.com/workers
|
||||
- **Context7**: `use context7 for cloudflare workers`
|
||||
- **Common topics**: routing, KV storage, Durable Objects, bindings, middleware
|
||||
|
||||
#### AWS Lambda
|
||||
- **Aliases**: `aws lambda`, `lambda`, `aws λ`
|
||||
- **Docs**: https://docs.aws.amazon.com/lambda
|
||||
- **Context7**: `use context7 for aws lambda`
|
||||
- **Common topics**: handlers, layers, environment variables, triggers, TypeScript
|
||||
|
||||
#### Vercel
|
||||
- **Aliases**: `vercel`
|
||||
- **Docs**: https://vercel.com/docs
|
||||
- **Context7**: `use context7 for vercel`
|
||||
- **Common topics**: deployment, environment variables, edge functions, serverless
|
||||
|
||||
---
|
||||
|
||||
### UI Libraries & Styling
|
||||
|
||||
#### Shadcn/ui
|
||||
- **Aliases**: `shadcn`, `shadcn/ui`, `shadcn-ui`
|
||||
- **Docs**: https://ui.shadcn.com/
|
||||
- **Context7**: `use context7 for shadcn`
|
||||
- **Common topics**: components, installation, theming, customization
|
||||
|
||||
#### Radix UI
|
||||
- **Aliases**: `radix`, `radix ui`, `radix-ui`, `@radix-ui`
|
||||
- **Docs**: https://www.radix-ui.com/
|
||||
- **Context7**: `use context7 for radix`
|
||||
- **Common topics**: primitives, accessibility, composition
|
||||
|
||||
#### Tailwind CSS
|
||||
- **Aliases**: `tailwind`, `tailwindcss`, `tailwind css`
|
||||
- **Docs**: https://tailwindcss.com/docs
|
||||
- **Context7**: `use context7 for tailwind`
|
||||
- **Common topics**: configuration, utilities, responsive design, dark mode
|
||||
|
||||
---
|
||||
|
||||
### State Management
|
||||
|
||||
#### Zustand
|
||||
- **Aliases**: `zustand`
|
||||
- **Docs**: https://zustand-demo.pmnd.rs/
|
||||
- **Context7**: `use context7 for zustand`
|
||||
- **Common topics**: store creation, selectors, middleware, TypeScript
|
||||
|
||||
#### Jotai
|
||||
- **Aliases**: `jotai`
|
||||
- **Docs**: https://jotai.org/
|
||||
- **Context7**: `use context7 for jotai`
|
||||
- **Common topics**: atoms, async atoms, utilities
|
||||
|
||||
---
|
||||
|
||||
### Validation & Forms
|
||||
|
||||
#### Zod
|
||||
- **Aliases**: `zod`
|
||||
- **Docs**: https://zod.dev/
|
||||
- **Context7**: `use context7 for zod`
|
||||
- **Common topics**: schema validation, TypeScript inference, parsing, refinements
|
||||
|
||||
#### React Hook Form
|
||||
- **Aliases**: `react hook form`, `react-hook-form`, `rhf`
|
||||
- **Docs**: https://react-hook-form.com/
|
||||
- **Context7**: `use context7 for react hook form`
|
||||
- **Common topics**: register, validation, errors, TypeScript
|
||||
|
||||
---
|
||||
|
||||
### Testing
|
||||
|
||||
#### Vitest
|
||||
- **Aliases**: `vitest`
|
||||
- **Docs**: https://vitest.dev/
|
||||
- **Context7**: `use context7 for vitest`
|
||||
- **Common topics**: configuration, testing, mocking, coverage
|
||||
|
||||
#### Playwright
|
||||
- **Aliases**: `playwright`
|
||||
- **Docs**: https://playwright.dev/
|
||||
- **Context7**: `use context7 for playwright`
|
||||
- **Common topics**: browser automation, testing, selectors, assertions
|
||||
|
||||
---
|
||||
|
||||
## Detection Patterns
|
||||
|
||||
ContextScout and ExternalScout should match queries containing:
|
||||
- Library name (case-insensitive)
|
||||
- Common variations (e.g., "next.js" vs "nextjs")
|
||||
- Package names (e.g., "@tanstack/react-query")
|
||||
|
||||
**Examples**:
|
||||
- "How do I use **Drizzle** with PostgreSQL?" → Match: Drizzle ORM
|
||||
- "Show me **Next.js** App Router setup" → Match: Next.js
|
||||
- "**TanStack Query** with Server Components" → Match: TanStack Query
|
||||
- "**Better Auth** integration" → Match: Better Auth
|
||||
|
||||
---
|
||||
|
||||
## Query Optimization Patterns
|
||||
|
||||
### Drizzle ORM
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| Setup/Installation | `PostgreSQL+setup+configuration+TypeScript+installation` |
|
||||
| Modular schemas | `modular+schema+organization+domain+driven+design` |
|
||||
| Relations | `relational+queries+one+to+many+joins+with+relations` |
|
||||
| Migrations | `drizzle-kit+migrations+generate+push+PostgreSQL` |
|
||||
| Transactions | `database+transactions+patterns+TypeScript` |
|
||||
| Type safety | `TypeScript+type+inference+schema+types+inferInsert` |
|
||||
|
||||
### Better Auth
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| Setup | `setup+configuration+Next.js+TypeScript+installation` |
|
||||
| Next.js integration | `Next.js+App+Router+integration+setup+configuration` |
|
||||
| Drizzle adapter | `Drizzle+adapter+PostgreSQL+schema+generation+configuration` |
|
||||
| Social providers | `social+providers+OAuth+GitHub+Google+setup` |
|
||||
| Email/password | `email+password+authentication+signup+signin` |
|
||||
| Session management | `session+management+cookies+JWT+middleware` |
|
||||
|
||||
### Next.js
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| App Router | `App+Router+file+conventions+layouts+pages+routing` |
|
||||
| Server Actions | `Server+Actions+form+mutations+revalidation+TypeScript` |
|
||||
| Server Components | `React+Server+Components+async+data+fetching+patterns` |
|
||||
| Dynamic routes | `dynamic+routes+params+TypeScript+generateStaticParams` |
|
||||
| Middleware | `middleware+authentication+redirects+headers+cookies` |
|
||||
| API routes | `API+routes+route+handlers+TypeScript+POST+GET` |
|
||||
|
||||
### TanStack Query
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| Setup | `setup+QueryClient+provider+Next.js+TypeScript` |
|
||||
| Data fetching | `useQuery+data+fetching+TypeScript+patterns+async` |
|
||||
| Mutations | `useMutation+optimistic+updates+invalidation+TypeScript` |
|
||||
| Prefetching | `prefetchQuery+Server+Components+hydration+Next.js` |
|
||||
| Caching | `cache+configuration+staleTime+gcTime+invalidation` |
|
||||
|
||||
### Cloudflare Workers
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| Setup | `getting+started+setup+TypeScript+wrangler+configuration` |
|
||||
| Routing | `routing+itty-router+hono+request+handling` |
|
||||
| KV storage | `KV+storage+key+value+bindings+TypeScript` |
|
||||
| Durable Objects | `Durable+Objects+state+WebSockets+coordination` |
|
||||
|
||||
### AWS Lambda
|
||||
|
||||
| User Intent | Optimized Query |
|
||||
|-------------|-----------------|
|
||||
| Setup | `getting+started+setup+TypeScript+handler+configuration` |
|
||||
| Handlers | `handler+function+event+context+TypeScript+patterns` |
|
||||
| Layers | `layers+dependencies+shared+code+deployment` |
|
||||
| Environment variables | `environment+variables+secrets+configuration+SSM` |
|
||||
|
||||
---
|
||||
|
||||
## Adding New Libraries
|
||||
|
||||
To add a new library:
|
||||
1. Add entry under appropriate category
|
||||
2. Include: Name, aliases, docs link, Context7 command, common topics
|
||||
3. (Optional) Add query optimization patterns
|
||||
4. Update ExternalScout if needed (usually automatic)
|
||||
|
||||
**Template**:
|
||||
```markdown
|
||||
#### Library Name
|
||||
- **Aliases**: `alias1`, `alias2`, `package-name`
|
||||
- **Docs**: https://example.com/docs
|
||||
- **Context7**: `use context7 for library-name`
|
||||
- **Common topics**: topic1, topic2, topic3
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## Usage by ExternalScout
|
||||
|
||||
ExternalScout uses this file to:
|
||||
1. **Detect** which library the user is asking about
|
||||
2. **Load** query optimization patterns for that library
|
||||
3. **Build** optimized Context7 queries
|
||||
4. **Fetch** live documentation
|
||||
5. **Return** filtered, relevant results
|
||||
Reference in New Issue
Block a user