api-design-principles
wshobson/agents
Master REST and GraphQL API design principles to build intuitive, scalable, and maintainable APIs.
What is api-design-principles?
This skill teaches core REST and GraphQL design principles, versioning strategies, and best practices for building developer-friendly APIs. Use it when designing new APIs, reviewing specifications, establishing team standards, or migrating between API paradigms.
- Apply resource-oriented architecture and HTTP method semantics for REST APIs
- Design schema-first GraphQL APIs with queries, mutations, and subscriptions
- Implement API versioning strategies (URL, header, query parameter)
- Establish consistent naming conventions and error response formats
- Apply pagination, rate limiting, and authentication patterns
- Avoid common pitfalls like over-fetching, breaking changes, and tight coupling
How to install api-design-principles
npx skills add https://github.com/wshobson/agents --skill api-design-principlesHow to use api-design-principles
- 1.Review the core concepts section to understand REST resource-oriented architecture and GraphQL schema-first design
- 2.Choose your API paradigm (REST or GraphQL) and study the relevant best practices
- 3.Apply consistent naming conventions and HTTP semantics to your API design
- 4.Plan your versioning strategy before implementation
- 5.Document your API using OpenAPI/Swagger (REST) or introspection (GraphQL)
- 6.Implement pagination, rate limiting, and error handling according to the patterns provided
- 7.Reference the common pitfalls section during design review to catch issues early
Use cases
- Designing a new REST API for a web service or mobile app
- Migrating from REST to GraphQL to reduce over-fetching
- Establishing API design standards and guidelines for a development team
- Reviewing and refactoring existing APIs for better usability and consistency
- Planning API versioning strategy before implementation to handle future breaking changes
- Backend engineers designing or refactoring APIs
- API architects establishing standards and governance
- Full-stack developers building client-server applications
- Technical leads reviewing API specifications
- Teams migrating between API paradigms
api-design-principles FAQ
REST is simpler for straightforward CRUD operations and caching. GraphQL excels when clients need flexible data queries and you want to reduce over-fetching. Consider your use case: mobile apps benefit from GraphQL's efficiency, while public APIs often work well with REST.
Plan versioning from day one using URL versioning (/api/v1, /api/v2), header versioning, or query parameters. For GraphQL, use the @deprecated directive for gradual migration. Always communicate deprecation timelines to API consumers.
PUT replaces the entire resource (idempotent), while PATCH applies partial updates. Use PUT when you want to replace the full resource and PATCH for incremental changes. Both are idempotent but have different semantics.
Use DataLoaders to batch database queries. DataLoaders collect all requested items during a resolver execution phase and fetch them in a single query, dramatically improving performance.
Use 2xx for success (200 OK, 201 Created), 4xx for client errors (400 Bad Request, 404 Not Found, 429 Too Many Requests), and 5xx for server errors (500 Internal Server Error). Always match the code to the actual error condition.
Full instructions (SKILL.md)
Source of truth, from wshobson/agents.
name: api-design-principles description: Master REST and GraphQL API design principles to build intuitive, scalable, and maintainable APIs that delight developers. Use when designing new APIs, reviewing API specifications, or establishing API design standards.
API Design Principles
Master REST and GraphQL API design principles to build intuitive, scalable, and maintainable APIs that delight developers and stand the test of time.
When to Use This Skill
- Designing new REST or GraphQL APIs
- Refactoring existing APIs for better usability
- Establishing API design standards for your team
- Reviewing API specifications before implementation
- Migrating between API paradigms (REST to GraphQL, etc.)
- Creating developer-friendly API documentation
- Optimizing APIs for specific use cases (mobile, third-party integrations)
Core Concepts
1. RESTful Design Principles
Resource-Oriented Architecture
- Resources are nouns (users, orders, products), not verbs
- Use HTTP methods for actions (GET, POST, PUT, PATCH, DELETE)
- URLs represent resource hierarchies
- Consistent naming conventions
HTTP Methods Semantics:
GET: Retrieve resources (idempotent, safe)POST: Create new resourcesPUT: Replace entire resource (idempotent)PATCH: Partial resource updatesDELETE: Remove resources (idempotent)
2. GraphQL Design Principles
Schema-First Development
- Types define your domain model
- Queries for reading data
- Mutations for modifying data
- Subscriptions for real-time updates
Query Structure:
- Clients request exactly what they need
- Single endpoint, multiple operations
- Strongly typed schema
- Introspection built-in
3. API Versioning Strategies
URL Versioning:
/api/v1/users
/api/v2/users
Header Versioning:
Accept: application/vnd.api+json; version=1
Query Parameter Versioning:
/api/users?version=1
Detailed patterns and worked examples
Detailed pattern documentation lives in references/details.md. Read that file when the navigation tier above is insufficient.
Best Practices
REST APIs
- Consistent Naming: Use plural nouns for collections (
/users, not/user) - Stateless: Each request contains all necessary information
- Use HTTP Status Codes Correctly: 2xx success, 4xx client errors, 5xx server errors
- Version Your API: Plan for breaking changes from day one
- Pagination: Always paginate large collections
- Rate Limiting: Protect your API with rate limits
- Documentation: Use OpenAPI/Swagger for interactive docs
GraphQL APIs
- Schema First: Design schema before writing resolvers
- Avoid N+1: Use DataLoaders for efficient data fetching
- Input Validation: Validate at schema and resolver levels
- Error Handling: Return structured errors in mutation payloads
- Pagination: Use cursor-based pagination (Relay spec)
- Deprecation: Use
@deprecateddirective for gradual migration - Monitoring: Track query complexity and execution time
Common Pitfalls
- Over-fetching/Under-fetching (REST): Fixed in GraphQL but requires DataLoaders
- Breaking Changes: Version APIs or use deprecation strategies
- Inconsistent Error Formats: Standardize error responses
- Missing Rate Limits: APIs without limits are vulnerable to abuse
- Poor Documentation: Undocumented APIs frustrate developers
- Ignoring HTTP Semantics: POST for idempotent operations breaks expectations
- Tight Coupling: API structure shouldn't mirror database schema
Related skills
More from wshobson/agents and the wider catalog.
tailwind-design-system
Build production-ready design systems with Tailwind CSS v4, design tokens, and component libraries.
typescript-advanced-types
Master TypeScript's advanced type system: generics, conditional types, mapped types, and utility types for type-safe applications.
nodejs-backend-patterns
Build production-ready Node.js backends with Express/Fastify, middleware patterns, auth, and database integration.
python-performance-optimization
Profile and optimize Python code using cProfile, memory profilers, and performance best practices.
brand-landingpage
Brand-first landing page designer with guided interviews and Stitch-powered iteration.
python-testing-patterns
Implement comprehensive testing strategies with pytest, fixtures, mocking, and test-driven development.