Skip to content

A best practice for NestJS framework with using Prisma + Postgres, Socket.IO, Zod and Vitest

License

Notifications You must be signed in to change notification settings

hasmokan/nest-http-prisma-zod

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Nest Http Template

A best practice for using Prisma + Postgres, Socket.IO (Guest or authentication required) and Zod data validation. And it covers unit testing and integration testing.

Which Tech Stack In Use

  • Framework: NestJS (Based on Fastify)
  • Language: TypeScript (Best practices, Not AnyScript)
  • Database ODM: Prisma (Fully type-safe schema and query)
  • Data Validation: Zod
  • Testing: Vitest
  • Package Manager: pnpm
  • DevOps: Docker
  • Other: Monorepo, Prettier, ESLint, Husky, Bump Version, etc.

Run in docker compose

  1. Copy and adjust .env.template to .env
cp .env.template .env
vim .env
docker build . -t innei/nest-http-prisma-zod
docker compose up

How to start development

pnpm run init # first time
npm run dev

Before you start dev, do not forget copy .env.template to .env

Using this template for your own project

Just tap the Fork button.

Write an service unit test

Write an route integration test

TODO

  • Custom Logger without consola
  • Prisma pagination implementation
  • Fully testing unit and e2e
  • Data caching and API caching without cache-manager

License

2023 © Innei, Released under the MIT License.

Personal Website · GitHub @Innei

About

A best practice for NestJS framework with using Prisma + Postgres, Socket.IO, Zod and Vitest

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 96.1%
  • Shell 2.8%
  • JavaScript 1.1%