summaryrefslogtreecommitdiff
path: root/server/providers/gateways
diff options
context:
space:
mode:
authorLogan Hunt <loganhunt@simponic.xyz>2022-03-30 22:15:20 -0600
committerLogan Hunt <loganhunt@simponic.xyz>2022-03-30 22:15:20 -0600
commit42cf50ee7521bd751f4d0f0798276e548bb83fee (patch)
tree5b2e8877a137a9b62ea630cc69135183804131d5 /server/providers/gateways
parentae0c829453d4663203887979349047850cb98626 (diff)
downloadlocchat-42cf50ee7521bd751f4d0f0798276e548bb83fee.tar.gz
locchat-42cf50ee7521bd751f4d0f0798276e548bb83fee.zip
Working
Diffstat (limited to 'server/providers/gateways')
-rw-r--r--server/providers/gateways/chat_room.gateway.ts (renamed from server/providers/gateways/ping.gateway.ts)52
1 files changed, 26 insertions, 26 deletions
diff --git a/server/providers/gateways/ping.gateway.ts b/server/providers/gateways/chat_room.gateway.ts
index 27fe785..b565d40 100644
--- a/server/providers/gateways/ping.gateway.ts
+++ b/server/providers/gateways/chat_room.gateway.ts
@@ -1,27 +1,29 @@
import { UseGuards } from '@nestjs/common';
-import { ConnectedSocket, MessageBody, OnGatewayConnection, OnGatewayDisconnect, OnGatewayInit, SubscribeMessage, WebSocketGateway, WebSocketServer, WsException } from '@nestjs/websockets';
+import {
+ ConnectedSocket,
+ MessageBody,
+ OnGatewayConnection,
+ OnGatewayDisconnect,
+ OnGatewayInit,
+ SubscribeMessage,
+ WebSocketGateway,
+ WebSocketServer,
+ WsException,
+} from '@nestjs/websockets';
import { GatewayJwtBody } from 'server/decorators/gateway_jwt_body.decorator';
import { JwtBodyDto } from 'server/dto/jwt_body.dto';
import { Server, Socket } from 'socket.io';
import { GatewayAuthGuard } from '../guards/gatewayauth.guard';
import { JwtService } from '../services/jwt.service';
-
-class JoinPayload {
- currentRoom?: string;
- newRoom: string;
-}
-
-class PingPayload {
- currentRoom: string;
-}
+import { UsersService } from '../services/users.service';
@WebSocketGateway()
@UseGuards(GatewayAuthGuard)
-export class PingGateway implements OnGatewayInit, OnGatewayConnection, OnGatewayDisconnect {
+export class ChatRoomGateway implements OnGatewayInit, OnGatewayConnection, OnGatewayDisconnect {
@WebSocketServer()
server: Server;
- constructor(private jwtService: JwtService) {}
+ constructor(private jwtService: JwtService, private userService: UsersService) {}
afterInit(server: Server) {
console.log('Sockets initialized');
@@ -36,8 +38,9 @@ export class PingGateway implements OnGatewayInit, OnGatewayConnection, OnGatewa
try {
const jwt = client.handshake.auth.token;
const jwtBody = this.jwtService.parseToken(jwt);
- console.log(client.handshake.query);
+ const chatRoomId = client.handshake.query.chatRoomId;
console.log('Client Connected: ', jwtBody.userId);
+ client.join(chatRoomId);
} catch (e) {
throw new WsException('Invalid token');
}
@@ -47,21 +50,18 @@ export class PingGateway implements OnGatewayInit, OnGatewayConnection, OnGatewa
console.log('Client Disconnected');
}
- @SubscribeMessage('ping')
- public handlePing(
+ @SubscribeMessage('message')
+ public async handleMessage(
@ConnectedSocket() client: Socket,
- @MessageBody() payload: PingPayload,
+ @MessageBody() data: string,
@GatewayJwtBody() jwtBody: JwtBodyDto,
) {
- this.server.to(payload.currentRoom).emit('pong', { message: { userId: jwtBody.userId } });
- console.log(client.rooms);
- }
-
- @SubscribeMessage('join-room')
- public async joinRoom(client: Socket, payload: JoinPayload) {
- console.log(payload);
- payload.currentRoom && (await client.leave(payload.currentRoom));
- await client.join(payload.newRoom);
- return { msg: 'Joined room', room: payload.newRoom };
+ const user = await this.userService.find(jwtBody.userId);
+ this.server.to(client.handshake.query.chatRoomId).emit('new-message', {
+ id: user.id * Math.random() * 2048 * Date.now(),
+ content: data,
+ userName: `${user.firstName} ${user.lastName}`,
+ userId: user.id,
+ });
}
}