API
RESTful API Design
- An architectural style for designing networked applications, relying on stateless, client-server communication, typically over HTTP.
- 
Designing URL - Use plural nouns to present resources collections, e.g., /userfor the collection of users
- For a specific resource, include an identifier, e.g., /users/{userId}for a specific user
- Avoid: Using verbs in URIs, e.g., /getUser is not RESTful
 
- Use plural nouns to present resources collections, e.g., 
- 
Use HTTP Methods - Use appropriate HTTP methods to define operations on resources, ensuring the method’s semantics match the action:
- GET: Retrieve a resource or collection.
- POST: Create a new resource.
- PUT: Update an existing resource (full update).
- PATCH: Partially update a resource.
 
 
- Use appropriate HTTP methods to define operations on resources, ensuring the method’s semantics match the action:
- 
Using HTTP Status Codes - Use standard HTTP status codes to indicate the outcome of API requests:
- 201 Created: Resource successfully created.
- 400 Bad Request: Invalid request from the client.
- 401 Unauthorized: Authentication required or failed.
- 500 Internal Server Error: Server encountered an error.
 
 
- Use standard HTTP status codes to indicate the outcome of API requests:
- 
API Versioning - Implement versioning to manage API changes without disrupting existing users. Common approaches:
- URL Versioning: Include the version in the URL, e.g., /api/v1/users.
- Header Versioning: Specify the version in an HTTP header, e.g., X-API-Version: 1.0.
- Query Parameter Versioning: Include the version in a query parameter, e.g., /api/users?version=1.0.
 
- URL Versioning: Include the version in the URL, e.g., 
- Goal: Enable smooth API upgrades without breaking existing client integrations.
 
- Implement versioning to manage API changes without disrupting existing users. Common approaches:
- 
Standardized Response Format - Use a consistent response structure for all API endpoints to improve predictability and usability:
{
 "status": "failed",
 "data": {
 },
 "message": "Failed to retrieve user details",
 "errorCode": "WL-001"
 }
 
- Use a consistent response structure for all API endpoints to improve predictability and usability:
- 
Ensuring Idempotence - Design APIs to support idempotence for safe retry mechanisms, preventing unintended duplicate submissions.
- Idempotent Methods:
- PUT: Updating a resource with the same request multiple times produces the same result (e.g., setting a user’s data to the same values).
- PATCH: Partial updates should also be idempotent when designed to set specific fields to defined values.
- GET and DELETE are inherently idempotent.
 
- Non-Idempotent Method:
- POST: Typically creates new resources, so repeated calls may create duplicates unless handled (e.g., using unique request IDs or checks).
 
- Use mechanisms like unique request IDs or conditional checks to ensure idempotence for operations prone to duplication.