GET /api/jobs
Retrieve a list of all job opportunities in Dzaleka Refugee Camp.Query Parameters
This endpoint does not require any query parameters.Response Format
Status of the API response (“success” or “error”)
Total number of jobs returned
Container for the jobs data
Array of job objects
Unique identifier for the job
Collection name (“jobs”)
Job title
Hiring organization name
Job location (e.g., “Remote”, “Dzaleka”, “Remote / Dzaleka”)
Job type (e.g., “full-time”, “part-time”, “contract”, “internship”)
Job category (e.g., “business”, “technology”, “education”)
Date posted (YYYY-MM-DD)
Application deadline (YYYY-MM-DD)
Job status (“open”, “closed”, “filled”)
Whether the job is featured
Job description summary
Array of required skills
Error Responses
“error”
Error message description
Detailed error information
200- Success429- Rate limit exceeded (60 requests per minute)500- Internal server error
Rate Limiting
All API endpoints are rate-limited to 60 requests per minute per IP address. Rate limit headers are included in responses:X-RateLimit-Limit: Maximum requests per windowX-RateLimit-Remaining: Remaining requests in current windowX-RateLimit-Reset: Timestamp when the rate limit resetsRetry-After: Seconds to wait before retrying (only on 429 responses)
Example Request
Example Response
POST /api/jobs
Retrieve jobs data with optional metadata and statistics.Request Body
Response Format
Same as GET endpoint, with optional additional fields:Example Request
Example Response
Implementation
The Jobs API is implemented using thecreateGetHandler and createPostHandler utility functions from src/utils/api-utils.ts:118.
Source code: src/pages/api/jobs.ts:5