Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/anshuldhakate/task-management-system

The Task Management System is a backend API built using Node.js and Express.js. It provides task management functionality with secure user authentication and role-based access control. The API uses MongoDB to store data and follows best practices for code quality
https://github.com/anshuldhakate/task-management-system

bcrypt dotenv express-js jwt-authentication mongodb nodejs

Last synced: 3 months ago
JSON representation

The Task Management System is a backend API built using Node.js and Express.js. It provides task management functionality with secure user authentication and role-based access control. The API uses MongoDB to store data and follows best practices for code quality

Awesome Lists containing this project

README

        

# Task Management System

## Deployed Link- https://task-management-system-afof.onrender.com/

## Overview

The Task Management System is a backend API built using Node.js and Express.js. It provides task management functionality with secure user authentication and role-based access control. The API uses MongoDB to store data and follows best practices for code quality, including dependency injection and proper design patterns.

## Features

- User Registration with JWT-based Authentication
- Role-Based Access Control (Admin, User)
- CRUD Operations for Tasks
- Filtering Tasks by Priority, Status, and Assigned User
- Secure Endpoints with Route Guards and Input Validation
- Dependency Injection for Authentication, Role Management, and Task Handling

## Technologies Used

- Node.js
- Express.js
- MongoDB (Mongoose)
- JWT (JSON Web Token) for Authentication
- bcryptjs for Password Hashing
- dotenv for Environment Variables
- Postman for API Testing

## Getting Started

### Prerequisites

- Node.js installed on your machine
- MongoDB installed and running locally or a connection URI to a remote MongoDB instance
- Postman installed for testing API endpoints

### Installation

1. **Clone the Repository:**

```bash
git clone https://github.com/Anshuldhakate/task-management-system.git
cd task-management-system

2. **Install Dependencies:**
- npm install
-
3. **Set Up Environment Variables:**
- MONGOURL= mongodb+srv://user-new-11:[email protected]/task_management?retryWrites=true&w=majority&appName=Cluster0
- JWT_SECRET= Anshul1234

4. **Start the Server:**
- npm start

### API Endpoints
#### Authentication
#### Register User

- URL: /api/auth/register
- Method: POST
- Headers: Content-Type: application/json
- Body: json

{
"name": "John Doe",
"email": "[email protected]",
"password": "password123"
}
- Response: json

{
"token": "your_jwt_token_here"
}
- Login User

- URL: /api/auth/login
- Method: POST
- Headers: Content-Type: application/json
- Body: json

{
"email": "[email protected]",
"password": "password123"
}
- Response: json

{
"token": "your_jwt_token_here"
}
#### Tasks
- Get All Tasks

- URL: /api/tasks
- Method: GET
- Headers:
- Authorization: Bearer your_jwt_token_here

#### Create a Task

- URL: /api/tasks
- Method: POST
- Headers:
- Content-Type: application/json
- Authorization: Bearer your_jwt_token_here
- Body: json

{
"title": "New Task",
"description": "Task description",
"priority": "High",
"status": "Pending",
"assignedTo": "userId"
}
#### Update a Task

- URL: /api/tasks/:taskId
- Method: PUT
- Headers:
- ontent-Type: application/json
- Authorization: Bearer your_jwt_token_here
- Body: json

{
"title": "Updated Task",
"description": "Updated task description",
"priority": "Low",
"status": "Completed",
"assignedTo": "userId"
}
#### Delete a Task

- URL: /api/tasks/:taskId
- Method: DELETE
- Headers:
- Authorization: Bearer your_jwt_token_here
- Testing the API with Postman

#### Register a New User:

- Make a POST request to /api/auth/register with the required fields in the body.
- Login with the Registered User:

- Make a POST request to /api/auth/login with the user's email and password.
- Copy the Token from the Login Response:

- Use this token to authenticate requests to protected routes.
- Set Authorization Header in Postman:

- Go to the Headers tab in Postman.
- Add a new header:
- Key: Authorization
- Value: Bearer your_jwt_token_here

### ontributing
- Contributions are welcome! Please fork the repository and submit a pull request for any enhancements or bug fixes.