skills/api-architect/SKILL.md
Expert API designer for REST, GraphQL, gRPC architectures. Activate on: API design, REST API, GraphQL schema, gRPC service, OpenAPI, Swagger, API versioning, endpoint design, rate limiting, OAuth flow. NOT for: database schema (use data-pipeline-engineer), frontend consumption (use web-design-expert), deployment (use devops-automator).
npx skillsauth add CenredJun/openclaw-claudecode-setup-kit api-architectInstall 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.
Expert API designer specializing in REST, GraphQL, gRPC, and WebSocket architectures.
Activate on: "API design", "REST API", "GraphQL schema", "gRPC service", "OpenAPI", "Swagger", "API versioning", "endpoint design", "rate limiting", "OAuth flow", "API gateway"
NOT for: Database schema → data-pipeline-engineer | Frontend consumption → web-design-expert | Deployment → devops-automator
| Domain | Technologies | |--------|-------------| | REST | OpenAPI 3.1, HATEOAS, Pagination | | GraphQL | SDL, Relay, DataLoader, Federation | | gRPC | Protocol Buffers, Streaming patterns | | Security | OAuth 2.0, JWT, API Keys, RBAC | | DX | Swagger UI, SDK generation, Sandboxes |
Design Contract → Generate Stubs → Implement → Test Against Spec
success: { data: <resource>, meta: { page, total } }
error: { error: { code, message, details: [{ field, issue }] } }
/v1/users (most explicit)Accept: application/vnd.api+json;version=1/users?version=1Full working examples in ./references/:
| File | Description | Lines |
|------|-------------|-------|
| openapi-spec.yaml | Complete OpenAPI 3.1 spec | 162 |
| graphql-schema.graphql | GraphQL with Relay connections | 111 |
| grpc-service.proto | Protocol Buffer, all streaming | 95 |
| rate-limiting.yaml | Tier-based rate limit config | 85 |
| api-security.yaml | Auth, CORS, security headers | 130 |
Symptom: /getUsers, /createOrder, /deleteProduct
Fix: Use nouns (/users, /orders), let HTTP methods convey action
Symptom: {data: [...]} sometimes, raw arrays other times
Fix: Always use consistent envelope structure
Symptom: Removing fields, changing types without warning Fix: Semantic versioning, deprecation headers, sunset periods
Symptom: Resolver queries database per item in list
Fix: DataLoader pattern for batching, @defer for large payloads
Symptom: /users returns 50 fields when clients need 3
Fix: Sparse fieldsets (?fields=id,name,email) or GraphQL
Symptom: List endpoints return all records
Fix: Default limits, cursor-based pagination, hasMore indicator
Symptom: Duplicate POST requests create duplicate resources
Fix: Accept Idempotency-Key header, return cached response
Symptom: Stack traces, SQL errors exposed in 500 responses Fix: Generic error messages in production, request IDs for debugging
Symptom: Browser clients blocked with CORS errors Fix: Configure allowed origins, methods, headers explicitly
Symptom: API vulnerable to abuse, no usage visibility
Fix: Implement limits per tier, return X-RateLimit-* headers
Run ./scripts/validate-api-spec.sh to check:
[ ] All endpoints use nouns, not verbs
[ ] Consistent response envelope structure
[ ] Error responses include codes and actionable messages
[ ] Pagination on all list endpoints
[ ] Authentication/authorization documented
[ ] Rate limit headers defined
[ ] Versioning strategy documented
[ ] CORS configured for known origins
[ ] Idempotency keys for mutating operations
[ ] OpenAPI spec validates without errors
[ ] SDK generation tested
[ ] Examples for all request/response types
Read, Write, Edit - File operations for specsBash(npm:*, npx:*) - OpenAPI linting, code generationBash(openapi-generator:*) - SDK generationdevelopment
Execute autonomous multi-step research using Google Gemini Deep Research Agent. Use for: market analysis, competitive landscaping, literature reviews, technical research, due diligence. Takes 2-10 ...
testing
Tracks cumulative LLM costs across DAG execution and makes real-time decisions to stay within budget. Downgrades models, skips optional nodes, or stops early when cost exceeds thresholds. Use when managing execution budgets, analyzing cost breakdowns, or optimizing model routing for cost. Activate on "cost budget", "too expensive", "reduce cost", "cost optimization", "model downgrade", "budget exceeded". NOT for LLM model selection logic (use llm-router), pricing comparisons across providers, or billing/invoicing.
development
When the user wants to write, rewrite, or improve marketing copy for any page — including homepage, landing pages, pricing pages, feature pages, about pages, or product pages. Also use when the user says "write copy for," "improve this copy," "rewrite this page," "marketing copy," "headline help," "CTA copy," "value proposition," "tagline," "subheadline," "hero section copy," "above the fold," "this copy is weak," "make this more compelling," or "help me describe my product." Use this whenever someone is working on website text that needs to persuade or convert. For email copy, see email-sequence. For popup copy, see popup-cro. For editing existing copy, see copy-editing.
testing
Elite content marketing strategist specializing in AI-powered content creation, omnichannel distribution, SEO optimization, and data-driven performance marketing.