skills/api-design-patterns/SKILL.md
RESTful API design, error handling, versioning, and best practices. Use when designing APIs, reviewing endpoints, implementing error responses, or setting up API structure. Triggers on "design API", "review API", "REST best practices", or "API patterns".
npx skillsauth add asyrafhussin/agent-skills api-design-patternsInstall 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.
RESTful API design principles for building consistent, developer-friendly APIs. Contains 38 rules across 7 categories covering resource design, error handling, security, pagination, versioning, response format, and documentation.
Reference these guidelines when:
| Priority | Category | Impact | Prefix |
|----------|----------|--------|--------|
| 1 | Resource Design | CRITICAL | rest- |
| 2 | Error Handling | CRITICAL | error- |
| 3 | Security | CRITICAL | sec- |
| 4 | Pagination & Filtering | HIGH | page-, filter-, sort- |
| 5 | Versioning | HIGH | ver- |
| 6 | Response Format | MEDIUM | resp- |
| 7 | Documentation | MEDIUM | doc- |
rest-nouns-not-verbs - Use nouns for endpoints, not verbsrest-plural-resources - Use plural resource namesrest-http-methods - Correct HTTP method usage (GET, POST, PUT, PATCH, DELETE)rest-nested-resources - Proper resource nesting (max 2 levels)rest-status-codes - Appropriate HTTP status codesrest-idempotency - Idempotent operations with idempotency keysrest-hateoas - Hypermedia links for discoverabilityrest-resource-actions - Non-CRUD actions as sub-resourceserror-consistent-format - Consistent error response structureerror-meaningful-messages - Helpful, actionable error messageserror-validation-details - Field-level validation errorserror-error-codes - Machine-readable error codeserror-no-stack-traces - Never expose stack traces in productionerror-request-id - Include request IDs for debuggingsec-authentication - Proper auth implementation (OAuth2/JWT)sec-authorization - Resource-level permissions (RBAC)sec-rate-limiting - Prevent abuse with rate limitingsec-input-validation - Validate and sanitize all inputsec-cors-config - CORS configuration with whitelistssec-https-only - Enforce HTTPS for all trafficsec-sensitive-data - Protect passwords, tokens, PIIpage-cursor-based - Cursor pagination for large datasetspage-offset-based - Offset pagination for simple casespage-consistent-params - Consistent parameter namingpage-metadata - Include pagination metadata in responsesfilter-query-params - Filter via query parameterssort-flexible - Flexible sorting with - prefix for descendingver-url-path - Version in URL path (/api/v1/)ver-header-based - Version via Accept headerver-backward-compatible - Maintain backward compatibilityver-deprecation - Deprecation strategy with Sunset headerresp-consistent-structure - Consistent response enveloperesp-json-conventions - JSON naming conventionsresp-partial-responses - Field selection (sparse fieldsets)resp-compression - Response compression (gzip/Brotli)doc-openapi - OpenAPI/Swagger specificationdoc-examples - Request/response examplesdoc-changelog - API changelog# ❌ Verbs in URLs
GET /getUsers
POST /createUser
# ✅ Nouns with HTTP methods
GET /users # List users
POST /users # Create user
GET /users/123 # Get user
PUT /users/123 # Update user (full)
PATCH /users/123 # Update user (partial)
DELETE /users/123 # Delete user
{
"error": {
"code": "VALIDATION_ERROR",
"message": "The request contains invalid data",
"details": [
{
"field": "email",
"code": "INVALID_FORMAT",
"message": "Please provide a valid email address"
}
],
"request_id": "req_abc123"
}
}
{
"data": [...],
"meta": {
"current_page": 2,
"per_page": 20,
"total_pages": 10,
"total_count": 195
},
"links": {
"first": "/users?page=1&per_page=20",
"prev": "/users?page=1&per_page=20",
"next": "/users?page=3&per_page=20",
"last": "/users?page=10&per_page=20"
}
}
HTTP/1.1 200 OK
X-RateLimit-Limit: 1000
X-RateLimit-Remaining: 998
X-RateLimit-Reset: 1640995200
Read individual rule files for detailed explanations:
rules/rest-http-methods.md
rules/error-consistent-format.md
rules/page-cursor-based.md
rules/sec-authentication.md
rules/ver-url-path.md
rules/doc-openapi.md
For the complete guide with all rules expanded: AGENTS.md
development
Laravel 13 conventions and best practices. Use when creating controllers, models, migrations, validation, services, or structuring Laravel applications. Triggers on tasks involving Laravel architecture, Eloquent, database, API development, or PHP patterns.
tools
Laravel AI SDK for building AI-powered features. Use when creating agents, generating images or audio, working with embeddings, vector search, or testing AI features. Triggers on tasks involving laravel/ai, AI agents, tool-calling, structured output, streaming, embeddings, reranking, or AI faking in tests.
tools
Git best practices, branching strategies, commit conventions, and PR workflows. Use when reviewing git history, writing commits, setting up branching strategy, or improving git practices. Triggers on "git best practices", "commit message", "branching strategy", or "PR workflow".
tools
End-to-end testing with Playwright for web applications. Use when writing E2E tests, browser automation, form submission testing, or user flow testing. Triggers on "playwright", "e2e test", "browser test", "end-to-end", "form flow testing", or test files in tests/e2e/.