A ready-to-use Express and TypeScript REST API template based on MongoDB.
Table of Contents
Althpugh there are many Express templates out there, most of them come lacking specific features like media file upload, schema validation, and no adoption of TypeScript, I built this probject as a template for my future Express projects since it contains the most imortant parts to get your hands on other parts of your code.
With this template you could benefit from:
- Getting up and running as fast as possible with your projects. No need to write the functionality for auth from scratch.
- Type-safe schemas and validation with Zod.
- API Documentation with Swagge
- Docker & Docker Compose integration.
- E-mail service with Nodemailer.
- Media & S3 upload and auto resize functinality with Sharp.
- Metrics Report using Promethious.
- Logging & rotation with Winston and Morgan.
- REST API location that can be simple extended to any language.
- E-mail Templates
- Cookie-based & Google Oauth2 authentication.
- Multi-role authorization.
You might want to furtherly tailor this template for your needs, for example you might use a different emailing service like Sendgrid instead of nodemailer. The separation of concerns approach implemented in this project makes customizying it super easy.
- Node.js
- MongoDB
- TypeScript
- Zod
- Bullmq
- Docker & Docker-Compose
Using this template in your new projects starts gives you the freedom to run it with a container tool like Docker, or you can use Node directly from the OS.
To get this project working, the first step is to create an environment-variables .env
file that contains all required variables needed in the project.
- If you don't want to use Docker, make sure you have a recent Node version.
- To use with Docker, have Docker installed on your computer from its website.
- Clone the repo / Use the template.
- Fill the values for the environment variables inside the
.env
file I have provided. - If you wish to continue with Docker, run
make build-up local
ordocker-compose --env-file .env.local up --build
. This command will do the installation and running steps for your. If you have correctly set your environment variables, the server will be ready to use. - Navigate to
api
folder. - Install NPM packages
npm i
- Execute the server entry
index.ts
using npm commandnpm run dev
. - Visit `http://localhost:8000
- MVP API Starter
- Add Tests
- Improve the Swagger documentation
- Deployment to AWS guide
If you noticed anything that you could improve for the better/fix or recommend feel free to open an issue or make a pull request.
Distributed under the MIT License.
Ali H. Kudeir - @kalideir -