forked from noxious/server
World load improvement
This commit is contained in:
parent
ad56cfe3a5
commit
2490b08479
@ -8,13 +8,18 @@ interface IPayload {
|
|||||||
zoneId: number;
|
zoneId: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface IResponse {
|
||||||
|
zone: Zone;
|
||||||
|
characters: Character[];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle character zone request event
|
* Handle character zone request event
|
||||||
* @param socket
|
* @param socket
|
||||||
* @param io
|
* @param io
|
||||||
*/
|
*/
|
||||||
export default function (socket: TSocket, io: Server) {
|
export default function (socket: TSocket, io: Server) {
|
||||||
socket.on('character:zone:request', async (data: IPayload) => {
|
socket.on('character:zone:request', async (data: IPayload, callback: (response: IResponse) => void) => {
|
||||||
console.log(`---User ${socket.character?.id} has requested zone.`);
|
console.log(`---User ${socket.character?.id} has requested zone.`);
|
||||||
|
|
||||||
if (!data.zoneId) {
|
if (!data.zoneId) {
|
||||||
@ -32,10 +37,7 @@ export default function (socket: TSocket, io: Server) {
|
|||||||
socket.join(zone.id.toString());
|
socket.join(zone.id.toString());
|
||||||
|
|
||||||
// send over zone and characters to socket
|
// send over zone and characters to socket
|
||||||
socket.emit('character:zone:load', {
|
callback({zone, characters: ZoneManager.getCharactersInZone(zone.id)});
|
||||||
zone: zone,
|
|
||||||
characters: ZoneManager.getCharactersInZone(zone.id),
|
|
||||||
});
|
|
||||||
|
|
||||||
// let other clients know of new character
|
// let other clients know of new character
|
||||||
io.to(zone.id.toString()).emit('zone:character:join', socket.character);
|
io.to(zone.id.toString()).emit('zone:character:join', socket.character);
|
||||||
@ -44,8 +46,3 @@ export default function (socket: TSocket, io: Server) {
|
|||||||
ZoneManager.addCharacterToZone(zone.id, socket.character as Character);
|
ZoneManager.addCharacterToZone(zone.id, socket.character as Character);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Resources:
|
|
||||||
* https://stackoverflow.com/questions/6873607/socket-io-rooms-difference-between-broadcast-to-and-sockets-in
|
|
||||||
*/
|
|
@ -1,5 +1,5 @@
|
|||||||
import { Socket } from 'socket.io';
|
import { Socket } from 'socket.io';
|
||||||
import {Character, Character as ICharacter, User} from "@prisma/client";
|
import {Character, User} from "@prisma/client";
|
||||||
|
|
||||||
export type TSocket = Socket & {
|
export type TSocket = Socket & {
|
||||||
user?: User
|
user?: User
|
||||||
@ -18,7 +18,7 @@ export type TSocket = Socket & {
|
|||||||
|
|
||||||
export type TCharacter = Socket & {
|
export type TCharacter = Socket & {
|
||||||
user?: User,
|
user?: User,
|
||||||
character?: ICharacter
|
character?: Character
|
||||||
}
|
}
|
||||||
|
|
||||||
export type TZoneCharacter = Character & {
|
export type TZoneCharacter = Character & {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user