Skip to content

Latest commit

 

History

History
104 lines (76 loc) · 2.87 KB

Readme.md

File metadata and controls

104 lines (76 loc) · 2.87 KB

Airtribe Task Manager API

This project is a RESTful API developed using Node.js, Express.js, and NPM packages. The API allows users to perform CRUD operations (Create, Read, Update, and Delete) on tasks. Each task has a title, description, and completion status flag. The API can be tested using Postman or Curl.

Routes

  • GET /tasks: Retrieve all tasks.
  • GET /tasks/:id: Retrieve a single task by its ID.
  • POST /tasks: Create a new task.
  • PUT /tasks/:id: Update an existing task by its ID.
  • DELETE /tasks/:id: Delete a task by its ID.
  • GET /tasks?completed=true: Retrieve all tasks filtered by completed status.
  • GET /tasks?sortBy=createdOn: Retrieve all tasks sorted by createdOn in ascending order .
  • GET /tasks?sortBy=-createdOn: Retrieve all tasks sorted by createdOn in descending order.
  • GET /tasks/priority/:level: Retrieve all tasks filtered by priority.

Installation

  1. Clone the repository: git clone <repository_url>

  2. Install dependencies: npm install

Usage

  1. Start the server: npm start

  2. Access the API routes using the following URL: http://localhost:3000/tasks

  3. Test the API using Postman or Curl:

GET ALL TASKS

curl --location 'http://localhost:3000/tasks' 

NOTE: Above GET /tasks API supports filter by field completed and sorting on field createdOn in query param. Example URIs are as follows:

curl --location 'http://localhost:3000/tasks?completed=true&sortBy=createdOn' // filter by completed status, sort by createdOn in ascending order
curl --location 'http://localhost:3000/tasks?completed=true&sortBy=-createdOn' // filter by completed status, sort by createdOn in descending order. Emphasis on the negative sign for descending order

POST A TASK

curl --location 'http://localhost:3000/tasks' \
--data '{
    "id": 5,
    "title": "Task new",
    "description": "Task new description",
    "completed": false
}' 

NOTE: By Default, tasks are assigned a priority of low out of high, medium and low

GET SINGLE TASK

curl --location 'http://localhost:3000/tasks/5' 

GET TASKS filtered by priority: high, medium or low

curl --location 'http://localhost:3000/tasks/priority/low' 

UPDATE A TASK STATUS

curl --location 'http://localhost:3000/tasks/5' \
--data '{
    "id": 5,
    "title": "Task new",
    "description": "Task new description",
    "completed": true
}'

UPDATE A TASK Priority

curl --location 'http://localhost:3000/tasks/5' \
--data '{
    "priority": "high"
}'

DELETE A TASK

curl --location 'http://localhost:3000/tasks/5' 

Contributing

Contributions are welcome! If you would like to contribute to this project, please fork the repository and submit a pull request.

Contact

For any further inquiries or feedback, please contact [[email protected]].