aboutsummaryrefslogtreecommitdiff
path: root/src/ServerUtils.ts
diff options
context:
space:
mode:
authorbobzel <zzzman@gmail.com>2024-05-14 23:15:24 -0400
committerbobzel <zzzman@gmail.com>2024-05-14 23:15:24 -0400
commit3534aaf88a3c30a474b3b5a5b7f04adfe6f15fac (patch)
tree47fb7a8671b209bd4d76e0f755a5b035c6936607 /src/ServerUtils.ts
parent87bca251d87b5a95da06b2212400ce9427152193 (diff)
parent5cb7ad90e120123ca572e8ef5b1aa6ca41581134 (diff)
Merge branch 'restoringEslint' into sarah-ai-visualization
Diffstat (limited to 'src/ServerUtils.ts')
-rw-r--r--src/ServerUtils.ts27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/ServerUtils.ts b/src/ServerUtils.ts
new file mode 100644
index 000000000..ade4ca35d
--- /dev/null
+++ b/src/ServerUtils.ts
@@ -0,0 +1,27 @@
+import { Socket } from 'socket.io';
+import { Message } from './server/Message';
+import { Utils } from './Utils';
+
+export namespace ServerUtils {
+ export function Emit<T>(socket: Socket, message: Message<T>, args: T) {
+ Utils.log('Emit', message.Name, args, false);
+ socket.emit(message.Message, args);
+ }
+
+ export function AddServerHandler<T>(socket: Socket, message: Message<T>, handler: (args: T) => any) {
+ socket.on(message.Message, Utils.loggingCallback('Incoming', handler, message.Name));
+ }
+
+ export function AddServerHandlerCallback<T>(socket: Socket, message: Message<T>, handler: (args: [T, (res: any) => any]) => any) {
+ socket.on(message.Message, (arg: T, fn: (res: any) => any) => {
+ Utils.log('S receiving', message.Name, arg, true);
+ handler([arg, Utils.loggingCallback('S sending', fn, message.Name)]);
+ });
+ }
+ export type RoomHandler = (socket: Socket, room: string) => any;
+ export type UsedSockets = Socket;
+ export type RoomMessage = 'create or join' | 'created' | 'joined';
+ export function AddRoomHandler(socket: Socket, message: RoomMessage, handler: RoomHandler) {
+ socket.on(message, (room: any) => handler(socket, room));
+ }
+}