Skip to content

SocketUseBefore

@tsed/socketio

Usage

typescript
import { SocketUseBefore } from "@tsed/socketio";

See /packages/third-parties/socketio/src/types/decorators/socketUseBefore.ts.

Overview

ts
function SocketUseBefore(...middlewares: Type<any>[]): (target: any, propertyKey?: string, descriptor?: PropertyDescriptor) => void;

Description

Attach a Socket Middleware to a method or a class.

Example

A middleware can be also used on a SocketService either on a class or on a method.

Here an example of a middleware:

typescript
@SocketMiddleware()
export class UserConverterSocketMiddleware {
    constructor(private converterService: ConverterService) {
    }
    async use(@Args() args: any[]) {

        let [user] = args;
        // update Arguments
        user = ConverterService.deserialize(user, User);

        return [user];
    }
}

The user instance will be forwarded to the next middleware and to your decorated method.

Then:

typescript
import {SocketService, SocketUseAfter, SocketUseBefore, Emit, Input, Args} from "@tsed/socketio";
import {UserConverterSocketMiddleware} from "../middlewares.js";
import {User} from "../models/User.js";

@SocketService("/my-namespace")
@SocketUseBefore(UserConverterSocketMiddleware) // global version
export class MySocketService {

   @Input("eventName")
   @Emit("responseEventName") // or Broadcast or BroadcastOthers
   @SocketUseBefore(UserConverterSocketMiddleware)
   async myMethod(@Args(0) user: User) {

       console.log(user);

       return user;
   }
}

Released under the MIT License.