@skalfa/skalfa-socket 1.0.0 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/workflows/publish.yml +40 -0
- package/CONTRIBUTING.md +45 -0
- package/LICENSE +21 -0
- package/README.md +55 -0
- package/dist/disconnect.d.ts +2 -0
- package/dist/disconnect.js +7 -0
- package/dist/disconnect.js.map +1 -0
- package/dist/emit.d.ts +1 -0
- package/dist/emit.js +5 -0
- package/dist/emit.js.map +1 -0
- package/dist/event-registry.d.ts +12 -0
- package/dist/event-registry.js +46 -0
- package/dist/event-registry.js.map +1 -0
- package/dist/index.d.ts +20 -23
- package/dist/index.js +23 -133
- package/dist/index.js.map +1 -1
- package/dist/join.d.ts +2 -0
- package/dist/join.js +4 -0
- package/dist/join.js.map +1 -0
- package/dist/leave.d.ts +2 -0
- package/dist/leave.js +4 -0
- package/dist/leave.js.map +1 -0
- package/dist/of.d.ts +1 -0
- package/dist/of.js +7 -0
- package/dist/of.js.map +1 -0
- package/dist/room.d.ts +3 -0
- package/dist/room.js +9 -0
- package/dist/room.js.map +1 -0
- package/dist/send.d.ts +2 -0
- package/dist/send.js +4 -0
- package/dist/send.js.map +1 -0
- package/dist/shutdown.d.ts +1 -0
- package/dist/shutdown.js +10 -0
- package/dist/shutdown.js.map +1 -0
- package/dist/start.d.ts +2 -0
- package/dist/start.js +51 -0
- package/dist/start.js.map +1 -0
- package/dist/state.d.ts +3 -0
- package/dist/state.js +5 -0
- package/dist/state.js.map +1 -0
- package/package.json +3 -3
- package/src/disconnect.ts +8 -0
- package/src/emit.ts +5 -0
- package/src/event-registry.ts +55 -0
- package/src/index.ts +25 -155
- package/src/join.ts +5 -0
- package/src/leave.ts +5 -0
- package/src/of.ts +6 -0
- package/src/room.ts +9 -0
- package/src/send.ts +5 -0
- package/src/shutdown.ts +9 -0
- package/src/start.ts +57 -0
- package/src/state.ts +7 -0
- package/bun.lock +0 -119
package/dist/start.js
ADDED
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import os from 'os';
|
|
2
|
+
import { Server } from "socket.io";
|
|
3
|
+
import { logger } from "@skalfa/skalfa-api-core";
|
|
4
|
+
import { io, setIo } from "./state";
|
|
5
|
+
import { socket } from "./index";
|
|
6
|
+
export function start(port) {
|
|
7
|
+
if (io)
|
|
8
|
+
return io;
|
|
9
|
+
const server = new Server(port, {
|
|
10
|
+
cors: {
|
|
11
|
+
origin: process.env.SOCKET_CORS_ORIGINS || "*",
|
|
12
|
+
credentials: true,
|
|
13
|
+
},
|
|
14
|
+
transports: ["websocket"],
|
|
15
|
+
});
|
|
16
|
+
setIo(server);
|
|
17
|
+
server.use(async (client, next) => {
|
|
18
|
+
try {
|
|
19
|
+
const accessKey = client.handshake.auth?.accessKey || client.handshake.headers["x-api-key"];
|
|
20
|
+
if (process.env.SOCKET_KEY) {
|
|
21
|
+
if (accessKey !== process.env.SOCKET_APP_KEY) {
|
|
22
|
+
return next(new Error("INVALID_SOCKET_KEY"));
|
|
23
|
+
}
|
|
24
|
+
;
|
|
25
|
+
}
|
|
26
|
+
next();
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
next(new Error("AUTH_ERROR"));
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
server.on("connection", (client) => {
|
|
33
|
+
logger.socket(`client connected: ${client.id}`);
|
|
34
|
+
socket.event.bind(client);
|
|
35
|
+
client.on("disconnect", (reason) => {
|
|
36
|
+
logger.socket(`client disconnected: ${client.id, reason}`);
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
function getLocalIP() {
|
|
40
|
+
const interfaces = os.networkInterfaces();
|
|
41
|
+
for (const name of Object.keys(interfaces)) {
|
|
42
|
+
for (const net of interfaces[name] || []) {
|
|
43
|
+
if (net.family === 'IPv4' && !net.internal)
|
|
44
|
+
return net.address;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
setTimeout(() => logger.start(`WS Server running on \n [LOCAL] http://localhost:${port} \n [NETWORK] http://${getLocalIP()}:${port}!`), 300);
|
|
49
|
+
return server;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=start.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../src/start.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,EAAE,MAAM,EAAU,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,MAAM,UAAU,KAAK,CAAC,IAAY;IAChC,IAAI,EAAE;QAAE,OAAO,EAAE,CAAC;IAElB,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE;QAC9B,IAAI,EAAE;YACJ,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,GAAG;YAC9C,WAAW,EAAE,IAAI;SAClB;QACD,UAAU,EAAE,CAAC,WAAW,CAAC;KAC1B,CAAC,CAAC;IAEH,KAAK,CAAC,MAAM,CAAC,CAAC;IAEd,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;QAChC,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAE5F,IAAG,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;gBAC1B,IAAI,SAAS,KAAK,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC;oBAC7C,OAAO,IAAI,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;gBAC/C,CAAC;gBAAA,CAAC;YACJ,CAAC;YAED,IAAI,EAAE,CAAC;QACT,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;QAChC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,MAAc,EAAE,EAAE;QACzC,MAAM,CAAC,MAAM,CAAC,qBAAqB,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;QAEhD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE1B,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,MAAM,EAAE,EAAE;YACjC,MAAM,CAAC,MAAM,CAAC,wBAAwB,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,SAAS,UAAU;QACjB,MAAM,UAAU,GAAG,EAAE,CAAC,iBAAiB,EAAE,CAAA;QACzC,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3C,KAAK,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;gBACzC,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,GAAG,CAAC,QAAQ;oBAAE,OAAO,GAAG,CAAC,OAAO,CAAA;YAChE,CAAC;QACH,CAAC;IACH,CAAC;IAED,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,8DAA8D,IAAI,gCAAgC,UAAU,EAAE,IAAI,IAAI,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;IAC/J,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
package/dist/state.d.ts
ADDED
package/dist/state.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.js","sourceRoot":"","sources":["../src/state.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,IAAI,EAAE,GAAkB,IAAI,CAAC;AAEpC,MAAM,UAAU,KAAK,CAAC,MAAqB;IACzC,EAAE,GAAG,MAAM,CAAC;AACd,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@skalfa/skalfa-socket",
|
|
3
|
-
"version": "1.0.
|
|
4
|
-
"description": "Socket.io
|
|
3
|
+
"version": "1.0.4",
|
|
4
|
+
"description": "Socket.io real-time server gateway and event handler extension for Skalfa backend services.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"scripts": {
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
"license": "UNLICENSED",
|
|
19
19
|
"dependencies": {
|
|
20
20
|
"socket.io": "^4.7.5",
|
|
21
|
-
"@skalfa/skalfa-api-core": "
|
|
21
|
+
"@skalfa/skalfa-api-core": "^1.0.0"
|
|
22
22
|
},
|
|
23
23
|
"devDependencies": {
|
|
24
24
|
"@types/node": "^26.0.0",
|
package/src/emit.ts
ADDED
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Socket } from "socket.io";
|
|
2
|
+
import { auth } from "@skalfa/skalfa-api-core";
|
|
3
|
+
|
|
4
|
+
type Handler = (client: Socket, data: any) => void;
|
|
5
|
+
|
|
6
|
+
export class EventRegistry {
|
|
7
|
+
private events = new Map<string, Handler[]>();
|
|
8
|
+
private authEvents = new Map<string, Handler[]>();
|
|
9
|
+
|
|
10
|
+
on(event: string, handler: Handler) {
|
|
11
|
+
if (!this.events.has(event)) {
|
|
12
|
+
this.events.set(event, []);
|
|
13
|
+
}
|
|
14
|
+
this.events.get(event)!.push(handler);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
auth() {
|
|
18
|
+
return {
|
|
19
|
+
on: (event: string, handler: Handler) => {
|
|
20
|
+
if (!this.authEvents.has(event)) {
|
|
21
|
+
this.authEvents.set(event, []);
|
|
22
|
+
}
|
|
23
|
+
this.authEvents.get(event)!.push(handler);
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
bind(client: Socket) {
|
|
29
|
+
this.events.forEach((handlers, eventName) => {
|
|
30
|
+
client.on(eventName, (data) => {
|
|
31
|
+
handlers.forEach((handler) => handler(client, data));
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
this.authEvents.forEach((handlers, eventName) => {
|
|
36
|
+
client.on(eventName, async (data) => {
|
|
37
|
+
const token = data?.accessToken;
|
|
38
|
+
|
|
39
|
+
const session = await auth.verifyAccessToken(token);
|
|
40
|
+
|
|
41
|
+
if (!session) {
|
|
42
|
+
client.emit("error", {
|
|
43
|
+
event: eventName,
|
|
44
|
+
message: "UNAUTHORIZED_USER",
|
|
45
|
+
});
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
client.data.user = {id: session.user.id, token: session.token};
|
|
50
|
+
|
|
51
|
+
handlers.forEach((handler) => handler(client, data));
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -1,197 +1,67 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
private authEvents = new Map<string, Handler[]>();
|
|
15
|
-
|
|
16
|
-
on(event: string, handler: Handler) {
|
|
17
|
-
if (!this.events.has(event)) {
|
|
18
|
-
this.events.set(event, []);
|
|
19
|
-
}
|
|
20
|
-
this.events.get(event)!.push(handler);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
auth() {
|
|
24
|
-
return {
|
|
25
|
-
on: (event: string, handler: Handler) => {
|
|
26
|
-
if (!this.authEvents.has(event)) {
|
|
27
|
-
this.authEvents.set(event, []);
|
|
28
|
-
}
|
|
29
|
-
this.authEvents.get(event)!.push(handler);
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
bind(client: Socket) {
|
|
36
|
-
this.events.forEach((handlers, eventName) => {
|
|
37
|
-
client.on(eventName, (data) => {
|
|
38
|
-
handlers.forEach((handler) => handler(client, data));
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
this.authEvents.forEach((handlers, eventName) => {
|
|
43
|
-
client.on(eventName, async (data) => {
|
|
44
|
-
const token = data?.accessToken;
|
|
45
|
-
|
|
46
|
-
const session = await auth.verifyAccessToken(token);
|
|
47
|
-
|
|
48
|
-
if (!session) {
|
|
49
|
-
client.emit("error", {
|
|
50
|
-
event: eventName,
|
|
51
|
-
message: "UNAUTHORIZED_USER",
|
|
52
|
-
});
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
client.data.user = {id: session.user.id, token: session.token};
|
|
57
|
-
|
|
58
|
-
handlers.forEach((handler) => handler(client, data));
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
}
|
|
1
|
+
import { registry } from "@skalfa/skalfa-api-core";
|
|
2
|
+
import { EventRegistry } from "./event-registry";
|
|
3
|
+
import { start } from "./start";
|
|
4
|
+
import { emit } from "./emit";
|
|
5
|
+
import { send } from "./send";
|
|
6
|
+
import { join } from "./join";
|
|
7
|
+
import { leave } from "./leave";
|
|
8
|
+
import { room } from "./room";
|
|
9
|
+
import { of } from "./of";
|
|
10
|
+
import { disconnect } from "./disconnect";
|
|
11
|
+
import { shutdown } from "./shutdown";
|
|
12
|
+
|
|
13
|
+
export { EventRegistry };
|
|
63
14
|
|
|
64
15
|
export const socket = {
|
|
65
16
|
// ===============================
|
|
66
17
|
// ## socket: start server
|
|
67
18
|
// ===============================
|
|
68
|
-
start
|
|
69
|
-
if (io) return io;
|
|
70
|
-
|
|
71
|
-
io = new Server(port, {
|
|
72
|
-
cors: {
|
|
73
|
-
origin: process.env.SOCKET_CORS_ORIGINS || "*",
|
|
74
|
-
credentials: true,
|
|
75
|
-
},
|
|
76
|
-
transports: ["websocket"],
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
io.use(async (client, next) => {
|
|
80
|
-
try {
|
|
81
|
-
const accessKey = client.handshake.auth?.accessKey || client.handshake.headers["x-api-key"];
|
|
82
|
-
|
|
83
|
-
if(process.env.SOCKET_KEY) {
|
|
84
|
-
if (accessKey !== process.env.SOCKET_APP_KEY) {
|
|
85
|
-
return next(new Error("INVALID_SOCKET_KEY"));
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
next();
|
|
90
|
-
} catch {
|
|
91
|
-
next(new Error("AUTH_ERROR"));
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
io.on("connection", (client: Socket) => {
|
|
96
|
-
logger.socket(`client connected: ${client.id}`);
|
|
97
|
-
|
|
98
|
-
socket.event.bind(client);
|
|
99
|
-
|
|
100
|
-
client.on("disconnect", (reason) => {
|
|
101
|
-
logger.socket(`client disconnected: ${client.id, reason}`);
|
|
102
|
-
});
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
function getLocalIP() {
|
|
106
|
-
const interfaces = os.networkInterfaces()
|
|
107
|
-
for (const name of Object.keys(interfaces)) {
|
|
108
|
-
for (const net of interfaces[name] || []) {
|
|
109
|
-
if (net.family === 'IPv4' && !net.internal) return net.address
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
setTimeout(() => logger.start(`WS Server running on \n [LOCAL] http://localhost:${port} \n [NETWORK] http://${getLocalIP()}:${port}!`), 300);
|
|
115
|
-
return io;
|
|
116
|
-
},
|
|
117
|
-
|
|
19
|
+
start,
|
|
118
20
|
|
|
119
21
|
// ===============================
|
|
120
22
|
// ## socket: event register
|
|
121
23
|
// ===============================
|
|
122
24
|
event: new EventRegistry(),
|
|
123
25
|
|
|
124
|
-
|
|
125
26
|
// ===============================
|
|
126
27
|
// ## socket: emit
|
|
127
28
|
// ===============================
|
|
128
|
-
emit
|
|
129
|
-
io?.emit(event, payload);
|
|
130
|
-
},
|
|
131
|
-
|
|
29
|
+
emit,
|
|
132
30
|
|
|
133
31
|
// ===============================
|
|
134
32
|
// ## socket: emit specific client
|
|
135
33
|
// ===============================
|
|
136
|
-
send
|
|
137
|
-
client.emit(event, payload);
|
|
138
|
-
},
|
|
139
|
-
|
|
34
|
+
send,
|
|
140
35
|
|
|
141
36
|
// ===============================
|
|
142
37
|
// ## socket: join room
|
|
143
38
|
// ===============================
|
|
144
|
-
join
|
|
145
|
-
client.join(room);
|
|
146
|
-
},
|
|
147
|
-
|
|
39
|
+
join,
|
|
148
40
|
|
|
149
41
|
// ===============================
|
|
150
42
|
// ## socket: leave
|
|
151
43
|
// ===============================
|
|
152
|
-
leave
|
|
153
|
-
client.leave(room);
|
|
154
|
-
},
|
|
44
|
+
leave,
|
|
155
45
|
|
|
156
46
|
// ===============================
|
|
157
|
-
// ## socket:
|
|
47
|
+
// ## socket: room
|
|
158
48
|
// ===============================
|
|
159
|
-
room
|
|
160
|
-
return {
|
|
161
|
-
emit(event: string, payload?: any) {
|
|
162
|
-
io?.to(room).emit(event, payload);
|
|
163
|
-
},
|
|
164
|
-
};
|
|
165
|
-
},
|
|
166
|
-
|
|
49
|
+
room,
|
|
167
50
|
|
|
168
51
|
// ===============================
|
|
169
52
|
// ## socket: namespace
|
|
170
53
|
// ===============================
|
|
171
|
-
of
|
|
172
|
-
if (!io) return null;
|
|
173
|
-
return io.of(namespace);
|
|
174
|
-
},
|
|
175
|
-
|
|
54
|
+
of,
|
|
176
55
|
|
|
177
56
|
// ===============================
|
|
178
57
|
// ## socket: disconnect
|
|
179
58
|
// ===============================
|
|
180
|
-
disconnect
|
|
181
|
-
if (reason) {
|
|
182
|
-
client.emit("force-disconnect", { reason });
|
|
183
|
-
}
|
|
184
|
-
client.disconnect(true);
|
|
185
|
-
},
|
|
186
|
-
|
|
59
|
+
disconnect,
|
|
187
60
|
|
|
188
61
|
// ===============================
|
|
189
62
|
// ## socket: shutdown server
|
|
190
63
|
// ===============================
|
|
191
|
-
shutdown
|
|
192
|
-
if (!io) return;
|
|
193
|
-
io.close();
|
|
194
|
-
io = null;
|
|
195
|
-
logger.socket("WS shutdown complete");
|
|
196
|
-
},
|
|
64
|
+
shutdown,
|
|
197
65
|
};
|
|
66
|
+
|
|
67
|
+
registry.register("socket", socket);
|
package/src/join.ts
ADDED
package/src/leave.ts
ADDED
package/src/of.ts
ADDED
package/src/room.ts
ADDED
package/src/send.ts
ADDED
package/src/shutdown.ts
ADDED
package/src/start.ts
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import os from 'os'
|
|
2
|
+
import { Server, Socket } from "socket.io";
|
|
3
|
+
import { logger } from "@skalfa/skalfa-api-core";
|
|
4
|
+
import { io, setIo } from "./state";
|
|
5
|
+
import { socket } from "./index";
|
|
6
|
+
|
|
7
|
+
export function start(port: number) {
|
|
8
|
+
if (io) return io;
|
|
9
|
+
|
|
10
|
+
const server = new Server(port, {
|
|
11
|
+
cors: {
|
|
12
|
+
origin: process.env.SOCKET_CORS_ORIGINS || "*",
|
|
13
|
+
credentials: true,
|
|
14
|
+
},
|
|
15
|
+
transports: ["websocket"],
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
setIo(server);
|
|
19
|
+
|
|
20
|
+
server.use(async (client, next) => {
|
|
21
|
+
try {
|
|
22
|
+
const accessKey = client.handshake.auth?.accessKey || client.handshake.headers["x-api-key"];
|
|
23
|
+
|
|
24
|
+
if(process.env.SOCKET_KEY) {
|
|
25
|
+
if (accessKey !== process.env.SOCKET_APP_KEY) {
|
|
26
|
+
return next(new Error("INVALID_SOCKET_KEY"));
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
next();
|
|
31
|
+
} catch {
|
|
32
|
+
next(new Error("AUTH_ERROR"));
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
server.on("connection", (client: Socket) => {
|
|
37
|
+
logger.socket(`client connected: ${client.id}`);
|
|
38
|
+
|
|
39
|
+
socket.event.bind(client);
|
|
40
|
+
|
|
41
|
+
client.on("disconnect", (reason) => {
|
|
42
|
+
logger.socket(`client disconnected: ${client.id, reason}`);
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
function getLocalIP() {
|
|
47
|
+
const interfaces = os.networkInterfaces()
|
|
48
|
+
for (const name of Object.keys(interfaces)) {
|
|
49
|
+
for (const net of interfaces[name] || []) {
|
|
50
|
+
if (net.family === 'IPv4' && !net.internal) return net.address
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
setTimeout(() => logger.start(`WS Server running on \n [LOCAL] http://localhost:${port} \n [NETWORK] http://${getLocalIP()}:${port}!`), 300);
|
|
56
|
+
return server;
|
|
57
|
+
}
|
package/src/state.ts
ADDED
package/bun.lock
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"lockfileVersion": 1,
|
|
3
|
-
"workspaces": {
|
|
4
|
-
"": {
|
|
5
|
-
"name": "@skalfa/skalfa-socket",
|
|
6
|
-
"dependencies": {
|
|
7
|
-
"@skalfa/skalfa-api-core": "file:../skalfa-api-core",
|
|
8
|
-
"socket.io": "^4.7.5",
|
|
9
|
-
},
|
|
10
|
-
"devDependencies": {
|
|
11
|
-
"@types/node": "^26.0.0",
|
|
12
|
-
"typescript": "^6.0.3",
|
|
13
|
-
},
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
"packages": {
|
|
17
|
-
"@borewit/text-codec": ["@borewit/text-codec@0.2.2", "", {}, "sha512-DDaRehssg1aNrH4+2hnj1B7vnUGEjU6OIlyRdkMd0aUdIUvKXrJfXsy8LVtXAy7DRvYVluWbMspsRhz2lcW0mQ=="],
|
|
18
|
-
|
|
19
|
-
"@sinclair/typebox": ["@sinclair/typebox@0.34.49", "", {}, "sha512-brySQQs7Jtn0joV8Xh9ZV/hZb9Ozb0pmazDIASBkYKCjXrXU3mpcFahmK/z4YDhGkQvP9mWJbVyahdtU5wQA+A=="],
|
|
20
|
-
|
|
21
|
-
"@skalfa/skalfa-api-core": ["@skalfa/skalfa-api-core@file:../skalfa-api-core", { "dependencies": { "@skalfa/skalfa-orm": "file:../skalfa-orm", "bcrypt": "^6.0.0", "commander": "^12.1.0", "dotenv": "^17.2.2", "elysia": "latest", "nodemailer": "^7.0.9", "validator": "^13.15.15" }, "devDependencies": { "@types/bcrypt": "^6.0.0", "@types/node": "^26.0.0", "@types/nodemailer": "^7.0.2", "@types/validator": "^13.15.3", "bun-types": "latest", "typescript": "^6.0.3" } }],
|
|
22
|
-
|
|
23
|
-
"@socket.io/component-emitter": ["@socket.io/component-emitter@3.1.2", "", {}, "sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA=="],
|
|
24
|
-
|
|
25
|
-
"@tokenizer/inflate": ["@tokenizer/inflate@0.4.1", "", { "dependencies": { "debug": "^4.4.3", "token-types": "^6.1.1" } }, "sha512-2mAv+8pkG6GIZiF1kNg1jAjh27IDxEPKwdGul3snfztFerfPGI1LjDezZp3i7BElXompqEtPmoPx6c2wgtWsOA=="],
|
|
26
|
-
|
|
27
|
-
"@tokenizer/token": ["@tokenizer/token@0.3.0", "", {}, "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A=="],
|
|
28
|
-
|
|
29
|
-
"@types/bcrypt": ["@types/bcrypt@6.0.0", "", { "dependencies": { "@types/node": "*" } }, "sha512-/oJGukuH3D2+D+3H4JWLaAsJ/ji86dhRidzZ/Od7H/i8g+aCmvkeCc6Ni/f9uxGLSQVCRZkX2/lqEFG2BvWtlQ=="],
|
|
30
|
-
|
|
31
|
-
"@types/cors": ["@types/cors@2.8.19", "", { "dependencies": { "@types/node": "*" } }, "sha512-mFNylyeyqN93lfe/9CSxOGREz8cpzAhH+E93xJ4xWQf62V8sQ/24reV2nyzUWM6H6Xji+GGHpkbLe7pVoUEskg=="],
|
|
32
|
-
|
|
33
|
-
"@types/node": ["@types/node@26.0.0", "", { "dependencies": { "undici-types": "~8.3.0" } }, "sha512-vf2YFi1iY9lHGwNJMs01biZFbKJkrZR1T6/MlzjhJLPdntOHLhTrDSnSVcdtvjihi4VQNlrFRIxLsDBlQpAipA=="],
|
|
34
|
-
|
|
35
|
-
"@types/nodemailer": ["@types/nodemailer@7.0.12", "", { "dependencies": { "@types/node": "*" } }, "sha512-80vKwiIsVSyFA1rRovH59jNPLBOuc6dRZIHEu40gXTkBkZnQv8vog1xSGEb9j5q/tdMAs5ivvDR2pLTU0hGHXA=="],
|
|
36
|
-
|
|
37
|
-
"@types/validator": ["@types/validator@13.15.10", "", {}, "sha512-T8L6i7wCuyoK8A/ZeLYt1+q0ty3Zb9+qbSSvrIVitzT3YjZqkTZ40IbRsPanlB4h1QB3JVL1SYCdR6ngtFYcuA=="],
|
|
38
|
-
|
|
39
|
-
"@types/ws": ["@types/ws@8.18.1", "", { "dependencies": { "@types/node": "*" } }, "sha512-ThVF6DCVhA8kUGy+aazFQ4kXQ7E1Ty7A3ypFOe0IcJV8O/M511G99AW24irKrW56Wt44yG9+ij8FaqoBGkuBXg=="],
|
|
40
|
-
|
|
41
|
-
"accepts": ["accepts@1.3.8", "", { "dependencies": { "mime-types": "~2.1.34", "negotiator": "0.6.3" } }, "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw=="],
|
|
42
|
-
|
|
43
|
-
"base64id": ["base64id@2.0.0", "", {}, "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog=="],
|
|
44
|
-
|
|
45
|
-
"bcrypt": ["bcrypt@6.0.0", "", { "dependencies": { "node-addon-api": "^8.3.0", "node-gyp-build": "^4.8.4" } }, "sha512-cU8v/EGSrnH+HnxV2z0J7/blxH8gq7Xh2JFT6Aroax7UohdmiJJlxApMxtKfuI7z68NvvVcmR78k2LbT6efhRg=="],
|
|
46
|
-
|
|
47
|
-
"bun-types": ["bun-types@1.3.14", "", { "dependencies": { "@types/node": "*" } }, "sha512-4N0ig0fEomHt5R0KCFWjovxow98rIoRwKolrYdCcknNwMekCXRnWEUvgu5soYV8QXtVsrUD8B95MBOZGPvr6KQ=="],
|
|
48
|
-
|
|
49
|
-
"commander": ["commander@12.1.0", "", {}, "sha512-Vw8qHK3bZM9y/P10u3Vib8o/DdkvA2OtPtZvD871QKjy74Wj1WSKFILMPRPSdUSx5RFK1arlJzEtA4PkFgnbuA=="],
|
|
50
|
-
|
|
51
|
-
"cookie": ["cookie@1.1.1", "", {}, "sha512-ei8Aos7ja0weRpFzJnEA9UHJ/7XQmqglbRwnf2ATjcB9Wq874VKH9kfjjirM6UhU2/E5fFYadylyhFldcqSidQ=="],
|
|
52
|
-
|
|
53
|
-
"cors": ["cors@2.8.6", "", { "dependencies": { "object-assign": "^4", "vary": "^1" } }, "sha512-tJtZBBHA6vjIAaF6EnIaq6laBBP9aq/Y3ouVJjEfoHbRBcHBAHYcMh/w8LDrk2PvIMMq8gmopa5D4V8RmbrxGw=="],
|
|
54
|
-
|
|
55
|
-
"debug": ["debug@4.4.3", "", { "dependencies": { "ms": "^2.1.3" } }, "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA=="],
|
|
56
|
-
|
|
57
|
-
"dotenv": ["dotenv@17.4.2", "", {}, "sha512-nI4U3TottKAcAD9LLud4Cb7b2QztQMUEfHbvhTH09bqXTxnSie8WnjPALV/WMCrJZ6UV/qHJ6L03OqO3LcdYZw=="],
|
|
58
|
-
|
|
59
|
-
"elysia": ["elysia@1.4.29", "", { "dependencies": { "cookie": "^1.1.1", "exact-mirror": "^0.2.7", "fast-decode-uri-component": "^1.0.1", "memoirist": "^0.4.0" }, "peerDependencies": { "@sinclair/typebox": ">= 0.34.0 < 1", "@types/bun": ">= 1.2.0", "file-type": ">= 20.0.0", "openapi-types": ">= 12.0.0", "typescript": ">= 5.0.0" }, "optionalPeers": ["@types/bun", "typescript"] }, "sha512-GwMRGGwSdjfPt+w3LA0fqTuYJtS8uVRJicvoar98/HrO5qdFKDc9CwjIb6Kja+v39lkY+58hr2JvdR9jQzlUuA=="],
|
|
60
|
-
|
|
61
|
-
"engine.io": ["engine.io@6.6.9", "", { "dependencies": { "@types/cors": "^2.8.12", "@types/node": ">=10.0.0", "@types/ws": "^8.5.12", "accepts": "~1.3.4", "base64id": "2.0.0", "cookie": "~0.7.2", "cors": "~2.8.5", "debug": "~4.4.1", "engine.io-parser": "~5.2.1", "ws": "~8.21.0" } }, "sha512-clKkw4C7nJ22mGgoVcCg6V/W/TxdNyIOTr89k2ONZu81qqkddPFDF0LXcbAwhzPD8DjkiRCjzuiO6Y+fkpD4vg=="],
|
|
62
|
-
|
|
63
|
-
"engine.io-parser": ["engine.io-parser@5.2.3", "", {}, "sha512-HqD3yTBfnBxIrbnM1DoD6Pcq8NECnh8d4As1Qgh0z5Gg3jRRIqijury0CL3ghu/edArpUYiYqQiDUQBIs4np3Q=="],
|
|
64
|
-
|
|
65
|
-
"exact-mirror": ["exact-mirror@0.2.7", "", { "peerDependencies": { "@sinclair/typebox": "^0.34.15" }, "optionalPeers": ["@sinclair/typebox"] }, "sha512-+MeEmDcLA4o/vjK2zujgk+1VTxPR4hdp23qLqkWfStbECtAq9gmsvQa3LW6z/0GXZyHJobrCnmy1cdeE7BjsYg=="],
|
|
66
|
-
|
|
67
|
-
"fast-decode-uri-component": ["fast-decode-uri-component@1.0.1", "", {}, "sha512-WKgKWg5eUxvRZGwW8FvfbaH7AXSh2cL+3j5fMGzUMCxWBJ3dV3a7Wz8y2f/uQ0e3B6WmodD3oS54jTQ9HVTIIg=="],
|
|
68
|
-
|
|
69
|
-
"file-type": ["file-type@22.0.1", "", { "dependencies": { "@tokenizer/inflate": "^0.4.1", "strtok3": "^10.3.5", "token-types": "^6.1.2", "uint8array-extras": "^1.5.0" } }, "sha512-ww5Mhre0EE+jmBvOXTmXAbEMuZE7uX4a3+oRCQFNj8w++g3ev913N6tXQz0XTXbueQ5TWQfm6BdaViEHHn8bhA=="],
|
|
70
|
-
|
|
71
|
-
"ieee754": ["ieee754@1.2.1", "", {}, "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA=="],
|
|
72
|
-
|
|
73
|
-
"memoirist": ["memoirist@0.4.0", "", {}, "sha512-zxTgA0mSYELa66DimuNQDvyLq36AwDlTuVRbnQtB+VuTcKWm5Qc4z3WkSpgsFWHNhexqkIooqpv4hdcqrX5Nmg=="],
|
|
74
|
-
|
|
75
|
-
"mime-db": ["mime-db@1.52.0", "", {}, "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg=="],
|
|
76
|
-
|
|
77
|
-
"mime-types": ["mime-types@2.1.35", "", { "dependencies": { "mime-db": "1.52.0" } }, "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw=="],
|
|
78
|
-
|
|
79
|
-
"ms": ["ms@2.1.3", "", {}, "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="],
|
|
80
|
-
|
|
81
|
-
"negotiator": ["negotiator@0.6.3", "", {}, "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg=="],
|
|
82
|
-
|
|
83
|
-
"node-addon-api": ["node-addon-api@8.8.0", "", {}, "sha512-c5Ko1fZJIJmzhFIkhRN76WTq+fC6tWnGy9CXA0fA+XygsWZmEwG8vmbkNqxMyoaa0Tin4djul49NzdVcJJcjeA=="],
|
|
84
|
-
|
|
85
|
-
"node-gyp-build": ["node-gyp-build@4.8.4", "", { "bin": { "node-gyp-build": "bin.js", "node-gyp-build-optional": "optional.js", "node-gyp-build-test": "build-test.js" } }, "sha512-LA4ZjwlnUblHVgq0oBF3Jl/6h/Nvs5fzBLwdEF4nuxnFdsfajde4WfxtJr3CaiH+F6ewcIB/q4jQ4UzPyid+CQ=="],
|
|
86
|
-
|
|
87
|
-
"nodemailer": ["nodemailer@7.0.13", "", {}, "sha512-PNDFSJdP+KFgdsG3ZzMXCgquO7I6McjY2vlqILjtJd0hy8wEvtugS9xKRF2NWlPNGxvLCXlTNIae4serI7dinw=="],
|
|
88
|
-
|
|
89
|
-
"object-assign": ["object-assign@4.1.1", "", {}, "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg=="],
|
|
90
|
-
|
|
91
|
-
"openapi-types": ["openapi-types@12.1.3", "", {}, "sha512-N4YtSYJqghVu4iek2ZUvcN/0aqH1kRDuNqzcycDxhOUpg7GdvLa2F3DgS6yBNhInhv2r/6I0Flkn7CqL8+nIcw=="],
|
|
92
|
-
|
|
93
|
-
"socket.io": ["socket.io@4.8.3", "", { "dependencies": { "accepts": "~1.3.4", "base64id": "~2.0.0", "cors": "~2.8.5", "debug": "~4.4.1", "engine.io": "~6.6.0", "socket.io-adapter": "~2.5.2", "socket.io-parser": "~4.2.4" } }, "sha512-2Dd78bqzzjE6KPkD5fHZmDAKRNe3J15q+YHDrIsy9WEkqttc7GY+kT9OBLSMaPbQaEd0x1BjcmtMtXkfpc+T5A=="],
|
|
94
|
-
|
|
95
|
-
"socket.io-adapter": ["socket.io-adapter@2.5.8", "", { "dependencies": { "debug": "~4.4.1", "ws": "~8.21.0" } }, "sha512-6Oy52pbg+kvdCVvjcN+FnY7BvxZ7cIHNScbvztT/It5d0vbwoJoVZmF2gjJmnV0/4WlXRfG15zc45ySk9Ah8bw=="],
|
|
96
|
-
|
|
97
|
-
"socket.io-parser": ["socket.io-parser@4.2.6", "", { "dependencies": { "@socket.io/component-emitter": "~3.1.0", "debug": "~4.4.1" } }, "sha512-asJqbVBDsBCJx0pTqw3WfesSY0iRX+2xzWEWzrpcH7L6fLzrhyF8WPI8UaeM4YCuDfpwA/cgsdugMsmtz8EJeg=="],
|
|
98
|
-
|
|
99
|
-
"strtok3": ["strtok3@10.3.5", "", { "dependencies": { "@tokenizer/token": "^0.3.0" } }, "sha512-ki4hZQfh5rX0QDLLkOCj+h+CVNkqmp/CMf8v8kZpkNVK6jGQooMytqzLZYUVYIZcFZ6yDB70EfD8POcFXiF5oA=="],
|
|
100
|
-
|
|
101
|
-
"token-types": ["token-types@6.1.2", "", { "dependencies": { "@borewit/text-codec": "^0.2.1", "@tokenizer/token": "^0.3.0", "ieee754": "^1.2.1" } }, "sha512-dRXchy+C0IgK8WPC6xvCHFRIWYUbqqdEIKPaKo/AcTUNzwLTK6AH7RjdLWsEZcAN/TBdtfUw3PYEgPr5VPr6ww=="],
|
|
102
|
-
|
|
103
|
-
"typescript": ["typescript@6.0.3", "", { "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" } }, "sha512-y2TvuxSZPDyQakkFRPZHKFm+KKVqIisdg9/CZwm9ftvKXLP8NRWj38/ODjNbr43SsoXqNuAisEf1GdCxqWcdBw=="],
|
|
104
|
-
|
|
105
|
-
"uint8array-extras": ["uint8array-extras@1.5.0", "", {}, "sha512-rvKSBiC5zqCCiDZ9kAOszZcDvdAHwwIKJG33Ykj43OKcWsnmcBRL09YTU4nOeHZ8Y2a7l1MgTd08SBe9A8Qj6A=="],
|
|
106
|
-
|
|
107
|
-
"undici-types": ["undici-types@8.3.0", "", {}, "sha512-j375ScV60dom+YkPFIfTLcOiPxkN/buHz5GobjLhixFuANaNs3C9l4GmrWqejgXWJ7BbJcFYpTEUkS1Ge8bpZQ=="],
|
|
108
|
-
|
|
109
|
-
"validator": ["validator@13.15.35", "", {}, "sha512-TQ5pAGhd5whStmqWvYF4OjQROlmv9SMFVt37qoCBdqRffuuklWYQlCNnEs2ZaIBD1kZRNnikiZOS1eqgkar0iw=="],
|
|
110
|
-
|
|
111
|
-
"vary": ["vary@1.1.2", "", {}, "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg=="],
|
|
112
|
-
|
|
113
|
-
"ws": ["ws@8.21.0", "", { "peerDependencies": { "bufferutil": "^4.0.1", "utf-8-validate": ">=5.0.2" }, "optionalPeers": ["bufferutil", "utf-8-validate"] }, "sha512-Vsp28b7DRcimFQvrqu2Wek3z1iYxDCWqHYB8Qsnk/S4RfaCQzPGPyBNuVjJV3cd6UiKtUtp6sNM77gWvzcCH+g=="],
|
|
114
|
-
|
|
115
|
-
"@skalfa/skalfa-api-core/@skalfa/skalfa-orm": ["@skalfa/skalfa-orm@file:..\\skalfa-orm", {}],
|
|
116
|
-
|
|
117
|
-
"engine.io/cookie": ["cookie@0.7.2", "", {}, "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w=="],
|
|
118
|
-
}
|
|
119
|
-
}
|