Files
Rohit Ghumare c3f43d8b61 Expand toolkit to 135 agents, 120 plugins, 796 total files
- Add 60 new agents across all 10 categories (75 -> 135)
- Add 95 new plugins with command files (25 -> 120)
- Update all agents to use model: opus
- Update README with complete plugin/agent tables
- Update marketplace.json with all 120 plugins
2026-02-04 21:08:28 +00:00

47 lines
2.3 KiB
Markdown

# API Design
## REST Conventions
- Use plural nouns for resource paths: `/users`, `/orders`, `/products`.
- Map HTTP methods to operations: GET (read), POST (create), PUT (full update), PATCH (partial update), DELETE (remove).
- Use nested routes for relationships: `/users/:id/orders` not `/getUserOrders`.
- Keep URLs lowercase with hyphens: `/order-items` not `/orderItems`.
- Limit nesting to two levels. Beyond that, use query parameters or top-level routes.
## Status Codes
- 200 OK: Successful read or update.
- 201 Created: Successful resource creation. Include `Location` header.
- 204 No Content: Successful delete with no response body.
- 400 Bad Request: Validation failure or malformed input.
- 401 Unauthorized: Missing or invalid authentication.
- 403 Forbidden: Authenticated but lacks permission.
- 404 Not Found: Resource does not exist.
- 409 Conflict: Duplicate or state conflict.
- 422 Unprocessable Entity: Valid syntax but semantic errors.
- 429 Too Many Requests: Rate limit exceeded. Include `Retry-After` header.
- 500 Internal Server Error: Unhandled server failure. Never expose stack traces.
## Versioning
- Use URL path versioning for public APIs: `/api/v1/users`.
- Use header versioning for internal APIs: `Accept: application/vnd.api.v2+json`.
- Support the previous version for at least 6 months after deprecation.
- Return a `Deprecation` header on sunset-path endpoints.
## Pagination
- Use cursor-based pagination for large or real-time datasets: `?cursor=abc&limit=20`.
- Use offset pagination only for small, static datasets: `?page=1&per_page=25`.
- Default limit: 20 items. Maximum limit: 100 items.
- Return pagination metadata in the response: `{ data, meta: { cursor, hasMore, total } }`.
## Response Format
- Consistent envelope: `{ data, error, meta }` across all endpoints.
- Error responses: `{ error: { code: "VALIDATION_ERROR", message: "...", details: [...] } }`.
- Use ISO 8601 for all timestamps: `2026-01-15T09:30:00Z`.
- Return `null` for absent optional fields, not missing keys.
- Include `requestId` in all responses for traceability.
## Rate Limiting
- Public endpoints: 60 requests per minute.
- Authenticated endpoints: 600 requests per minute.
- Write endpoints: 30 requests per minute.
- Return `X-RateLimit-Limit`, `X-RateLimit-Remaining`, `X-RateLimit-Reset` headers.