data:image/s3,"s3://crabby-images/ff2c8/ff2c83e1f0de61c13963641349a47c8b2dc8177d" alt="ParchmentTMS Logo"
This is a toy project for a headless TMS built with NestJS and MongoDB, enabling teams to create, manage, and close tickets, track their status and prioritize tasks.
To get started with this project, you can choose to either run the project natively on your machine, or with Docker.
To run the project natively, you will need to have Node.js v22.12.0 or higher and npm v10.9.0 or higher installed on your machine.
- 🍴 Clone this repository to your local machine.
- 💻 Run
npm install
to install the necessary dependencies. - 🚀 Start a MongoDB instance on your machine by following the instructions provided by MongoDB for your specific operating system. You can download the MongoDB Community Server from here.
- 📝 Rename .env.example to .env and replace the values with your own MongoDB connection details and desired api port.
- 🚀 Run
npm start
to start the server.
To run the project with Docker, you will need to have Docker installed on your machine.
- 🍴 Clone this repository to your local machine.
- 📝 Copy the .env.example file and rename it to .env. Open the .env file and specify the desired values for MONGODB_URI and PORT variables.
For example:
# The MongoDB connection string for the TMS database MONGODB_URI="mongodb://mongodb/test" # The port on which the TMS API will run PORT="3000" # The seed string to be used for the JwtStrategy JWT_SECRET="42"
- 🐳 Run
docker compose build
to build the containers. - 🐳 Run
docker compose up
to start the containers. - 🌍 The API will be available at
http://localhost:3000/
.
Once the server is running, you can use the following endpoints to manage your projects/tickets:
POST /api/v1/register
: Gives the ability to registerPOST /api/v1/login
: Returns a jwt token for authentication
GET /api/v1/projects
: Returns a list of all projectsPOST /api/v1/projects
: Create a new projectGET /api/v1/projects/:id
: Returns a specific project by project ID.PATCH /api/v1/projects/:id
: Update a project by IDDELETE /api/v1/projects/:id
: Delete a project by ID
GET /api/v1/tickets
: Returns a list of all ticketsPOST /api/v1/tickets
: Create a new ticketGET /api/v1/tickets/:id
: Returns a specific ticket by ticket ID.PATCH /api/v1/tickets/:id
: Update an existing ticket by IDDELETE /api/v1/tickets:id
: Delete a ticket by ID
GET /heath
: Returns useful system information, such as server uptime and memory usage. This endpoint can be used to monitor the health of the application.
Here are some potential improvements that could be made to this project:
- Write Jest tests
- Add a process manager
- Add API rate limiting to prevent abuse
- Introduce automated ticket workflows or rules
- Create a frontend interface for ticket management.
- Add support for more auth providers (Auth0, OAuth2, etc)
- Implement backup and restore mechanism for data recovery
- Implement real-time ticket updates using WebSockets or SSE
- Add search and filter functionality for tickets and projects
- Enable file attachments for tickets (e.g., screenshots, logs)
- Improve documentation with detailed user guides and API examples
- Implement audit logs to track changes made to tickets and projects
- Optimize system performance (database queries, caching, file uploads)
- Support multiple languages for localization/internationalization (i18n)
- Add Github Actions to publish image to Docker Hub, Github Registry, etc.
- Allow customization of ticket fields (priority, labels, custom statuses)
- Support multiple deployment environments (e.g., dev, staging, production)
- Enable user profile changes and preferences (e.g., email notifications, themes)
- Create a reporting feature for ticket data (e.g., total tickets, resolution time)
- Add User Roles and Permissions for different access levels (admin, manager, developer)
Contributions to this project are welcome! If you have any suggestions, bug reports, or feature requests, please open an issue or submit a pull request.
This project is licensed under the Apache License, Version 2.0. See the LICENSE file for details.