| id | SKL-api-APIDESIGN |
| name | Api Design |
| description | RESTful API design is an architectural style and set of constraints for building web services that emphasize consistency, scalability, and developer experience. This skill provides comprehensive guida |
| version | 1.0.0 |
| status | active |
| owner | @cerebra-team |
| last_updated | 2026-02-22 |
| category | Backend |
| tags | ["api","backend","server","database"] |
| stack | ["Python","Node.js","REST API","GraphQL"] |
| difficulty | Intermediate |
Api Design
Skill Profile
(Select at least one profile to enable specific modules)
Overview
RESTful API design is an architectural style and set of constraints for building web services that emphasize consistency, scalability, and developer experience. This skill provides comprehensive guidance on REST principles, HTTP method semantics, URL structure, status codes, authentication, pagination, and documentation to create APIs that are intuitive, maintainable, and evolve gracefully over time.
Why This Matters
- Enables Ecosystem Growth: Consistent, well-documented APIs allow third-party developers to integrate easily with your platform
- Reduces Integration Friction: Clear patterns and standard response formats reduce developer confusion and integration errors
- Improves Developer Experience: Predictable URLs, clear error messages, and intuitive design make APIs pleasant to work with
- Supports Scalability: Proper resource modeling and architectural patterns enable systems to grow without major redesigns
- Ensures Client Compatibility: Versioning strategies and backward compatibility policies prevent breaking existing consumers
- Reduces Support Costs: Self-documenting APIs and standardizing responses reduce documentation burden and support ticket volume
Core Concepts & Rules
1. Core Principles
- Follow established patterns and conventions
- Maintain consistency across codebase
- Document decisions and trade-offs
2. Implementation Guidelines
- Start with the simplest viable solution
- Iterate based on feedback and requirements
- Test thoroughly before deployment
Inputs / Outputs / Contracts
- Inputs:
- Business requirements and use cases
- Resource models and relationships
- Security and compliance requirements
- Performance and scalability targets
- Entry Conditions:
- API requirements are defined
- Resource models are available
- Security requirements are understood
- Outputs:
- API specification (OpenAPI/Swagger)
- Endpoint documentation
- Request/response schemas
- Error handling specification
- Authentication and authorization design
- Artifacts Required (Deliverables):
- OpenAPI specification file
- API documentation
- Postman collection or similar
- Integration examples
- Acceptance Evidence:
- API specification is complete and validated
- All endpoints are documented
- Authentication and authorization are implemented
- Rate limiting is configured
- Success Criteria:
- API follows REST principles
- Documentation is complete and accurate
- All endpoints are tested
- Security measures are in place
Skill Composition
Quick Start / Implementation Example
- Review requirements and constraints
- Set up development environment
- Implement core functionality following patterns
- Write tests for critical paths
- Run tests and fix issues
- Document any deviations or decisions
def example_function():
pass
Assumptions / Constraints / Non-goals
- Assumptions:
- Development environment is properly configured
- Required dependencies are available
- Team has basic understanding of domain
- Constraints:
- Must follow existing codebase conventions
- Time and resource limitations
- Compatibility requirements
- Non-goals:
- This skill does not cover edge cases outside scope
- Not a replacement for formal training
Compatibility & Prerequisites
- Supported Versions:
- Python 3.8+
- Node.js 16+
- Modern browsers (Chrome, Firefox, Safari, Edge)
- Required AI Tools:
- Code editor (VS Code recommended)
- Testing framework appropriate for language
- Version control (Git)
- Dependencies:
- Language-specific package manager
- Build tools
- Testing libraries
- Environment Setup:
.env.example keys: API_KEY, DATABASE_URL (no values)
Test Scenario Matrix (QA Strategy)
| Type | Focus Area | Required Scenarios / Mocks |
|---|
| Unit | Core Logic | Must cover primary logic and at least 3 edge/error cases. Target minimum 80% coverage |
| Integration | DB / API | All external API calls or database connections must be mocked during unit tests |
| E2E | User Journey | Critical user flows to test |
| Performance | Latency / Load | Benchmark requirements |
| Security | Vuln / Auth | SAST/DAST or dependency audit |
| Frontend | UX / A11y | Accessibility checklist (WCAG), Performance Budget (Lighthouse score) |
Technical Guardrails & Security Threat Model
1. Security & Privacy (Threat Model)
- Top Threats: Injection attacks, authentication bypass, data exposure
2. Performance & Resources
3. Architecture & Scalability
4. Observability & Reliability
Agent Directives & Error Recovery
(ข้อกำหนดสำหรับ AI Agent ในการคิดและแก้ปัญหาเมื่อเกิดข้อผิดพลาด)
- Thinking Process: Analyze root cause before fixing. Do not brute-force.
- Fallback Strategy: Stop after 3 failed test attempts. Output root cause and ask for human intervention/clarification.
- Self-Review: Check against Guardrails & Anti-patterns before finalizing.
- Output Constraints: Output ONLY the modified code block. Do not explain unless asked.
Definition of Done (DoD) Checklist
Anti-patterns / Pitfalls
- ⛔ Don't: Log PII, catch-all exception, N+1 queries
- ⚠️ Watch out for: Common symptoms and quick fixes
- 💡 Instead: Use proper error handling, pagination, and logging
Reference Links & Examples
- Internal documentation and examples
- Official documentation and best practices
- Community resources and discussions
Versioning & Changelog
- Version: 1.0.0
- Changelog:
- 2026-02-22: Initial version with complete template structure