https://github.com/iamnnort/nestjs-serializer
  
  
    Serialization module for NestJS - Efficient - Flexible - Streamlined 
    https://github.com/iamnnort/nestjs-serializer
  
deserialization dto mapping nestjs serialization serializer transform
        Last synced: 7 months ago 
        JSON representation
    
Serialization module for NestJS - Efficient - Flexible - Streamlined
- Host: GitHub
- URL: https://github.com/iamnnort/nestjs-serializer
- Owner: iamnnort
- License: mit
- Created: 2024-10-11T22:52:50.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-12T23:32:34.000Z (11 months ago)
- Last Synced: 2025-03-18T06:55:31.699Z (7 months ago)
- Topics: deserialization, dto, mapping, nestjs, serialization, serializer, transform
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/@iamnnort/nestjs-serializer
- Size: 149 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE.md
- Security: SECURITY.md
 
Awesome Lists containing this project
README
          ## Info
Serialization module for NestJS - Efficient - Flexible - Streamlined
## Installation
```bash
yarn install @iamnnort/nestjs-serializer
```
## Usage
```javascript
// types.ts
export enum Scopes {
  BASE = 'BASE',
  FULL = 'FULL',
}
// model.ts
import { SerializeField } from '@iamnnort/nestjs-serializer';
import { Scopes } from './types';
export class Model {
  @SerializeField([{ scopes: [Scopes.BASE] }])
  id: number;
  constructor(dto: { id: number }) {
    this.id = dto.id;
  }
}
// city.ts
import { SerializeField } from '@iamnnort/nestjs-serializer';
import { Model } from './model';
import { Scopes } from './types';
export class City extends Model {
  @SerializeField([{ scopes: [Scopes.FULL] }])
  name: string;
  constructor(dto: { id: number; name: string }) {
    super(dto);
    this.name = dto.name;
  }
}
// user.ts
import { SerializeField, SerializeRelation } from '@iamnnort/nestjs-serializer';
import { City } from './city';
import { Model } from './model';
import { Scopes } from './types';
export class User extends Model {
  @SerializeField([{ scopes: [Scopes.FULL] }])
  name: string;
  @SerializeRelation([{ scopes: [Scopes.FULL], relationScopes: [Scopes.BASE, Scopes.FULL] }])
  city: City;
  constructor(dto: { id: number; name: string; city: City }) {
    super(dto);
    this.name = dto.name;
    this.city = dto.city;
  }
}
// controller.ts
import { Controller, Get, Post, UseInterceptors } from '@nestjs/common';
import { SerializerIdInterceptor, SerializerInterceptor } from '@iamnnort/nestjs-serializer';
import { User } from './user';
import { Scopes } from './types';
import { City } from './city';
@Controller()
export class AppController {
  @Get()
  @UseInterceptors(SerializerInterceptor({ scopes: [Scopes.BASE] }))
  search() {
    const city = new City({
      id: 1,
      name: 'London',
    });
    const user = new User({
      id: 1,
      name: 'John',
      city,
    });
    return [user];
  }
  @Get(':id')
  @UseInterceptors(SerializerInterceptor({ scopes: [Scopes.BASE, Scopes.FULL] }))
  get() {
    const city = new City({
      id: 1,
      name: 'London',
    });
    const user = new User({
      id: 1,
      name: 'John',
      city,
    });
    return user;
  }
  @Post()
  @UseInterceptors(SerializerIdInterceptor)
  create() {
    const city = new City({
      id: 1,
      name: 'London',
    });
    const user = new User({
      id: 1,
      name: 'John',
      city,
    });
    return user;
  }
}
// module.ts
import { Module } from '@nestjs/common';
import { LoggerModule } from '@iamnnort/nestjs-logger';
import { SerializerModule } from '@iamnnort/nestjs-serializer';
import { Model } from './model';
import { AppController } from './controller';
@Module({
  imports: [
    LoggerModule,
    SerializerModule.register({
      globalEntityNames: [Model.name],
    }),
  ],
  controllers: [AppController],
})
export class AppModule {}
// index.ts
import { NestFactory } from '@nestjs/core';
import { LoggerService } from '@iamnnort/nestjs-logger';
import { AppModule } from './module';
async function bootstrap() {
  const app = await NestFactory.create(AppModule, {
    bufferLogs: true,
  });
  app.useLogger(new LoggerService());
  await app.listen(3000);
}
bootstrap();
```
## Output
```bash
[System] Application is starting...
[System] Application started.
[System] [Request] GET /
[System] [Response] GET / 200 OK [{ id: 1 }]
[System] [Request] GET /1
[System] [Response] GET /1 200 OK [{ id: 1, name: "John", city: { id: 1, name: "London" } }]
[System] [Request] POST /1
[System] [Response] POST /1 201 Created { id: 1 }
```
## License
This project is licensed under the MIT license. See the [LICENSE](LICENSE) file for more info.