@venizia/ignis 0.0.6-6 → 0.0.7-0
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/base/applications/abstract.d.ts +7 -1
- package/dist/base/applications/abstract.d.ts.map +1 -1
- package/dist/base/applications/abstract.js +21 -0
- package/dist/base/applications/abstract.js.map +1 -1
- package/dist/base/mixins/component.mixin.d.ts +14 -1
- package/dist/base/mixins/component.mixin.d.ts.map +1 -1
- package/dist/base/mixins/controller.mixin.d.ts +14 -1
- package/dist/base/mixins/controller.mixin.d.ts.map +1 -1
- package/dist/base/mixins/repository.mixin.d.ts +14 -1
- package/dist/base/mixins/repository.mixin.d.ts.map +1 -1
- package/dist/base/mixins/service.mixin.d.ts +14 -1
- package/dist/base/mixins/service.mixin.d.ts.map +1 -1
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +1 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/socket-io/common/index.d.ts +3 -0
- package/dist/components/socket-io/common/index.d.ts.map +1 -0
- package/dist/components/socket-io/common/index.js +19 -0
- package/dist/components/socket-io/common/index.js.map +1 -0
- package/dist/components/socket-io/{keys.d.ts → common/keys.d.ts} +1 -0
- package/dist/components/socket-io/common/keys.d.ts.map +1 -0
- package/dist/components/socket-io/{keys.js → common/keys.js} +1 -0
- package/dist/components/socket-io/common/keys.js.map +1 -0
- package/dist/components/socket-io/common/types.d.ts +13 -0
- package/dist/components/socket-io/common/types.d.ts.map +1 -0
- package/dist/components/socket-io/common/types.js +24 -0
- package/dist/components/socket-io/common/types.js.map +1 -0
- package/dist/components/socket-io/component.d.ts +4 -5
- package/dist/components/socket-io/component.d.ts.map +1 -1
- package/dist/components/socket-io/component.js +122 -63
- package/dist/components/socket-io/component.js.map +1 -1
- package/dist/components/socket-io/handlers/bun.handler.d.ts +15 -0
- package/dist/components/socket-io/handlers/bun.handler.d.ts.map +1 -0
- package/dist/components/socket-io/handlers/bun.handler.js +36 -0
- package/dist/components/socket-io/handlers/bun.handler.js.map +1 -0
- package/dist/components/socket-io/handlers/index.d.ts +3 -0
- package/dist/components/socket-io/handlers/index.d.ts.map +1 -0
- package/dist/components/socket-io/handlers/index.js +19 -0
- package/dist/components/socket-io/handlers/index.js.map +1 -0
- package/dist/components/socket-io/handlers/node.handler.d.ts +9 -0
- package/dist/components/socket-io/handlers/node.handler.d.ts.map +1 -0
- package/dist/components/socket-io/handlers/node.handler.js +21 -0
- package/dist/components/socket-io/handlers/node.handler.js.map +1 -0
- package/dist/components/socket-io/index.d.ts +1 -1
- package/dist/components/socket-io/index.d.ts.map +1 -1
- package/dist/components/socket-io/index.js +1 -1
- package/dist/components/socket-io/index.js.map +1 -1
- package/dist/components/websocket/common/index.d.ts +3 -0
- package/dist/components/websocket/common/index.d.ts.map +1 -0
- package/dist/components/websocket/common/index.js +19 -0
- package/dist/components/websocket/common/index.js.map +1 -0
- package/dist/components/websocket/common/keys.d.ts +11 -0
- package/dist/components/websocket/common/keys.d.ts.map +1 -0
- package/dist/components/websocket/common/keys.js +15 -0
- package/dist/components/websocket/common/keys.js.map +1 -0
- package/dist/components/websocket/common/types.d.ts +19 -0
- package/dist/components/websocket/common/types.d.ts.map +1 -0
- package/dist/components/websocket/common/types.js +9 -0
- package/dist/components/websocket/common/types.js.map +1 -0
- package/dist/components/websocket/component.d.ts +13 -0
- package/dist/components/websocket/component.d.ts.map +1 -0
- package/dist/components/websocket/component.js +169 -0
- package/dist/components/websocket/component.js.map +1 -0
- package/dist/components/websocket/handlers/bun.handler.d.ts +7 -0
- package/dist/components/websocket/handlers/bun.handler.d.ts.map +1 -0
- package/dist/components/websocket/handlers/bun.handler.js +25 -0
- package/dist/components/websocket/handlers/bun.handler.js.map +1 -0
- package/dist/components/websocket/handlers/index.d.ts +2 -0
- package/dist/components/websocket/handlers/index.d.ts.map +1 -0
- package/dist/components/websocket/handlers/index.js +18 -0
- package/dist/components/websocket/handlers/index.js.map +1 -0
- package/dist/components/websocket/index.d.ts +3 -0
- package/dist/components/websocket/index.d.ts.map +1 -0
- package/dist/components/websocket/index.js +19 -0
- package/dist/components/websocket/index.js.map +1 -0
- package/package.json +10 -5
- package/dist/components/socket-io/keys.d.ts.map +0 -1
- package/dist/components/socket-io/keys.js.map +0 -1
|
@@ -20,92 +20,151 @@ const metadata_1 = require("../../base/metadata");
|
|
|
20
20
|
const bindings_1 = require("../../common/bindings");
|
|
21
21
|
const inversion_1 = require("../../helpers/inversion");
|
|
22
22
|
const ignis_helpers_1 = require("@venizia/ignis-helpers");
|
|
23
|
-
const
|
|
24
|
-
const
|
|
25
|
-
|
|
26
|
-
path: '/io',
|
|
27
|
-
cors: {
|
|
28
|
-
origin: '*',
|
|
29
|
-
methods: ['GET', 'POST'],
|
|
30
|
-
preflightContinue: false,
|
|
31
|
-
optionsSuccessStatus: 204,
|
|
32
|
-
credentials: true,
|
|
33
|
-
},
|
|
34
|
-
perMessageDeflate: {
|
|
35
|
-
threshold: 4096,
|
|
36
|
-
zlibDeflateOptions: { chunkSize: 10 * 1024 },
|
|
37
|
-
zlibInflateOptions: { windowBits: 12, memLevel: 8 },
|
|
38
|
-
clientNoContextTakeover: true,
|
|
39
|
-
serverNoContextTakeover: true,
|
|
40
|
-
serverMaxWindowBits: 10,
|
|
41
|
-
concurrencyLimit: 20,
|
|
42
|
-
},
|
|
43
|
-
};
|
|
23
|
+
const common_1 = require("./common");
|
|
24
|
+
const handlers_1 = require("./handlers");
|
|
25
|
+
const handlers_2 = require("./handlers");
|
|
44
26
|
let SocketIOComponent = SocketIOComponent_1 = class SocketIOComponent extends components_1.BaseComponent {
|
|
45
27
|
constructor(application) {
|
|
46
|
-
super({
|
|
28
|
+
super({
|
|
29
|
+
scope: SocketIOComponent_1.name,
|
|
30
|
+
initDefault: { enable: true, container: application },
|
|
31
|
+
bindings: {
|
|
32
|
+
[common_1.SocketIOBindingKeys.SERVER_OPTIONS]: inversion_1.Binding.bind({
|
|
33
|
+
key: common_1.SocketIOBindingKeys.SERVER_OPTIONS,
|
|
34
|
+
}).toValue(common_1.DEFAULT_SERVER_OPTIONS),
|
|
35
|
+
[common_1.SocketIOBindingKeys.REDIS_CONNECTION]: inversion_1.Binding.bind({
|
|
36
|
+
key: common_1.SocketIOBindingKeys.REDIS_CONNECTION,
|
|
37
|
+
}).toValue(null),
|
|
38
|
+
[common_1.SocketIOBindingKeys.AUTHENTICATE_HANDLER]: inversion_1.Binding.bind({
|
|
39
|
+
key: common_1.SocketIOBindingKeys.AUTHENTICATE_HANDLER,
|
|
40
|
+
}).toValue(null),
|
|
41
|
+
[common_1.SocketIOBindingKeys.VALIDATE_ROOM_HANDLER]: inversion_1.Binding.bind({
|
|
42
|
+
key: common_1.SocketIOBindingKeys.VALIDATE_ROOM_HANDLER,
|
|
43
|
+
}).toValue(null),
|
|
44
|
+
[common_1.SocketIOBindingKeys.CLIENT_CONNECTED_HANDLER]: inversion_1.Binding.bind({
|
|
45
|
+
key: common_1.SocketIOBindingKeys.CLIENT_CONNECTED_HANDLER,
|
|
46
|
+
}).toValue(null),
|
|
47
|
+
},
|
|
48
|
+
});
|
|
47
49
|
this.application = application;
|
|
48
|
-
this.bindings = {
|
|
49
|
-
[keys_1.SocketIOBindingKeys.SERVER_OPTIONS]: inversion_1.Binding.bind({
|
|
50
|
-
key: keys_1.SocketIOBindingKeys.SERVER_OPTIONS,
|
|
51
|
-
}).toValue(DEFAULT_SERVER_OPTIONS),
|
|
52
|
-
[keys_1.SocketIOBindingKeys.REDIS_CONNECTION]: inversion_1.Binding.bind({
|
|
53
|
-
key: keys_1.SocketIOBindingKeys.REDIS_CONNECTION,
|
|
54
|
-
}).toValue(null),
|
|
55
|
-
[keys_1.SocketIOBindingKeys.AUTHENTICATE_HANDLER]: inversion_1.Binding.bind({ key: keys_1.SocketIOBindingKeys.AUTHENTICATE_HANDLER }).toValue(null),
|
|
56
|
-
[keys_1.SocketIOBindingKeys.CLIENT_CONNECTED_HANDLER]: inversion_1.Binding.bind({ key: keys_1.SocketIOBindingKeys.CLIENT_CONNECTED_HANDLER }).toValue(null),
|
|
57
|
-
};
|
|
58
50
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
throw (0, ignis_helpers_1.getError)({
|
|
62
|
-
statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
|
|
63
|
-
message: '[binding] Invalid application to bind AuthenticateComponent',
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
this.logger.for(this.binding.name).info('Binding authenticate for application...');
|
|
51
|
+
// --------------------------------------------------------------------------
|
|
52
|
+
resolveBindings() {
|
|
67
53
|
const extraServerOptions = this.application.get({
|
|
68
|
-
key:
|
|
54
|
+
key: common_1.SocketIOBindingKeys.SERVER_OPTIONS,
|
|
69
55
|
isOptional: true,
|
|
70
56
|
}) ?? {};
|
|
71
|
-
this.serverOptions = Object.assign({}, DEFAULT_SERVER_OPTIONS, extraServerOptions);
|
|
72
|
-
this.logger.for(this.binding.name).debug('Socket.IO Server Options: %j', this.serverOptions);
|
|
57
|
+
this.serverOptions = Object.assign({}, common_1.DEFAULT_SERVER_OPTIONS, extraServerOptions);
|
|
73
58
|
const redisConnection = this.application.get({
|
|
74
|
-
key:
|
|
59
|
+
key: common_1.SocketIOBindingKeys.REDIS_CONNECTION,
|
|
75
60
|
});
|
|
76
61
|
if (!(redisConnection instanceof ignis_helpers_1.DefaultRedisHelper)) {
|
|
77
62
|
throw (0, ignis_helpers_1.getError)({
|
|
78
|
-
message: '[SocketIOComponent][
|
|
63
|
+
message: '[SocketIOComponent][resolveBindings] Invalid instance of redisConnection | Please init connection with RedisHelper for single redis connection or RedisClusterHelper for redis cluster mode!',
|
|
79
64
|
});
|
|
80
65
|
}
|
|
81
66
|
const authenticateFn = this.application.get({
|
|
82
|
-
key:
|
|
67
|
+
key: common_1.SocketIOBindingKeys.AUTHENTICATE_HANDLER,
|
|
83
68
|
});
|
|
84
69
|
if (!authenticateFn) {
|
|
85
70
|
throw (0, ignis_helpers_1.getError)({
|
|
86
71
|
message: '[DANGER][SocketIOComponent] Invalid authenticateFn to setup io socket server!',
|
|
87
72
|
});
|
|
88
73
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
|
|
74
|
+
const validateRoomFn = this.application.get({
|
|
75
|
+
key: common_1.SocketIOBindingKeys.VALIDATE_ROOM_HANDLER,
|
|
76
|
+
}) ?? undefined;
|
|
77
|
+
const clientConnectedFn = this.application.get({
|
|
78
|
+
key: common_1.SocketIOBindingKeys.CLIENT_CONNECTED_HANDLER,
|
|
79
|
+
}) ?? undefined;
|
|
80
|
+
return { redisConnection, authenticateFn, validateRoomFn, clientConnectedFn };
|
|
81
|
+
}
|
|
82
|
+
// --------------------------------------------------------------------------
|
|
83
|
+
registerBunHook(opts) {
|
|
84
|
+
const { redisConnection, authenticateFn, validateRoomFn, clientConnectedFn } = opts;
|
|
85
|
+
const serverOptions = this.serverOptions;
|
|
86
|
+
const logger = this.logger.for(this.registerBunHook.name);
|
|
87
|
+
this.application.registerPostStartHook({
|
|
88
|
+
identifier: 'socket-io-initialize',
|
|
89
|
+
hook: async () => {
|
|
90
|
+
const { engine, engineHandler } = await (0, handlers_1.createBunEngine)({ serverOptions });
|
|
91
|
+
const socketIOHelper = new ignis_helpers_1.SocketIOServerHelper({
|
|
92
|
+
runtime: ignis_helpers_1.RuntimeModules.BUN,
|
|
93
|
+
identifier: serverOptions.identifier,
|
|
94
|
+
engine,
|
|
95
|
+
serverOptions,
|
|
96
|
+
redisConnection,
|
|
97
|
+
authenticateFn,
|
|
98
|
+
validateRoomFn,
|
|
99
|
+
clientConnectedFn,
|
|
100
|
+
});
|
|
101
|
+
await socketIOHelper.configure();
|
|
102
|
+
this.application
|
|
103
|
+
.bind({ key: common_1.SocketIOBindingKeys.SOCKET_IO_INSTANCE })
|
|
104
|
+
.toValue(socketIOHelper);
|
|
105
|
+
// Wire engine into the running Bun server via reload
|
|
106
|
+
const serverInstance = this.application.getServerInstance();
|
|
107
|
+
const honoServer = this.application.getServer();
|
|
108
|
+
const enginePath = serverOptions.path ?? '/socket.io/';
|
|
109
|
+
serverInstance.reload({
|
|
110
|
+
fetch: (0, handlers_1.createBunFetchHandler)({ engine, enginePath, honoServer }),
|
|
111
|
+
websocket: engineHandler.websocket,
|
|
112
|
+
});
|
|
113
|
+
logger.info('SocketIO initialized for Bun runtime');
|
|
114
|
+
},
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
// --------------------------------------------------------------------------
|
|
118
|
+
registerNodeHook(opts) {
|
|
119
|
+
const serverOptions = this.serverOptions;
|
|
120
|
+
const logger = this.logger.for(this.registerNodeHook.name);
|
|
121
|
+
this.application.registerPostStartHook({
|
|
122
|
+
identifier: 'socket-io-initialize',
|
|
123
|
+
hook: async () => {
|
|
124
|
+
const httpServer = this.application.getServerInstance();
|
|
125
|
+
if (!httpServer) {
|
|
126
|
+
throw (0, ignis_helpers_1.getError)({
|
|
127
|
+
message: '[SocketIOComponent] HTTP server not available for Node.js runtime!',
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
const socketIOHelper = await (0, handlers_2.createNodeSocketIOHelper)({
|
|
131
|
+
serverOptions,
|
|
132
|
+
httpServer,
|
|
133
|
+
resolvedBindings: opts,
|
|
134
|
+
});
|
|
135
|
+
this.application
|
|
136
|
+
.bind({ key: common_1.SocketIOBindingKeys.SOCKET_IO_INSTANCE })
|
|
137
|
+
.toValue(socketIOHelper);
|
|
138
|
+
logger.info('SocketIO initialized for Node.js runtime');
|
|
139
|
+
},
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
// --------------------------------------------------------------------------
|
|
143
|
+
binding() {
|
|
144
|
+
const logger = this.logger.for(this.binding.name);
|
|
145
|
+
if (!this.application) {
|
|
97
146
|
throw (0, ignis_helpers_1.getError)({
|
|
98
|
-
|
|
147
|
+
statusCode: ignis_helpers_1.HTTP.ResultCodes.RS_5.InternalServerError,
|
|
148
|
+
message: '[binding] Invalid application to bind SocketIOComponent',
|
|
99
149
|
});
|
|
100
150
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
151
|
+
logger.info('Binding SocketIO for application...');
|
|
152
|
+
const resolved = this.resolveBindings();
|
|
153
|
+
logger.debug('Socket.IO Server Options: %j', this.serverOptions);
|
|
154
|
+
const runtime = ignis_helpers_1.RuntimeModules.detect();
|
|
155
|
+
switch (runtime) {
|
|
156
|
+
case ignis_helpers_1.RuntimeModules.BUN: {
|
|
157
|
+
this.registerBunHook(resolved);
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
case ignis_helpers_1.RuntimeModules.NODE: {
|
|
161
|
+
this.registerNodeHook(resolved);
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
default: {
|
|
165
|
+
throw (0, ignis_helpers_1.getError)({ message: `[SocketIOComponent] Unsupported runtime: ${runtime}` });
|
|
166
|
+
}
|
|
167
|
+
}
|
|
109
168
|
}
|
|
110
169
|
};
|
|
111
170
|
exports.SocketIOComponent = SocketIOComponent;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/components/socket-io/component.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/components/socket-io/component.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAA0E;AAC1E,kDAAkD;AAClD,8CAAyC;AACzC,gDAAiD;AACjD,mDAA8C;AAC9C,0DAUgC;AAEhC,qCAKkB;AAClB,yCAAoE;AACpE,yCAAsD;AAEtD,IAAa,iBAAiB,yBAA9B,MAAa,iBAAkB,SAAQ,0BAAa;IAGlD,YAC8D,WAA4B;QAExF,KAAK,CAAC;YACJ,KAAK,EAAE,mBAAiB,CAAC,IAAI;YAC7B,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE;YACrD,QAAQ,EAAE;gBACR,CAAC,4BAAmB,CAAC,cAAc,CAAC,EAAE,mBAAO,CAAC,IAAI,CAAyB;oBACzE,GAAG,EAAE,4BAAmB,CAAC,cAAc;iBACxC,CAAC,CAAC,OAAO,CAAC,+BAAsB,CAAC;gBAElC,CAAC,4BAAmB,CAAC,gBAAgB,CAAC,EAAE,mBAAO,CAAC,IAAI,CAA4B;oBAC9E,GAAG,EAAE,4BAAmB,CAAC,gBAAgB;iBAC1C,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;gBAEhB,CAAC,4BAAmB,CAAC,oBAAoB,CAAC,EAAE,mBAAO,CAAC,IAAI,CAAiC;oBACvF,GAAG,EAAE,4BAAmB,CAAC,oBAAoB;iBAC9C,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;gBAEhB,CAAC,4BAAmB,CAAC,qBAAqB,CAAC,EAAE,mBAAO,CAAC,IAAI,CAAiC;oBACxF,GAAG,EAAE,4BAAmB,CAAC,qBAAqB;iBAC/C,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;gBAEhB,CAAC,4BAAmB,CAAC,wBAAwB,CAAC,EAC5C,mBAAO,CAAC,IAAI,CAAoC;oBAC9C,GAAG,EAAE,4BAAmB,CAAC,wBAAwB;iBAClD,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;aACnB;SACF,CAAC,CAAC;QA3ByD,gBAAW,GAAX,WAAW,CAAiB;IA4B1F,CAAC;IAED,6EAA6E;IACrE,eAAe;QACrB,MAAM,kBAAkB,GACtB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAyB;YAC3C,GAAG,EAAE,4BAAmB,CAAC,cAAc;YACvC,UAAU,EAAE,IAAI;SACjB,CAAC,IAAI,EAAE,CAAC;QACX,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,+BAAsB,EAAE,kBAAkB,CAAC,CAAC;QAEnF,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAqB;YAC/D,GAAG,EAAE,4BAAmB,CAAC,gBAAgB;SAC1C,CAAC,CAAC;QACH,IAAI,CAAC,CAAC,eAAe,YAAY,kCAAkB,CAAC,EAAE,CAAC;YACrD,MAAM,IAAA,wBAAQ,EAAC;gBACb,OAAO,EACL,8LAA8L;aACjM,CAAC,CAAC;QACL,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAA0B;YACnE,GAAG,EAAE,4BAAmB,CAAC,oBAAoB;SAC9C,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,MAAM,IAAA,wBAAQ,EAAC;gBACb,OAAO,EAAE,+EAA+E;aACzF,CAAC,CAAC;QACL,CAAC;QAED,MAAM,cAAc,GAClB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAiC;YACnD,GAAG,EAAE,4BAAmB,CAAC,qBAAqB;SAC/C,CAAC,IAAI,SAAS,CAAC;QAElB,MAAM,iBAAiB,GACrB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAoC;YACtD,GAAG,EAAE,4BAAmB,CAAC,wBAAwB;SAClD,CAAC,IAAI,SAAS,CAAC;QAElB,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,EAAE,iBAAiB,EAAE,CAAC;IAChF,CAAC;IAED,6EAA6E;IACrE,eAAe,CAAC,IAAuB;QAC7C,MAAM,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC;QACpF,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAE1D,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC;YACrC,UAAU,EAAE,sBAAsB;YAClC,IAAI,EAAE,KAAK,IAAI,EAAE;gBACf,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,IAAA,0BAAe,EAAC,EAAE,aAAa,EAAE,CAAC,CAAC;gBAE3E,MAAM,cAAc,GAAG,IAAI,oCAAoB,CAAC;oBAC9C,OAAO,EAAE,8BAAc,CAAC,GAAG;oBAC3B,UAAU,EAAE,aAAa,CAAC,UAAW;oBACrC,MAAM;oBACN,aAAa;oBACb,eAAe;oBACf,cAAc;oBACd,cAAc;oBACd,iBAAiB;iBAClB,CAAC,CAAC;gBACH,MAAM,cAAc,CAAC,SAAS,EAAE,CAAC;gBAEjC,IAAI,CAAC,WAAW;qBACb,IAAI,CAAC,EAAE,GAAG,EAAE,4BAAmB,CAAC,kBAAkB,EAAE,CAAC;qBACrD,OAAO,CAAC,cAAc,CAAC,CAAC;gBAE3B,qDAAqD;gBACrD,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAsB,CAAC;gBAChF,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;gBAChD,MAAM,UAAU,GAAG,aAAa,CAAC,IAAI,IAAI,aAAa,CAAC;gBAEvD,cAAe,CAAC,MAAM,CAAC;oBACrB,KAAK,EAAE,IAAA,gCAAqB,EAAC,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC;oBAChE,SAAS,EAAE,aAAa,CAAC,SAAS;iBACnC,CAAC,CAAC;gBAEH,MAAM,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;YACtD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,6EAA6E;IACrE,gBAAgB,CAAC,IAAuB;QAC9C,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAE3D,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC;YACrC,UAAU,EAAE,sBAAsB;YAClC,IAAI,EAAE,KAAK,IAAI,EAAE;gBACf,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE,CAAC;gBACxD,IAAI,CAAC,UAAU,EAAE,CAAC;oBAChB,MAAM,IAAA,wBAAQ,EAAC;wBACb,OAAO,EAAE,oEAAoE;qBAC9E,CAAC,CAAC;gBACL,CAAC;gBAED,MAAM,cAAc,GAAG,MAAM,IAAA,mCAAwB,EAAC;oBACpD,aAAa;oBACb,UAAU;oBACV,gBAAgB,EAAE,IAAI;iBACvB,CAAC,CAAC;gBAEH,IAAI,CAAC,WAAW;qBACb,IAAI,CAAC,EAAE,GAAG,EAAE,4BAAmB,CAAC,kBAAkB,EAAE,CAAC;qBACrD,OAAO,CAAC,cAAc,CAAC,CAAC;gBAE3B,MAAM,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC;YAC1D,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,6EAA6E;IACpE,OAAO;QACd,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAElD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,IAAA,wBAAQ,EAAC;gBACb,UAAU,EAAE,oBAAI,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB;gBACrD,OAAO,EAAE,yDAAyD;aACnE,CAAC,CAAC;QACL,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;QAEnD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,8BAA8B,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAEjE,MAAM,OAAO,GAAG,8BAAc,CAAC,MAAM,EAAE,CAAC;QAExC,QAAQ,OAAO,EAAE,CAAC;YAChB,KAAK,8BAAc,CAAC,GAAG,CAAC,CAAC,CAAC;gBACxB,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC/B,MAAM;YACR,CAAC;YACD,KAAK,8BAAc,CAAC,IAAI,CAAC,CAAC,CAAC;gBACzB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;gBAChC,MAAM;YACR,CAAC;YACD,OAAO,CAAC,CAAC,CAAC;gBACR,MAAM,IAAA,wBAAQ,EAAC,EAAE,OAAO,EAAE,4CAA4C,OAAO,EAAE,EAAE,CAAC,CAAC;YACrF,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAA;AAnLY,8CAAiB;4BAAjB,iBAAiB;IAIzB,WAAA,IAAA,iBAAM,EAAC,EAAE,GAAG,EAAE,uBAAY,CAAC,oBAAoB,EAAE,CAAC,CAAA;qCAAsB,8BAAe;GAJ/E,iBAAiB,CAmL7B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { OpenAPIHono } from '@hono/zod-openapi';
|
|
2
|
+
import type { TBunServerInstance } from '../../../base/applications';
|
|
3
|
+
import type { ServerOptions } from 'socket.io';
|
|
4
|
+
export declare function createBunEngine(opts: {
|
|
5
|
+
serverOptions: Partial<ServerOptions>;
|
|
6
|
+
}): Promise<{
|
|
7
|
+
engine: any;
|
|
8
|
+
engineHandler: any;
|
|
9
|
+
}>;
|
|
10
|
+
export declare function createBunFetchHandler(opts: {
|
|
11
|
+
engine: any;
|
|
12
|
+
enginePath: string;
|
|
13
|
+
honoServer: OpenAPIHono;
|
|
14
|
+
}): (req: Request, server: TBunServerInstance) => Response | Promise<Response>;
|
|
15
|
+
//# sourceMappingURL=bun.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bun.handler.d.ts","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/bun.handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE/C,wBAAsB,eAAe,CAAC,IAAI,EAAE;IAC1C,aAAa,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;CACvC,GAAG,OAAO,CAAC;IAAE,MAAM,EAAE,GAAG,CAAC;IAAC,aAAa,EAAE,GAAG,CAAA;CAAE,CAAC,CAuB/C;AAED,wBAAgB,qBAAqB,CAAC,IAAI,EAAE;IAC1C,MAAM,EAAE,GAAG,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,WAAW,CAAC;CACzB,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,kBAAkB,KAAK,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,CAY7E"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createBunEngine = createBunEngine;
|
|
4
|
+
exports.createBunFetchHandler = createBunFetchHandler;
|
|
5
|
+
async function createBunEngine(opts) {
|
|
6
|
+
const { serverOptions } = opts;
|
|
7
|
+
const { Server: BunEngine } = await import('@socket.io/bun-engine');
|
|
8
|
+
// Extract cors fields explicitly to bridge socket.io/bun-engine type differences
|
|
9
|
+
const corsConfig = typeof serverOptions.cors === 'object' ? serverOptions.cors : undefined;
|
|
10
|
+
const engine = new BunEngine({
|
|
11
|
+
path: serverOptions.path ?? '/socket.io/',
|
|
12
|
+
...(corsConfig && {
|
|
13
|
+
cors: {
|
|
14
|
+
origin: corsConfig.origin,
|
|
15
|
+
methods: corsConfig.methods,
|
|
16
|
+
credentials: corsConfig.credentials,
|
|
17
|
+
allowedHeaders: corsConfig.allowedHeaders,
|
|
18
|
+
exposedHeaders: corsConfig.exposedHeaders,
|
|
19
|
+
maxAge: corsConfig.maxAge,
|
|
20
|
+
},
|
|
21
|
+
}),
|
|
22
|
+
});
|
|
23
|
+
const engineHandler = engine.handler();
|
|
24
|
+
return { engine, engineHandler };
|
|
25
|
+
}
|
|
26
|
+
function createBunFetchHandler(opts) {
|
|
27
|
+
const { engine, enginePath, honoServer } = opts;
|
|
28
|
+
return (req, server) => {
|
|
29
|
+
const url = new URL(req.url);
|
|
30
|
+
if (!url.pathname.startsWith(enginePath)) {
|
|
31
|
+
return honoServer.fetch(req, server);
|
|
32
|
+
}
|
|
33
|
+
return engine.handleRequest(req, server) ?? new Response(null, { status: 404 });
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=bun.handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bun.handler.js","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/bun.handler.ts"],"names":[],"mappings":";;AAIA,0CAyBC;AAED,sDAgBC;AA3CM,KAAK,UAAU,eAAe,CAAC,IAErC;IACC,MAAM,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;IAC/B,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;IAEpE,iFAAiF;IACjF,MAAM,UAAU,GAAG,OAAO,aAAa,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3F,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC;QAC3B,IAAI,EAAE,aAAa,CAAC,IAAI,IAAI,aAAa;QACzC,GAAG,CAAC,UAAU,IAAI;YAChB,IAAI,EAAE;gBACJ,MAAM,EAAE,UAAU,CAAC,MAA2D;gBAC9E,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,cAAc,EAAE,UAAU,CAAC,cAAc;gBACzC,cAAc,EAAE,UAAU,CAAC,cAAc;gBACzC,MAAM,EAAE,UAAU,CAAC,MAAM;aAC1B;SACF,CAAC;KACH,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;IAEvC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;AACnC,CAAC;AAED,SAAgB,qBAAqB,CAAC,IAIrC;IACC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;IAEhD,OAAO,CAAC,GAAY,EAAE,MAA0B,EAAgC,EAAE;QAChF,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE7B,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YACzC,OAAO,UAAU,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACvC,CAAC;QAED,OAAO,MAAM,CAAC,aAAa,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;IAClF,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./bun.handler"), exports);
|
|
18
|
+
__exportStar(require("./node.handler"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,iDAA+B"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TNodeServerInstance } from '../../../base/applications';
|
|
2
|
+
import { SocketIOServerHelper } from '@venizia/ignis-helpers';
|
|
3
|
+
import type { IResolvedBindings, IServerOptions } from '../common';
|
|
4
|
+
export declare function createNodeSocketIOHelper(opts: {
|
|
5
|
+
serverOptions: Partial<IServerOptions>;
|
|
6
|
+
httpServer: TNodeServerInstance;
|
|
7
|
+
resolvedBindings: IResolvedBindings;
|
|
8
|
+
}): Promise<SocketIOServerHelper>;
|
|
9
|
+
//# sourceMappingURL=node.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.handler.d.ts","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/node.handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAkB,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9E,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEnE,wBAAsB,wBAAwB,CAAC,IAAI,EAAE;IACnD,aAAa,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;IACvC,UAAU,EAAE,mBAAmB,CAAC;IAChC,gBAAgB,EAAE,iBAAiB,CAAC;CACrC,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAiBhC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createNodeSocketIOHelper = createNodeSocketIOHelper;
|
|
4
|
+
const ignis_helpers_1 = require("@venizia/ignis-helpers");
|
|
5
|
+
async function createNodeSocketIOHelper(opts) {
|
|
6
|
+
const { serverOptions, httpServer, resolvedBindings } = opts;
|
|
7
|
+
const { redisConnection, authenticateFn, validateRoomFn, clientConnectedFn } = resolvedBindings;
|
|
8
|
+
const socketIOHelper = new ignis_helpers_1.SocketIOServerHelper({
|
|
9
|
+
runtime: ignis_helpers_1.RuntimeModules.NODE,
|
|
10
|
+
identifier: serverOptions.identifier,
|
|
11
|
+
server: httpServer,
|
|
12
|
+
serverOptions,
|
|
13
|
+
redisConnection,
|
|
14
|
+
authenticateFn,
|
|
15
|
+
validateRoomFn,
|
|
16
|
+
clientConnectedFn,
|
|
17
|
+
});
|
|
18
|
+
await socketIOHelper.configure();
|
|
19
|
+
return socketIOHelper;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=node.handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.handler.js","sourceRoot":"","sources":["../../../../src/components/socket-io/handlers/node.handler.ts"],"names":[],"mappings":";;AAIA,4DAqBC;AAxBD,0DAA8E;AAGvE,KAAK,UAAU,wBAAwB,CAAC,IAI9C;IACC,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC;IAC7D,MAAM,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,EAAE,iBAAiB,EAAE,GAAG,gBAAgB,CAAC;IAEhG,MAAM,cAAc,GAAG,IAAI,oCAAoB,CAAC;QAC9C,OAAO,EAAE,8BAAc,CAAC,IAAI;QAC5B,UAAU,EAAE,aAAa,CAAC,UAAW;QACrC,MAAM,EAAE,UAAU;QAClB,aAAa;QACb,eAAe;QACf,cAAc;QACd,cAAc;QACd,iBAAiB;KAClB,CAAC,CAAC;IACH,MAAM,cAAc,CAAC,SAAS,EAAE,CAAC;IAEjC,OAAO,cAAc,CAAC;AACxB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/socket-io/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/socket-io/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC"}
|
|
@@ -14,6 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./common/keys"), exports);
|
|
17
18
|
__exportStar(require("./component"), exports);
|
|
18
|
-
__exportStar(require("./keys"), exports);
|
|
19
19
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/socket-io/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/socket-io/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,8CAA4B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/websocket/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./keys"), exports);
|
|
18
|
+
__exportStar(require("./types"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/websocket/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare class WebSocketBindingKeys {
|
|
2
|
+
static readonly WEBSOCKET_INSTANCE = "@app/websocket/instance";
|
|
3
|
+
static readonly SERVER_OPTIONS = "@app/websocket/server-options";
|
|
4
|
+
static readonly REDIS_CONNECTION = "@app/websocket/redis-connection";
|
|
5
|
+
static readonly AUTHENTICATE_HANDLER = "@app/websocket/authenticate-handler";
|
|
6
|
+
static readonly VALIDATE_ROOM_HANDLER = "@app/websocket/validate-room-handler";
|
|
7
|
+
static readonly CLIENT_CONNECTED_HANDLER = "@app/websocket/client-connected-handler";
|
|
8
|
+
static readonly CLIENT_DISCONNECTED_HANDLER = "@app/websocket/client-disconnected-handler";
|
|
9
|
+
static readonly MESSAGE_HANDLER = "@app/websocket/message-handler";
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=keys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keys.d.ts","sourceRoot":"","sources":["../../../../src/components/websocket/common/keys.ts"],"names":[],"mappings":"AAAA,qBAAa,oBAAoB;IAC/B,MAAM,CAAC,QAAQ,CAAC,kBAAkB,6BAA6B;IAE/D,MAAM,CAAC,QAAQ,CAAC,cAAc,mCAAmC;IACjE,MAAM,CAAC,QAAQ,CAAC,gBAAgB,qCAAqC;IAErE,MAAM,CAAC,QAAQ,CAAC,oBAAoB,yCAAyC;IAC7E,MAAM,CAAC,QAAQ,CAAC,qBAAqB,0CAA0C;IAC/E,MAAM,CAAC,QAAQ,CAAC,wBAAwB,6CAA6C;IACrF,MAAM,CAAC,QAAQ,CAAC,2BAA2B,gDAAgD;IAC3F,MAAM,CAAC,QAAQ,CAAC,eAAe,oCAAoC;CACpE"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WebSocketBindingKeys = void 0;
|
|
4
|
+
class WebSocketBindingKeys {
|
|
5
|
+
static { this.WEBSOCKET_INSTANCE = '@app/websocket/instance'; }
|
|
6
|
+
static { this.SERVER_OPTIONS = '@app/websocket/server-options'; }
|
|
7
|
+
static { this.REDIS_CONNECTION = '@app/websocket/redis-connection'; }
|
|
8
|
+
static { this.AUTHENTICATE_HANDLER = '@app/websocket/authenticate-handler'; }
|
|
9
|
+
static { this.VALIDATE_ROOM_HANDLER = '@app/websocket/validate-room-handler'; }
|
|
10
|
+
static { this.CLIENT_CONNECTED_HANDLER = '@app/websocket/client-connected-handler'; }
|
|
11
|
+
static { this.CLIENT_DISCONNECTED_HANDLER = '@app/websocket/client-disconnected-handler'; }
|
|
12
|
+
static { this.MESSAGE_HANDLER = '@app/websocket/message-handler'; }
|
|
13
|
+
}
|
|
14
|
+
exports.WebSocketBindingKeys = WebSocketBindingKeys;
|
|
15
|
+
//# sourceMappingURL=keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keys.js","sourceRoot":"","sources":["../../../../src/components/websocket/common/keys.ts"],"names":[],"mappings":";;;AAAA,MAAa,oBAAoB;aACf,uBAAkB,GAAG,yBAAyB,CAAC;aAE/C,mBAAc,GAAG,+BAA+B,CAAC;aACjD,qBAAgB,GAAG,iCAAiC,CAAC;aAErD,yBAAoB,GAAG,qCAAqC,CAAC;aAC7D,0BAAqB,GAAG,sCAAsC,CAAC;aAC/D,6BAAwB,GAAG,yCAAyC,CAAC;aACrE,gCAA2B,GAAG,4CAA4C,CAAC;aAC3E,oBAAe,GAAG,gCAAgC,CAAC;;AAVrE,oDAWC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { DefaultRedisHelper, IBunWebSocketConfig, TWebSocketAuthenticateFn, TWebSocketClientConnectedFn, TWebSocketClientDisconnectedFn, TWebSocketMessageHandler, TWebSocketValidateRoomFn } from '@venizia/ignis-helpers';
|
|
2
|
+
export interface IServerOptions {
|
|
3
|
+
identifier: string;
|
|
4
|
+
path?: string;
|
|
5
|
+
defaultRooms?: string[];
|
|
6
|
+
serverOptions?: IBunWebSocketConfig;
|
|
7
|
+
heartbeatInterval?: number;
|
|
8
|
+
heartbeatTimeout?: number;
|
|
9
|
+
}
|
|
10
|
+
export declare const DEFAULT_SERVER_OPTIONS: IServerOptions;
|
|
11
|
+
export interface IResolvedBindings {
|
|
12
|
+
redisConnection: DefaultRedisHelper;
|
|
13
|
+
authenticateFn: TWebSocketAuthenticateFn;
|
|
14
|
+
validateRoomFn?: TWebSocketValidateRoomFn;
|
|
15
|
+
clientConnectedFn?: TWebSocketClientConnectedFn;
|
|
16
|
+
clientDisconnectedFn?: TWebSocketClientDisconnectedFn;
|
|
17
|
+
messageHandler?: TWebSocketMessageHandler;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/websocket/common/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,mBAAmB,EACnB,wBAAwB,EACxB,2BAA2B,EAC3B,8BAA8B,EAC9B,wBAAwB,EACxB,wBAAwB,EACzB,MAAM,wBAAwB,CAAC;AAGhC,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,aAAa,CAAC,EAAE,mBAAmB,CAAC;IACpC,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,eAAO,MAAM,sBAAsB,EAAE,cAGpC,CAAC;AAEF,MAAM,WAAW,iBAAiB;IAChC,eAAe,EAAE,kBAAkB,CAAC;IACpC,cAAc,EAAE,wBAAwB,CAAC;IACzC,cAAc,CAAC,EAAE,wBAAwB,CAAC;IAC1C,iBAAiB,CAAC,EAAE,2BAA2B,CAAC;IAChD,oBAAoB,CAAC,EAAE,8BAA8B,CAAC;IACtD,cAAc,CAAC,EAAE,wBAAwB,CAAC;CAC3C"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DEFAULT_SERVER_OPTIONS = void 0;
|
|
4
|
+
const ignis_helpers_1 = require("@venizia/ignis-helpers");
|
|
5
|
+
exports.DEFAULT_SERVER_OPTIONS = {
|
|
6
|
+
identifier: 'WEBSOCKET_SERVER',
|
|
7
|
+
path: ignis_helpers_1.WebSocketDefaults.PATH,
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/websocket/common/types.ts"],"names":[],"mappings":";;;AASA,0DAA2D;AAW9C,QAAA,sBAAsB,GAAmB;IACpD,UAAU,EAAE,kBAAkB;IAC9B,IAAI,EAAE,iCAAiB,CAAC,IAAI;CAC7B,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { BaseApplication } from '../../base/applications';
|
|
2
|
+
import { BaseComponent } from '../../base/components';
|
|
3
|
+
import { ValueOrPromise } from '@venizia/ignis-helpers';
|
|
4
|
+
import { type IServerOptions } from './common';
|
|
5
|
+
export declare class WebSocketComponent extends BaseComponent {
|
|
6
|
+
private application;
|
|
7
|
+
protected serverOptions: IServerOptions;
|
|
8
|
+
constructor(application: BaseApplication);
|
|
9
|
+
private resolveBindings;
|
|
10
|
+
private registerBunHook;
|
|
11
|
+
binding(): ValueOrPromise<void>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"component.d.ts","sourceRoot":"","sources":["../../../src/components/websocket/component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAsB,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAIlD,OAAO,EAWL,cAAc,EAGf,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,UAAU,CAAC;AAGlB,qBAAa,kBAAmB,SAAQ,aAAa;IAIG,OAAO,CAAC,WAAW;IAHzE,SAAS,CAAC,aAAa,EAAE,cAAc,CAAC;gBAGsB,WAAW,EAAE,eAAe;IA0C1F,OAAO,CAAC,eAAe;IAuDvB,OAAO,CAAC,eAAe;IAyDd,OAAO,IAAI,cAAc,CAAC,IAAI,CAAC;CA2BzC"}
|