@lagless/relay-game-server 0.0.33
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/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/lib/cors.d.ts +3 -0
- package/dist/lib/cors.d.ts.map +1 -0
- package/dist/lib/cors.js +13 -0
- package/dist/lib/latency-setup.d.ts +9 -0
- package/dist/lib/latency-setup.d.ts.map +1 -0
- package/dist/lib/latency-setup.js +46 -0
- package/dist/lib/relay-game-server.d.ts +14 -0
- package/dist/lib/relay-game-server.d.ts.map +1 -0
- package/dist/lib/relay-game-server.js +155 -0
- package/dist/lib/token.d.ts +8 -0
- package/dist/lib/token.d.ts.map +1 -0
- package/dist/lib/token.js +14 -0
- package/dist/lib/types.d.ts +31 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +1 -0
- package/dist/lib/ws-router.d.ts +43 -0
- package/dist/lib/ws-router.d.ts.map +1 -0
- package/dist/lib/ws-router.js +133 -0
- package/dist/tsconfig.lib.tsbuildinfo +1 -0
- package/package.json +38 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { RelayGameServer } from './lib/relay-game-server.js';
|
|
2
|
+
export type { RelayGameServerConfig, RouteHandler, RouteHelpers } from './lib/types.js';
|
|
3
|
+
export { corsHeaders, corsJson } from './lib/cors.js';
|
|
4
|
+
export { generateToken, validateToken, type MatchTokenPayload } from './lib/token.js';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,YAAY,EAAE,qBAAqB,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACxF,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,KAAK,iBAAiB,EAAE,MAAM,gBAAgB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cors.d.ts","sourceRoot":"","sources":["../../src/lib/cors.ts"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAMpD;AAED,wBAAgB,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,SAAM,GAAG,QAAQ,CAK9D"}
|
package/dist/lib/cors.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function corsHeaders() {
|
|
2
|
+
return {
|
|
3
|
+
'Access-Control-Allow-Origin': '*',
|
|
4
|
+
'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',
|
|
5
|
+
'Access-Control-Allow-Headers': 'Content-Type, Authorization',
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
export function corsJson(data, status = 200) {
|
|
9
|
+
return new Response(JSON.stringify(data), {
|
|
10
|
+
status,
|
|
11
|
+
headers: { 'Content-Type': 'application/json', ...corsHeaders() },
|
|
12
|
+
});
|
|
13
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { LatencySimulator } from '@lagless/relay-server';
|
|
2
|
+
import type { RoomRegistry } from '@lagless/relay-server';
|
|
3
|
+
import type { Logger } from '@lagless/misc';
|
|
4
|
+
export interface LatencyState {
|
|
5
|
+
simulator: LatencySimulator | null;
|
|
6
|
+
}
|
|
7
|
+
export declare function setupLatencySimulator(roomRegistry: RoomRegistry, state: LatencyState): void;
|
|
8
|
+
export declare function handleLatencyEndpoint(req: Request, roomRegistry: RoomRegistry, state: LatencyState, log: Logger): Response | Promise<Response> | null;
|
|
9
|
+
//# sourceMappingURL=latency-setup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"latency-setup.d.ts","sourceRoot":"","sources":["../../src/lib/latency-setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,gBAAgB,GAAG,IAAI,CAAC;CACpC;AAED,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,YAAY,GAClB,IAAI,CAON;AAQD,wBAAgB,qBAAqB,CACnC,GAAG,EAAE,OAAO,EACZ,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE,YAAY,EACnB,GAAG,EAAE,MAAM,GACV,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,CAiCrC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { LatencySimulator } from '@lagless/relay-server';
|
|
2
|
+
export function setupLatencySimulator(roomRegistry, state) {
|
|
3
|
+
const _origCreateRoom = roomRegistry.createRoom.bind(roomRegistry);
|
|
4
|
+
roomRegistry.createRoom = async (...args) => {
|
|
5
|
+
const room = await _origCreateRoom(...args);
|
|
6
|
+
room.latencySimulator = state.simulator;
|
|
7
|
+
return room;
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
function applySimulatorToAllRooms(roomRegistry, sim) {
|
|
11
|
+
roomRegistry.forEachRoom((room) => {
|
|
12
|
+
room.latencySimulator = sim;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
export function handleLatencyEndpoint(req, roomRegistry, state, log) {
|
|
16
|
+
if (req.method === 'GET') {
|
|
17
|
+
return Response.json(state.simulator?.config ?? { delayMs: 0, jitterMs: 0, packetLossPercent: 0 });
|
|
18
|
+
}
|
|
19
|
+
if (req.method === 'POST') {
|
|
20
|
+
return (async () => {
|
|
21
|
+
const body = (await req.json());
|
|
22
|
+
const delayMs = Number(body.delayMs ?? 0);
|
|
23
|
+
const jitterMs = Number(body.jitterMs ?? 0);
|
|
24
|
+
const packetLossPercent = Number(body.packetLossPercent ?? 0);
|
|
25
|
+
if (delayMs === 0 && jitterMs === 0 && packetLossPercent === 0) {
|
|
26
|
+
state.simulator = null;
|
|
27
|
+
applySimulatorToAllRooms(roomRegistry, null);
|
|
28
|
+
log.info('Latency simulator disabled');
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
if (state.simulator) {
|
|
32
|
+
state.simulator.setDelay(delayMs);
|
|
33
|
+
state.simulator.setJitter(jitterMs);
|
|
34
|
+
state.simulator.setPacketLoss(packetLossPercent);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
state.simulator = new LatencySimulator({ delayMs, jitterMs, packetLossPercent });
|
|
38
|
+
}
|
|
39
|
+
applySimulatorToAllRooms(roomRegistry, state.simulator);
|
|
40
|
+
log.info(`Latency simulator: delay=${delayMs}ms jitter=${jitterMs}ms loss=${packetLossPercent}%`);
|
|
41
|
+
}
|
|
42
|
+
return Response.json(state.simulator?.config ?? { delayMs: 0, jitterMs: 0, packetLossPercent: 0 });
|
|
43
|
+
})();
|
|
44
|
+
}
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { RoomRegistry } from '@lagless/relay-server';
|
|
2
|
+
import { MatchmakingService } from '@lagless/matchmaking';
|
|
3
|
+
import type { RelayGameServerConfig } from './types.js';
|
|
4
|
+
export declare class RelayGameServer {
|
|
5
|
+
private readonly _config;
|
|
6
|
+
private readonly _roomRegistry;
|
|
7
|
+
private readonly _matchmaking;
|
|
8
|
+
private readonly _latencyState;
|
|
9
|
+
constructor(config: RelayGameServerConfig);
|
|
10
|
+
start(): void;
|
|
11
|
+
get roomRegistry(): RoomRegistry;
|
|
12
|
+
get matchmaking(): MatchmakingService;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=relay-game-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relay-game-server.d.ts","sourceRoot":"","sources":["../../src/lib/relay-game-server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAoB,MAAM,uBAAuB,CAAC;AACvE,OAAO,EACL,kBAAkB,EAInB,MAAM,sBAAsB,CAAC;AAM9B,OAAO,KAAK,EAAE,qBAAqB,EAAgB,MAAM,YAAY,CAAC;AAEtE,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAwB;IAChD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAe;IAC7C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAqB;IAClD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAe;gBAEjC,MAAM,EAAE,qBAAqB;IAkGlC,KAAK,IAAI,IAAI;IA6EpB,IAAW,YAAY,IAAI,YAAY,CAEtC;IAED,IAAW,WAAW,IAAI,kBAAkB,CAE3C;CACF"}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { RoomRegistry, LatencySimulator } from '@lagless/relay-server';
|
|
2
|
+
import { MatchmakingService, InMemoryQueueStore, } from '@lagless/matchmaking';
|
|
3
|
+
import { createLogger, setLogLevel, LogLevel, UUID } from '@lagless/misc';
|
|
4
|
+
import { createWsRouter } from './ws-router.js';
|
|
5
|
+
import { generateToken, validateToken } from './token.js';
|
|
6
|
+
import { corsHeaders, corsJson } from './cors.js';
|
|
7
|
+
import { setupLatencySimulator, handleLatencyEndpoint } from './latency-setup.js';
|
|
8
|
+
export class RelayGameServer {
|
|
9
|
+
_config;
|
|
10
|
+
_roomRegistry;
|
|
11
|
+
_matchmaking;
|
|
12
|
+
_latencyState;
|
|
13
|
+
constructor(config) {
|
|
14
|
+
this._config = config;
|
|
15
|
+
setLogLevel(LogLevel.Debug);
|
|
16
|
+
const log = createLogger(config.loggerName);
|
|
17
|
+
// ─── Room Registry ────────────────────────────────────
|
|
18
|
+
this._roomRegistry = new RoomRegistry();
|
|
19
|
+
this._roomRegistry.registerRoomType(config.roomType.name, config.roomType.config, config.roomType.hooks, config.roomType.inputRegistry);
|
|
20
|
+
// ─── Matchmaking ──────────────────────────────────────
|
|
21
|
+
this._matchmaking = new MatchmakingService(new InMemoryQueueStore());
|
|
22
|
+
this._matchmaking.registerScope(config.matchmaking.scope, config.matchmaking.config);
|
|
23
|
+
const port = config.port;
|
|
24
|
+
const roomRegistry = this._roomRegistry;
|
|
25
|
+
const fillBots = config.matchmaking.fillBots ?? false;
|
|
26
|
+
this._matchmaking.setOnMatchFormed(async (match) => {
|
|
27
|
+
const { matchId, scope, players, botsNeeded } = match;
|
|
28
|
+
const allPlayers = [
|
|
29
|
+
...players.map((p) => ({
|
|
30
|
+
playerId: p.playerId,
|
|
31
|
+
isBot: false,
|
|
32
|
+
metadata: p.metadata,
|
|
33
|
+
})),
|
|
34
|
+
...(fillBots
|
|
35
|
+
? Array.from({ length: botsNeeded }, () => ({
|
|
36
|
+
playerId: crypto.randomUUID(),
|
|
37
|
+
isBot: true,
|
|
38
|
+
metadata: {},
|
|
39
|
+
}))
|
|
40
|
+
: []),
|
|
41
|
+
];
|
|
42
|
+
log.info(`Match formed: ${matchId} (${players.length}P${fillBots ? ` + ${botsNeeded}B` : ''})`);
|
|
43
|
+
const seed = UUID.fromString(matchId).asUint8();
|
|
44
|
+
await roomRegistry.createRoom({ matchId, roomType: scope, players: allPlayers }, seed, JSON.stringify({ gameType: scope }));
|
|
45
|
+
const result = new Map();
|
|
46
|
+
let slot = 0;
|
|
47
|
+
for (const p of allPlayers) {
|
|
48
|
+
if (!p.isBot) {
|
|
49
|
+
result.set(p.playerId, {
|
|
50
|
+
playerSlot: slot,
|
|
51
|
+
token: generateToken(p.playerId, matchId, slot),
|
|
52
|
+
serverUrl: `ws://localhost:${port}`,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
slot++;
|
|
56
|
+
}
|
|
57
|
+
return result;
|
|
58
|
+
});
|
|
59
|
+
this._matchmaking.setTryLateJoin((playerId, scope, metadata) => {
|
|
60
|
+
const room = roomRegistry.findRoomForLateJoin(scope);
|
|
61
|
+
if (!room)
|
|
62
|
+
return null;
|
|
63
|
+
const playerInfo = room.addPlayer(playerId, false, metadata);
|
|
64
|
+
if (!playerInfo)
|
|
65
|
+
return null;
|
|
66
|
+
return {
|
|
67
|
+
matchId: room.matchId,
|
|
68
|
+
playerData: {
|
|
69
|
+
playerSlot: playerInfo.slot,
|
|
70
|
+
token: generateToken(playerId, room.matchId, playerInfo.slot),
|
|
71
|
+
serverUrl: `ws://localhost:${port}`,
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
});
|
|
75
|
+
this._matchmaking.setCheckInterval(config.matchmaking.checkIntervalMs ?? 500);
|
|
76
|
+
// ─── Latency Simulator ────────────────────────────────
|
|
77
|
+
this._latencyState = {
|
|
78
|
+
simulator: config.initialLatency
|
|
79
|
+
? new LatencySimulator(config.initialLatency)
|
|
80
|
+
: null,
|
|
81
|
+
};
|
|
82
|
+
setupLatencySimulator(this._roomRegistry, this._latencyState);
|
|
83
|
+
}
|
|
84
|
+
start() {
|
|
85
|
+
const config = this._config;
|
|
86
|
+
const log = createLogger(config.loggerName);
|
|
87
|
+
const instanceId = crypto.randomUUID().slice(0, 8);
|
|
88
|
+
const roomRegistry = this._roomRegistry;
|
|
89
|
+
const matchmaking = this._matchmaking;
|
|
90
|
+
const latencyState = this._latencyState;
|
|
91
|
+
const customRoutes = config.customRoutes ?? [];
|
|
92
|
+
const authCustomizer = config.authResponseCustomizer;
|
|
93
|
+
const helpers = { corsHeaders, corsJson };
|
|
94
|
+
matchmaking.start();
|
|
95
|
+
const wsRouter = createWsRouter(roomRegistry, matchmaking, validateToken);
|
|
96
|
+
Bun.serve({
|
|
97
|
+
port: config.port,
|
|
98
|
+
async fetch(req, server) {
|
|
99
|
+
const wsResp = wsRouter.handleUpgrade(req, server);
|
|
100
|
+
if (wsResp !== undefined)
|
|
101
|
+
return wsResp;
|
|
102
|
+
const url = new URL(req.url);
|
|
103
|
+
// Health
|
|
104
|
+
if (url.pathname === '/health') {
|
|
105
|
+
return Response.json({
|
|
106
|
+
status: 'ok',
|
|
107
|
+
instance: instanceId,
|
|
108
|
+
rooms: roomRegistry.roomCount,
|
|
109
|
+
queue: matchmaking.getQueueCount(config.matchmaking.scope),
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
// Mock Player Auth
|
|
113
|
+
if (url.pathname === '/api/player/auth/instant' && req.method === 'POST') {
|
|
114
|
+
const playerId = crypto.randomUUID();
|
|
115
|
+
const token = btoa(JSON.stringify({ playerId, exp: Date.now() + 86_400_000 }));
|
|
116
|
+
const extra = authCustomizer ? authCustomizer(playerId) : {};
|
|
117
|
+
return corsJson({
|
|
118
|
+
token,
|
|
119
|
+
player: {
|
|
120
|
+
id: playerId,
|
|
121
|
+
username: `Player-${playerId.slice(0, 4)}`,
|
|
122
|
+
score: 0,
|
|
123
|
+
...extra,
|
|
124
|
+
},
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
// CORS preflight
|
|
128
|
+
if (req.method === 'OPTIONS') {
|
|
129
|
+
return new Response(null, { status: 204, headers: corsHeaders() });
|
|
130
|
+
}
|
|
131
|
+
// Latency endpoint
|
|
132
|
+
if (url.pathname === '/api/latency') {
|
|
133
|
+
const resp = handleLatencyEndpoint(req, roomRegistry, latencyState, log);
|
|
134
|
+
if (resp)
|
|
135
|
+
return resp;
|
|
136
|
+
}
|
|
137
|
+
// Custom routes
|
|
138
|
+
for (const handler of customRoutes) {
|
|
139
|
+
const resp = handler(req, url, helpers);
|
|
140
|
+
if (resp)
|
|
141
|
+
return resp;
|
|
142
|
+
}
|
|
143
|
+
return new Response('Not found', { status: 404 });
|
|
144
|
+
},
|
|
145
|
+
websocket: wsRouter.websocket,
|
|
146
|
+
});
|
|
147
|
+
log.info(`${config.loggerName} on http://localhost:${config.port} [${instanceId}]`);
|
|
148
|
+
}
|
|
149
|
+
get roomRegistry() {
|
|
150
|
+
return this._roomRegistry;
|
|
151
|
+
}
|
|
152
|
+
get matchmaking() {
|
|
153
|
+
return this._matchmaking;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface MatchTokenPayload {
|
|
2
|
+
playerId: string;
|
|
3
|
+
matchId: string;
|
|
4
|
+
playerSlot: number;
|
|
5
|
+
}
|
|
6
|
+
export declare function generateToken(playerId: string, matchId: string, playerSlot: number): string;
|
|
7
|
+
export declare function validateToken(token: string): MatchTokenPayload | null;
|
|
8
|
+
//# sourceMappingURL=token.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.d.ts","sourceRoot":"","sources":["../../src/lib/token.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAE3F;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,iBAAiB,GAAG,IAAI,CAQrE"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export function generateToken(playerId, matchId, playerSlot) {
|
|
2
|
+
return btoa(JSON.stringify({ playerId, matchId, playerSlot, exp: Date.now() + 60_000 }));
|
|
3
|
+
}
|
|
4
|
+
export function validateToken(token) {
|
|
5
|
+
try {
|
|
6
|
+
const p = JSON.parse(atob(token));
|
|
7
|
+
if (typeof p.exp === 'number' && p.exp < Date.now())
|
|
8
|
+
return null;
|
|
9
|
+
return { playerId: p.playerId, matchId: p.matchId, playerSlot: p.playerSlot };
|
|
10
|
+
}
|
|
11
|
+
catch {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { RoomTypeConfig, RoomHooks, InputRegistry } from '@lagless/relay-server';
|
|
2
|
+
import type { ScopeConfig } from '@lagless/matchmaking';
|
|
3
|
+
export interface RelayGameServerConfig {
|
|
4
|
+
port: number;
|
|
5
|
+
loggerName: string;
|
|
6
|
+
roomType: {
|
|
7
|
+
name: string;
|
|
8
|
+
config: RoomTypeConfig;
|
|
9
|
+
hooks: RoomHooks<unknown>;
|
|
10
|
+
inputRegistry: InputRegistry;
|
|
11
|
+
};
|
|
12
|
+
matchmaking: {
|
|
13
|
+
scope: string;
|
|
14
|
+
config: ScopeConfig;
|
|
15
|
+
fillBots?: boolean;
|
|
16
|
+
checkIntervalMs?: number;
|
|
17
|
+
};
|
|
18
|
+
initialLatency?: {
|
|
19
|
+
delayMs: number;
|
|
20
|
+
jitterMs: number;
|
|
21
|
+
packetLossPercent: number;
|
|
22
|
+
} | null;
|
|
23
|
+
authResponseCustomizer?: (playerId: string) => Record<string, unknown>;
|
|
24
|
+
customRoutes?: RouteHandler[];
|
|
25
|
+
}
|
|
26
|
+
export interface RouteHelpers {
|
|
27
|
+
corsHeaders(): Record<string, string>;
|
|
28
|
+
corsJson(data: unknown, status?: number): Response;
|
|
29
|
+
}
|
|
30
|
+
export type RouteHandler = (req: Request, url: URL, helpers: RouteHelpers) => Response | Promise<Response> | null;
|
|
31
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/lib/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE;QACR,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,cAAc,CAAC;QACvB,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;QAC1B,aAAa,EAAE,aAAa,CAAC;KAC9B,CAAC;IACF,WAAW,EAAE;QACX,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,WAAW,CAAC;QACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC1B,CAAC;IACF,cAAc,CAAC,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,iBAAiB,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACzF,sBAAsB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,YAAY,EAAE,CAAC;CAC/B;AAED,MAAM,WAAW,YAAY;IAC3B,WAAW,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;CACpD;AAED,MAAM,MAAM,YAAY,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,YAAY,KAAK,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { ServerWebSocket } from 'bun';
|
|
2
|
+
import type { RoomRegistry } from '@lagless/relay-server';
|
|
3
|
+
import type { MatchmakingService } from '@lagless/matchmaking';
|
|
4
|
+
export type WsData = {
|
|
5
|
+
readonly type: 'matchmaking';
|
|
6
|
+
playerId: string;
|
|
7
|
+
scope: string | null;
|
|
8
|
+
} | {
|
|
9
|
+
readonly type: 'match';
|
|
10
|
+
matchId: string;
|
|
11
|
+
playerId: string;
|
|
12
|
+
playerSlot: number;
|
|
13
|
+
};
|
|
14
|
+
export interface MatchTokenPayload {
|
|
15
|
+
playerId: string;
|
|
16
|
+
matchId: string;
|
|
17
|
+
playerSlot: number;
|
|
18
|
+
}
|
|
19
|
+
export type ValidateMatchToken = (token: string) => MatchTokenPayload | null;
|
|
20
|
+
/**
|
|
21
|
+
* Creates Bun WebSocket handlers that multiplex between
|
|
22
|
+
* matchmaking and relay connections based on ws.data.type.
|
|
23
|
+
*/
|
|
24
|
+
export declare function createWsRouter(roomRegistry: RoomRegistry, matchmaking: MatchmakingService, validateMatchToken: ValidateMatchToken): {
|
|
25
|
+
/**
|
|
26
|
+
* Handle HTTP upgrade requests for WebSocket connections.
|
|
27
|
+
* Returns Response if handled, undefined if not a WS route.
|
|
28
|
+
*/
|
|
29
|
+
handleUpgrade(req: Request, server: {
|
|
30
|
+
upgrade: (req: Request, opts: {
|
|
31
|
+
data: WsData;
|
|
32
|
+
}) => boolean;
|
|
33
|
+
}): Response | undefined;
|
|
34
|
+
/**
|
|
35
|
+
* Bun WebSocket handler object.
|
|
36
|
+
*/
|
|
37
|
+
websocket: {
|
|
38
|
+
open(ws: ServerWebSocket<WsData>): void;
|
|
39
|
+
message(ws: ServerWebSocket<WsData>, message: string | Buffer<ArrayBuffer>): void;
|
|
40
|
+
close(ws: ServerWebSocket<WsData>): void;
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=ws-router.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ws-router.d.ts","sourceRoot":"","sources":["../../src/lib/ws-router.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,KAAK,CAAC;AAE3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAM/D,MAAM,MAAM,MAAM,GACd;IAAE,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,GACxE;IAAE,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,CAAC;AAItF,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GAAG,CAAC,KAAK,EAAE,MAAM,KAAK,iBAAiB,GAAG,IAAI,CAAC;AAI7E;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,kBAAkB,EAC/B,kBAAkB,EAAE,kBAAkB;IAGpC;;;OAGG;uBAEI,OAAO,UACJ;QAAE,OAAO,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE;YAAE,IAAI,EAAE,MAAM,CAAA;SAAE,KAAK,OAAO,CAAA;KAAE,GACrE,QAAQ,GAAG,SAAS;IAmDvB;;OAEG;;iBAEQ,eAAe,CAAC,MAAM,CAAC;oBA4BpB,eAAe,CAAC,MAAM,CAAC,WAAW,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC;kBA6BhE,eAAe,CAAC,MAAM,CAAC;;EAetC"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { createLogger } from '@lagless/misc';
|
|
2
|
+
const log = createLogger('WsRouter');
|
|
3
|
+
// ─── WS Router ──────────────────────────────────────────────
|
|
4
|
+
/**
|
|
5
|
+
* Creates Bun WebSocket handlers that multiplex between
|
|
6
|
+
* matchmaking and relay connections based on ws.data.type.
|
|
7
|
+
*/
|
|
8
|
+
export function createWsRouter(roomRegistry, matchmaking, validateMatchToken) {
|
|
9
|
+
return {
|
|
10
|
+
/**
|
|
11
|
+
* Handle HTTP upgrade requests for WebSocket connections.
|
|
12
|
+
* Returns Response if handled, undefined if not a WS route.
|
|
13
|
+
*/
|
|
14
|
+
handleUpgrade(req, server) {
|
|
15
|
+
const url = new URL(req.url);
|
|
16
|
+
// Matchmaking WebSocket: /matchmaking?playerId=...
|
|
17
|
+
if (url.pathname === '/matchmaking') {
|
|
18
|
+
const playerId = url.searchParams.get('playerId');
|
|
19
|
+
if (!playerId) {
|
|
20
|
+
return new Response('Missing playerId', { status: 400 });
|
|
21
|
+
}
|
|
22
|
+
const upgraded = server.upgrade(req, {
|
|
23
|
+
data: { type: 'matchmaking', playerId, scope: null },
|
|
24
|
+
});
|
|
25
|
+
return upgraded ? undefined : new Response('Upgrade failed', { status: 500 });
|
|
26
|
+
}
|
|
27
|
+
// Relay match WebSocket: /match/:matchId?token=...
|
|
28
|
+
const matchRoute = url.pathname.match(/^\/match\/([a-f0-9-]+)$/);
|
|
29
|
+
if (matchRoute) {
|
|
30
|
+
const matchId = matchRoute[1];
|
|
31
|
+
const token = url.searchParams.get('token');
|
|
32
|
+
if (!token) {
|
|
33
|
+
return new Response('Missing token', { status: 401 });
|
|
34
|
+
}
|
|
35
|
+
const payload = validateMatchToken(token);
|
|
36
|
+
if (!payload || payload.matchId !== matchId) {
|
|
37
|
+
return new Response('Invalid token', { status: 403 });
|
|
38
|
+
}
|
|
39
|
+
const room = roomRegistry.getRoom(matchId);
|
|
40
|
+
if (!room) {
|
|
41
|
+
return new Response('Room not found', { status: 404 });
|
|
42
|
+
}
|
|
43
|
+
const upgraded = server.upgrade(req, {
|
|
44
|
+
data: {
|
|
45
|
+
type: 'match',
|
|
46
|
+
matchId,
|
|
47
|
+
playerId: payload.playerId,
|
|
48
|
+
playerSlot: payload.playerSlot,
|
|
49
|
+
},
|
|
50
|
+
});
|
|
51
|
+
return upgraded ? undefined : new Response('Upgrade failed', { status: 500 });
|
|
52
|
+
}
|
|
53
|
+
return undefined; // Not a WS route
|
|
54
|
+
},
|
|
55
|
+
/**
|
|
56
|
+
* Bun WebSocket handler object.
|
|
57
|
+
*/
|
|
58
|
+
websocket: {
|
|
59
|
+
open(ws) {
|
|
60
|
+
const { data } = ws;
|
|
61
|
+
if (data.type === 'match') {
|
|
62
|
+
// Bun delivers binary as Buffer by default. Switch to ArrayBuffer
|
|
63
|
+
// so `message instanceof ArrayBuffer` works in the message handler.
|
|
64
|
+
ws.binaryType = 'arraybuffer';
|
|
65
|
+
const room = roomRegistry.getRoom(data.matchId);
|
|
66
|
+
if (!room) {
|
|
67
|
+
log.warn(`open: room ${data.matchId} not found for player ${data.playerId}`);
|
|
68
|
+
ws.close();
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
log.info(`open: player=${data.playerId} slot=${data.playerSlot} match=${data.matchId}`);
|
|
72
|
+
room
|
|
73
|
+
.handlePlayerConnect(data.playerId, {
|
|
74
|
+
sendBinary: (msg) => ws.sendBinary(msg),
|
|
75
|
+
close: () => ws.close(),
|
|
76
|
+
})
|
|
77
|
+
.catch((err) => log.error(`handlePlayerConnect error: ${err}`));
|
|
78
|
+
}
|
|
79
|
+
// Matchmaking: nothing to do on open — client sends join message
|
|
80
|
+
},
|
|
81
|
+
message(ws, message) {
|
|
82
|
+
const { data } = ws;
|
|
83
|
+
if (data.type === 'match') {
|
|
84
|
+
const room = roomRegistry.getRoom(data.matchId);
|
|
85
|
+
if (!room) {
|
|
86
|
+
log.warn(`message: room ${data.matchId} gone`);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const messageArrayBuffer = message instanceof ArrayBuffer
|
|
90
|
+
? message
|
|
91
|
+
: null;
|
|
92
|
+
if (messageArrayBuffer === null) {
|
|
93
|
+
log.warn(`message: expected binary message for match ${data.matchId}, got text`);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
room.handleMessage(data.playerId, messageArrayBuffer);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
if (data.type === 'matchmaking' && typeof message === 'string') {
|
|
100
|
+
handleMatchmakingMessage(ws, data, message, matchmaking);
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
close(ws) {
|
|
105
|
+
const { data } = ws;
|
|
106
|
+
if (data.type === 'match') {
|
|
107
|
+
log.info(`close: player=${data.playerId} match=${data.matchId}`);
|
|
108
|
+
const room = roomRegistry.getRoom(data.matchId);
|
|
109
|
+
room?.handlePlayerDisconnect(data.playerId);
|
|
110
|
+
}
|
|
111
|
+
if (data.type === 'matchmaking') {
|
|
112
|
+
matchmaking.removePlayer(data.playerId);
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
function handleMatchmakingMessage(ws, data, raw, matchmaking) {
|
|
119
|
+
let msg;
|
|
120
|
+
try {
|
|
121
|
+
msg = JSON.parse(raw);
|
|
122
|
+
}
|
|
123
|
+
catch {
|
|
124
|
+
ws.send(JSON.stringify({ type: 'error', message: 'Invalid JSON' }));
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (msg.type === 'join') {
|
|
128
|
+
data.scope = msg.scope;
|
|
129
|
+
matchmaking.addPlayer(data.playerId, msg.scope, msg.mmr ?? 1000, msg.metadata ?? {}, (notification) => {
|
|
130
|
+
ws.send(JSON.stringify(notification));
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"fileNames":["../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.core.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.collection.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.generator.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.iterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.proxy.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.reflect.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.array.include.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.date.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.regexp.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.symbol.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.bigint.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.date.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.number.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.weakref.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.error.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.regexp.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.legacy.d.ts","../../../node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/tslib.d.ts","../../../node_modules/.pnpm/tslib@2.8.1/node_modules/tslib/modules/index.d.ts","../../relay-server/dist/lib/types.d.ts","../../relay-server/dist/lib/server-clock.d.ts","../../relay-server/dist/lib/player-connection.d.ts","../../binary/dist/lib/binary.d.ts","../../binary/dist/lib/types.d.ts","../../binary/dist/index.d.ts","../../net-wire/dist/lib/protocol.d.ts","../../net-wire/dist/lib/clock-sync.d.ts","../../net-wire/dist/lib/input-delay-controller.d.ts","../../net-wire/dist/lib/tick-input-buffer.d.ts","../../net-wire/dist/index.d.ts","../../relay-server/dist/lib/input-handler.d.ts","../../relay-server/dist/lib/state-transfer.d.ts","../../relay-server/dist/lib/latency-simulator.d.ts","../../relay-server/dist/lib/relay-room.d.ts","../../relay-server/dist/lib/room-registry.d.ts","../../relay-server/dist/index.d.ts","../../matchmaking/dist/lib/types.d.ts","../../matchmaking/dist/lib/queue-store.d.ts","../../matchmaking/dist/lib/match-formation.d.ts","../../matchmaking/dist/lib/matchmaking-service.d.ts","../../matchmaking/dist/index.d.ts","../../misc/dist/lib/now.d.ts","../../misc/dist/lib/uuid.d.ts","../../misc/dist/lib/ring-buffer.d.ts","../../misc/dist/lib/snapshot-history.d.ts","../../misc/dist/lib/phase-nudger.d.ts","../../misc/dist/lib/simulation-clock.d.ts","../../misc/dist/lib/transform2d-utils.d.ts","../../misc/dist/lib/visual-smoother-2d.d.ts","../../misc/dist/lib/logger.d.ts","../../misc/dist/index.d.ts","../../../node_modules/.pnpm/buffer@6.0.3/node_modules/buffer/index.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/header.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/readable.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/compatibility/disposable.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/compatibility/indexable.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/compatibility/iterators.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/compatibility/index.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/globals.typedarray.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/buffer.buffer.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/globals.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/assert.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/assert/strict.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/async_hooks.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/buffer.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/child_process.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/cluster.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/console.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/constants.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/crypto.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/dgram.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/diagnostics_channel.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/dns.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/dns/promises.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/domain.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/dom-events.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/events.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/fs.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/fs/promises.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/http.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/http2.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/https.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/inspector.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/module.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/net.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/os.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/path.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/perf_hooks.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/process.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/punycode.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/querystring.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/readline.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/readline/promises.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/repl.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/sea.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/stream.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/stream/promises.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/stream/consumers.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/stream/web.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/string_decoder.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/test.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/timers.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/timers/promises.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/tls.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/trace_events.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/tty.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/url.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/util.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/v8.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/vm.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/wasi.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/worker_threads.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/zlib.d.ts","../../../node_modules/.pnpm/@types+node@20.19.9/node_modules/@types/node/index.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/file.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/fetch.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/formdata.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/connector.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/client.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/errors.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/dispatcher.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-dispatcher.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/global-origin.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool-stats.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/pool.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/handlers.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/balanced-pool.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/agent.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-interceptor.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-agent.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-client.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-pool.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/mock-errors.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/proxy-agent.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/env-http-proxy-agent.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-handler.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/retry-agent.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/api.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/interceptors.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/util.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cookies.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/patch.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/websocket.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/eventsource.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/filereader.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/diagnostics-channel.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/content-type.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/cache.d.ts","../../../node_modules/.pnpm/undici-types@6.21.0/node_modules/undici-types/index.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/globals.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/s3.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/fetch.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/jsx.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/bun.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/extensions.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/devserver.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/ffi.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/html-rewriter.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/jsc.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/sqlite.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/vendor/expect-type/utils.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/vendor/expect-type/overloads.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/vendor/expect-type/branding.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/vendor/expect-type/messages.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/vendor/expect-type/index.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/test.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/wasm.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/overrides.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/deprecated.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/redis.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/shell.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/serve.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/sql.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/security.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/bundle.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/bun.ns.d.ts","../../../node_modules/.pnpm/bun-types@1.3.9/node_modules/bun-types/index.d.ts","../../../node_modules/.pnpm/@types+bun@1.3.9/node_modules/@types/bun/index.d.ts","../src/lib/ws-router.ts","../src/lib/token.ts","../src/lib/cors.ts","../src/lib/latency-setup.ts","../src/lib/types.ts","../src/lib/relay-game-server.ts","../src/index.ts"],"fileIdsList":[[63,64,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[64,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[63,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[77,78,79,80,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[77,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[82,83,84,85,87,88,89,90,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[86,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[66,67,68,69,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[65,66,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[65,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[59,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214,220,221,223,224],[59,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[59,76,91,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[59,76,81,91,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214,219,220,221,222,223],[59,76,81,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[59,76,81,91,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,61,62,71,72,73,74,75,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,61,62,70,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,73,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,74,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[60,62,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,207,208,209,210,211,212,213,214,217],[100,102,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,104,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,110,139,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,106,111,117,118,125,136,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,106,107,117,125,190,191,192,194,196,207,208,209,210,211,212,213,214],[95,96,97,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,108,148,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,109,110,118,126,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,110,136,144,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,111,113,117,125,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,104,105,112,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,113,114,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,115,117,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,104,105,117,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,118,119,136,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,118,119,132,136,139,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,189,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,113,117,120,125,136,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,118,120,121,125,136,144,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,120,122,136,144,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,123,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,124,147,152,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,113,117,125,136,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,126,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,127,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,104,105,128,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,102,103,104,105,106,107,108,109,110,111,112,113,114,115,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,130,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,131,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,132,133,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,132,134,148,150,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,136,137,139,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,138,139,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,136,137,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,139,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,140,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,102,105,136,141,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,142,143,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,142,143,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,110,125,136,144,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,145,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,125,146,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,120,131,147,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,110,148,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,136,149,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,124,150,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,151,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,117,119,128,136,139,147,150,152,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,136,153,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,110,118,120,144,148,152,189,190,191,192,193,196,197,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,207,208,210,211,212,213,214],[100,105,190,191,192,194,207,208,209,210,211,212,213,214],[100,105,189,190,191,194,196,207,208,209,210,211,212,213,214],[100,105,110,128,136,139,144,148,152,189,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,154,190,191,192,194,195,196,197,198,199,200,206,207,208,209,210,211,212,213,214,215,216],[100,101,105,108,110,118,119,126,139,144,147,153,190,191,192,194,196,207,209,210,211,212,213,214],[100,105,190,191,192,194,196,207,208,209,211,212,213,214],[100,105,118,190,192,194,196,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,207,208,209,210,211,212,213],[100,105,190,191,192,194,196,207,208,209,210,211,213,214],[100,105,190,191,192,194,196,207,208,209,210,212,213,214],[100,105,190,191,192,194,196,200,207,208,209,210,211,212,214],[100,105,190,191,192,194,196,205,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,201,202,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,201,202,203,204,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,201,203,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,201,207,208,209,210,211,212,213,214],[100,105,190,191,192,194,196,208,209,210,211,212,213,214],[58,100,105,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,147,161,165,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,136,147,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,156,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,144,147,158,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,125,144,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,154,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,154,156,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,125,147,158,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[93,94,100,105,117,136,147,157,160,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,168,190,191,192,194,196,207,208,209,210,211,212,213,214],[93,100,105,159,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,182,183,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,139,147,154,157,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,154,182,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,154,155,156,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,155,156,157,158,159,160,161,162,163,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,183,184,185,186,187,188,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,176,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,168,169,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,159,161,169,170,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,160,190,191,192,194,196,207,208,209,210,211,212,213,214],[93,100,105,156,161,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,161,165,169,170,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,165,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,147,159,161,164,190,191,192,194,196,207,208,209,210,211,212,213,214],[93,100,105,158,161,168,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,136,190,191,192,194,196,207,208,209,210,211,212,213,214],[100,105,152,154,156,161,182,190,191,192,194,196,207,208,209,210,211,212,213,214]],"fileInfos":[{"version":"c430d44666289dae81f30fa7b2edebf186ecc91a2d4c71266ea6ae76388792e1","affectsGlobalScope":true,"impliedFormat":1},{"version":"45b7ab580deca34ae9729e97c13cfd999df04416a79116c3bfb483804f85ded4","impliedFormat":1},{"version":"3facaf05f0c5fc569c5649dd359892c98a85557e3e0c847964caeb67076f4d75","impliedFormat":1},{"version":"e44bb8bbac7f10ecc786703fe0a6a4b952189f908707980ba8f3c8975a760962","impliedFormat":1},{"version":"5e1c4c362065a6b95ff952c0eab010f04dcd2c3494e813b493ecfd4fcb9fc0d8","impliedFormat":1},{"version":"68d73b4a11549f9c0b7d352d10e91e5dca8faa3322bfb77b661839c42b1ddec7","impliedFormat":1},{"version":"5efce4fc3c29ea84e8928f97adec086e3dc876365e0982cc8479a07954a3efd4","impliedFormat":1},{"version":"feecb1be483ed332fad555aff858affd90a48ab19ba7272ee084704eb7167569","impliedFormat":1},{"version":"ee7bad0c15b58988daa84371e0b89d313b762ab83cb5b31b8a2d1162e8eb41c2","impliedFormat":1},{"version":"c57796738e7f83dbc4b8e65132f11a377649c00dd3eee333f672b8f0a6bea671","affectsGlobalScope":true,"impliedFormat":1},{"version":"dc2df20b1bcdc8c2d34af4926e2c3ab15ffe1160a63e58b7e09833f616efff44","affectsGlobalScope":true,"impliedFormat":1},{"version":"515d0b7b9bea2e31ea4ec968e9edd2c39d3eebf4a2d5cbd04e88639819ae3b71","affectsGlobalScope":true,"impliedFormat":1},{"version":"0559b1f683ac7505ae451f9a96ce4c3c92bdc71411651ca6ddb0e88baaaad6a3","affectsGlobalScope":true,"impliedFormat":1},{"version":"0dc1e7ceda9b8b9b455c3a2d67b0412feab00bd2f66656cd8850e8831b08b537","affectsGlobalScope":true,"impliedFormat":1},{"version":"ce691fb9e5c64efb9547083e4a34091bcbe5bdb41027e310ebba8f7d96a98671","affectsGlobalScope":true,"impliedFormat":1},{"version":"8d697a2a929a5fcb38b7a65594020fcef05ec1630804a33748829c5ff53640d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ff2a353abf8a80ee399af572debb8faab2d33ad38c4b4474cff7f26e7653b8d","affectsGlobalScope":true,"impliedFormat":1},{"version":"fb0f136d372979348d59b3f5020b4cdb81b5504192b1cacff5d1fbba29378aa1","affectsGlobalScope":true,"impliedFormat":1},{"version":"d15bea3d62cbbdb9797079416b8ac375ae99162a7fba5de2c6c505446486ac0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"68d18b664c9d32a7336a70235958b8997ebc1c3b8505f4f1ae2b7e7753b87618","affectsGlobalScope":true,"impliedFormat":1},{"version":"eb3d66c8327153d8fa7dd03f9c58d351107fe824c79e9b56b462935176cdf12a","affectsGlobalScope":true,"impliedFormat":1},{"version":"38f0219c9e23c915ef9790ab1d680440d95419ad264816fa15009a8851e79119","affectsGlobalScope":true,"impliedFormat":1},{"version":"69ab18c3b76cd9b1be3d188eaf8bba06112ebbe2f47f6c322b5105a6fbc45a2e","affectsGlobalScope":true,"impliedFormat":1},{"version":"a680117f487a4d2f30ea46f1b4b7f58bef1480456e18ba53ee85c2746eeca012","affectsGlobalScope":true,"impliedFormat":1},{"version":"2f11ff796926e0832f9ae148008138ad583bd181899ab7dd768a2666700b1893","affectsGlobalScope":true,"impliedFormat":1},{"version":"4de680d5bb41c17f7f68e0419412ca23c98d5749dcaaea1896172f06435891fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"954296b30da6d508a104a3a0b5d96b76495c709785c1d11610908e63481ee667","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac9538681b19688c8eae65811b329d3744af679e0bdfa5d842d0e32524c73e1c","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a969edff4bd52585473d24995c5ef223f6652d6ef46193309b3921d65dd4376","affectsGlobalScope":true,"impliedFormat":1},{"version":"9e9fbd7030c440b33d021da145d3232984c8bb7916f277e8ffd3dc2e3eae2bdb","affectsGlobalScope":true,"impliedFormat":1},{"version":"811ec78f7fefcabbda4bfa93b3eb67d9ae166ef95f9bff989d964061cbf81a0c","affectsGlobalScope":true,"impliedFormat":1},{"version":"717937616a17072082152a2ef351cb51f98802fb4b2fdabd32399843875974ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"d7e7d9b7b50e5f22c915b525acc5a49a7a6584cf8f62d0569e557c5cfc4b2ac2","affectsGlobalScope":true,"impliedFormat":1},{"version":"71c37f4c9543f31dfced6c7840e068c5a5aacb7b89111a4364b1d5276b852557","affectsGlobalScope":true,"impliedFormat":1},{"version":"576711e016cf4f1804676043e6a0a5414252560eb57de9faceee34d79798c850","affectsGlobalScope":true,"impliedFormat":1},{"version":"89c1b1281ba7b8a96efc676b11b264de7a8374c5ea1e6617f11880a13fc56dc6","affectsGlobalScope":true,"impliedFormat":1},{"version":"74f7fa2d027d5b33eb0471c8e82a6c87216223181ec31247c357a3e8e2fddc5b","affectsGlobalScope":true,"impliedFormat":1},{"version":"d6d7ae4d1f1f3772e2a3cde568ed08991a8ae34a080ff1151af28b7f798e22ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"063600664504610fe3e99b717a1223f8b1900087fab0b4cad1496a114744f8df","affectsGlobalScope":true,"impliedFormat":1},{"version":"934019d7e3c81950f9a8426d093458b65d5aff2c7c1511233c0fd5b941e608ab","affectsGlobalScope":true,"impliedFormat":1},{"version":"52ada8e0b6e0482b728070b7639ee42e83a9b1c22d205992756fe020fd9f4a47","affectsGlobalScope":true,"impliedFormat":1},{"version":"3bdefe1bfd4d6dee0e26f928f93ccc128f1b64d5d501ff4a8cf3c6371200e5e6","affectsGlobalScope":true,"impliedFormat":1},{"version":"59fb2c069260b4ba00b5643b907ef5d5341b167e7d1dbf58dfd895658bda2867","affectsGlobalScope":true,"impliedFormat":1},{"version":"639e512c0dfc3fad96a84caad71b8834d66329a1f28dc95e3946c9b58176c73a","affectsGlobalScope":true,"impliedFormat":1},{"version":"368af93f74c9c932edd84c58883e736c9e3d53cec1fe24c0b0ff451f529ceab1","affectsGlobalScope":true,"impliedFormat":1},{"version":"af3dd424cf267428f30ccfc376f47a2c0114546b55c44d8c0f1d57d841e28d74","affectsGlobalScope":true,"impliedFormat":1},{"version":"995c005ab91a498455ea8dfb63aa9f83fa2ea793c3d8aa344be4a1678d06d399","affectsGlobalScope":true,"impliedFormat":1},{"version":"959d36cddf5e7d572a65045b876f2956c973a586da58e5d26cde519184fd9b8a","affectsGlobalScope":true,"impliedFormat":1},{"version":"965f36eae237dd74e6cca203a43e9ca801ce38824ead814728a2807b1910117d","affectsGlobalScope":true,"impliedFormat":1},{"version":"3925a6c820dcb1a06506c90b1577db1fdbf7705d65b62b99dce4be75c637e26b","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a3d63ef2b853447ec4f749d3f368ce642264246e02911fcb1590d8c161b8005","affectsGlobalScope":true,"impliedFormat":1},{"version":"8cdf8847677ac7d20486e54dd3fcf09eda95812ac8ace44b4418da1bbbab6eb8","affectsGlobalScope":true,"impliedFormat":1},{"version":"8444af78980e3b20b49324f4a16ba35024fef3ee069a0eb67616ea6ca821c47a","affectsGlobalScope":true,"impliedFormat":1},{"version":"3287d9d085fbd618c3971944b65b4be57859f5415f495b33a6adc994edd2f004","affectsGlobalScope":true,"impliedFormat":1},{"version":"b4b67b1a91182421f5df999988c690f14d813b9850b40acd06ed44691f6727ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e7f8264d0fb4c5339605a15daadb037bf238c10b654bb3eee14208f860a32ea","affectsGlobalScope":true,"impliedFormat":1},{"version":"782dec38049b92d4e85c1585fbea5474a219c6984a35b004963b00beb1aab538","affectsGlobalScope":true,"impliedFormat":1},{"version":"a6a5253138c5432c68a1510c70fe78a644fe2e632111ba778e1978010d6edfec","impliedFormat":1},{"version":"b8f34dd1757f68e03262b1ca3ddfa668a855b872f8bdd5224d6f993a7b37dc2c","impliedFormat":99},{"version":"a2cecd31123871b233beeadb2f05e6df0d7487de5404b79523de531075f9d407","impliedFormat":99},{"version":"206efc83e001899650e7769a107f011ee132dce1e66e0e25d54032056838aaf3","impliedFormat":99},{"version":"1e0ae5e3ce9f1ce472bd7ea00b1f3664d3089c364c59f4b07eb243f3f3467616","impliedFormat":99},{"version":"ac089737c8fddcff7af3b4b11d52ceb4053ecacb1e408186981a121b45d471ae","impliedFormat":99},{"version":"ddd386b335a31a931a79bb4a4194e4ad53836920f3eb847f9239577df45f0ada","impliedFormat":99},{"version":"21c5388dfa2af6acd9a77f68ace5f393e5f1163b371a7c4346742ebf0e102117","impliedFormat":99},{"version":"f1d219537856b85b587d64dbf8233115cc3b5a20d5a9ca29d71ab82f1d40fdeb","impliedFormat":99},{"version":"0adc1e3975856b12a811ab06af29a2d9e343b06e48c826f3c72bd7ceaf4be54f","impliedFormat":99},{"version":"4a169791aad1f002f3412ce6ed18bff156d2e97a645e1c5c6ba07dfcae10c1d3","impliedFormat":99},{"version":"e2264c936ae9474c390623d8b41ae4ee992554cac7f3f20109e22ef27725e764","impliedFormat":99},{"version":"03474982ddfb89dd5b162522e3e2a2c91ea40656a9e901bf71541402124a9bdf","impliedFormat":99},{"version":"331f9e4882265ff382b5ebfd881d5cd3c9ea1fc30c1e7f99c617a88cdf44f4b3","impliedFormat":99},{"version":"7a4bfb2fca81b367baed0786544dbf792c6ac58f3429ed2727f717a893686460","impliedFormat":99},{"version":"f2bb0016c124c0bbe8a8f644e4aa8172b1eb72c6a026fe0dfd6dea5077038d10","impliedFormat":99},{"version":"9e0dc9f99b98836d7c3fb7dc69c83489f522038ad8482770ca59b60626502ae3","impliedFormat":99},{"version":"3df791c24cec73da0b23b0aefbb1c3211acf420195493ed9042e6de45c47f000","impliedFormat":99},{"version":"e7c289d49c2ea0afb45c360a3b6f65ef4c66a088d24e10a0103500983c3d57ae","impliedFormat":99},{"version":"78b4867fd719507480b68976a9028479aa6e705e31f5f927915b4639f020d972","impliedFormat":99},{"version":"9d52f85421532743dae44cfafc8708b0ececdffdae60c62610a36470b95316f8","impliedFormat":99},{"version":"155cc9549bf4287b7999ca4db940aa4f0718b04e93335b5098aee1c8614b4125","impliedFormat":99},{"version":"3fcf7014890797f5035e960c8275a331deaedfa4fbb6b5b8425d4a67ef106a1f","impliedFormat":99},{"version":"4a99900153e7d1420d7f9be6cbf920f3fe38bbd153f09e8b1770e71c119507c6","impliedFormat":99},{"version":"b6c4414ae580cf1ab858f1851520f1d0cee1ca59117ca7e836116cf9618c8819","impliedFormat":99},{"version":"1c440fad2b3f198c3b034257840dcf2999a41770d0b2cfccfc047189d98df18f","impliedFormat":99},{"version":"ef9f67b0f0bd71f90d52d8589b3b3c45e1267129b13f874c049a805ecd7ac37f","impliedFormat":99},{"version":"3d26b5544141b556e3b263e78bbe30fe9927f48f58a3ade62c0de58b4d41d9a4","impliedFormat":99},{"version":"d1beb1ffdddb2cf5fe1e58557c8783d3070680c6165bc6652993ed2a7bf48f38","impliedFormat":99},{"version":"4e3121b5b60b986fa48641a69098b66f0b37c876a973fb0d671394b09913752c","impliedFormat":99},{"version":"6573f1553e8ab870f43047dac35527ec3281a9f1c57c4f2be9872306a6dbe5ae","impliedFormat":99},{"version":"899a34e4f158e0b0ef1a72b566bf4041edeef09d0547f8882f740ec5dfd2c775","impliedFormat":99},{"version":"6b42cbd9637a7b84238d4cd7212e5405d9a3274f505a1cc8dc008f5ef7cbce12","impliedFormat":99},{"version":"23c7c084d919b1a6d948a8a0952a18969caaf0740f19651f046d978440b06d57","impliedFormat":99},{"version":"4967529644e391115ca5592184d4b63980569adf60ee685f968fd59ab1557188","impliedFormat":1},{"version":"5929864ce17fba74232584d90cb721a89b7ad277220627cc97054ba15a98ea8f","impliedFormat":1},{"version":"763fe0f42b3d79b440a9b6e51e9ba3f3f91352469c1e4b3b67bfa4ff6352f3f4","impliedFormat":1},{"version":"70521b6ab0dcba37539e5303104f29b721bfb2940b2776da4cc818c07e1fefc1","affectsGlobalScope":true,"impliedFormat":1},{"version":"ab41ef1f2cdafb8df48be20cd969d875602483859dc194e9c97c8a576892c052","affectsGlobalScope":true,"impliedFormat":1},{"version":"d153a11543fd884b596587ccd97aebbeed950b26933ee000f94009f1ab142848","affectsGlobalScope":true,"impliedFormat":1},{"version":"21d819c173c0cf7cc3ce57c3276e77fd9a8a01d35a06ad87158781515c9a438a","impliedFormat":1},{"version":"a79e62f1e20467e11a904399b8b18b18c0c6eea6b50c1168bf215356d5bebfaf","affectsGlobalScope":true,"impliedFormat":1},{"version":"49a5a44f2e68241a1d2bd9ec894535797998841c09729e506a7cbfcaa40f2180","affectsGlobalScope":true,"impliedFormat":1},{"version":"1ca84b44ad1d8e4576f24904d8b95dd23b94ea67e1575f89614ac90062fc67f4","affectsGlobalScope":true,"impliedFormat":1},{"version":"6d586db0a09a9495ebb5dece28f54df9684bfbd6e1f568426ca153126dac4a40","impliedFormat":1},{"version":"7394959e5a741b185456e1ef5d64599c36c60a323207450991e7a42e08911419","impliedFormat":1},{"version":"8c0bcd6c6b67b4b503c11e91a1fb91522ed585900eab2ab1f61bba7d7caa9d6f","impliedFormat":1},{"version":"567b7f607f400873151d7bc63a049514b53c3c00f5f56e9e95695d93b66a138e","affectsGlobalScope":true,"impliedFormat":1},{"version":"f3e58c4c18a031cbb17abec7a4ad0bd5ae9fc70c1f4ba1e7fb921ad87c504aca","impliedFormat":1},{"version":"84c1930e33d1bb12ad01bcbe11d656f9646bd21b2fb2afd96e8e10615a021aef","impliedFormat":1},{"version":"35ec8b6760fd7138bbf5809b84551e31028fb2ba7b6dc91d95d098bf212ca8b4","affectsGlobalScope":true,"impliedFormat":1},{"version":"5524481e56c48ff486f42926778c0a3cce1cc85dc46683b92b1271865bcf015a","impliedFormat":1},{"version":"4b87f767c7bc841511113c876a6b8bf1fd0cb0b718c888ad84478b372ec486b1","affectsGlobalScope":true,"impliedFormat":1},{"version":"8d04e3640dd9eb67f7f1e5bd3d0bf96c784666f7aefc8ac1537af6f2d38d4c29","impliedFormat":1},{"version":"9d19808c8c291a9010a6c788e8532a2da70f811adb431c97520803e0ec649991","impliedFormat":1},{"version":"2bf469abae4cc9c0f340d4e05d9d26e37f936f9c8ca8f007a6534f109dcc77e4","impliedFormat":1},{"version":"4aacb0dd020eeaef65426153686cc639a78ec2885dc72ad220be1d25f1a439df","impliedFormat":1},{"version":"f0bd7e6d931657b59605c44112eaf8b980ba7f957a5051ed21cb93d978cf2f45","impliedFormat":1},{"version":"71450bbc2d82821d24ca05699a533e72758964e9852062c53b30f31c36978ab8","affectsGlobalScope":true,"impliedFormat":1},{"version":"0ada07543808f3b967624645a8e1ccd446f8b01ade47842acf1328aec899fed0","affectsGlobalScope":true,"impliedFormat":1},{"version":"4c21aaa8257d7950a5b75a251d9075b6a371208fc948c9c8402f6690ef3b5b55","impliedFormat":1},{"version":"b5895e6353a5d708f55d8685c38a235c3a6d8138e374dee8ceb8ffde5aa8002a","impliedFormat":1},{"version":"54c4f21f578864961efc94e8f42bc893a53509e886370ec7dd602e0151b9266c","impliedFormat":1},{"version":"de735eca2c51dd8b860254e9fdb6d9ec19fe402dfe597c23090841ce3937cfc5","impliedFormat":1},{"version":"4ff41188773cbf465807dd2f7059c7494cbee5115608efc297383832a1150c43","impliedFormat":1},{"version":"5650cf3dace09e7c25d384e3e6b818b938f68f4e8de96f52d9c5a1b3db068e86","impliedFormat":1},{"version":"1354ca5c38bd3fd3836a68e0f7c9f91f172582ba30ab15bb8c075891b91502b7","affectsGlobalScope":true,"impliedFormat":1},{"version":"5155da3047ef977944d791a2188ff6e6c225f6975cc1910ab7bb6838ab84cede","impliedFormat":1},{"version":"93f437e1398a4f06a984f441f7fa7a9f0535c04399619b5c22e0b87bdee182cb","impliedFormat":1},{"version":"afbe24ab0d74694372baa632ecb28bb375be53f3be53f9b07ecd7fc994907de5","impliedFormat":1},{"version":"e16d218a30f6a6810b57f7e968124eaa08c7bb366133ea34bbf01e7cd6b8c0ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"eb8692dea24c27821f77e397272d9ed2eda0b95e4a75beb0fdda31081d15a8ae","affectsGlobalScope":true,"impliedFormat":1},{"version":"9e043a1bc8fbf2a255bccf9bf27e0f1caf916c3b0518ea34aa72357c0afd42ec","impliedFormat":1},{"version":"b4f70ec656a11d570e1a9edce07d118cd58d9760239e2ece99306ee9dfe61d02","impliedFormat":1},{"version":"3bc2f1e2c95c04048212c569ed38e338873f6a8593930cf5a7ef24ffb38fc3b6","impliedFormat":1},{"version":"8145e07aad6da5f23f2fcd8c8e4c5c13fb26ee986a79d03b0829b8fce152d8b2","impliedFormat":1},{"version":"f9d9d753d430ed050dc1bf2667a1bab711ccbb1c1507183d794cc195a5b085cc","impliedFormat":1},{"version":"9eece5e586312581ccd106d4853e861aaaa1a39f8e3ea672b8c3847eedd12f6e","impliedFormat":1},{"version":"5b6844ad931dcc1d3aca53268f4bd671428421464b1286746027aede398094f2","impliedFormat":1},{"version":"37ba7b45141a45ce6e80e66f2a96c8a5ab1bcef0fc2d0f56bb58df96ec67e972","impliedFormat":1},{"version":"125d792ec6c0c0f657d758055c494301cc5fdb327d9d9d5960b3f129aff76093","impliedFormat":1},{"version":"0dbcebe2126d03936c70545e96a6e41007cf065be38a1ce4d32a39fcedefead4","affectsGlobalScope":true,"impliedFormat":1},{"version":"1851a3b4db78664f83901bb9cac9e45e03a37bb5933cc5bf37e10bb7e91ab4eb","impliedFormat":1},{"version":"461e54289e6287e8494a0178ba18182acce51a02bca8dea219149bf2cf96f105","impliedFormat":1},{"version":"12ed4559eba17cd977aa0db658d25c4047067444b51acfdcbf38470630642b23","affectsGlobalScope":true,"impliedFormat":1},{"version":"f3ffabc95802521e1e4bcba4c88d8615176dc6e09111d920c7a213bdda6e1d65","impliedFormat":1},{"version":"e31e51c55800014d926e3f74208af49cb7352803619855c89296074d1ecbb524","impliedFormat":1},{"version":"ae56f65caf3be91108707bd8dfbccc2a57a91feb5daabf7165a06a945545ed26","impliedFormat":1},{"version":"a136d5de521da20f31631a0a96bf712370779d1c05b7015d7019a9b2a0446ca9","impliedFormat":1},{"version":"dfb96ba5177b68003deec9e773c47257da5c4c8a74053d8956389d832df72002","affectsGlobalScope":true,"impliedFormat":1},{"version":"92d3070580cf72b4bb80959b7f16ede9a3f39e6f4ef2ac87cfa4561844fdc69f","affectsGlobalScope":true,"impliedFormat":1},{"version":"d3dffd70e6375b872f0b4e152de4ae682d762c61a24881ecc5eb9f04c5caf76f","impliedFormat":1},{"version":"613deebaec53731ff6b74fe1a89f094b708033db6396b601df3e6d5ab0ec0a47","impliedFormat":1},{"version":"d91a7d8b5655c42986f1bdfe2105c4408f472831c8f20cf11a8c3345b6b56c8c","impliedFormat":1},{"version":"e56eb632f0281c9f8210eb8c86cc4839a427a4ffffcfd2a5e40b956050b3e042","affectsGlobalScope":true,"impliedFormat":1},{"version":"e8a979b8af001c9fc2e774e7809d233c8ca955a28756f52ee5dee88ccb0611d2","impliedFormat":1},{"version":"cac793cc47c29e26e4ac3601dcb00b4435ebed26203485790e44f2ad8b6ad847","impliedFormat":1},{"version":"25c8056edf4314820382a5fdb4bb7816999acdcb929c8f75e3f39473b87e85bc","impliedFormat":1},{"version":"c464d66b20788266e5353b48dc4aa6bc0dc4a707276df1e7152ab0c9ae21fad8","impliedFormat":1},{"version":"78d0d27c130d35c60b5e5566c9f1e5be77caf39804636bc1a40133919a949f21","impliedFormat":1},{"version":"c6fd2c5a395f2432786c9cb8deb870b9b0e8ff7e22c029954fabdd692bff6195","impliedFormat":1},{"version":"1d6e127068ea8e104a912e42fc0a110e2aa5a66a356a917a163e8cf9a65e4a75","impliedFormat":1},{"version":"5ded6427296cdf3b9542de4471d2aa8d3983671d4cac0f4bf9c637208d1ced43","impliedFormat":1},{"version":"7f182617db458e98fc18dfb272d40aa2fff3a353c44a89b2c0ccb3937709bfb5","impliedFormat":1},{"version":"cadc8aced301244057c4e7e73fbcae534b0f5b12a37b150d80e5a45aa4bebcbd","impliedFormat":1},{"version":"385aab901643aa54e1c36f5ef3107913b10d1b5bb8cbcd933d4263b80a0d7f20","impliedFormat":1},{"version":"9670d44354bab9d9982eca21945686b5c24a3f893db73c0dae0fd74217a4c219","impliedFormat":1},{"version":"0b8a9268adaf4da35e7fa830c8981cfa22adbbe5b3f6f5ab91f6658899e657a7","impliedFormat":1},{"version":"11396ed8a44c02ab9798b7dca436009f866e8dae3c9c25e8c1fbc396880bf1bb","impliedFormat":1},{"version":"ba7bc87d01492633cb5a0e5da8a4a42a1c86270e7b3d2dea5d156828a84e4882","impliedFormat":1},{"version":"4893a895ea92c85345017a04ed427cbd6a1710453338df26881a6019432febdd","impliedFormat":1},{"version":"c21dc52e277bcfc75fac0436ccb75c204f9e1b3fa5e12729670910639f27343e","impliedFormat":1},{"version":"13f6f39e12b1518c6650bbb220c8985999020fe0f21d818e28f512b7771d00f9","impliedFormat":1},{"version":"9b5369969f6e7175740bf51223112ff209f94ba43ecd3bb09eefff9fd675624a","impliedFormat":1},{"version":"4fe9e626e7164748e8769bbf74b538e09607f07ed17c2f20af8d680ee49fc1da","impliedFormat":1},{"version":"24515859bc0b836719105bb6cc3d68255042a9f02a6022b3187948b204946bd2","impliedFormat":1},{"version":"ea0148f897b45a76544ae179784c95af1bd6721b8610af9ffa467a518a086a43","impliedFormat":1},{"version":"24c6a117721e606c9984335f71711877293a9651e44f59f3d21c1ea0856f9cc9","impliedFormat":1},{"version":"dd3273ead9fbde62a72949c97dbec2247ea08e0c6952e701a483d74ef92d6a17","impliedFormat":1},{"version":"405822be75ad3e4d162e07439bac80c6bcc6dbae1929e179cf467ec0b9ee4e2e","impliedFormat":1},{"version":"0db18c6e78ea846316c012478888f33c11ffadab9efd1cc8bcc12daded7a60b6","impliedFormat":1},{"version":"e61be3f894b41b7baa1fbd6a66893f2579bfad01d208b4ff61daef21493ef0a8","impliedFormat":1},{"version":"bd0532fd6556073727d28da0edfd1736417a3f9f394877b6d5ef6ad88fba1d1a","impliedFormat":1},{"version":"89167d696a849fce5ca508032aabfe901c0868f833a8625d5a9c6e861ef935d2","impliedFormat":1},{"version":"615ba88d0128ed16bf83ef8ccbb6aff05c3ee2db1cc0f89ab50a4939bfc1943f","impliedFormat":1},{"version":"a4d551dbf8746780194d550c88f26cf937caf8d56f102969a110cfaed4b06656","impliedFormat":1},{"version":"8bd86b8e8f6a6aa6c49b71e14c4ffe1211a0e97c80f08d2c8cc98838006e4b88","impliedFormat":1},{"version":"317e63deeb21ac07f3992f5b50cdca8338f10acd4fbb7257ebf56735bf52ab00","impliedFormat":1},{"version":"4732aec92b20fb28c5fe9ad99521fb59974289ed1e45aecb282616202184064f","impliedFormat":1},{"version":"2e85db9e6fd73cfa3d7f28e0ab6b55417ea18931423bd47b409a96e4a169e8e6","impliedFormat":1},{"version":"c46e079fe54c76f95c67fb89081b3e399da2c7d109e7dca8e4b58d83e332e605","impliedFormat":1},{"version":"bf67d53d168abc1298888693338cb82854bdb2e69ef83f8a0092093c2d562107","impliedFormat":1},{"version":"6e215dac8b234548d91b718f9c07d5b09473cd5cabb29053fcd8be0af190acb6","affectsGlobalScope":true,"impliedFormat":1},{"version":"dbecf494aac7d3ee1b23cdaafae0d0bfea8590567fc153db58fe00ed9fa66c24","impliedFormat":1},{"version":"f3d3e999a323c85c8a63ce90c6e4624ff89fe137a0e2508fddc08e0556d08abf","impliedFormat":1},{"version":"314607151cc203975193d5f44765f38597be3b0a43f466d3c1bfb17176dd3bd3","impliedFormat":1},{"version":"e155d961d69d5a5a5d1492a0a69d2a8f3b40a7197989484ba8c62e26e4ecd213","impliedFormat":1},{"version":"f40aad6c91017f20fc542f5701ec41e0f6aeba63c61bbf7aa13266ec29a50a3b","impliedFormat":1},{"version":"fc9e630f9302d0414ccd6c8ed2706659cff5ae454a56560c6122fa4a3fac5bbd","affectsGlobalScope":true,"impliedFormat":1},{"version":"aa0a44af370a2d7c1aac988a17836f57910a6c52689f52f5b3ac1d4c6cadcb23","impliedFormat":1},{"version":"0ac74c7586880e26b6a599c710b59284a284e084a2bbc82cd40fb3fbfdea71ae","affectsGlobalScope":true,"impliedFormat":1},{"version":"2ce12357dadbb8efc4e4ec4dab709c8071bf992722fc9adfea2fe0bd5b50923f","impliedFormat":1},{"version":"b5a907deaba678e5083ccdd7cc063a3a8c3413c688098f6de29d6e4cefabc85f","impliedFormat":1},{"version":"ffd344731abee98a0a85a735b19052817afd2156d97d1410819cd9bcd1bd575e","impliedFormat":1},{"version":"475e07c959f4766f90678425b45cf58ac9b95e50de78367759c1e5118e85d5c3","impliedFormat":1},{"version":"a524ae401b30a1b0814f1bbcdae459da97fa30ae6e22476e506bb3f82e3d9456","impliedFormat":1},{"version":"7375e803c033425e27cb33bae21917c106cb37b508fd242cccd978ef2ee244c7","impliedFormat":1},{"version":"eeb890c7e9218afdad2f30ad8a76b0b0b5161d11ce13b6723879de408e6bc47a","impliedFormat":1},{"version":"998da6b85ebace9ebea67040dd1a640f0156064e3d28dbe9bd9c0229b6f72347","impliedFormat":1},{"version":"dfbcc400ac6d20b941ccc7bd9031b9d9f54e4d495dd79117334e771959df4805","affectsGlobalScope":true,"impliedFormat":1},{"version":"944d65951e33a13068be5cd525ec42bf9bc180263ba0b723fa236970aa21f611","affectsGlobalScope":true,"impliedFormat":1},{"version":"6b386c7b6ce6f369d18246904fa5eac73566167c88fb6508feba74fa7501a384","affectsGlobalScope":true,"impliedFormat":1},{"version":"592a109e67b907ffd2078cd6f727d5c326e06eaada169eef8fb18546d96f6797","impliedFormat":1},{"version":"f2eb1e35cae499d57e34b4ac3650248776fe7dbd9a3ec34b23754cfd8c22fceb","impliedFormat":1},{"version":"fbed43a6fcf5b675f5ec6fc960328114777862b58a2bb19c109e8fc1906caa09","impliedFormat":1},{"version":"9e98bd421e71f70c75dae7029e316745c89fa7b8bc8b43a91adf9b82c206099c","impliedFormat":1},{"version":"fc803e6b01f4365f71f51f9ce13f71396766848204d4f7a1b2b6154434b84b15","impliedFormat":1},{"version":"f3afcc0d6f77a9ca2d2c5c92eb4b89cd38d6fa4bdc1410d626bd701760a977ec","impliedFormat":1},{"version":"c8109fe76467db6e801d0edfbc50e6826934686467c9418ce6b246232ce7f109","affectsGlobalScope":true,"impliedFormat":1},{"version":"e6f803e4e45915d58e721c04ec17830c6e6678d1e3e00e28edf3d52720909cea","affectsGlobalScope":true,"impliedFormat":1},{"version":"37be812b06e518320ba82e2aff3ac2ca37370a9df917db708f081b9043fa3315","impliedFormat":1},{"version":"1635b0e79138711ceeef870230b5b1efcc89f509e513a288c23eebd95c2aa140","signature":"aa7174abbe8d2f017b1e16ef731a05a3a7b30111a396e41138610b43b9587285","impliedFormat":99},{"version":"b4c7ab264a3870c6906a35413dddec8ec315b0f1e8bb68a4a6c7214d30b1f40d","signature":"8f3db65880dbfa79ea05969f7fe07ba1936ffdd817060a14aaa243422adfb0bf","impliedFormat":99},{"version":"64890629969a2774dd19f7fca4cd13e8ae265593114439f18c01da68439143ca","signature":"ebc3a97e58a0650fb630c015c3fa9415bb705ad71f37afafaa2e9a0517f7a9b4","impliedFormat":99},{"version":"b48c6924f6f964dd7221bbbc6133015299169cbc51edb7f89c3434da87d84863","signature":"021f5901e3b446dc641ac289507ffc2fd61fba6e27a9ec6ddbd9ad98c8b5820c","impliedFormat":99},{"version":"d179e715228e1c10bb1fbd966e210723e5d2637488bf94457e982e9524bed4e9","signature":"7a5634acfc33c5805022fe45445c05764c800a736eacd06a0b5ef17dd958f935","impliedFormat":99},{"version":"b14ba5a5c4200458a83176a52bf376318301f924005a2088e795c40269ec1e2c","signature":"1e681b8db62cccff5303f5c0010729901e5a34e50401bfccadff6852a1e8e06e","impliedFormat":99},{"version":"d9049080a669c892b05b37298fdf46ebc93114e16bdfe1eed90191a4880a0ce5","impliedFormat":99}],"root":[[219,225]],"options":{"composite":true,"declarationMap":true,"emitDeclarationOnly":false,"emitDecoratorMetadata":true,"experimentalDecorators":true,"importHelpers":true,"module":199,"noEmitOnError":true,"noFallthroughCasesInSwitch":true,"noImplicitOverride":true,"noImplicitReturns":true,"noUnusedLocals":true,"outDir":"./","rootDir":"../src","skipLibCheck":true,"strict":true,"target":9,"tsBuildInfoFile":"./tsconfig.lib.tsbuildinfo"},"referencedMap":[[65,1],[63,2],[64,3],[81,4],[79,5],[80,5],[78,5],[77,6],[91,7],[90,6],[82,6],[86,6],[84,6],[87,8],[85,6],[88,6],[83,6],[89,6],[70,9],[67,10],[68,6],[66,11],[69,6],[225,12],[221,13],[222,14],[224,15],[220,13],[223,16],[219,17],[76,18],[71,19],[73,6],[62,20],[74,21],[75,22],[61,6],[72,23],[60,6],[218,24],[102,25],[103,25],[104,26],[100,27],[105,28],[106,29],[107,30],[95,6],[98,31],[96,6],[97,6],[108,32],[109,33],[110,34],[111,35],[112,36],[113,37],[114,37],[116,6],[115,38],[117,39],[118,40],[119,41],[101,42],[99,6],[120,43],[121,44],[122,45],[154,46],[123,47],[124,48],[125,49],[126,50],[127,51],[128,52],[129,53],[130,54],[131,55],[132,56],[133,56],[134,57],[135,6],[136,58],[138,59],[137,60],[139,61],[140,62],[141,63],[142,64],[143,65],[144,66],[145,67],[146,68],[147,69],[148,70],[149,71],[150,72],[151,73],[152,74],[153,75],[92,6],[194,76],[216,6],[215,6],[209,77],[196,78],[195,6],[192,79],[197,6],[190,80],[198,6],[217,81],[199,6],[193,6],[208,82],[210,83],[191,84],[214,85],[212,86],[211,87],[213,88],[200,6],[206,89],[203,90],[205,91],[204,92],[202,93],[201,6],[207,94],[59,95],[58,6],[56,6],[57,6],[11,6],[10,6],[2,6],[12,6],[13,6],[14,6],[15,6],[16,6],[17,6],[18,6],[19,6],[3,6],[20,6],[21,6],[4,6],[22,6],[26,6],[23,6],[24,6],[25,6],[27,6],[28,6],[29,6],[5,6],[30,6],[31,6],[32,6],[33,6],[6,6],[37,6],[34,6],[35,6],[36,6],[38,6],[7,6],[39,6],[44,6],[45,6],[40,6],[41,6],[42,6],[43,6],[8,6],[49,6],[46,6],[47,6],[48,6],[50,6],[9,6],[51,6],[52,6],[53,6],[55,6],[54,6],[1,6],[168,96],[178,97],[167,96],[188,98],[159,99],[158,100],[187,101],[181,102],[186,103],[161,104],[175,105],[160,106],[184,107],[156,108],[155,101],[185,109],[157,110],[162,111],[163,6],[166,111],[93,6],[189,112],[179,113],[170,114],[171,115],[173,116],[169,117],[172,118],[182,101],[164,119],[165,120],[174,121],[94,122],[177,113],[176,111],[180,6],[183,123]],"latestChangedDtsFile":"./lib/ws-router.d.ts","version":"5.9.3"}
|
package/package.json
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@lagless/relay-game-server",
|
|
3
|
+
"version": "0.0.33",
|
|
4
|
+
"license": "MIT",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "https://github.com/ppauel/lagless",
|
|
8
|
+
"directory": "libs/relay-game-server"
|
|
9
|
+
},
|
|
10
|
+
"type": "module",
|
|
11
|
+
"main": "./dist/index.js",
|
|
12
|
+
"types": "./dist/index.d.ts",
|
|
13
|
+
"exports": {
|
|
14
|
+
"./package.json": "./package.json",
|
|
15
|
+
".": {
|
|
16
|
+
"@lagless/source": "./src/index.ts",
|
|
17
|
+
"types": "./dist/index.d.ts",
|
|
18
|
+
"import": "./dist/index.js",
|
|
19
|
+
"default": "./dist/index.js"
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"@lagless/relay-server": "0.0.33",
|
|
24
|
+
"@lagless/matchmaking": "0.0.33",
|
|
25
|
+
"@lagless/core": "0.0.33",
|
|
26
|
+
"@lagless/misc": "0.0.33"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@types/bun": "latest"
|
|
30
|
+
},
|
|
31
|
+
"files": [
|
|
32
|
+
"dist",
|
|
33
|
+
"README.md"
|
|
34
|
+
],
|
|
35
|
+
"publishConfig": {
|
|
36
|
+
"access": "public"
|
|
37
|
+
}
|
|
38
|
+
}
|