Welcome to the Express TypeScript Boilerplate 2024 โ a streamlined, efficient, and scalable foundation for building powerful backend services. This boilerplate merges modern tools and practices in Express.js and TypeScript, enhancing productivity, code quality, and performance.
Developed to streamline backend development, this boilerplate is your solution for:
- โจ Reducing setup time for new projects.
- ๐ Ensuring code consistency and quality.
- โก Facilitating rapid development with cutting-edge tools.
- ๐ก๏ธ Encouraging best practices in security, testing, and performance.
- ๐ Modular Structure: Organized by feature for easy navigation and scalability.
- ๐จ Faster Execution with tsx: Rapid TypeScript execution with esbuild, complemented by tsc for type checking.
- ๐ Stable Node Environment: Latest LTS Node version in .nvmrc.
- ๐ง Simplified Environment Variables with Envalid: Centralized and easy-to-manage configuration.
- ๐ Path Aliases: Cleaner code with shortcut imports.
- ๐ Dependabot Integration: Automatic updates for secure and up-to-date dependencies.
- ๐ Security: Helmet for HTTP header security and CORS setup.
- ๐ Logging: Efficient logging with pino-http.
- ๐งช Comprehensive Testing: Robust setup with Vitest and Supertest.
- ๐ Code Quality Assurance: Husky and lint-staged for consistent quality.
- โ Unified Code Style: ESLint and Prettier for a consistent coding standard.
- ๐ API Response Standardization: ServiceResponse class for consistent API responses.
- ๐ณ Docker Support: Ready for containerization and deployment.
- ๐ Input Validation with Zod: Strongly typed request validation using Zod.
- ๐งฉ API Spec Generation: Automated OpenAPI specification generation from Zod schemas to ensure up-to-date and accurate API documentation.
- Clone the repository:
git clone https://github.com/edwinhern/express-typescript-2024.git
- Navigate:
cd express-typescript-2024
- Install dependencies:
npm ci
- Create
.env
: Copy.env.template
to.env
- Update
.env
: Fill in necessary environment variables
- Development Mode:
npm run dev
- Building:
npm run build
- Production Mode: Set
.env
toNODE_ENV="production"
thennpm run build && npm run start
.
โโโ api
โ โโโ healthCheck
โ โ โโโ __tests__
โ โ โ โโโ healthCheckRouter.test.ts
โ โ โโโ healthCheckRouter.ts
โ โโโ user
โ โโโ __tests__
โ โ โโโ userRouter.test.ts
โ โ โโโ userService.test.ts
โ โโโ userModel.ts
โ โโโ userRepository.ts
โ โโโ userRouter.ts
โ โโโ userService.ts
โโโ api-docs
โ โโโ __tests__
โ โ โโโ openAPIRouter.test.ts
โ โโโ openAPIDocumentGenerator.ts
โ โโโ openAPIResponseBuilders.ts
โ โโโ openAPIRouter.ts
โโโ common
โ โโโ __tests__
โ โ โโโ errorHandler.test.ts
โ โ โโโ requestLogger.test.ts
โ โโโ middleware
โ โ โโโ errorHandler.ts
โ โ โโโ rateLimiter.ts
โ โ โโโ requestLogger.ts
โ โโโ models
โ โ โโโ serviceResponse.ts
โ โโโ utils
โ โโโ commonValidation.ts
โ โโโ envConfig.ts
โ โโโ httpHandlers.ts
โโโ index.ts
โโโ server.ts
We'd love to hear your feedback and suggestions for further improvements. Feel free to contribute and join us in making backend development cleaner and faster!
๐ Happy coding!