Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/anshuldhakate/task-management-system
- Owner: Anshuldhakate
- Created: 2024-08-22T16:24:51.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-23T10:00:20.000Z (5 months ago)
- Last Synced: 2024-10-10T06:41:19.971Z (3 months ago)
- Topics: bcrypt, dotenv, express-js, jwt-authentication, mongodb, nodejs
- Language: JavaScript
- Homepage: https://task-management-system-afof.onrender.com/
- Size: 23.4 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
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-system2. **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.