@crdsyntax/mondb-module
v1.2.0
Published
π οΈ Generate Module Script
Readme
π οΈ Generate Module Script
This script automates the creation of a NestJS module with Mongoose integration. It scaffolds all the essential files and folders for a new module, including DTOs, schema, service, resource, controller, and module definition.
π Features
Creates a complete NestJS module structure automatically.
Generates folders:
services/
controllers/
dto/
schemas/
resources/
tests/
Pre-generates:
Mongoose schema with timestamps.
DTOs (create and update).
Resource class for database access with CRUD operations.
Service class to handle business logic.
Controller with REST endpoints.
NestJS module preconfigured with MongooseModule.
π¦ Usage
Run the script with the desired module name:
node scripts/generate-module.js ModuleName
ModuleName should be in PascalCase (e.g., User, Product, Order).
Example:
node scripts/generate-module.js User
ποΈ What it Generates
For a module named User, the script will create:
src/user/ βββ controllers/ β βββ user.controller.ts βββ dto/ β βββ create-user.dto.ts β βββ update-user.dto.ts βββ resources/ β βββ user.resource.ts βββ schemas/ β βββ user.schema.ts βββ services/ β βββ user.service.ts βββ tests/ βββ user.module.ts
π Generated Files
Schema β Defines the Mongoose schema with timestamps.
DTOs β For validation and API docs (create and update).
Resource β Encapsulates direct database operations.
Service β Handles business logic using the resource.
Controller β Provides REST endpoints (CRUD + count).
Module β Registers schema, service, resource, and controller with NestJS.
β‘ Benefits
Saves time by automating repetitive boilerplate code.
Ensures consistent structure across all modules.
Ready-to-use CRUD module with minimal adjustments.
Integrates seamlessly with NestJS + Mongoose.
β Example Endpoints (for User)
POST /user β Create a new user
GET /user β Get all users
GET /user/:id β Get a user by ID
PATCH /user/:id β Update a user
DELETE /user/:id β Delete a user
GET /user/count/all β Get total count of users
