티스토리 뷰

Nest

#6 Nest Gateway

림디 2024. 12. 6. 15:00

종속성 주입, 데코레이터, 예외 필터, 파이프, 가드, 인터셉터 등 이 문서의 다른 곳에서 설명하는 대부분의 개념은 게이트웨이에도 동일하게 적용됩니다. Nest는 가능한 경우 구현 세부 사항을 추상화하여 동일한 구성 요소가 HTTP 기반 플랫폼, 웹소켓 및 마이크로서비스에서 실행될 수 있도록 합니다.

Nest에서 게이트웨이는 @WebSocketGateway() 데코레이터로 주석을 단 클래스일 뿐입니다. 기술적으로 게이트웨이는 플랫폼에 구애받지 않으므로 어댑터가 생성되면 모든 WebSockets 라이브러리와 호환됩니다. 기본적으로 지원되는 WS 플랫폼은 socket.io와 ws의 두 가지입니다.

게이트웨이는 프로바이더로 취급될 수 있으며, 이는 클래스 생성자를 통해 종속성을 주입할 수 있음을 의미합니다. 또한 게이트웨이는 다른 클래스(프로바이더 및 컨트롤러)에서도 주입할 수 있습니다.

사용하기 위해서는 다음과 같은 패키지를 설치해야합니다. 

@nestjs/websockets @nestjs/platform-socket.io


nest cli 명령어를 통하여  nest g module events, nest g ga events 모듈과 게이트 웨이를 만들어 사용 하면 편리합니다.

@SubcribeMessage 데코레이터를 활용하여 이벤트 핸들러 예시 

@SubscribeMessage('events')
handleEvent(@MessageBody() data: string): string {
  return data;
}
@SubscribeMessage('events')
handleEvent(@MessageBody('id') id: number): number {
  // id === messageBody.id
  return id;
}
@SubscribeMessage('events')
handleEvent(client: Socket, data: string): string {
  return data;
}
@SubscribeMessage('events')
handleEvent(
  @MessageBody() data: string,
  @ConnectedSocket() client: Socket,
): string {
  return data;
}

플랫폼별 서버 인스턴스에 직접 액세스 예시

@WebSocketServer()
server: Server;

or

@WebSocketServer({ namespace: 'my-namespace' })
namespace: Namespace;


Nest JS 공식 사이트에서 제공 하는 예시: https://github.com/nestjs/nest/tree/master/sample/02-gateways

출처:
https://docs.nestjs.com/websockets/gateways

'Nest' 카테고리의 다른 글

#5 Nest 모듈 (Module)  (1) 2024.12.05
#4 Nest 커스텀 프로바이더  (0) 2024.12.05
#3 Nest 프로바이더(Provider)  (0) 2024.12.04
#2 Nest Controller  (1) 2024.12.04
#1 Nest 와 데코레이터(Decorator)  (0) 2024.12.04
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함