The Fake Jobs API is a stateless API created using Node.js and Express.js. It utilizes a JSON data source as a database and provides CRUD (Create, Read, Update, Delete) functionality for job listings.
This API is designed to help frontend developers integrate job listing functionality into their applications. It serves as a backend service for managing job data, allowing developers to focus on building frontend interfaces without worrying about backend logic.
Developers can use this API to create applications for various purposes, including:
- Portfolio websites: Showcase job listing functionality in frontend portfolios.
- Proof of concept projects: Quickly prototype job-related applications using dummy data.
- Learning projects: Practice frontend development skills by integrating with a backend API.
- Endpoint:
/jobs
- Method: GET
- Description: Fetches all job listings.
- Usage: Send a GET request to
/jobs
to retrieve all job listings. - Response: An array of job objects.
Note
This API will return 30 job listing objects.
- Endpoint:
/jobs/:id
- Method: GET
- Description: Fetches a specific job listing by its ID.
- Usage: Send a GET request to
/jobs/:id
, where:id
is the ID of the job you want to retrieve. - Response: The job object with the specified ID. If no job is found, a 404 response is returned with a message indicating that no job was found with the provided ID.
- Endpoint:
/jobs
- Method: POST
- Description: Adds a new job listing.
- Usage: Send a POST request to
/jobs
with the details of the new job in the request body.
Note
You can include id
in the body but still backend will generate new id value
for id
property for the created new job listing.
- Example for
Body of the request
:
{
"id": "1",
"title": "Senior Front-End Developer",
"type": "Full-Time",
"location": "New York, NY",
"description": "Join our team as a Senior Front-End Developer in the heart of New York City. We are looking for an experienced individual with a passion for cutting-edge technologies and a track record of delivering high-quality web applications.",
"salary": "$100K - $120K",
"company": {
"name": "Tech Innovations Inc",
"description": "Tech Innovations Inc is a leading technology company specializing in software development and digital solutions. Our team is dedicated to pushing the boundaries of innovation to deliver exceptional products and services.",
"contactEmail": "[email protected]",
"contactPhone": "555-123-4567"
}
}
- Response: If successful, returns a success message along with the newly created job object. If there's an error, an appropriate error message is returned.
- Example of success response:
{
"success": true,
"msg": "Job Created Successfully!",
"job": {
"id": "197666",
"title": "Senior Front-End Developer",
"type": "Full-Time",
"location": "New York, NY",
"description": "Join our team as a Senior Front-End Developer in the heart of New York City. We are looking for an experienced individual with a passion for cutting-edge technologies and a track record of delivering high-quality web applications.",
"salary": "$100K - $120K",
"company": {
"name": "Tech Innovations Inc",
"description": "Tech Innovations Inc is a leading technology company specializing in software development and digital solutions. Our team is dedicated to pushing the boundaries of innovation to deliver exceptional products and services.",
"contactEmail": "[email protected]",
"contactPhone": "555-123-4567"
}
}
}
- Endpoint:
/jobs/:id
- Method: PUT
- Description: Updates an existing job listing by its ID.
- Usage: Send a PUT request to
/jobs/:id
, where:id
is the ID of the job you want to update, with the updated job details in the request body.
Note
You can include id
in the body but still backend will ignore that and update the other properties as per request body. If you don't include the id
property then at the end id
property with the value of :id
will be added.
- Example for
Body of the request
:Make sure to include the value of the properties with updated data.
{
"id": "1",
"title": "Senior Front-End Developer",
"type": "Full-Time",
"location": "New York, NY",
"description": "Join our team as a Senior Front-End Developer in the heart of New York City. We are looking for an experienced individual with a passion for cutting-edge technologies and a track record of delivering high-quality web applications.",
"salary": "$100K - $120K",
"company": {
"name": "Tech Innovations Inc",
"description": "Tech Innovations Inc is a leading technology company specializing in software development and digital solutions. Our team is dedicated to pushing the boundaries of innovation to deliver exceptional products and services.",
"contactEmail": "[email protected]",
"contactPhone": "555-123-4567"
}
}
- Response: If successful, returns a success message along with the updated job object. If no job is found with the provided ID, a 404 response is returned with a message indicating that no job was found.
- Example of success response:
{
"success": true,
"msg": "Job with id 1 has been updated",
"job": {
"id": "1",
"title": "Senior Front-End Developer",
"type": "Part-Time",
"location": "New York, NY",
"description": "Join our team as a Senior Front-End Developer in the heart of New York City. We are looking for an experienced individual with a passion for cutting-edge technologies and a track record of delivering high-quality web applications.",
"salary": "$100K - $120K",
"company": {
"name": "Tech Innovations Inc",
"description": "Tech Innovations Inc is a leading technology company specializing in software development and digital solutions. Our team is dedicated to pushing the boundaries of innovation to deliver exceptional products and services.",
"contactEmail": "[email protected]",
"contactPhone": "555-123-4567"
}
}
}
- Example of 404 not found response:
{
"success": false,
"msg": "Job not found!"
}
- Endpoint:
/jobs/:id
- Method: DELETE
- Description: Deletes a job listing by its ID.
- Usage: Send a DELETE request to
/jobs/:id
, where:id
is the ID of the job you want to delete. - Response: If successful, returns a success message along with the deleted job object. If no job is found with the provided ID, a 404 response is returned with a message indicating that no job was found.
- Example of success response:
{
"success": true,
"msg": "Job with id 1 has been deleted",
"job": {
"id": "1",
"title": "Senior Front-End Developer",
"type": "Full-Time",
"location": "New York, NY",
"description": "Join our team as a Senior Front-End Developer in the heart of New York City. We are looking for an experienced individual with a passion for cutting-edge technologies and a track record of delivering high-quality web applications.",
"salary": "$100K - $120K",
"company": {
"name": "Tech Innovations Inc",
"description": "Tech Innovations Inc is a leading technology company specializing in software development and digital solutions. Our team is dedicated to pushing the boundaries of innovation to deliver exceptional products and services.",
"contactEmail": "[email protected]",
"contactPhone": "555-123-4567"
}
}
}
- Example of 404 not found response:
{
"success": false,
"msg": "Job not found!"
}
The cache
will be automatically cleared every 4 minutes
, resetting all API data to its initial state. Consequently, any CRUD operations performed within this timeframe will be reverted, ensuring that API responses consistently reflect the initial data state.
Feel free to Star✨ the repository. Fork🤩, explore🔍 and contribute🧙♂️ to any existing issues or initiate a new one to begin your contributions.
There's ample opportunity to enhance FakeJobs-Api with a variety of functional APIs awaiting implementation.
We expect all contributors to abide by the terms of our Code of Conduct.
Head over to our issue tracker to check more about it.
Check the Contributing Guide out.
This repository is licensed under the MIT license