Refactor and fix error hydration message socket io
- Position message send will be on format : message : userId : user identification roomId: room identification position: position of user in map x: user x position on map y: user y position on map - Create Point object and interface to have position x and y of user in map.
This commit is contained in:
parent
ba47d8b1d4
commit
e8da727cae
5 changed files with 49 additions and 17 deletions
|
@ -1,8 +1,8 @@
|
|||
import socketIO = require('socket.io');
|
||||
import {Socket} from "socket.io";
|
||||
import * as http from "http";
|
||||
import {MessageUserPosition} from "@Model/Websocket/MessageUserPosition";
|
||||
import {ExSocketInterface} from "@Model/Websocket/ExSocketInterface";
|
||||
import {MessageUserPosition} from "../Model/Websocket/MessageUserPosition"; //TODO fix to use "_Model/.."
|
||||
import {ExSocketInterface} from "../Model/Websocket/ExSocketInterface"; //TODO fix to use "_Model/.."
|
||||
import Jwt, {JsonWebTokenError} from "jsonwebtoken";
|
||||
|
||||
const SECRET_KEY = process.env.SECRET_KEY || "THECODINGMACHINE_SECRET_KEY";
|
||||
|
@ -35,19 +35,29 @@ export class IoSocketController{
|
|||
message :
|
||||
userId : user identification
|
||||
roomId: room identification
|
||||
positionXUser: user x position map
|
||||
positionYUser: user y position on map
|
||||
position: position of user in map
|
||||
x: user x position on map
|
||||
y: user y position on map
|
||||
*/
|
||||
socket.on('join-room', (message : MessageUserPosition) => {
|
||||
socket.join(message.roomId);
|
||||
socket.on('join-room', (message : string) => {
|
||||
let messageUserPosition = new MessageUserPosition(message);
|
||||
socket.join(messageUserPosition.roomId);
|
||||
// sending to all clients in room except sender
|
||||
socket.to(message.roomId).emit('join-room', message.toString());
|
||||
this.saveUserPosition((socket as ExSocketInterface), messageUserPosition);
|
||||
socket.to(messageUserPosition.roomId).emit('join-room', messageUserPosition.toString());
|
||||
});
|
||||
|
||||
socket.on('user-position', (message : MessageUserPosition) => {
|
||||
socket.on('user-position', (message : string) => {
|
||||
let messageUserPosition = new MessageUserPosition(message);
|
||||
// sending to all clients in room except sender
|
||||
socket.to(message.roomId).emit('join-room', message.toString());
|
||||
this.saveUserPosition((socket as ExSocketInterface), messageUserPosition);
|
||||
socket.to(messageUserPosition.roomId).emit('join-room', messageUserPosition.toString());
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
//permit to save user position in socket
|
||||
saveUserPosition(socket : ExSocketInterface, message : MessageUserPosition){
|
||||
socket.position = message.position;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue