@ragemp-mango/core 2.0.6-beta.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/LICENSE +21 -0
- package/README.md +20 -0
- package/dist/app/constants/index.d.ts +26 -0
- package/dist/app/constants/index.js +49 -0
- package/dist/app/controller/index.d.ts +70 -0
- package/dist/app/controller/index.js +24 -0
- package/dist/app/enums/index.d.ts +27 -0
- package/dist/app/enums/index.js +16 -0
- package/dist/app/index.d.ts +138 -0
- package/dist/app/index.js +132 -0
- package/dist/app/interfaces/index.d.ts +157 -0
- package/dist/app/interfaces/index.js +2 -0
- package/dist/app/module/index.d.ts +27 -0
- package/dist/app/module/index.js +16 -0
- package/dist/app/module-tree/index.d.ts +56 -0
- package/dist/app/module-tree/index.js +25 -0
- package/dist/app/pipeline/index.d.ts +5 -0
- package/dist/app/pipeline/index.js +14 -0
- package/dist/app/services/index.d.ts +37 -0
- package/dist/app/services/index.js +14 -0
- package/dist/app/utils/index.d.ts +16 -0
- package/dist/app/utils/index.js +10 -0
- package/dist/call-handler.interface-DVdaknsB.d.ts +52 -0
- package/dist/chunk-2ADQZWQE.js +170 -0
- package/dist/chunk-6YEWPMZJ.js +69 -0
- package/dist/chunk-73LIJA6X.js +176 -0
- package/dist/chunk-7QVYU63E.js +7 -0
- package/dist/chunk-AO6BXG54.js +139 -0
- package/dist/chunk-CFHBJ5MV.js +1906 -0
- package/dist/chunk-CW7WAA3P.js +1906 -0
- package/dist/chunk-DEPJRTVT.js +1 -0
- package/dist/chunk-DJZCOYB3.js +17 -0
- package/dist/chunk-DXPVUDXD.js +81 -0
- package/dist/chunk-E6IQL4S6.js +40 -0
- package/dist/chunk-HK7QTFPA.js +81 -0
- package/dist/chunk-ITEHLEIP.js +29 -0
- package/dist/chunk-M55YEQ7J.js +1 -0
- package/dist/chunk-PGWRESZG.js +790 -0
- package/dist/chunk-PQK4E654.js +1 -0
- package/dist/chunk-RYOUF322.js +68 -0
- package/dist/chunk-SKPH3K2M.js +570 -0
- package/dist/chunk-TBWHLT75.js +61 -0
- package/dist/constants/index.d.ts +8 -0
- package/dist/constants/index.js +18 -0
- package/dist/controller-Ss0TVrxQ.d.ts +30 -0
- package/dist/custom-decorator.type-BHRvXIGz.d.ts +5 -0
- package/dist/decorators/index.d.ts +90 -0
- package/dist/decorators/index.js +91 -0
- package/dist/enums/index.d.ts +66 -0
- package/dist/enums/index.js +12 -0
- package/dist/errors/index.d.ts +23 -0
- package/dist/errors/index.js +17 -0
- package/dist/event-destination.enum-DT8jJFwR.d.ts +7 -0
- package/dist/event-emmiter.interface-7Ne9W8SM.d.ts +10 -0
- package/dist/event-metadata.interface-CREizDNq.d.ts +89 -0
- package/dist/execution-context-type.enum-fwYPtPvp.d.ts +6 -0
- package/dist/execution-context.interface-DpRN4oVj.d.ts +56 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.js +190 -0
- package/dist/injectable-options.interface-8Gp9oRY6.d.ts +10 -0
- package/dist/injectable-scope.enum-CjyQMpW2.d.ts +7 -0
- package/dist/injection-token.type-dQTkkP6p.d.ts +5 -0
- package/dist/interfaces/index.d.ts +38 -0
- package/dist/interfaces/index.js +2 -0
- package/dist/logger-service.interface-BGV-o_Fx.d.ts +8 -0
- package/dist/method-param-type.enum-BfrJ8zqa.d.ts +11 -0
- package/dist/module-metadata.interface-B3bn1vqq.d.ts +59 -0
- package/dist/multiplayer-timers.interface-CFDTWwAT.d.ts +22 -0
- package/dist/newable.type-BdhG3MZC.d.ts +5 -0
- package/dist/nullable.type-C-lE7JU4.d.ts +3 -0
- package/dist/pipe-transform.interface-BlzOrUy3.d.ts +14 -0
- package/dist/pipes/index.d.ts +12 -0
- package/dist/pipes/index.js +9 -0
- package/dist/reflectable-decorator.interface-CLOGdtEQ.d.ts +14 -0
- package/dist/rpc-call-options.interface-BJ5mHrvT.d.ts +5 -0
- package/dist/rpc-error.interface-CeaZLqzE.d.ts +6 -0
- package/dist/rpc-metadata.interface-DS-GqgqA.d.ts +11 -0
- package/dist/rpc-result.interface-C758heM0.d.ts +10 -0
- package/dist/schemas/index.d.ts +189 -0
- package/dist/schemas/index.js +39 -0
- package/dist/script-event-handler.interface-B-Th4Ssg.d.ts +24 -0
- package/dist/script-event-handler.interface-vUr_v6tV.d.ts +5 -0
- package/dist/script-rpc-handler.interface-DBpD9-yk.d.ts +8 -0
- package/dist/services/index.d.ts +45 -0
- package/dist/services/index.js +23 -0
- package/dist/types/index.d.ts +9 -0
- package/dist/types/index.js +2 -0
- package/dist/utils/index.d.ts +16 -0
- package/dist/utils/index.js +32 -0
- package/package.json +133 -0
|
@@ -0,0 +1,1906 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Module,
|
|
3
|
+
ModuleContainer,
|
|
4
|
+
ModuleMetadataReader
|
|
5
|
+
} from "./chunk-73LIJA6X.js";
|
|
6
|
+
import {
|
|
7
|
+
ExecutionContextBase,
|
|
8
|
+
MangoRequestBase,
|
|
9
|
+
MangoResponseBase
|
|
10
|
+
} from "./chunk-AO6BXG54.js";
|
|
11
|
+
import {
|
|
12
|
+
Tree,
|
|
13
|
+
TreeNode
|
|
14
|
+
} from "./chunk-RYOUF322.js";
|
|
15
|
+
import {
|
|
16
|
+
validateControllerOptions,
|
|
17
|
+
validateErrorFilter,
|
|
18
|
+
validateGuard,
|
|
19
|
+
validateInjectableMetadata,
|
|
20
|
+
validateInjectionToken,
|
|
21
|
+
validateInterceptor,
|
|
22
|
+
validateModuleOptions,
|
|
23
|
+
validatePipe
|
|
24
|
+
} from "./chunk-PGWRESZG.js";
|
|
25
|
+
import {
|
|
26
|
+
Controller,
|
|
27
|
+
ControllerEventHandler,
|
|
28
|
+
ControllerFlowHandler,
|
|
29
|
+
ControllerMetadataReader,
|
|
30
|
+
ControllerRPCHandler,
|
|
31
|
+
PipelineHandler
|
|
32
|
+
} from "./chunk-SKPH3K2M.js";
|
|
33
|
+
import {
|
|
34
|
+
APP_ENVIROMENT,
|
|
35
|
+
CONTAINER_OPTIONS,
|
|
36
|
+
ENABLE_SHUTDOWN_HOOKS,
|
|
37
|
+
EXECUTION_CONTEXT_FACTORY,
|
|
38
|
+
GLOBAL_APP_CONTAINER,
|
|
39
|
+
GLOBAL_ERROR_FILTERS,
|
|
40
|
+
GLOBAL_GUARDS,
|
|
41
|
+
GLOBAL_INTERCEPTORS,
|
|
42
|
+
GLOBAL_PIPES,
|
|
43
|
+
INTERNAL_APP_CONTAINER,
|
|
44
|
+
MANGO_REQUEST_FACTORY,
|
|
45
|
+
MANGO_RESPONSE_FACTORY,
|
|
46
|
+
MULTIPLAYER_SERVICE,
|
|
47
|
+
PLUGINS
|
|
48
|
+
} from "./chunk-HK7QTFPA.js";
|
|
49
|
+
import {
|
|
50
|
+
CoreMetadataKey,
|
|
51
|
+
MethodParamType
|
|
52
|
+
} from "./chunk-TBWHLT75.js";
|
|
53
|
+
import {
|
|
54
|
+
LOGGER_SERVICE,
|
|
55
|
+
MODULE_CONTAINER,
|
|
56
|
+
REFLECTOR_SERVICE,
|
|
57
|
+
TIMER_SERVICE
|
|
58
|
+
} from "./chunk-DJZCOYB3.js";
|
|
59
|
+
import {
|
|
60
|
+
ErrorMessage
|
|
61
|
+
} from "./chunk-DXPVUDXD.js";
|
|
62
|
+
import {
|
|
63
|
+
generateRandomId,
|
|
64
|
+
isEmpty,
|
|
65
|
+
isNil,
|
|
66
|
+
isNumber,
|
|
67
|
+
isObject,
|
|
68
|
+
isString
|
|
69
|
+
} from "./chunk-E6IQL4S6.js";
|
|
70
|
+
import {
|
|
71
|
+
__name
|
|
72
|
+
} from "./chunk-7QVYU63E.js";
|
|
73
|
+
|
|
74
|
+
// src/services/reflector.service.ts
|
|
75
|
+
import { injectable as injectable9 } from "inversify";
|
|
76
|
+
|
|
77
|
+
// src/decorators/core/controller.decorator.ts
|
|
78
|
+
import { injectable } from "inversify";
|
|
79
|
+
function Controller2(options) {
|
|
80
|
+
return (target) => {
|
|
81
|
+
if (Reflect.hasMetadata(CoreMetadataKey.Controller, target)) {
|
|
82
|
+
throw new Error(ErrorMessage.DuplicateDecoratorUsage);
|
|
83
|
+
}
|
|
84
|
+
const { valid, value, error } = validateControllerOptions(options);
|
|
85
|
+
if (!valid) throw new Error(error);
|
|
86
|
+
Reflect.defineMetadata(CoreMetadataKey.Controller, value, target);
|
|
87
|
+
return injectable()(target);
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
__name(Controller2, "Controller");
|
|
91
|
+
|
|
92
|
+
// src/decorators/core/global.decorator.ts
|
|
93
|
+
function Global() {
|
|
94
|
+
return (target) => {
|
|
95
|
+
Reflect.defineMetadata(CoreMetadataKey.GlobalModule, true, target);
|
|
96
|
+
return target;
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
__name(Global, "Global");
|
|
100
|
+
|
|
101
|
+
// src/decorators/core/inject.decorator.ts
|
|
102
|
+
import { inject } from "inversify";
|
|
103
|
+
function Inject(key) {
|
|
104
|
+
return (target, propertyKey, paramIndex) => {
|
|
105
|
+
if (!isNil(key) && !validateInjectionToken(key).valid) {
|
|
106
|
+
throw new Error(ErrorMessage.InvalidInjectionTokenSpecified);
|
|
107
|
+
}
|
|
108
|
+
const token = key ?? Reflect.getMetadata("design:type", target, propertyKey);
|
|
109
|
+
if (!token) {
|
|
110
|
+
throw new Error(ErrorMessage.InjectionTokenNotFound);
|
|
111
|
+
}
|
|
112
|
+
inject(token)(target, propertyKey, paramIndex);
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
__name(Inject, "Inject");
|
|
116
|
+
|
|
117
|
+
// src/decorators/core/injectable.decorator.ts
|
|
118
|
+
import { injectable as injectable2 } from "inversify";
|
|
119
|
+
function Injectable(options) {
|
|
120
|
+
return (target) => {
|
|
121
|
+
if (Reflect.hasMetadata(CoreMetadataKey.Injectable, target)) {
|
|
122
|
+
throw new Error(ErrorMessage.DuplicateDecoratorUsage);
|
|
123
|
+
}
|
|
124
|
+
const { valid, value, error } = validateInjectableMetadata(options);
|
|
125
|
+
if (!valid) throw new Error(error);
|
|
126
|
+
Reflect.defineMetadata(CoreMetadataKey.Injectable, value, target);
|
|
127
|
+
return injectable2()(target);
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
__name(Injectable, "Injectable");
|
|
131
|
+
|
|
132
|
+
// src/decorators/core/module.decorator.ts
|
|
133
|
+
import { injectable as injectable3 } from "inversify";
|
|
134
|
+
function Module2(options) {
|
|
135
|
+
return (target) => {
|
|
136
|
+
if (Reflect.hasMetadata(CoreMetadataKey.Module, target)) {
|
|
137
|
+
throw new Error(ErrorMessage.DuplicateDecoratorUsage);
|
|
138
|
+
}
|
|
139
|
+
const { valid, value, error } = validateModuleOptions(options);
|
|
140
|
+
if (!valid) throw new Error(error);
|
|
141
|
+
Reflect.defineMetadata(CoreMetadataKey.Module, value, target);
|
|
142
|
+
return injectable3()(target);
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
__name(Module2, "Module");
|
|
146
|
+
|
|
147
|
+
// src/decorators/core/optional.decorator.ts
|
|
148
|
+
import { optional } from "inversify";
|
|
149
|
+
function Optional() {
|
|
150
|
+
return (target, propertyKey, paramIndex) => {
|
|
151
|
+
return optional()(target, propertyKey, paramIndex);
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
__name(Optional, "Optional");
|
|
155
|
+
|
|
156
|
+
// src/decorators/core/set-metadata.decorator.ts
|
|
157
|
+
function SetMetadata(key, value) {
|
|
158
|
+
const decoratorFactory = /* @__PURE__ */ __name((target, _method, descriptor) => {
|
|
159
|
+
if (descriptor) {
|
|
160
|
+
Reflect.defineMetadata(key, value, descriptor.value);
|
|
161
|
+
return descriptor;
|
|
162
|
+
}
|
|
163
|
+
Reflect.defineMetadata(key, value, target);
|
|
164
|
+
return target;
|
|
165
|
+
}, "decoratorFactory");
|
|
166
|
+
decoratorFactory.KEY = key;
|
|
167
|
+
return decoratorFactory;
|
|
168
|
+
}
|
|
169
|
+
__name(SetMetadata, "SetMetadata");
|
|
170
|
+
|
|
171
|
+
// src/decorators/errors/catch.decorator.ts
|
|
172
|
+
function Catch(...exceptions) {
|
|
173
|
+
return (target) => {
|
|
174
|
+
if (Reflect.hasMetadata(CoreMetadataKey.Catch, target)) {
|
|
175
|
+
throw new Error(ErrorMessage.DuplicateDecoratorUsage);
|
|
176
|
+
}
|
|
177
|
+
const duplicates = exceptions.filter((exception, index) => exceptions.indexOf(exception) !== index);
|
|
178
|
+
if (duplicates.length) {
|
|
179
|
+
throw new Error(ErrorMessage.ExceptionHandlingConflict);
|
|
180
|
+
}
|
|
181
|
+
Reflect.defineMetadata(CoreMetadataKey.Catch, exceptions, target);
|
|
182
|
+
return target;
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
__name(Catch, "Catch");
|
|
186
|
+
|
|
187
|
+
// src/decorators/errors/use-filters.decorator.ts
|
|
188
|
+
function UseFilters(...filters) {
|
|
189
|
+
return (target, method, descriptor) => {
|
|
190
|
+
const validatedFilters = [];
|
|
191
|
+
for (const filter of filters) {
|
|
192
|
+
const { valid, value, error } = validateErrorFilter(filter);
|
|
193
|
+
if (!valid) throw new Error(error);
|
|
194
|
+
validatedFilters.push(value);
|
|
195
|
+
}
|
|
196
|
+
if (!isNil(descriptor) && !isNil(descriptor.value)) {
|
|
197
|
+
if (filters.length === 0) {
|
|
198
|
+
throw new Error(ErrorMessage.AtLeastOneFilterRequired);
|
|
199
|
+
}
|
|
200
|
+
const methodFilters = Reflect.getMetadata(CoreMetadataKey.ErrorFilters, target.constructor, method) || [];
|
|
201
|
+
if (!isNil(methodFilters.find((filter) => filters.includes(filter)))) {
|
|
202
|
+
throw new Error(ErrorMessage.DuplicateErrorFilterDetected);
|
|
203
|
+
}
|
|
204
|
+
Reflect.defineMetadata(CoreMetadataKey.ErrorFilters, [
|
|
205
|
+
...validatedFilters,
|
|
206
|
+
...methodFilters
|
|
207
|
+
], target.constructor, method);
|
|
208
|
+
return descriptor;
|
|
209
|
+
}
|
|
210
|
+
if (filters.length === 0) {
|
|
211
|
+
throw new Error(ErrorMessage.AtLeastOneFilterRequired);
|
|
212
|
+
}
|
|
213
|
+
const classFilters = Reflect.getMetadata(CoreMetadataKey.ErrorFilters, target) || [];
|
|
214
|
+
if (!isNil(classFilters.find((filter) => filters.includes(filter)))) {
|
|
215
|
+
throw new Error(ErrorMessage.DuplicateErrorFilterDetected);
|
|
216
|
+
}
|
|
217
|
+
Reflect.defineMetadata(CoreMetadataKey.ErrorFilters, [
|
|
218
|
+
...validatedFilters,
|
|
219
|
+
...classFilters
|
|
220
|
+
], target);
|
|
221
|
+
return target;
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
__name(UseFilters, "UseFilters");
|
|
225
|
+
|
|
226
|
+
// src/app/module-tree/app-runtime.ts
|
|
227
|
+
import { inject as inject2, injectable as injectable4, optional as optional2 } from "inversify";
|
|
228
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
229
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
230
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
231
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
232
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
233
|
+
}
|
|
234
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
235
|
+
function _ts_metadata(k, v) {
|
|
236
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
237
|
+
}
|
|
238
|
+
__name(_ts_metadata, "_ts_metadata");
|
|
239
|
+
var AppRuntime = class {
|
|
240
|
+
static {
|
|
241
|
+
__name(this, "AppRuntime");
|
|
242
|
+
}
|
|
243
|
+
eventHandler;
|
|
244
|
+
rpcHandler;
|
|
245
|
+
globalGuards;
|
|
246
|
+
globalInterceptors;
|
|
247
|
+
globalPipes;
|
|
248
|
+
globalErrorFilters;
|
|
249
|
+
loggerService;
|
|
250
|
+
enableShutdownHooks;
|
|
251
|
+
async boot(resolvedTree) {
|
|
252
|
+
await resolvedTree.asyncTraverse(async (node) => {
|
|
253
|
+
const startTime = Date.now();
|
|
254
|
+
const module = node.value;
|
|
255
|
+
module.instance = module.container.get(module.metadata.classRef);
|
|
256
|
+
module.controllers.forEach((controller) => controller.instance = module.container.get(controller.metadata.classRef));
|
|
257
|
+
[
|
|
258
|
+
...module.metadata.internalProviders,
|
|
259
|
+
...module.metadata.externalProviders
|
|
260
|
+
].forEach(([token]) => module.container.get(token));
|
|
261
|
+
this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~loaded ~lk~(${Date.now() - startTime}ms)`);
|
|
262
|
+
await this.runLifecycleMethod(module, "onModuleInit");
|
|
263
|
+
});
|
|
264
|
+
await this.runLifecycleMethods(resolvedTree, "onAppBootstrap");
|
|
265
|
+
resolvedTree.traverse((node) => {
|
|
266
|
+
const module = node.value;
|
|
267
|
+
module.controllers.forEach((controller) => {
|
|
268
|
+
const time = Date.now();
|
|
269
|
+
this.registerTimers(controller);
|
|
270
|
+
this.registerListeners(controller);
|
|
271
|
+
this.loggerService.log(`~lw~Controller ~lc~${controller.metadata.classRef.name} ~lw~timers and listeners registered ~lk~(${Date.now() - time}ms)`);
|
|
272
|
+
});
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
async shutdown(resolvedTree) {
|
|
276
|
+
if (this.enableShutdownHooks) {
|
|
277
|
+
await this.runLifecycleMethods(resolvedTree, "onModuleDestroy");
|
|
278
|
+
await this.runLifecycleMethods(resolvedTree, "beforeAppShutdown");
|
|
279
|
+
}
|
|
280
|
+
await resolvedTree.asyncTraverse(async (node) => {
|
|
281
|
+
const module = node.value;
|
|
282
|
+
module.controllers.forEach((controller) => {
|
|
283
|
+
const timerService = controller.owner.container.get(TIMER_SERVICE);
|
|
284
|
+
timerService.everyticks.forEach((timer) => timer.destroy());
|
|
285
|
+
timerService.intervals.forEach((timer) => timer.destroy());
|
|
286
|
+
timerService.timeouts.forEach((timer) => timer.destroy());
|
|
287
|
+
timerService.crons.forEach((cron) => cron.stop());
|
|
288
|
+
controller.eventHandlers.forEach((handler) => handler.destroy());
|
|
289
|
+
controller.rpcHandlers.forEach((handler) => handler.destroy());
|
|
290
|
+
});
|
|
291
|
+
});
|
|
292
|
+
if (this.enableShutdownHooks) {
|
|
293
|
+
await this.runLifecycleMethods(resolvedTree, "onAppShutdown");
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
registerListeners(controller) {
|
|
297
|
+
const module = controller.owner;
|
|
298
|
+
controller.metadata.events.forEach((event) => {
|
|
299
|
+
const guards = [
|
|
300
|
+
...this.globalGuards,
|
|
301
|
+
...module.metadata.guards,
|
|
302
|
+
...controller.metadata.guards,
|
|
303
|
+
...event.guards
|
|
304
|
+
];
|
|
305
|
+
const interceptors = [
|
|
306
|
+
...this.globalInterceptors,
|
|
307
|
+
...module.metadata.interceptors,
|
|
308
|
+
...controller.metadata.interceptors,
|
|
309
|
+
...event.interceptors
|
|
310
|
+
];
|
|
311
|
+
const pipes = [
|
|
312
|
+
...this.globalPipes,
|
|
313
|
+
...module.metadata.pipes,
|
|
314
|
+
...controller.metadata.pipes,
|
|
315
|
+
...event.pipes
|
|
316
|
+
];
|
|
317
|
+
const mappedErrorFilters = this.mapErrorFilters([
|
|
318
|
+
...this.globalErrorFilters,
|
|
319
|
+
...module.metadata.errorFilters,
|
|
320
|
+
...controller.metadata.errorFilters,
|
|
321
|
+
...event.errorFilters
|
|
322
|
+
]);
|
|
323
|
+
const handler = this.eventHandler.registerEvent(guards, interceptors, pipes, mappedErrorFilters, controller, event);
|
|
324
|
+
controller.eventHandlers.push(handler);
|
|
325
|
+
});
|
|
326
|
+
controller.metadata.rpcs.forEach(async (rpc) => {
|
|
327
|
+
const guards = [
|
|
328
|
+
...this.globalGuards,
|
|
329
|
+
...module.metadata.guards,
|
|
330
|
+
...controller.metadata.guards,
|
|
331
|
+
...rpc.guards
|
|
332
|
+
];
|
|
333
|
+
const interceptors = [
|
|
334
|
+
...this.globalInterceptors,
|
|
335
|
+
...module.metadata.interceptors,
|
|
336
|
+
...controller.metadata.interceptors,
|
|
337
|
+
...rpc.interceptors
|
|
338
|
+
];
|
|
339
|
+
const pipes = [
|
|
340
|
+
...this.globalPipes,
|
|
341
|
+
...module.metadata.pipes,
|
|
342
|
+
...controller.metadata.pipes,
|
|
343
|
+
...rpc.pipes
|
|
344
|
+
];
|
|
345
|
+
const mappedErrorFilters = this.mapErrorFilters([
|
|
346
|
+
...this.globalErrorFilters,
|
|
347
|
+
...module.metadata.errorFilters,
|
|
348
|
+
...controller.metadata.errorFilters,
|
|
349
|
+
...rpc.errorFilters
|
|
350
|
+
]);
|
|
351
|
+
const handler = await this.rpcHandler.registerRPC(guards, interceptors, pipes, mappedErrorFilters, controller, rpc);
|
|
352
|
+
controller.rpcHandlers.push(handler);
|
|
353
|
+
});
|
|
354
|
+
}
|
|
355
|
+
registerTimers(controller) {
|
|
356
|
+
const timerService = controller.owner.container.get(TIMER_SERVICE);
|
|
357
|
+
controller.metadata.timers.forEach((timer) => {
|
|
358
|
+
if (timer.type === "cron") {
|
|
359
|
+
timerService.createCronJob(controller.instance[timer.method].bind(controller.instance), timer.options);
|
|
360
|
+
} else if (timer.type === "everytick") {
|
|
361
|
+
timerService.createEveryTick(controller.instance[timer.method].bind(controller.instance), timer.name);
|
|
362
|
+
} else if (timer.type === "interval") {
|
|
363
|
+
timerService.createInterval(controller.instance[timer.method].bind(controller.instance), timer.options.timeout, timer.name);
|
|
364
|
+
} else if (timer.type === "timeout") {
|
|
365
|
+
timerService.createTimeout(controller.instance[timer.method].bind(controller.instance), timer.options.timeout, timer.name);
|
|
366
|
+
}
|
|
367
|
+
});
|
|
368
|
+
}
|
|
369
|
+
mapErrorFilters(errorFilters) {
|
|
370
|
+
const filterMap = [];
|
|
371
|
+
for (const filter of errorFilters) {
|
|
372
|
+
const errors = Reflect.getMetadata(CoreMetadataKey.Catch, filter) ?? [];
|
|
373
|
+
if (errors.length === 0) {
|
|
374
|
+
errors.push("MANGO_ANY_ERROR");
|
|
375
|
+
}
|
|
376
|
+
for (const error of errors) {
|
|
377
|
+
if (!isNil(filterMap.find((filterError) => filterError[0] === error))) {
|
|
378
|
+
this.loggerService.error("An error occurred while trying to map error filters.");
|
|
379
|
+
throw new Error(ErrorMessage.ErrorAlreadyHandledByFilter);
|
|
380
|
+
}
|
|
381
|
+
filterMap.push([
|
|
382
|
+
error,
|
|
383
|
+
filter
|
|
384
|
+
]);
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
return filterMap;
|
|
388
|
+
}
|
|
389
|
+
async runLifecycleMethods(resolvedTree, method) {
|
|
390
|
+
return resolvedTree.asyncTraverse(async (node) => await this.runLifecycleMethod(node.value, method));
|
|
391
|
+
}
|
|
392
|
+
async runLifecycleMethod(module, method) {
|
|
393
|
+
await Promise.all(module.controllers.map(async (controller) => {
|
|
394
|
+
if (!isObject(controller.instance) || isNil(controller.instance[method])) return;
|
|
395
|
+
await controller.instance[method]();
|
|
396
|
+
}));
|
|
397
|
+
await Promise.all([
|
|
398
|
+
...module.metadata.internalProviders,
|
|
399
|
+
...module.metadata.externalProviders
|
|
400
|
+
].map(async ([token]) => {
|
|
401
|
+
const providerInstance = module.container.get(token);
|
|
402
|
+
if (!isObject(providerInstance) || isNil(providerInstance[method])) return;
|
|
403
|
+
await providerInstance[method]();
|
|
404
|
+
}));
|
|
405
|
+
if (!isObject(module.instance) || isNil(module.instance[method])) return;
|
|
406
|
+
await module.instance[method]();
|
|
407
|
+
}
|
|
408
|
+
};
|
|
409
|
+
_ts_decorate([
|
|
410
|
+
inject2(ControllerEventHandler),
|
|
411
|
+
_ts_metadata("design:type", typeof ControllerEventHandler === "undefined" ? Object : ControllerEventHandler)
|
|
412
|
+
], AppRuntime.prototype, "eventHandler", void 0);
|
|
413
|
+
_ts_decorate([
|
|
414
|
+
inject2(ControllerRPCHandler),
|
|
415
|
+
_ts_metadata("design:type", typeof ControllerRPCHandler === "undefined" ? Object : ControllerRPCHandler)
|
|
416
|
+
], AppRuntime.prototype, "rpcHandler", void 0);
|
|
417
|
+
_ts_decorate([
|
|
418
|
+
inject2(GLOBAL_GUARDS),
|
|
419
|
+
_ts_metadata("design:type", Array)
|
|
420
|
+
], AppRuntime.prototype, "globalGuards", void 0);
|
|
421
|
+
_ts_decorate([
|
|
422
|
+
inject2(GLOBAL_INTERCEPTORS),
|
|
423
|
+
_ts_metadata("design:type", Array)
|
|
424
|
+
], AppRuntime.prototype, "globalInterceptors", void 0);
|
|
425
|
+
_ts_decorate([
|
|
426
|
+
inject2(GLOBAL_PIPES),
|
|
427
|
+
_ts_metadata("design:type", Array)
|
|
428
|
+
], AppRuntime.prototype, "globalPipes", void 0);
|
|
429
|
+
_ts_decorate([
|
|
430
|
+
inject2(GLOBAL_ERROR_FILTERS),
|
|
431
|
+
_ts_metadata("design:type", Array)
|
|
432
|
+
], AppRuntime.prototype, "globalErrorFilters", void 0);
|
|
433
|
+
_ts_decorate([
|
|
434
|
+
inject2(LOGGER_SERVICE),
|
|
435
|
+
_ts_metadata("design:type", typeof LoggerService === "undefined" ? Object : LoggerService)
|
|
436
|
+
], AppRuntime.prototype, "loggerService", void 0);
|
|
437
|
+
_ts_decorate([
|
|
438
|
+
inject2(ENABLE_SHUTDOWN_HOOKS),
|
|
439
|
+
optional2(),
|
|
440
|
+
_ts_metadata("design:type", Boolean)
|
|
441
|
+
], AppRuntime.prototype, "enableShutdownHooks", void 0);
|
|
442
|
+
AppRuntime = _ts_decorate([
|
|
443
|
+
injectable4()
|
|
444
|
+
], AppRuntime);
|
|
445
|
+
|
|
446
|
+
// src/app/module-tree/dependency-binder.ts
|
|
447
|
+
import { Container, inject as inject3, injectable as injectable5, optional as optional3 } from "inversify";
|
|
448
|
+
function _ts_decorate2(decorators, target, key, desc) {
|
|
449
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
450
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
451
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
452
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
453
|
+
}
|
|
454
|
+
__name(_ts_decorate2, "_ts_decorate");
|
|
455
|
+
function _ts_metadata2(k, v) {
|
|
456
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
457
|
+
}
|
|
458
|
+
__name(_ts_metadata2, "_ts_metadata");
|
|
459
|
+
var ModuleDependencyBinder = class {
|
|
460
|
+
static {
|
|
461
|
+
__name(this, "ModuleDependencyBinder");
|
|
462
|
+
}
|
|
463
|
+
globalAppContainer;
|
|
464
|
+
loggerService;
|
|
465
|
+
containerOptions;
|
|
466
|
+
async bind(resolvedTree) {
|
|
467
|
+
await resolvedTree.asyncTraverse(async (node) => {
|
|
468
|
+
const startTime = Date.now();
|
|
469
|
+
const module = node.value;
|
|
470
|
+
module.container = new ModuleContainer(module.metadata.container ?? this.containerOptions);
|
|
471
|
+
module.container.parent = this.globalAppContainer;
|
|
472
|
+
this.globalAppContainer.bind(module.metadata.classRef).toSelf().inSingletonScope();
|
|
473
|
+
if (module.metadata.global) {
|
|
474
|
+
for (const [_, provider] of module.metadata.externalProviders) {
|
|
475
|
+
this.bindProvider(provider, this.globalAppContainer);
|
|
476
|
+
}
|
|
477
|
+
} else {
|
|
478
|
+
for (const [token, provider] of module.metadata.externalProviders) {
|
|
479
|
+
this.bindProvider(provider, module.container);
|
|
480
|
+
module.parent?.container.bind(token).toDynamicValue(() => module.container.get(token));
|
|
481
|
+
}
|
|
482
|
+
for (const importModule of module.repetitiveImports) {
|
|
483
|
+
for (const [token] of importModule.metadata.externalProviders) {
|
|
484
|
+
module.container.bind(token).toDynamicValue(() => importModule.container.get(token));
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
for (const [_, provider] of module.metadata.internalProviders) {
|
|
489
|
+
this.bindProvider(provider, module.container);
|
|
490
|
+
}
|
|
491
|
+
module.container.bind(MODULE_CONTAINER).toConstantValue(module.container);
|
|
492
|
+
for (const classRef of module.metadata.controllers) {
|
|
493
|
+
module.container.bind(classRef).toSelf().inSingletonScope();
|
|
494
|
+
}
|
|
495
|
+
module.container.bind(TIMER_SERVICE).to(TimerService).inSingletonScope();
|
|
496
|
+
this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~dependencies binded ~lk~(${Date.now() - startTime}ms)`);
|
|
497
|
+
});
|
|
498
|
+
}
|
|
499
|
+
bindProvider(provider, container) {
|
|
500
|
+
if ("useValue" in provider) {
|
|
501
|
+
container.bind(provider.provide).toConstantValue(provider.useValue);
|
|
502
|
+
} else if ("useFactory" in provider) {
|
|
503
|
+
const binding = container.bind(provider.provide).toDynamicValue((ctx) => {
|
|
504
|
+
const deps = provider.inject?.map((dep) => {
|
|
505
|
+
if (isObject(dep) && "token" in dep && "optional" in dep) {
|
|
506
|
+
try {
|
|
507
|
+
return ctx.container.get(dep.token);
|
|
508
|
+
} catch (err) {
|
|
509
|
+
if (dep.optional) return void 0;
|
|
510
|
+
this.loggerService.error("An error occurred while trying to resolve a dependency.");
|
|
511
|
+
throw err;
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
return ctx.container.get(dep);
|
|
515
|
+
}) ?? [];
|
|
516
|
+
return provider.useFactory(...deps);
|
|
517
|
+
});
|
|
518
|
+
if (provider.scope === "transient") binding.inTransientScope();
|
|
519
|
+
else if (provider.scope === "request") binding.inRequestScope();
|
|
520
|
+
else binding.inSingletonScope();
|
|
521
|
+
} else if ("useClass" in provider) {
|
|
522
|
+
const binding = container.bind(provider.provide).to(provider.useClass);
|
|
523
|
+
if (provider.scope === "transient") binding.inTransientScope();
|
|
524
|
+
else if (provider.scope === "request") binding.inRequestScope();
|
|
525
|
+
else binding.inSingletonScope();
|
|
526
|
+
} else if ("useExisting" in provider) {
|
|
527
|
+
container.bind(provider.provide).toService(provider.useExisting);
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
};
|
|
531
|
+
_ts_decorate2([
|
|
532
|
+
inject3(GLOBAL_APP_CONTAINER),
|
|
533
|
+
_ts_metadata2("design:type", typeof Container === "undefined" ? Object : Container)
|
|
534
|
+
], ModuleDependencyBinder.prototype, "globalAppContainer", void 0);
|
|
535
|
+
_ts_decorate2([
|
|
536
|
+
inject3(LOGGER_SERVICE),
|
|
537
|
+
_ts_metadata2("design:type", typeof LoggerService === "undefined" ? Object : LoggerService)
|
|
538
|
+
], ModuleDependencyBinder.prototype, "loggerService", void 0);
|
|
539
|
+
_ts_decorate2([
|
|
540
|
+
optional3(),
|
|
541
|
+
inject3(CONTAINER_OPTIONS),
|
|
542
|
+
_ts_metadata2("design:type", typeof interfaces === "undefined" || typeof interfaces.ContainerOptions === "undefined" ? Object : interfaces.ContainerOptions)
|
|
543
|
+
], ModuleDependencyBinder.prototype, "containerOptions", void 0);
|
|
544
|
+
ModuleDependencyBinder = _ts_decorate2([
|
|
545
|
+
injectable5()
|
|
546
|
+
], ModuleDependencyBinder);
|
|
547
|
+
|
|
548
|
+
// src/app/module-tree/module-tree-scanner.ts
|
|
549
|
+
import { inject as inject4, injectable as injectable6 } from "inversify";
|
|
550
|
+
function _ts_decorate3(decorators, target, key, desc) {
|
|
551
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
552
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
553
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
554
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
555
|
+
}
|
|
556
|
+
__name(_ts_decorate3, "_ts_decorate");
|
|
557
|
+
function _ts_metadata3(k, v) {
|
|
558
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
559
|
+
}
|
|
560
|
+
__name(_ts_metadata3, "_ts_metadata");
|
|
561
|
+
var ModuleTreeScanner = class {
|
|
562
|
+
static {
|
|
563
|
+
__name(this, "ModuleTreeScanner");
|
|
564
|
+
}
|
|
565
|
+
moduleMetadataReader;
|
|
566
|
+
controllerMetadataReader;
|
|
567
|
+
loggerService;
|
|
568
|
+
async scan(classRef) {
|
|
569
|
+
const startTime = Date.now();
|
|
570
|
+
const moduleMetadata = await this.moduleMetadataReader.read(classRef);
|
|
571
|
+
const module = new Module();
|
|
572
|
+
module.metadata = moduleMetadata;
|
|
573
|
+
this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);
|
|
574
|
+
await this.scanControllers(module);
|
|
575
|
+
const moduleTree = new Tree(module);
|
|
576
|
+
const scannedModules = /* @__PURE__ */ new Map();
|
|
577
|
+
scannedModules.set(classRef, module);
|
|
578
|
+
for (const importedModule of moduleMetadata.imports) {
|
|
579
|
+
await this.scanModules(moduleTree.root, importedModule, scannedModules);
|
|
580
|
+
}
|
|
581
|
+
return moduleTree;
|
|
582
|
+
}
|
|
583
|
+
async scanModules(parentNode, classRef, scannedModules = /* @__PURE__ */ new Map()) {
|
|
584
|
+
const scannedModule = scannedModules.get(classRef);
|
|
585
|
+
if (!isNil(scannedModule)) {
|
|
586
|
+
parentNode.value.repetitiveImports.add(scannedModule);
|
|
587
|
+
return;
|
|
588
|
+
}
|
|
589
|
+
const startTime = Date.now();
|
|
590
|
+
const moduleMetadata = await this.moduleMetadataReader.read(classRef);
|
|
591
|
+
this.checkCircularDependency(parentNode.value.metadata, moduleMetadata);
|
|
592
|
+
const module = new Module();
|
|
593
|
+
module.metadata = moduleMetadata;
|
|
594
|
+
module.parent = parentNode.value;
|
|
595
|
+
this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);
|
|
596
|
+
await this.scanControllers(module);
|
|
597
|
+
const treeNode = new TreeNode(module);
|
|
598
|
+
parentNode.addChild(treeNode);
|
|
599
|
+
scannedModules.set(classRef, module);
|
|
600
|
+
for (const importModule of moduleMetadata.imports) {
|
|
601
|
+
await this.scanModules(treeNode, importModule, scannedModules);
|
|
602
|
+
}
|
|
603
|
+
}
|
|
604
|
+
async scanControllers(module) {
|
|
605
|
+
for (const classRef of module.metadata.controllers) {
|
|
606
|
+
const startTime = Date.now();
|
|
607
|
+
const controllerMetadata = await this.controllerMetadataReader.read(classRef);
|
|
608
|
+
const controller = new Controller();
|
|
609
|
+
controller.metadata = controllerMetadata;
|
|
610
|
+
controller.owner = module;
|
|
611
|
+
module.controllers.push(controller);
|
|
612
|
+
this.loggerService.log(`~lw~Controller ~lc~${classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);
|
|
613
|
+
}
|
|
614
|
+
}
|
|
615
|
+
async checkCircularDependency(parentMetadata, moduleMetadata) {
|
|
616
|
+
if (moduleMetadata.imports.includes(parentMetadata.classRef)) {
|
|
617
|
+
throw new Error(ErrorMessage.CircularDependencyDetected);
|
|
618
|
+
}
|
|
619
|
+
}
|
|
620
|
+
};
|
|
621
|
+
_ts_decorate3([
|
|
622
|
+
inject4(ModuleMetadataReader),
|
|
623
|
+
_ts_metadata3("design:type", typeof ModuleMetadataReader === "undefined" ? Object : ModuleMetadataReader)
|
|
624
|
+
], ModuleTreeScanner.prototype, "moduleMetadataReader", void 0);
|
|
625
|
+
_ts_decorate3([
|
|
626
|
+
inject4(ControllerMetadataReader),
|
|
627
|
+
_ts_metadata3("design:type", typeof ControllerMetadataReader === "undefined" ? Object : ControllerMetadataReader)
|
|
628
|
+
], ModuleTreeScanner.prototype, "controllerMetadataReader", void 0);
|
|
629
|
+
_ts_decorate3([
|
|
630
|
+
inject4(LOGGER_SERVICE),
|
|
631
|
+
_ts_metadata3("design:type", typeof LoggerService === "undefined" ? Object : LoggerService)
|
|
632
|
+
], ModuleTreeScanner.prototype, "loggerService", void 0);
|
|
633
|
+
ModuleTreeScanner = _ts_decorate3([
|
|
634
|
+
injectable6()
|
|
635
|
+
], ModuleTreeScanner);
|
|
636
|
+
|
|
637
|
+
// src/app/multiplayer/ragemp/ragemp-script-event-handler.ts
|
|
638
|
+
var RageMPScriptEvent = class {
|
|
639
|
+
static {
|
|
640
|
+
__name(this, "RageMPScriptEvent");
|
|
641
|
+
}
|
|
642
|
+
eventName;
|
|
643
|
+
listener;
|
|
644
|
+
constructor(eventName, listener) {
|
|
645
|
+
this.eventName = eventName;
|
|
646
|
+
this.listener = listener;
|
|
647
|
+
}
|
|
648
|
+
destroy() {
|
|
649
|
+
mp.events.remove(this.eventName, this.listener);
|
|
650
|
+
}
|
|
651
|
+
};
|
|
652
|
+
|
|
653
|
+
// src/app/multiplayer/ragemp/ragemp-event-emmiter.ts
|
|
654
|
+
var RageMPEventEmmiter = class {
|
|
655
|
+
static {
|
|
656
|
+
__name(this, "RageMPEventEmmiter");
|
|
657
|
+
}
|
|
658
|
+
mapEvents;
|
|
659
|
+
mapEventsShared = {
|
|
660
|
+
// Map alt:V event names to RageMP equivalents
|
|
661
|
+
"entityColShapeEnter": "playerEnterColshape",
|
|
662
|
+
"entityColShapeLeave": "playerExitColshape"
|
|
663
|
+
};
|
|
664
|
+
constructor(mapEvents = {}) {
|
|
665
|
+
this.mapEvents = mapEvents;
|
|
666
|
+
}
|
|
667
|
+
getEventName(eventName) {
|
|
668
|
+
return this.mapEventsShared[eventName] || this.mapEvents[eventName] || eventName;
|
|
669
|
+
}
|
|
670
|
+
emit(eventName, ...args) {
|
|
671
|
+
mp.events.call(eventName, ...args);
|
|
672
|
+
}
|
|
673
|
+
on(eventName, listener) {
|
|
674
|
+
const mappedEventName = this.getEventName(eventName);
|
|
675
|
+
mp.events.add(mappedEventName, listener);
|
|
676
|
+
return new RageMPScriptEvent(mappedEventName, listener);
|
|
677
|
+
}
|
|
678
|
+
once(eventName, listener) {
|
|
679
|
+
const mappedEventName = this.getEventName(eventName);
|
|
680
|
+
const onceWrapper = /* @__PURE__ */ __name((...args) => {
|
|
681
|
+
mp.events.remove(mappedEventName, onceWrapper);
|
|
682
|
+
listener(...args);
|
|
683
|
+
}, "onceWrapper");
|
|
684
|
+
mp.events.add(mappedEventName, onceWrapper);
|
|
685
|
+
return new RageMPScriptEvent(mappedEventName, onceWrapper);
|
|
686
|
+
}
|
|
687
|
+
off(eventName, listener) {
|
|
688
|
+
mp.events.remove(eventName, listener);
|
|
689
|
+
}
|
|
690
|
+
};
|
|
691
|
+
|
|
692
|
+
// src/app/multiplayer/ragemp/ragemp-timer.ts
|
|
693
|
+
var RageMPTimer = class {
|
|
694
|
+
static {
|
|
695
|
+
__name(this, "RageMPTimer");
|
|
696
|
+
}
|
|
697
|
+
id;
|
|
698
|
+
interval;
|
|
699
|
+
once;
|
|
700
|
+
callback;
|
|
701
|
+
clearTimer;
|
|
702
|
+
lastTick = Date.now();
|
|
703
|
+
constructor(id, interval = 0, once, callback, clearTimer) {
|
|
704
|
+
this.id = id;
|
|
705
|
+
this.interval = interval;
|
|
706
|
+
this.once = once;
|
|
707
|
+
this.callback = callback;
|
|
708
|
+
this.clearTimer = clearTimer;
|
|
709
|
+
}
|
|
710
|
+
destroy() {
|
|
711
|
+
this.clearTimer();
|
|
712
|
+
}
|
|
713
|
+
};
|
|
714
|
+
|
|
715
|
+
// src/app/multiplayer/ragemp/ragemp-timers.ts
|
|
716
|
+
var RageMPTimers = class {
|
|
717
|
+
static {
|
|
718
|
+
__name(this, "RageMPTimers");
|
|
719
|
+
}
|
|
720
|
+
timerIncrementer = 0;
|
|
721
|
+
timers = /* @__PURE__ */ new Map();
|
|
722
|
+
everyTickHandlers = /* @__PURE__ */ new Map();
|
|
723
|
+
isEveryTickRunning = false;
|
|
724
|
+
everyTickMainHandler = null;
|
|
725
|
+
get all() {
|
|
726
|
+
return [
|
|
727
|
+
...this.timers.values()
|
|
728
|
+
];
|
|
729
|
+
}
|
|
730
|
+
get warningThreshold() {
|
|
731
|
+
return 0;
|
|
732
|
+
}
|
|
733
|
+
set warningThreshold(_value) {
|
|
734
|
+
}
|
|
735
|
+
get sourceLocationFrameSkipCount() {
|
|
736
|
+
return 0;
|
|
737
|
+
}
|
|
738
|
+
set sourceLocationFrameSkipCount(_value) {
|
|
739
|
+
}
|
|
740
|
+
getByID(id) {
|
|
741
|
+
const timer = this.timers.get(id);
|
|
742
|
+
return timer ?? null;
|
|
743
|
+
}
|
|
744
|
+
createTimer(createTimer, clear, callback, interval, once, ...args) {
|
|
745
|
+
const callbackBind = callback.bind(this, ...Array.isArray(args) ? args : []);
|
|
746
|
+
const timerId = typeof interval === "number" ? createTimer(callbackBind, interval) : createTimer(callbackBind);
|
|
747
|
+
const id = this.timerIncrementer++;
|
|
748
|
+
const rageMPTimer = new RageMPTimer(id, interval ?? 0, once, callbackBind, () => {
|
|
749
|
+
clear(timerId);
|
|
750
|
+
this.timers.delete(id);
|
|
751
|
+
});
|
|
752
|
+
this.timers.set(id, rageMPTimer);
|
|
753
|
+
return rageMPTimer;
|
|
754
|
+
}
|
|
755
|
+
setInterval(callback, time, ...args) {
|
|
756
|
+
return this.createTimer((cb, interval) => setInterval(cb, interval), (id) => clearInterval(id), callback, time, false, ...args);
|
|
757
|
+
}
|
|
758
|
+
setTimeout(callback, time, ...args) {
|
|
759
|
+
const id = this.timerIncrementer++;
|
|
760
|
+
const callbackBind = callback.bind(this, ...Array.isArray(args) ? args : []);
|
|
761
|
+
const timerId = setTimeout(() => {
|
|
762
|
+
callbackBind();
|
|
763
|
+
this.timers.delete(id);
|
|
764
|
+
}, time);
|
|
765
|
+
const rageMPTimer = new RageMPTimer(id, time, true, callbackBind, () => {
|
|
766
|
+
clearTimeout(timerId);
|
|
767
|
+
this.timers.delete(id);
|
|
768
|
+
});
|
|
769
|
+
this.timers.set(id, rageMPTimer);
|
|
770
|
+
return rageMPTimer;
|
|
771
|
+
}
|
|
772
|
+
everyTick(callback, ...args) {
|
|
773
|
+
const id = this.timerIncrementer++;
|
|
774
|
+
const callbackBind = callback.bind(this, ...Array.isArray(args) ? args : []);
|
|
775
|
+
this.everyTickHandlers.set(id, {
|
|
776
|
+
callback,
|
|
777
|
+
bound: callbackBind
|
|
778
|
+
});
|
|
779
|
+
const isClientSide = typeof mp !== "undefined" && typeof mp.browsers !== "undefined";
|
|
780
|
+
if (!this.isEveryTickRunning) {
|
|
781
|
+
this.isEveryTickRunning = true;
|
|
782
|
+
if (isClientSide) {
|
|
783
|
+
this.everyTickMainHandler = () => {
|
|
784
|
+
for (const [, handler] of this.everyTickHandlers) {
|
|
785
|
+
try {
|
|
786
|
+
handler.bound();
|
|
787
|
+
} catch (e) {
|
|
788
|
+
mp.console.logError(`Error in everyTick handler: ${e}`);
|
|
789
|
+
}
|
|
790
|
+
}
|
|
791
|
+
};
|
|
792
|
+
mp.events.add("render", this.everyTickMainHandler);
|
|
793
|
+
} else {
|
|
794
|
+
const intervalHandler = /* @__PURE__ */ __name(() => {
|
|
795
|
+
for (const [, handler] of this.everyTickHandlers) {
|
|
796
|
+
try {
|
|
797
|
+
handler.bound();
|
|
798
|
+
} catch (e) {
|
|
799
|
+
mp.console.logError(`Error in everyTick handler: ${e}`);
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
}, "intervalHandler");
|
|
803
|
+
this._everyTickInterval = setInterval(intervalHandler, 0);
|
|
804
|
+
}
|
|
805
|
+
}
|
|
806
|
+
const rageMPTimer = new RageMPTimer(id, 0, false, callbackBind, () => {
|
|
807
|
+
this.everyTickHandlers.delete(id);
|
|
808
|
+
this.timers.delete(id);
|
|
809
|
+
if (this.everyTickHandlers.size === 0) {
|
|
810
|
+
if (isClientSide && this.everyTickMainHandler) {
|
|
811
|
+
mp.events.remove("render", this.everyTickMainHandler);
|
|
812
|
+
this.everyTickMainHandler = null;
|
|
813
|
+
} else if (this._everyTickInterval) {
|
|
814
|
+
clearInterval(this._everyTickInterval);
|
|
815
|
+
this._everyTickInterval = null;
|
|
816
|
+
}
|
|
817
|
+
this.isEveryTickRunning = false;
|
|
818
|
+
}
|
|
819
|
+
});
|
|
820
|
+
this.timers.set(id, rageMPTimer);
|
|
821
|
+
return rageMPTimer;
|
|
822
|
+
}
|
|
823
|
+
nextTick(callback, ...args) {
|
|
824
|
+
const id = this.timerIncrementer++;
|
|
825
|
+
const callbackBind = callback.bind(this, ...Array.isArray(args) ? args : []);
|
|
826
|
+
const isClientSide = typeof mp !== "undefined" && typeof mp.browsers !== "undefined";
|
|
827
|
+
let timerId;
|
|
828
|
+
if (isClientSide) {
|
|
829
|
+
const handler = /* @__PURE__ */ __name(() => {
|
|
830
|
+
try {
|
|
831
|
+
callbackBind();
|
|
832
|
+
} finally {
|
|
833
|
+
mp.events.remove("render", handler);
|
|
834
|
+
this.timers.delete(id);
|
|
835
|
+
}
|
|
836
|
+
}, "handler");
|
|
837
|
+
mp.events.add("render", handler);
|
|
838
|
+
const rageMPTimer = new RageMPTimer(id, 0, true, callbackBind, () => {
|
|
839
|
+
mp.events.remove("render", handler);
|
|
840
|
+
this.timers.delete(id);
|
|
841
|
+
});
|
|
842
|
+
this.timers.set(id, rageMPTimer);
|
|
843
|
+
return rageMPTimer;
|
|
844
|
+
} else {
|
|
845
|
+
timerId = setTimeout(() => {
|
|
846
|
+
try {
|
|
847
|
+
callbackBind();
|
|
848
|
+
} finally {
|
|
849
|
+
this.timers.delete(id);
|
|
850
|
+
}
|
|
851
|
+
}, 0);
|
|
852
|
+
const rageMPTimer = new RageMPTimer(id, 0, true, callbackBind, () => {
|
|
853
|
+
clearTimeout(timerId);
|
|
854
|
+
this.timers.delete(id);
|
|
855
|
+
});
|
|
856
|
+
this.timers.set(id, rageMPTimer);
|
|
857
|
+
return rageMPTimer;
|
|
858
|
+
}
|
|
859
|
+
}
|
|
860
|
+
time(_name) {
|
|
861
|
+
}
|
|
862
|
+
timeEnd(_name) {
|
|
863
|
+
}
|
|
864
|
+
};
|
|
865
|
+
|
|
866
|
+
// src/app/multiplayer/ragemp/ragemp-multiplayer.service.ts
|
|
867
|
+
var RageMPMultiplayerService = class {
|
|
868
|
+
static {
|
|
869
|
+
__name(this, "RageMPMultiplayerService");
|
|
870
|
+
}
|
|
871
|
+
Timers;
|
|
872
|
+
Events;
|
|
873
|
+
constructor() {
|
|
874
|
+
this.Events = new RageMPEventEmmiter();
|
|
875
|
+
this.Timers = new RageMPTimers();
|
|
876
|
+
}
|
|
877
|
+
parseInternalArgs(...args) {
|
|
878
|
+
const player = isObject(args[0]) ? args[0] : void 0;
|
|
879
|
+
return {
|
|
880
|
+
player,
|
|
881
|
+
body: args
|
|
882
|
+
};
|
|
883
|
+
}
|
|
884
|
+
log(arg, ...args) {
|
|
885
|
+
const message = [
|
|
886
|
+
arg,
|
|
887
|
+
...args
|
|
888
|
+
].map((a) => typeof a === "object" ? JSON.stringify(a) : String(a)).join(" ");
|
|
889
|
+
mp.console.logInfo(message);
|
|
890
|
+
}
|
|
891
|
+
logError(arg, ...args) {
|
|
892
|
+
const message = [
|
|
893
|
+
arg,
|
|
894
|
+
...args
|
|
895
|
+
].map((a) => typeof a === "object" ? JSON.stringify(a) : String(a)).join(" ");
|
|
896
|
+
mp.console.logError(message);
|
|
897
|
+
}
|
|
898
|
+
logWarning(arg, ...args) {
|
|
899
|
+
const message = [
|
|
900
|
+
arg,
|
|
901
|
+
...args
|
|
902
|
+
].map((a) => typeof a === "object" ? JSON.stringify(a) : String(a)).join(" ");
|
|
903
|
+
mp.console.logWarning(message);
|
|
904
|
+
}
|
|
905
|
+
logDebug(arg, ...args) {
|
|
906
|
+
const message = [
|
|
907
|
+
arg,
|
|
908
|
+
...args
|
|
909
|
+
].map((a) => typeof a === "object" ? JSON.stringify(a) : String(a)).join(" ");
|
|
910
|
+
mp.console.logInfo(`[DEBUG] ${message}`);
|
|
911
|
+
}
|
|
912
|
+
};
|
|
913
|
+
|
|
914
|
+
// src/app/app-builder.ts
|
|
915
|
+
import { inject as inject6, Container as Container3, injectable as injectable8 } from "inversify";
|
|
916
|
+
|
|
917
|
+
// src/app/app.ts
|
|
918
|
+
import { Container as Container2, inject as inject5, injectable as injectable7 } from "inversify";
|
|
919
|
+
function _ts_decorate4(decorators, target, key, desc) {
|
|
920
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
921
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
922
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
923
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
924
|
+
}
|
|
925
|
+
__name(_ts_decorate4, "_ts_decorate");
|
|
926
|
+
function _ts_metadata4(k, v) {
|
|
927
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
928
|
+
}
|
|
929
|
+
__name(_ts_metadata4, "_ts_metadata");
|
|
930
|
+
var App = class {
|
|
931
|
+
static {
|
|
932
|
+
__name(this, "App");
|
|
933
|
+
}
|
|
934
|
+
moduleTreeScanner;
|
|
935
|
+
moduleDependencyBinder;
|
|
936
|
+
appRuntime;
|
|
937
|
+
internalAppContainer;
|
|
938
|
+
plugins;
|
|
939
|
+
loggerService;
|
|
940
|
+
moduleTree;
|
|
941
|
+
loaded = false;
|
|
942
|
+
async start(rootModule) {
|
|
943
|
+
if (this.loaded) {
|
|
944
|
+
this.loggerService.error("Error occurred while starting the app.");
|
|
945
|
+
throw new Error(ErrorMessage.AppAlreadyLoaded);
|
|
946
|
+
}
|
|
947
|
+
this.loggerService.log("~lw~Starting app...");
|
|
948
|
+
await this.runPluginMethods("beforeStart");
|
|
949
|
+
this.loggerService.log("~lw~Scanning module tree...");
|
|
950
|
+
await this.runPluginMethods("beforeScan");
|
|
951
|
+
this.moduleTree = await this.moduleTreeScanner.scan(rootModule);
|
|
952
|
+
await this.runPluginMethods("afterScan");
|
|
953
|
+
this.loggerService.log("~lw~Binding module dependencies...");
|
|
954
|
+
await this.runPluginMethods("beforeBind");
|
|
955
|
+
await this.moduleDependencyBinder.bind(this.moduleTree);
|
|
956
|
+
await this.runPluginMethods("afterBind");
|
|
957
|
+
this.loggerService.log("~lw~Loading app...");
|
|
958
|
+
await this.runPluginMethods("beforeLoad");
|
|
959
|
+
await this.appRuntime.boot(this.moduleTree);
|
|
960
|
+
this.loaded = true;
|
|
961
|
+
await this.runPluginMethods("afterLoad");
|
|
962
|
+
this.loggerService.log("~lw~App loaded");
|
|
963
|
+
await this.runPluginMethods("afterStart");
|
|
964
|
+
}
|
|
965
|
+
async stop() {
|
|
966
|
+
if (!this.loaded) {
|
|
967
|
+
this.loggerService.error("Error occurred while stopping the app.");
|
|
968
|
+
throw new Error(ErrorMessage.AppNotLoaded);
|
|
969
|
+
}
|
|
970
|
+
await this.runPluginMethods("beforeStop");
|
|
971
|
+
this.loggerService.log("~lw~Stopping app...");
|
|
972
|
+
await this.appRuntime.shutdown(this.moduleTree);
|
|
973
|
+
this.loaded = false;
|
|
974
|
+
this.loggerService.log("~lw~App stopped");
|
|
975
|
+
await this.runPluginMethods("afterStop");
|
|
976
|
+
}
|
|
977
|
+
async runPluginMethods(method) {
|
|
978
|
+
await Promise.all(this.plugins.map(async (p) => {
|
|
979
|
+
const plugin = this.internalAppContainer.get(p);
|
|
980
|
+
if (!plugin[method]) return Promise.resolve();
|
|
981
|
+
return Promise.resolve(plugin[method]());
|
|
982
|
+
}));
|
|
983
|
+
}
|
|
984
|
+
};
|
|
985
|
+
_ts_decorate4([
|
|
986
|
+
inject5(ModuleTreeScanner),
|
|
987
|
+
_ts_metadata4("design:type", typeof ModuleTreeScanner === "undefined" ? Object : ModuleTreeScanner)
|
|
988
|
+
], App.prototype, "moduleTreeScanner", void 0);
|
|
989
|
+
_ts_decorate4([
|
|
990
|
+
inject5(ModuleDependencyBinder),
|
|
991
|
+
_ts_metadata4("design:type", typeof ModuleDependencyBinder === "undefined" ? Object : ModuleDependencyBinder)
|
|
992
|
+
], App.prototype, "moduleDependencyBinder", void 0);
|
|
993
|
+
_ts_decorate4([
|
|
994
|
+
inject5(AppRuntime),
|
|
995
|
+
_ts_metadata4("design:type", typeof AppRuntime === "undefined" ? Object : AppRuntime)
|
|
996
|
+
], App.prototype, "appRuntime", void 0);
|
|
997
|
+
_ts_decorate4([
|
|
998
|
+
inject5(INTERNAL_APP_CONTAINER),
|
|
999
|
+
_ts_metadata4("design:type", typeof Container2 === "undefined" ? Object : Container2)
|
|
1000
|
+
], App.prototype, "internalAppContainer", void 0);
|
|
1001
|
+
_ts_decorate4([
|
|
1002
|
+
inject5(PLUGINS),
|
|
1003
|
+
_ts_metadata4("design:type", Array)
|
|
1004
|
+
], App.prototype, "plugins", void 0);
|
|
1005
|
+
_ts_decorate4([
|
|
1006
|
+
inject5(LOGGER_SERVICE),
|
|
1007
|
+
_ts_metadata4("design:type", typeof LoggerService === "undefined" ? Object : LoggerService)
|
|
1008
|
+
], App.prototype, "loggerService", void 0);
|
|
1009
|
+
App = _ts_decorate4([
|
|
1010
|
+
injectable7()
|
|
1011
|
+
], App);
|
|
1012
|
+
|
|
1013
|
+
// src/app/app-builder.ts
|
|
1014
|
+
function _ts_decorate5(decorators, target, key, desc) {
|
|
1015
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1016
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1017
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1018
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1019
|
+
}
|
|
1020
|
+
__name(_ts_decorate5, "_ts_decorate");
|
|
1021
|
+
function _ts_metadata5(k, v) {
|
|
1022
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
1023
|
+
}
|
|
1024
|
+
__name(_ts_metadata5, "_ts_metadata");
|
|
1025
|
+
var AppBuilder = class {
|
|
1026
|
+
static {
|
|
1027
|
+
__name(this, "AppBuilder");
|
|
1028
|
+
}
|
|
1029
|
+
enviroment;
|
|
1030
|
+
internalAppContainer;
|
|
1031
|
+
multiplayerService;
|
|
1032
|
+
plugins;
|
|
1033
|
+
globalContainerOptions = {};
|
|
1034
|
+
useGlobalGuards(...guards) {
|
|
1035
|
+
const validatedGuards = [];
|
|
1036
|
+
for (const guard of guards) {
|
|
1037
|
+
const { valid, value, error } = validateGuard(guard);
|
|
1038
|
+
if (!valid) throw new Error(error);
|
|
1039
|
+
validatedGuards.push(value);
|
|
1040
|
+
}
|
|
1041
|
+
this.internalAppContainer.bind(GLOBAL_GUARDS).toConstantValue(validatedGuards);
|
|
1042
|
+
return this;
|
|
1043
|
+
}
|
|
1044
|
+
useGlobalInterceptors(...interceptors) {
|
|
1045
|
+
const validatedInterceptors = [];
|
|
1046
|
+
for (const interceptor of interceptors) {
|
|
1047
|
+
const { valid, value, error } = validateInterceptor(interceptor);
|
|
1048
|
+
if (!valid) throw new Error(error);
|
|
1049
|
+
validatedInterceptors.push(value);
|
|
1050
|
+
}
|
|
1051
|
+
this.internalAppContainer.bind(GLOBAL_INTERCEPTORS).toConstantValue(validatedInterceptors);
|
|
1052
|
+
return this;
|
|
1053
|
+
}
|
|
1054
|
+
useGlobalPipes(...pipes) {
|
|
1055
|
+
const validatedPipes = [];
|
|
1056
|
+
for (const pipe of pipes) {
|
|
1057
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1058
|
+
if (!valid) throw new Error(error);
|
|
1059
|
+
validatedPipes.push(value);
|
|
1060
|
+
}
|
|
1061
|
+
this.internalAppContainer.bind(GLOBAL_PIPES).toConstantValue(validatedPipes);
|
|
1062
|
+
return this;
|
|
1063
|
+
}
|
|
1064
|
+
useGlobalFilters(...filters) {
|
|
1065
|
+
const validatedFIlters = [];
|
|
1066
|
+
for (const filter of filters) {
|
|
1067
|
+
const { valid, value, error } = validateErrorFilter(filter);
|
|
1068
|
+
if (!valid) throw new Error(error);
|
|
1069
|
+
validatedFIlters.push(value);
|
|
1070
|
+
}
|
|
1071
|
+
this.internalAppContainer.bind(GLOBAL_ERROR_FILTERS).toConstantValue(validatedFIlters);
|
|
1072
|
+
return this;
|
|
1073
|
+
}
|
|
1074
|
+
usePlugins(...plugins) {
|
|
1075
|
+
plugins.forEach((p) => this.internalAppContainer.bind(p).toSelf().inSingletonScope());
|
|
1076
|
+
const internalPlugins = this.internalAppContainer.get(PLUGINS);
|
|
1077
|
+
this.internalAppContainer.rebind(PLUGINS).toConstantValue([
|
|
1078
|
+
...internalPlugins,
|
|
1079
|
+
...plugins
|
|
1080
|
+
]);
|
|
1081
|
+
return this;
|
|
1082
|
+
}
|
|
1083
|
+
enableShutdownHooks() {
|
|
1084
|
+
this.internalAppContainer.bind(ENABLE_SHUTDOWN_HOOKS).toConstantValue(true);
|
|
1085
|
+
return this;
|
|
1086
|
+
}
|
|
1087
|
+
setContainerOptions(options, onlyGlobal = false) {
|
|
1088
|
+
this.globalContainerOptions = options;
|
|
1089
|
+
if (onlyGlobal) return this;
|
|
1090
|
+
this.internalAppContainer.bind(CONTAINER_OPTIONS).toConstantValue(options);
|
|
1091
|
+
return this;
|
|
1092
|
+
}
|
|
1093
|
+
async build() {
|
|
1094
|
+
const globalAppContainer = new Container3(this.globalContainerOptions);
|
|
1095
|
+
globalAppContainer.bind(REFLECTOR_SERVICE).toConstantValue(ReflectorService);
|
|
1096
|
+
globalAppContainer.bind(ReflectorService).toService(REFLECTOR_SERVICE);
|
|
1097
|
+
globalAppContainer.bind(MULTIPLAYER_SERVICE).toConstantValue(this.multiplayerService);
|
|
1098
|
+
this.internalAppContainer.bind(App).toSelf().inSingletonScope();
|
|
1099
|
+
this.internalAppContainer.bind(GLOBAL_APP_CONTAINER).toConstantValue(globalAppContainer);
|
|
1100
|
+
this.internalAppContainer.bind(ModuleTreeScanner).toSelf().inSingletonScope();
|
|
1101
|
+
this.internalAppContainer.bind(ModuleDependencyBinder).toSelf().inSingletonScope();
|
|
1102
|
+
this.internalAppContainer.bind(AppRuntime).toSelf().inSingletonScope();
|
|
1103
|
+
this.internalAppContainer.bind(PipelineHandler).toSelf().inSingletonScope();
|
|
1104
|
+
this.internalAppContainer.bind(Module).toSelf().inTransientScope();
|
|
1105
|
+
this.internalAppContainer.bind(ModuleMetadataReader).toSelf().inSingletonScope();
|
|
1106
|
+
this.internalAppContainer.bind(Controller).toSelf().inTransientScope();
|
|
1107
|
+
this.internalAppContainer.bind(ControllerMetadataReader).toSelf().inSingletonScope();
|
|
1108
|
+
this.internalAppContainer.bind(ControllerFlowHandler).toSelf().inSingletonScope();
|
|
1109
|
+
this.internalAppContainer.bind(ControllerEventHandler).toSelf().inSingletonScope();
|
|
1110
|
+
this.internalAppContainer.bind(ControllerRPCHandler).toSelf().inSingletonScope();
|
|
1111
|
+
this.internalAppContainer.bind(MangoRequestBase).toSelf().inTransientScope();
|
|
1112
|
+
this.internalAppContainer.bind(MANGO_REQUEST_FACTORY).toFactory((context) => {
|
|
1113
|
+
return (body, player) => {
|
|
1114
|
+
const request = context.container.get(MangoRequestBase);
|
|
1115
|
+
request.$body = body;
|
|
1116
|
+
request.$player = player;
|
|
1117
|
+
return request;
|
|
1118
|
+
};
|
|
1119
|
+
});
|
|
1120
|
+
this.internalAppContainer.bind(MangoResponseBase).toSelf().inTransientScope();
|
|
1121
|
+
this.internalAppContainer.bind(MANGO_RESPONSE_FACTORY).toFactory((context) => {
|
|
1122
|
+
return () => {
|
|
1123
|
+
return context.container.get(MangoResponseBase);
|
|
1124
|
+
};
|
|
1125
|
+
});
|
|
1126
|
+
this.internalAppContainer.bind(ExecutionContextBase).toSelf().inTransientScope();
|
|
1127
|
+
this.internalAppContainer.bind(EXECUTION_CONTEXT_FACTORY).toFactory((context) => {
|
|
1128
|
+
return (type, classRef, handler, request, response, name) => {
|
|
1129
|
+
const executionContext = context.container.get(ExecutionContextBase);
|
|
1130
|
+
executionContext.$type = type;
|
|
1131
|
+
executionContext.$request = request;
|
|
1132
|
+
executionContext.$response = response;
|
|
1133
|
+
executionContext.$handler = handler;
|
|
1134
|
+
executionContext.$classRef = classRef;
|
|
1135
|
+
executionContext.$name = name;
|
|
1136
|
+
return executionContext;
|
|
1137
|
+
};
|
|
1138
|
+
});
|
|
1139
|
+
for (const plugin of this.plugins) {
|
|
1140
|
+
this.internalAppContainer.bind(plugin).toSelf().inSingletonScope();
|
|
1141
|
+
const pluginInstance = this.internalAppContainer.get(plugin);
|
|
1142
|
+
if (!pluginInstance.onBuild) continue;
|
|
1143
|
+
await pluginInstance.onBuild();
|
|
1144
|
+
}
|
|
1145
|
+
if (!this.internalAppContainer.isBound(GLOBAL_GUARDS)) this.internalAppContainer.bind(GLOBAL_GUARDS).toConstantValue([]);
|
|
1146
|
+
if (!this.internalAppContainer.isBound(GLOBAL_INTERCEPTORS)) this.internalAppContainer.bind(GLOBAL_INTERCEPTORS).toConstantValue([]);
|
|
1147
|
+
if (!this.internalAppContainer.isBound(GLOBAL_PIPES)) this.internalAppContainer.bind(GLOBAL_PIPES).toConstantValue([]);
|
|
1148
|
+
if (!this.internalAppContainer.isBound(GLOBAL_ERROR_FILTERS)) this.internalAppContainer.bind(GLOBAL_ERROR_FILTERS).toConstantValue([]);
|
|
1149
|
+
return this.internalAppContainer.get(App);
|
|
1150
|
+
}
|
|
1151
|
+
};
|
|
1152
|
+
_ts_decorate5([
|
|
1153
|
+
inject6(APP_ENVIROMENT),
|
|
1154
|
+
_ts_metadata5("design:type", String)
|
|
1155
|
+
], AppBuilder.prototype, "enviroment", void 0);
|
|
1156
|
+
_ts_decorate5([
|
|
1157
|
+
inject6(INTERNAL_APP_CONTAINER),
|
|
1158
|
+
_ts_metadata5("design:type", typeof Container3 === "undefined" ? Object : Container3)
|
|
1159
|
+
], AppBuilder.prototype, "internalAppContainer", void 0);
|
|
1160
|
+
_ts_decorate5([
|
|
1161
|
+
inject6(MULTIPLAYER_SERVICE),
|
|
1162
|
+
_ts_metadata5("design:type", typeof MultiplayerService === "undefined" ? Object : MultiplayerService)
|
|
1163
|
+
], AppBuilder.prototype, "multiplayerService", void 0);
|
|
1164
|
+
_ts_decorate5([
|
|
1165
|
+
inject6(PLUGINS),
|
|
1166
|
+
_ts_metadata5("design:type", Array)
|
|
1167
|
+
], AppBuilder.prototype, "plugins", void 0);
|
|
1168
|
+
AppBuilder = _ts_decorate5([
|
|
1169
|
+
injectable8()
|
|
1170
|
+
], AppBuilder);
|
|
1171
|
+
|
|
1172
|
+
// src/app/create-app.ts
|
|
1173
|
+
import { Container as Container4 } from "inversify";
|
|
1174
|
+
async function createAppBuilder({ enviroment, plugins, appBuilderInherit, multiplayerService }) {
|
|
1175
|
+
const internalAppContainer = new Container4();
|
|
1176
|
+
if (multiplayerService) internalAppContainer.bind(MULTIPLAYER_SERVICE).toConstantValue(multiplayerService);
|
|
1177
|
+
internalAppContainer.bind(INTERNAL_APP_CONTAINER).toConstantValue(internalAppContainer);
|
|
1178
|
+
internalAppContainer.bind(APP_ENVIROMENT).toConstantValue(enviroment);
|
|
1179
|
+
internalAppContainer.bind(PLUGINS).toConstantValue(plugins);
|
|
1180
|
+
internalAppContainer.bind(appBuilderInherit).toSelf().inSingletonScope();
|
|
1181
|
+
return internalAppContainer.get(appBuilderInherit);
|
|
1182
|
+
}
|
|
1183
|
+
__name(createAppBuilder, "createAppBuilder");
|
|
1184
|
+
|
|
1185
|
+
// src/decorators/create-event-decorator.ts
|
|
1186
|
+
function createEventDecorator(type, name, webViewId) {
|
|
1187
|
+
return (target, method) => {
|
|
1188
|
+
if (!isNil(name) && !isString(name)) {
|
|
1189
|
+
throw new Error(ErrorMessage.EventNameMustBeString);
|
|
1190
|
+
}
|
|
1191
|
+
name = name ?? method;
|
|
1192
|
+
const events = Reflect.getMetadata(CoreMetadataKey.ControllerEvents, target) ?? [];
|
|
1193
|
+
if (events.some((event) => event.method === method && event.name === name && event.type === type)) {
|
|
1194
|
+
throw new Error(ErrorMessage.EventNameMustBeUnique);
|
|
1195
|
+
}
|
|
1196
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerEvents, [
|
|
1197
|
+
...events,
|
|
1198
|
+
{
|
|
1199
|
+
method,
|
|
1200
|
+
name,
|
|
1201
|
+
type,
|
|
1202
|
+
webViewId
|
|
1203
|
+
}
|
|
1204
|
+
], target);
|
|
1205
|
+
};
|
|
1206
|
+
}
|
|
1207
|
+
__name(createEventDecorator, "createEventDecorator");
|
|
1208
|
+
|
|
1209
|
+
// src/decorators/events/on-internal.decorator.ts
|
|
1210
|
+
function OnInternal(eventName) {
|
|
1211
|
+
return createEventDecorator("onInternal", eventName);
|
|
1212
|
+
}
|
|
1213
|
+
__name(OnInternal, "OnInternal");
|
|
1214
|
+
|
|
1215
|
+
// src/decorators/events/on-webview.decorator.ts
|
|
1216
|
+
function OnWebView(id, eventName) {
|
|
1217
|
+
return createEventDecorator("onWebView", eventName, id);
|
|
1218
|
+
}
|
|
1219
|
+
__name(OnWebView, "OnWebView");
|
|
1220
|
+
|
|
1221
|
+
// src/decorators/events/on.decorator.ts
|
|
1222
|
+
function On(eventName) {
|
|
1223
|
+
return createEventDecorator("on", eventName);
|
|
1224
|
+
}
|
|
1225
|
+
__name(On, "On");
|
|
1226
|
+
|
|
1227
|
+
// src/decorators/events/once-internal.decorator.ts
|
|
1228
|
+
function OnceInternal(eventName) {
|
|
1229
|
+
return createEventDecorator("onceInternal", eventName);
|
|
1230
|
+
}
|
|
1231
|
+
__name(OnceInternal, "OnceInternal");
|
|
1232
|
+
|
|
1233
|
+
// src/decorators/events/once.decorator.ts
|
|
1234
|
+
function Once(eventName) {
|
|
1235
|
+
return createEventDecorator("once", eventName);
|
|
1236
|
+
}
|
|
1237
|
+
__name(Once, "Once");
|
|
1238
|
+
|
|
1239
|
+
// src/decorators/events/once-webview.decorator.ts
|
|
1240
|
+
function OnceWebView(id, eventName) {
|
|
1241
|
+
return createEventDecorator("onceWebView", eventName, id);
|
|
1242
|
+
}
|
|
1243
|
+
__name(OnceWebView, "OnceWebView");
|
|
1244
|
+
|
|
1245
|
+
// src/decorators/params/body.decorator.ts
|
|
1246
|
+
function Body(...pipes) {
|
|
1247
|
+
return (target, method, index) => {
|
|
1248
|
+
const validatedPipes = [];
|
|
1249
|
+
for (const pipe of pipes) {
|
|
1250
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1251
|
+
if (!valid) throw new Error(error);
|
|
1252
|
+
validatedPipes.push(value);
|
|
1253
|
+
}
|
|
1254
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1255
|
+
if (params.some((param) => param.index === index)) {
|
|
1256
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1257
|
+
}
|
|
1258
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1259
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1260
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1261
|
+
...params,
|
|
1262
|
+
{
|
|
1263
|
+
index,
|
|
1264
|
+
method,
|
|
1265
|
+
pipes: validatedPipes,
|
|
1266
|
+
type: MethodParamType.Body,
|
|
1267
|
+
data: void 0,
|
|
1268
|
+
metatype
|
|
1269
|
+
}
|
|
1270
|
+
], target, method);
|
|
1271
|
+
};
|
|
1272
|
+
}
|
|
1273
|
+
__name(Body, "Body");
|
|
1274
|
+
|
|
1275
|
+
// src/decorators/params/index.decorator.ts
|
|
1276
|
+
function Index(key, ...pipes) {
|
|
1277
|
+
return (target, method, index) => {
|
|
1278
|
+
if (!isNumber(key)) {
|
|
1279
|
+
throw new Error(ErrorMessage.IndexKeyMustBeNumber);
|
|
1280
|
+
}
|
|
1281
|
+
const validatedPipes = [];
|
|
1282
|
+
for (const pipe of pipes) {
|
|
1283
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1284
|
+
if (!valid) throw new Error(error);
|
|
1285
|
+
validatedPipes.push(value);
|
|
1286
|
+
}
|
|
1287
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1288
|
+
if (params.some((param) => param.index === index)) {
|
|
1289
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1290
|
+
}
|
|
1291
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1292
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1293
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1294
|
+
...params,
|
|
1295
|
+
{
|
|
1296
|
+
index,
|
|
1297
|
+
method,
|
|
1298
|
+
pipes: validatedPipes,
|
|
1299
|
+
type: MethodParamType.Index,
|
|
1300
|
+
data: key,
|
|
1301
|
+
metatype
|
|
1302
|
+
}
|
|
1303
|
+
], target, method);
|
|
1304
|
+
};
|
|
1305
|
+
}
|
|
1306
|
+
__name(Index, "Index");
|
|
1307
|
+
|
|
1308
|
+
// src/decorators/params/request.decorator.ts
|
|
1309
|
+
function Request() {
|
|
1310
|
+
return (target, method, index) => {
|
|
1311
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1312
|
+
if (params.some((param) => param.index === index)) {
|
|
1313
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1314
|
+
}
|
|
1315
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1316
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1317
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1318
|
+
...params,
|
|
1319
|
+
{
|
|
1320
|
+
index,
|
|
1321
|
+
method,
|
|
1322
|
+
type: MethodParamType.Request,
|
|
1323
|
+
data: void 0,
|
|
1324
|
+
metatype
|
|
1325
|
+
}
|
|
1326
|
+
], target, method);
|
|
1327
|
+
};
|
|
1328
|
+
}
|
|
1329
|
+
__name(Request, "Request");
|
|
1330
|
+
function Req() {
|
|
1331
|
+
return Request();
|
|
1332
|
+
}
|
|
1333
|
+
__name(Req, "Req");
|
|
1334
|
+
|
|
1335
|
+
// src/decorators/params/param.decorator.ts
|
|
1336
|
+
function Param(key, ...pipes) {
|
|
1337
|
+
return (target, method, index) => {
|
|
1338
|
+
if (!isString(key)) {
|
|
1339
|
+
throw new Error(ErrorMessage.ParamKeyMustBeString);
|
|
1340
|
+
}
|
|
1341
|
+
const validatedPipes = [];
|
|
1342
|
+
for (const pipe of pipes) {
|
|
1343
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1344
|
+
if (!valid) throw new Error(error);
|
|
1345
|
+
validatedPipes.push(value);
|
|
1346
|
+
}
|
|
1347
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1348
|
+
if (params.some((param) => param.index === index)) {
|
|
1349
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1350
|
+
}
|
|
1351
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1352
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1353
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1354
|
+
...params,
|
|
1355
|
+
{
|
|
1356
|
+
index,
|
|
1357
|
+
method,
|
|
1358
|
+
data: key,
|
|
1359
|
+
pipes: validatedPipes,
|
|
1360
|
+
type: MethodParamType.Param,
|
|
1361
|
+
metatype
|
|
1362
|
+
}
|
|
1363
|
+
], target, method);
|
|
1364
|
+
};
|
|
1365
|
+
}
|
|
1366
|
+
__name(Param, "Param");
|
|
1367
|
+
|
|
1368
|
+
// src/decorators/params/response.deorator.ts
|
|
1369
|
+
function Response() {
|
|
1370
|
+
return (target, method, index) => {
|
|
1371
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1372
|
+
if (params.some((param) => param.index === index)) {
|
|
1373
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1374
|
+
}
|
|
1375
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1376
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1377
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1378
|
+
...params,
|
|
1379
|
+
{
|
|
1380
|
+
index,
|
|
1381
|
+
method,
|
|
1382
|
+
type: MethodParamType.Response,
|
|
1383
|
+
data: void 0,
|
|
1384
|
+
metatype
|
|
1385
|
+
}
|
|
1386
|
+
], target, method);
|
|
1387
|
+
};
|
|
1388
|
+
}
|
|
1389
|
+
__name(Response, "Response");
|
|
1390
|
+
function Res() {
|
|
1391
|
+
return Response();
|
|
1392
|
+
}
|
|
1393
|
+
__name(Res, "Res");
|
|
1394
|
+
|
|
1395
|
+
// src/decorators/pipeline/use-guards.decorator.ts
|
|
1396
|
+
function UseGuards(...guards) {
|
|
1397
|
+
return (target, method, descriptor) => {
|
|
1398
|
+
const validatedGuards = [];
|
|
1399
|
+
for (const guard of guards) {
|
|
1400
|
+
const { valid, value, error } = validateGuard(guard);
|
|
1401
|
+
if (!valid) throw new Error(error);
|
|
1402
|
+
validatedGuards.push(value);
|
|
1403
|
+
}
|
|
1404
|
+
if (!isNil(descriptor) && !isNil(descriptor.value)) {
|
|
1405
|
+
if (guards.length === 0) {
|
|
1406
|
+
throw new Error(ErrorMessage.AtLeastOneGuardRequired);
|
|
1407
|
+
}
|
|
1408
|
+
const methodGuards = Reflect.getMetadata(CoreMetadataKey.Guards, target.constructor, method) || [];
|
|
1409
|
+
Reflect.defineMetadata(CoreMetadataKey.Guards, [
|
|
1410
|
+
...validatedGuards,
|
|
1411
|
+
...methodGuards
|
|
1412
|
+
], target.constructor, method);
|
|
1413
|
+
return descriptor;
|
|
1414
|
+
}
|
|
1415
|
+
if (guards.length === 0) {
|
|
1416
|
+
throw new Error(ErrorMessage.AtLeastOneGuardRequired);
|
|
1417
|
+
}
|
|
1418
|
+
const classGuards = Reflect.getMetadata(CoreMetadataKey.Guards, target) || [];
|
|
1419
|
+
Reflect.defineMetadata(CoreMetadataKey.Guards, [
|
|
1420
|
+
...validatedGuards,
|
|
1421
|
+
...classGuards
|
|
1422
|
+
], target);
|
|
1423
|
+
return target;
|
|
1424
|
+
};
|
|
1425
|
+
}
|
|
1426
|
+
__name(UseGuards, "UseGuards");
|
|
1427
|
+
|
|
1428
|
+
// src/decorators/pipeline/use-interceptors.decorator.ts
|
|
1429
|
+
function UseInterceptors(...interceptors) {
|
|
1430
|
+
return (target, method, descriptor) => {
|
|
1431
|
+
const validatedInterceptors = [];
|
|
1432
|
+
for (const interceptor of interceptors) {
|
|
1433
|
+
const { valid, value, error } = validateInterceptor(interceptor);
|
|
1434
|
+
if (!valid) throw new Error(error);
|
|
1435
|
+
validatedInterceptors.push(value);
|
|
1436
|
+
}
|
|
1437
|
+
if (!isNil(descriptor) && !isNil(descriptor.value)) {
|
|
1438
|
+
if (interceptors.length === 0) {
|
|
1439
|
+
throw new Error(ErrorMessage.AtLeastOneInterceptorRequired);
|
|
1440
|
+
}
|
|
1441
|
+
const methodInterceptors = Reflect.getMetadata(CoreMetadataKey.Interceptors, target.constructor, method) || [];
|
|
1442
|
+
Reflect.defineMetadata(CoreMetadataKey.Interceptors, [
|
|
1443
|
+
...validatedInterceptors,
|
|
1444
|
+
...methodInterceptors
|
|
1445
|
+
], target.constructor, method);
|
|
1446
|
+
return descriptor;
|
|
1447
|
+
}
|
|
1448
|
+
if (interceptors.length === 0) {
|
|
1449
|
+
throw new Error(ErrorMessage.AtLeastOneInterceptorRequired);
|
|
1450
|
+
}
|
|
1451
|
+
const classInterceptors = Reflect.getMetadata(CoreMetadataKey.Interceptors, target) || [];
|
|
1452
|
+
Reflect.defineMetadata(CoreMetadataKey.Interceptors, [
|
|
1453
|
+
...validatedInterceptors,
|
|
1454
|
+
...classInterceptors
|
|
1455
|
+
], target);
|
|
1456
|
+
return target;
|
|
1457
|
+
};
|
|
1458
|
+
}
|
|
1459
|
+
__name(UseInterceptors, "UseInterceptors");
|
|
1460
|
+
|
|
1461
|
+
// src/decorators/pipeline/use-pipes.decorator.ts
|
|
1462
|
+
function UsePipes(...pipes) {
|
|
1463
|
+
return (target, method, descriptor) => {
|
|
1464
|
+
const validatedPipes = [];
|
|
1465
|
+
for (const pipe of pipes) {
|
|
1466
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1467
|
+
if (!valid) throw new Error(error);
|
|
1468
|
+
validatedPipes.push(value);
|
|
1469
|
+
}
|
|
1470
|
+
if (!isNil(descriptor) && !isNil(descriptor.value)) {
|
|
1471
|
+
if (pipes.length === 0) {
|
|
1472
|
+
throw new Error(ErrorMessage.AtLeastOnePipeRequired);
|
|
1473
|
+
}
|
|
1474
|
+
const methodPipes = Reflect.getMetadata(CoreMetadataKey.Pipes, target.constructor, method) || [];
|
|
1475
|
+
Reflect.defineMetadata(CoreMetadataKey.Pipes, [
|
|
1476
|
+
...validatedPipes,
|
|
1477
|
+
...methodPipes
|
|
1478
|
+
], target.constructor, method);
|
|
1479
|
+
return descriptor;
|
|
1480
|
+
}
|
|
1481
|
+
if (pipes.length === 0) {
|
|
1482
|
+
throw new Error(ErrorMessage.AtLeastOnePipeRequired);
|
|
1483
|
+
}
|
|
1484
|
+
const classPipes = Reflect.getMetadata(CoreMetadataKey.Pipes, target) || [];
|
|
1485
|
+
Reflect.defineMetadata(CoreMetadataKey.Pipes, [
|
|
1486
|
+
...validatedPipes,
|
|
1487
|
+
...classPipes
|
|
1488
|
+
], target);
|
|
1489
|
+
return target;
|
|
1490
|
+
};
|
|
1491
|
+
}
|
|
1492
|
+
__name(UsePipes, "UsePipes");
|
|
1493
|
+
|
|
1494
|
+
// src/decorators/create-rpc-decorator.ts
|
|
1495
|
+
function createRPCDecorator(type, name, webViewId) {
|
|
1496
|
+
return (target, method) => {
|
|
1497
|
+
if (!isNil(webViewId) && !isString(webViewId) && !isNumber(webViewId)) {
|
|
1498
|
+
throw new Error(ErrorMessage.WebViewIdMustBeStringOrNumber);
|
|
1499
|
+
}
|
|
1500
|
+
if (!isNil(name) && !isString(name)) {
|
|
1501
|
+
throw new Error(ErrorMessage.RPCNameMustBeString);
|
|
1502
|
+
}
|
|
1503
|
+
name = name ?? method;
|
|
1504
|
+
const rpcs = Reflect.getMetadata(CoreMetadataKey.ControllerRPCs, target) ?? [];
|
|
1505
|
+
if (rpcs.some((rpc) => rpc.method === method && rpc.name === name && rpc.type === type)) {
|
|
1506
|
+
throw new Error(ErrorMessage.RPCNameMustBeUnique);
|
|
1507
|
+
}
|
|
1508
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerRPCs, [
|
|
1509
|
+
...rpcs,
|
|
1510
|
+
{
|
|
1511
|
+
method,
|
|
1512
|
+
name,
|
|
1513
|
+
type,
|
|
1514
|
+
webViewId
|
|
1515
|
+
}
|
|
1516
|
+
], target);
|
|
1517
|
+
};
|
|
1518
|
+
}
|
|
1519
|
+
__name(createRPCDecorator, "createRPCDecorator");
|
|
1520
|
+
|
|
1521
|
+
// src/decorators/rpc/on-request.decorator.ts
|
|
1522
|
+
function OnRequest(rpcName) {
|
|
1523
|
+
return createRPCDecorator("onRequest", rpcName);
|
|
1524
|
+
}
|
|
1525
|
+
__name(OnRequest, "OnRequest");
|
|
1526
|
+
|
|
1527
|
+
// src/decorators/rpc/on-webview-request.decorator.ts
|
|
1528
|
+
function OnWebViewRequest(id, rpcName) {
|
|
1529
|
+
return createRPCDecorator("onWebViewRequest", rpcName, id);
|
|
1530
|
+
}
|
|
1531
|
+
__name(OnWebViewRequest, "OnWebViewRequest");
|
|
1532
|
+
|
|
1533
|
+
// src/decorators/create-timer.decorator.ts
|
|
1534
|
+
function createTimerDecorator(type, name, options) {
|
|
1535
|
+
return (target, method) => {
|
|
1536
|
+
if (!isNil(name) && !isString(name)) {
|
|
1537
|
+
throw new Error(ErrorMessage.TimerNameMustBeString);
|
|
1538
|
+
}
|
|
1539
|
+
name = name ?? method;
|
|
1540
|
+
const timers = Reflect.getMetadata(CoreMetadataKey.Timers, target) ?? [];
|
|
1541
|
+
if (timers.some((timer) => timer.method === method && timer.name === name && timer.type === type)) {
|
|
1542
|
+
throw new Error(ErrorMessage.EventNameMustBeUnique);
|
|
1543
|
+
}
|
|
1544
|
+
Reflect.defineMetadata(CoreMetadataKey.Timers, [
|
|
1545
|
+
...timers,
|
|
1546
|
+
{
|
|
1547
|
+
method,
|
|
1548
|
+
name,
|
|
1549
|
+
type,
|
|
1550
|
+
options
|
|
1551
|
+
}
|
|
1552
|
+
], target);
|
|
1553
|
+
};
|
|
1554
|
+
}
|
|
1555
|
+
__name(createTimerDecorator, "createTimerDecorator");
|
|
1556
|
+
|
|
1557
|
+
// src/decorators/timers/cron.decorator.ts
|
|
1558
|
+
function Cron(pattern, options = {}) {
|
|
1559
|
+
return createTimerDecorator("cron", options.name, {
|
|
1560
|
+
pattern,
|
|
1561
|
+
...options
|
|
1562
|
+
});
|
|
1563
|
+
}
|
|
1564
|
+
__name(Cron, "Cron");
|
|
1565
|
+
|
|
1566
|
+
// src/decorators/timers/every-tick.decorator.ts
|
|
1567
|
+
function EveryTick(name) {
|
|
1568
|
+
return createTimerDecorator("everytick", name);
|
|
1569
|
+
}
|
|
1570
|
+
__name(EveryTick, "EveryTick");
|
|
1571
|
+
|
|
1572
|
+
// src/decorators/timers/interval.decorator.ts
|
|
1573
|
+
function Interval(nameOrTimeout, timeout) {
|
|
1574
|
+
const [name, intervalTimeout] = isString(nameOrTimeout) ? [
|
|
1575
|
+
nameOrTimeout,
|
|
1576
|
+
timeout
|
|
1577
|
+
] : [
|
|
1578
|
+
void 0,
|
|
1579
|
+
nameOrTimeout
|
|
1580
|
+
];
|
|
1581
|
+
return createTimerDecorator("interval", name, {
|
|
1582
|
+
timeout: intervalTimeout
|
|
1583
|
+
});
|
|
1584
|
+
}
|
|
1585
|
+
__name(Interval, "Interval");
|
|
1586
|
+
|
|
1587
|
+
// src/decorators/timers/timeout.decorator.ts
|
|
1588
|
+
function Timeout(nameOrTimeout, timeout) {
|
|
1589
|
+
const [name, intervalTimeout] = isString(nameOrTimeout) ? [
|
|
1590
|
+
nameOrTimeout,
|
|
1591
|
+
timeout
|
|
1592
|
+
] : [
|
|
1593
|
+
void 0,
|
|
1594
|
+
nameOrTimeout
|
|
1595
|
+
];
|
|
1596
|
+
return createTimerDecorator("timeout", name, {
|
|
1597
|
+
timeout: intervalTimeout
|
|
1598
|
+
});
|
|
1599
|
+
}
|
|
1600
|
+
__name(Timeout, "Timeout");
|
|
1601
|
+
|
|
1602
|
+
// src/decorators/apply-decorator.util.ts
|
|
1603
|
+
function applyDecorators(...decorators) {
|
|
1604
|
+
return (target, propertyKey, descriptor) => {
|
|
1605
|
+
for (const decorator of decorators) {
|
|
1606
|
+
if (target instanceof Function && !descriptor) {
|
|
1607
|
+
decorator(target);
|
|
1608
|
+
continue;
|
|
1609
|
+
}
|
|
1610
|
+
decorator(target, propertyKey, descriptor);
|
|
1611
|
+
}
|
|
1612
|
+
};
|
|
1613
|
+
}
|
|
1614
|
+
__name(applyDecorators, "applyDecorators");
|
|
1615
|
+
|
|
1616
|
+
// src/decorators/create-param.util.ts
|
|
1617
|
+
function createParamDecorator(factory) {
|
|
1618
|
+
return (data, ...pipes) => {
|
|
1619
|
+
return (target, method, index) => {
|
|
1620
|
+
const validatedPipes = [];
|
|
1621
|
+
for (const pipe of pipes) {
|
|
1622
|
+
const { valid, value, error } = validatePipe(pipe);
|
|
1623
|
+
if (!valid) throw new Error(error);
|
|
1624
|
+
validatedPipes.push(value);
|
|
1625
|
+
}
|
|
1626
|
+
const params = Reflect.getMetadata(CoreMetadataKey.ControllerParams, target, method) ?? [];
|
|
1627
|
+
if (params.some((param) => param.index === index)) {
|
|
1628
|
+
throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);
|
|
1629
|
+
}
|
|
1630
|
+
const paramTypes = Reflect.getMetadata("design:paramtypes", target, method);
|
|
1631
|
+
const metatype = Array.isArray(paramTypes) ? paramTypes[index] : void 0;
|
|
1632
|
+
Reflect.defineMetadata(CoreMetadataKey.ControllerParams, [
|
|
1633
|
+
...params,
|
|
1634
|
+
{
|
|
1635
|
+
index,
|
|
1636
|
+
method,
|
|
1637
|
+
pipes: validatedPipes,
|
|
1638
|
+
type: MethodParamType.Custom,
|
|
1639
|
+
factory,
|
|
1640
|
+
data,
|
|
1641
|
+
metatype
|
|
1642
|
+
}
|
|
1643
|
+
], target, method);
|
|
1644
|
+
};
|
|
1645
|
+
};
|
|
1646
|
+
}
|
|
1647
|
+
__name(createParamDecorator, "createParamDecorator");
|
|
1648
|
+
|
|
1649
|
+
// src/decorators/forward-ref.util.ts
|
|
1650
|
+
import { LazyServiceIdentifer } from "inversify";
|
|
1651
|
+
function forwardRef(fn) {
|
|
1652
|
+
return new LazyServiceIdentifer(fn);
|
|
1653
|
+
}
|
|
1654
|
+
__name(forwardRef, "forwardRef");
|
|
1655
|
+
|
|
1656
|
+
// src/services/reflector.service.ts
|
|
1657
|
+
function _ts_decorate6(decorators, target, key, desc) {
|
|
1658
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1659
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1660
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1661
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1662
|
+
}
|
|
1663
|
+
__name(_ts_decorate6, "_ts_decorate");
|
|
1664
|
+
var ReflectorService = class {
|
|
1665
|
+
static {
|
|
1666
|
+
__name(this, "ReflectorService");
|
|
1667
|
+
}
|
|
1668
|
+
get(metadataKey, target) {
|
|
1669
|
+
return Reflect.getMetadata(metadataKey, target);
|
|
1670
|
+
}
|
|
1671
|
+
getAll(metadataKey, targets) {
|
|
1672
|
+
return (targets || []).map((target) => this.get(metadataKey, target));
|
|
1673
|
+
}
|
|
1674
|
+
getAllAndMerge(metadataKey, targets) {
|
|
1675
|
+
const metadataCollection = this.getAll(metadataKey, targets).filter((item) => item !== void 0);
|
|
1676
|
+
if (isEmpty(metadataCollection)) return metadataCollection;
|
|
1677
|
+
return metadataCollection.reduce((a, b) => {
|
|
1678
|
+
if (Array.isArray(a)) {
|
|
1679
|
+
return a.concat(b);
|
|
1680
|
+
}
|
|
1681
|
+
if (isObject(a) && isObject(b)) {
|
|
1682
|
+
return {
|
|
1683
|
+
...a,
|
|
1684
|
+
...b
|
|
1685
|
+
};
|
|
1686
|
+
}
|
|
1687
|
+
return [
|
|
1688
|
+
a,
|
|
1689
|
+
b
|
|
1690
|
+
];
|
|
1691
|
+
});
|
|
1692
|
+
}
|
|
1693
|
+
getAllAndOverride(metadataKey, targets) {
|
|
1694
|
+
for (const target of targets) {
|
|
1695
|
+
const result = this.get(metadataKey, target);
|
|
1696
|
+
if (result !== void 0) return result;
|
|
1697
|
+
}
|
|
1698
|
+
return void 0;
|
|
1699
|
+
}
|
|
1700
|
+
static createDecorator(options = {}) {
|
|
1701
|
+
const metadataKey = options.key ?? generateRandomId();
|
|
1702
|
+
const decoratorFn = /* @__PURE__ */ __name((metadataValue) => (target, key, descriptor) => {
|
|
1703
|
+
const value = options.transform ? options.transform(metadataValue) : metadataValue;
|
|
1704
|
+
SetMetadata(metadataKey, value ?? {})(target, key, descriptor);
|
|
1705
|
+
}, "decoratorFn");
|
|
1706
|
+
decoratorFn.KEY = metadataKey;
|
|
1707
|
+
return decoratorFn;
|
|
1708
|
+
}
|
|
1709
|
+
};
|
|
1710
|
+
ReflectorService = _ts_decorate6([
|
|
1711
|
+
injectable9()
|
|
1712
|
+
], ReflectorService);
|
|
1713
|
+
|
|
1714
|
+
// src/services/timer.service.ts
|
|
1715
|
+
import { inject as inject7, injectable as injectable10 } from "inversify";
|
|
1716
|
+
import { Cron as Cron2 } from "croner";
|
|
1717
|
+
function _ts_decorate7(decorators, target, key, desc) {
|
|
1718
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1719
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1720
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1721
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1722
|
+
}
|
|
1723
|
+
__name(_ts_decorate7, "_ts_decorate");
|
|
1724
|
+
function _ts_metadata6(k, v) {
|
|
1725
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
1726
|
+
}
|
|
1727
|
+
__name(_ts_metadata6, "_ts_metadata");
|
|
1728
|
+
var TimerService = class {
|
|
1729
|
+
static {
|
|
1730
|
+
__name(this, "TimerService");
|
|
1731
|
+
}
|
|
1732
|
+
multiplayerService;
|
|
1733
|
+
$everyticks = /* @__PURE__ */ new Map();
|
|
1734
|
+
$intervals = /* @__PURE__ */ new Map();
|
|
1735
|
+
$timeouts = /* @__PURE__ */ new Map();
|
|
1736
|
+
$crons = /* @__PURE__ */ new Map();
|
|
1737
|
+
get all() {
|
|
1738
|
+
return this.multiplayerService.Timers.all;
|
|
1739
|
+
}
|
|
1740
|
+
get everyticks() {
|
|
1741
|
+
return [
|
|
1742
|
+
...this.$everyticks.values()
|
|
1743
|
+
];
|
|
1744
|
+
}
|
|
1745
|
+
get intervals() {
|
|
1746
|
+
return [
|
|
1747
|
+
...this.$intervals.values()
|
|
1748
|
+
];
|
|
1749
|
+
}
|
|
1750
|
+
get timeouts() {
|
|
1751
|
+
return [
|
|
1752
|
+
...this.$timeouts.values()
|
|
1753
|
+
];
|
|
1754
|
+
}
|
|
1755
|
+
get crons() {
|
|
1756
|
+
return [
|
|
1757
|
+
...this.$crons.values()
|
|
1758
|
+
];
|
|
1759
|
+
}
|
|
1760
|
+
set warningThreshold(value) {
|
|
1761
|
+
this.multiplayerService.Timers.warningThreshold = value;
|
|
1762
|
+
}
|
|
1763
|
+
get warningThreshold() {
|
|
1764
|
+
return this.multiplayerService.Timers.warningThreshold;
|
|
1765
|
+
}
|
|
1766
|
+
set sourceLocationFrameSkipCount(value) {
|
|
1767
|
+
this.multiplayerService.Timers.sourceLocationFrameSkipCount = value;
|
|
1768
|
+
}
|
|
1769
|
+
get sourceLocationFrameSkipCount() {
|
|
1770
|
+
return this.multiplayerService.Timers.sourceLocationFrameSkipCount;
|
|
1771
|
+
}
|
|
1772
|
+
createCronJob(callback, options) {
|
|
1773
|
+
const { pattern, ...cronOptions } = options;
|
|
1774
|
+
const cron = Cron2(pattern, cronOptions, callback);
|
|
1775
|
+
if (isString(options.name)) this.$crons.set(options.name, cron);
|
|
1776
|
+
return cron;
|
|
1777
|
+
}
|
|
1778
|
+
createInterval(callback, interval, name) {
|
|
1779
|
+
const timer = this.multiplayerService.Timers.setInterval(callback, interval);
|
|
1780
|
+
if (isString(name)) this.$intervals.set(name, timer);
|
|
1781
|
+
return timer;
|
|
1782
|
+
}
|
|
1783
|
+
createTimeout(callback, timeout, name) {
|
|
1784
|
+
const timer = this.multiplayerService.Timers.setTimeout(callback, timeout);
|
|
1785
|
+
if (isString(name)) this.$timeouts.set(name, timer);
|
|
1786
|
+
return timer;
|
|
1787
|
+
}
|
|
1788
|
+
createEveryTick(callback, name) {
|
|
1789
|
+
const timer = this.multiplayerService.Timers.everyTick(callback);
|
|
1790
|
+
if (isString(name)) this.$everyticks.set(name, timer);
|
|
1791
|
+
return timer;
|
|
1792
|
+
}
|
|
1793
|
+
delete(type, name) {
|
|
1794
|
+
switch (type) {
|
|
1795
|
+
case "cron":
|
|
1796
|
+
const cronJob = this.$crons.get(name);
|
|
1797
|
+
if (cronJob) {
|
|
1798
|
+
cronJob.stop();
|
|
1799
|
+
this.$crons.delete(name);
|
|
1800
|
+
}
|
|
1801
|
+
break;
|
|
1802
|
+
case "everytick":
|
|
1803
|
+
const everytick = this.$everyticks.get(name);
|
|
1804
|
+
if (everytick) {
|
|
1805
|
+
everytick.destroy();
|
|
1806
|
+
this.$everyticks.delete(name);
|
|
1807
|
+
}
|
|
1808
|
+
break;
|
|
1809
|
+
case "interval":
|
|
1810
|
+
const interval = this.$intervals.get(name);
|
|
1811
|
+
if (interval) {
|
|
1812
|
+
interval.destroy();
|
|
1813
|
+
this.$intervals.delete(name);
|
|
1814
|
+
}
|
|
1815
|
+
break;
|
|
1816
|
+
case "timeout":
|
|
1817
|
+
const timeout = this.$timeouts.get(name);
|
|
1818
|
+
if (timeout) {
|
|
1819
|
+
timeout.destroy();
|
|
1820
|
+
this.$timeouts.delete(name);
|
|
1821
|
+
}
|
|
1822
|
+
break;
|
|
1823
|
+
}
|
|
1824
|
+
}
|
|
1825
|
+
getByName(type, name) {
|
|
1826
|
+
switch (type) {
|
|
1827
|
+
case "cron":
|
|
1828
|
+
return this.$crons.get(name);
|
|
1829
|
+
case "everytick":
|
|
1830
|
+
return this.$everyticks.get(name);
|
|
1831
|
+
case "interval":
|
|
1832
|
+
return this.$intervals.get(name);
|
|
1833
|
+
case "timeout":
|
|
1834
|
+
return this.$timeouts.get(name);
|
|
1835
|
+
}
|
|
1836
|
+
}
|
|
1837
|
+
getById(id) {
|
|
1838
|
+
return this.multiplayerService.Timers.getByID(id);
|
|
1839
|
+
}
|
|
1840
|
+
time(name) {
|
|
1841
|
+
return this.multiplayerService.Timers.time(name);
|
|
1842
|
+
}
|
|
1843
|
+
timeEnd(name) {
|
|
1844
|
+
return this.multiplayerService.Timers.timeEnd(name);
|
|
1845
|
+
}
|
|
1846
|
+
};
|
|
1847
|
+
_ts_decorate7([
|
|
1848
|
+
inject7(MULTIPLAYER_SERVICE),
|
|
1849
|
+
_ts_metadata6("design:type", typeof MultiplayerService === "undefined" ? Object : MultiplayerService)
|
|
1850
|
+
], TimerService.prototype, "multiplayerService", void 0);
|
|
1851
|
+
TimerService = _ts_decorate7([
|
|
1852
|
+
injectable10()
|
|
1853
|
+
], TimerService);
|
|
1854
|
+
|
|
1855
|
+
export {
|
|
1856
|
+
Controller2 as Controller,
|
|
1857
|
+
Global,
|
|
1858
|
+
Inject,
|
|
1859
|
+
Injectable,
|
|
1860
|
+
Module2 as Module,
|
|
1861
|
+
Optional,
|
|
1862
|
+
SetMetadata,
|
|
1863
|
+
Catch,
|
|
1864
|
+
UseFilters,
|
|
1865
|
+
AppRuntime,
|
|
1866
|
+
ReflectorService,
|
|
1867
|
+
TimerService,
|
|
1868
|
+
ModuleDependencyBinder,
|
|
1869
|
+
ModuleTreeScanner,
|
|
1870
|
+
RageMPScriptEvent,
|
|
1871
|
+
RageMPEventEmmiter,
|
|
1872
|
+
RageMPTimer,
|
|
1873
|
+
RageMPTimers,
|
|
1874
|
+
RageMPMultiplayerService,
|
|
1875
|
+
App,
|
|
1876
|
+
AppBuilder,
|
|
1877
|
+
createAppBuilder,
|
|
1878
|
+
createEventDecorator,
|
|
1879
|
+
OnInternal,
|
|
1880
|
+
OnWebView,
|
|
1881
|
+
On,
|
|
1882
|
+
OnceInternal,
|
|
1883
|
+
Once,
|
|
1884
|
+
OnceWebView,
|
|
1885
|
+
Body,
|
|
1886
|
+
Index,
|
|
1887
|
+
Request,
|
|
1888
|
+
Req,
|
|
1889
|
+
Param,
|
|
1890
|
+
Response,
|
|
1891
|
+
Res,
|
|
1892
|
+
UseGuards,
|
|
1893
|
+
UseInterceptors,
|
|
1894
|
+
UsePipes,
|
|
1895
|
+
createRPCDecorator,
|
|
1896
|
+
OnRequest,
|
|
1897
|
+
OnWebViewRequest,
|
|
1898
|
+
Cron,
|
|
1899
|
+
EveryTick,
|
|
1900
|
+
Interval,
|
|
1901
|
+
Timeout,
|
|
1902
|
+
applyDecorators,
|
|
1903
|
+
createParamDecorator,
|
|
1904
|
+
forwardRef
|
|
1905
|
+
};
|
|
1906
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/services/reflector.service.ts", "../src/decorators/core/controller.decorator.ts", "../src/decorators/core/global.decorator.ts", "../src/decorators/core/inject.decorator.ts", "../src/decorators/core/injectable.decorator.ts", "../src/decorators/core/module.decorator.ts", "../src/decorators/core/optional.decorator.ts", "../src/decorators/core/set-metadata.decorator.ts", "../src/decorators/errors/catch.decorator.ts", "../src/decorators/errors/use-filters.decorator.ts", "../src/app/module-tree/app-runtime.ts", "../src/app/module-tree/dependency-binder.ts", "../src/app/module-tree/module-tree-scanner.ts", "../src/app/multiplayer/ragemp/ragemp-script-event-handler.ts", "../src/app/multiplayer/ragemp/ragemp-event-emmiter.ts", "../src/app/multiplayer/ragemp/ragemp-timer.ts", "../src/app/multiplayer/ragemp/ragemp-timers.ts", "../src/app/multiplayer/ragemp/ragemp-multiplayer.service.ts", "../src/app/app-builder.ts", "../src/app/app.ts", "../src/app/create-app.ts", "../src/decorators/create-event-decorator.ts", "../src/decorators/events/on-internal.decorator.ts", "../src/decorators/events/on-webview.decorator.ts", "../src/decorators/events/on.decorator.ts", "../src/decorators/events/once-internal.decorator.ts", "../src/decorators/events/once.decorator.ts", "../src/decorators/events/once-webview.decorator.ts", "../src/decorators/params/body.decorator.ts", "../src/decorators/params/index.decorator.ts", "../src/decorators/params/request.decorator.ts", "../src/decorators/params/param.decorator.ts", "../src/decorators/params/response.deorator.ts", "../src/decorators/pipeline/use-guards.decorator.ts", "../src/decorators/pipeline/use-interceptors.decorator.ts", "../src/decorators/pipeline/use-pipes.decorator.ts", "../src/decorators/create-rpc-decorator.ts", "../src/decorators/rpc/on-request.decorator.ts", "../src/decorators/rpc/on-webview-request.decorator.ts", "../src/decorators/create-timer.decorator.ts", "../src/decorators/timers/cron.decorator.ts", "../src/decorators/timers/every-tick.decorator.ts", "../src/decorators/timers/interval.decorator.ts", "../src/decorators/timers/timeout.decorator.ts", "../src/decorators/apply-decorator.util.ts", "../src/decorators/create-param.util.ts", "../src/decorators/forward-ref.util.ts", "../src/services/timer.service.ts"],
  "sourcesContent": ["import { injectable } from 'inversify';\nimport { SetMetadata } from '../decorators';\nimport type { CreateDecoratorOptions, CreateDecoratorWithTransformOptions, ReflectableDecorator } from '../interfaces';\nimport type { Newable } from '../types';\nimport { generateRandomId, isEmpty, isObject } from '../utils';\n\n@injectable()\nexport class ReflectorService {\n    public get<TResult = unknown, TKey extends string | symbol = string>(metadataKey: TKey, target: Newable | Function) {\n        return Reflect.getMetadata<TResult>(metadataKey, target);\n    }\n\n    public getAll<TResult extends unknown[] = unknown[], TKey extends string | symbol = string>(\n        metadataKey: TKey,\n        targets: (Newable | Function)[],\n    ) {\n        return <TResult>(targets || []).map((target) => this.get(metadataKey, target));\n    }\n\n    public getAllAndMerge<TResult extends unknown[] = unknown[], TKey extends string | symbol = string>(\n        metadataKey: TKey,\n        targets: (Newable | Function)[],\n    ) {\n        const metadataCollection = this.getAll<TResult, TKey>(metadataKey, targets).filter((item) => item !== undefined);\n\n        if (isEmpty(metadataCollection)) return <TResult>metadataCollection;\n\n        return <TResult>metadataCollection.reduce((a, b) => {\n            if (Array.isArray(a)) {\n                return a.concat(b);\n            }\n            if (isObject(a) && isObject(b)) {\n                return {\n                    ...a,\n                    ...b,\n                };\n            }\n            return [a, b];\n        });\n    }\n\n    public getAllAndOverride<TResult = unknown, TKey extends string | symbol = string>(metadataKey: TKey, targets: (Newable | Function)[]) {\n        for (const target of targets) {\n            const result = this.get(metadataKey, target);\n            if (result !== undefined) return <TResult>result;\n        }\n        return undefined;\n    }\n\n    public static createDecorator<TParam>(options?: CreateDecoratorOptions<TParam>): ReflectableDecorator<TParam>;\n    public static createDecorator<TParam, TTransformed>(\n        options: CreateDecoratorWithTransformOptions<TParam, TTransformed>,\n    ): ReflectableDecorator<TParam, TTransformed>;\n    public static createDecorator<TParam, TTransformed = TParam>(\n        options: CreateDecoratorOptions<TParam, TTransformed> = {},\n    ): ReflectableDecorator<TParam, TTransformed> {\n        const metadataKey = options.key ?? generateRandomId();\n        const decoratorFn = (metadataValue: TParam) => (target: object | Function, key?: string | symbol, descriptor?: any) => {\n            const value = options.transform ? options.transform(metadataValue) : metadataValue;\n            SetMetadata(metadataKey, value ?? {})(target, key!, descriptor);\n        };\n\n        decoratorFn.KEY = metadataKey;\n        return decoratorFn as ReflectableDecorator<TParam, TTransformed>;\n    }\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { ControllerOptions } from '../../interfaces';\nimport { validateControllerOptions } from '../../schemas';\nimport type { Newable } from '../../types';\nimport { injectable } from 'inversify';\nimport { ErrorMessage } from '../../enums';\n\nexport function Controller<T extends Newable>(options?: ControllerOptions) {\n    return (target: T) => {\n        if (Reflect.hasMetadata(CoreMetadataKey.Controller, target)) {\n            throw new Error(ErrorMessage.DuplicateDecoratorUsage);\n        }\n\n        const { valid, value, error } = validateControllerOptions(options);\n        if (!valid) throw new Error(error);\n        Reflect.defineMetadata(CoreMetadataKey.Controller, value, target);\n\n        return injectable()(target);\n    };\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { Newable } from '../../types';\n\nexport function Global<T extends Newable>() {\n    return (target: T) => {\n        Reflect.defineMetadata(CoreMetadataKey.GlobalModule, true, target);\n        return target;\n    };\n}\n", "import { inject } from 'inversify';\nimport type { InjectionToken } from '../../types';\nimport { ErrorMessage } from '../../enums';\nimport { validateInjectionToken } from '../../schemas';\nimport { isNil } from '../../utils';\n\nexport function Inject<T = unknown>(key?: InjectionToken<T>) {\n    return <PropertyDecorator & ParameterDecorator>((target: Object, propertyKey: string, paramIndex?: number) => {\n        if (!isNil(key) && !validateInjectionToken(key).valid) {\n            throw new Error(ErrorMessage.InvalidInjectionTokenSpecified);\n        }\n\n        const token = key ?? Reflect.getMetadata<InjectionToken>('design:type', target, propertyKey);\n        if (!token) {\n            throw new Error(ErrorMessage.InjectionTokenNotFound);\n        }\n\n        inject(token)(target, propertyKey, paramIndex);\n    });\n}\n", "import { injectable } from 'inversify';\nimport type { Newable } from '../../types';\nimport { CoreMetadataKey } from '../../app/enums';\nimport type { InjectableOptions } from '../../interfaces';\nimport { ErrorMessage } from '../../enums';\nimport { validateInjectableMetadata } from '../../schemas';\n\nexport function Injectable<T extends Newable>(options?: InjectableOptions) {\n    return (target: T) => {\n        if (Reflect.hasMetadata(CoreMetadataKey.Injectable, target)) {\n            throw new Error(ErrorMessage.DuplicateDecoratorUsage);\n        }\n\n        const { valid, value, error } = validateInjectableMetadata(options);\n        if (!valid) throw new Error(error);\n        Reflect.defineMetadata(CoreMetadataKey.Injectable, value, target);\n\n        return injectable()(target);\n    };\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { ModuleOptions } from '../../interfaces';\nimport type { Newable } from '../../types';\nimport { injectable } from 'inversify';\nimport { ErrorMessage } from '../../enums';\nimport { validateModuleOptions } from '../../schemas';\n\nexport function Module<T extends Newable>(options?: ModuleOptions) {\n    return (target: T) => {\n        if (Reflect.hasMetadata(CoreMetadataKey.Module, target)) {\n            throw new Error(ErrorMessage.DuplicateDecoratorUsage);\n        }\n\n        const { valid, value, error } = validateModuleOptions(options);\n        if (!valid) throw new Error(error!);\n        Reflect.defineMetadata(CoreMetadataKey.Module, value, target);\n\n        return injectable()(target);\n    };\n}\n", "import { optional } from 'inversify';\n\nexport function Optional() {\n    return <PropertyDecorator & ParameterDecorator>((target: Object, propertyKey: string, paramIndex?: number) => {\n        return optional()(target, propertyKey, paramIndex);\n    });\n}\n", "import type { CustomDecorator } from '../../types';\n\nexport function SetMetadata<K extends string = string, V = unknown>(key: K, value: V) {\n    const decoratorFactory = <CustomDecorator>((target: object, _method?: string, descriptor?: PropertyDescriptor) => {\n        if (descriptor) {\n            Reflect.defineMetadata(key, value, descriptor.value);\n            return descriptor;\n        }\n        Reflect.defineMetadata(key, value, target);\n        return target;\n    });\n    decoratorFactory.KEY = key;\n    return decoratorFactory;\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport type { Newable } from '../../types';\n\nexport function Catch<T extends Newable>(...exceptions: unknown[]) {\n    return (target: T) => {\n        if (Reflect.hasMetadata(CoreMetadataKey.Catch, target)) {\n            throw new Error(ErrorMessage.DuplicateDecoratorUsage);\n        }\n\n        const duplicates = exceptions.filter((exception, index) => exceptions.indexOf(exception) !== index);\n        if (duplicates.length) {\n            throw new Error(ErrorMessage.ExceptionHandlingConflict);\n        }\n\n        Reflect.defineMetadata(CoreMetadataKey.Catch, exceptions, target);\n\n        return target;\n    };\n}\n", "import type { Newable } from '../../types';\nimport type { ErrorFilter } from '../../app/interfaces';\nimport { CoreMetadataKey } from '../../app/enums';\nimport { isNil } from '../../utils';\nimport { ErrorMessage } from '../../enums';\nimport { validateErrorFilter } from '../../schemas';\n\nexport function UseFilters(...filters: (Newable<ErrorFilter> | ErrorFilter)[]) {\n    return <ClassDecorator & MethodDecorator>((target: Object, method?: string, descriptor?: PropertyDescriptor) => {\n        const validatedFilters: (Newable<ErrorFilter> | ErrorFilter)[] = [];\n        for (const filter of filters) {\n            const { valid, value, error } = validateErrorFilter(filter);\n            if (!valid) throw new Error(error);\n            validatedFilters.push(value);\n        }\n\n        if (!isNil(descriptor) && !isNil(descriptor.value)) {\n            if (filters.length === 0) {\n                throw new Error(ErrorMessage.AtLeastOneFilterRequired);\n            }\n\n            const methodFilters =\n                Reflect.getMetadata<Newable<ErrorFilter>[]>(CoreMetadataKey.ErrorFilters, target.constructor, method) || [];\n            if (!isNil(methodFilters.find((filter) => filters.includes(filter)))) {\n                throw new Error(ErrorMessage.DuplicateErrorFilterDetected);\n            }\n            Reflect.defineMetadata(CoreMetadataKey.ErrorFilters, [...validatedFilters, ...methodFilters], target.constructor, method);\n            return descriptor;\n        }\n\n        if (filters.length === 0) {\n            throw new Error(ErrorMessage.AtLeastOneFilterRequired);\n        }\n\n        const classFilters = Reflect.getMetadata<Newable<ErrorFilter>[]>(CoreMetadataKey.ErrorFilters, target) || [];\n        if (!isNil(classFilters.find((filter) => filters.includes(filter)))) {\n            throw new Error(ErrorMessage.DuplicateErrorFilterDetected);\n        }\n        Reflect.defineMetadata(CoreMetadataKey.ErrorFilters, [...validatedFilters, ...classFilters], target);\n        return target;\n    });\n}\n", "import type { Newable } from '../../types';\nimport { isNil, isObject } from '../../utils';\nimport { ENABLE_SHUTDOWN_HOOKS, GLOBAL_ERROR_FILTERS, GLOBAL_GUARDS, GLOBAL_INTERCEPTORS, GLOBAL_PIPES } from '../constants';\nimport type { ErrorFilter, Guard, Interceptor } from '../interfaces';\nimport { Module } from '../module';\nimport { inject, injectable, optional } from 'inversify';\nimport { Controller, ControllerEventHandler, ControllerRPCHandler } from '../controller';\nimport { LOGGER_SERVICE, TIMER_SERVICE } from '../../constants';\nimport { CoreMetadataKey } from '../enums';\nimport { ErrorMessage } from '../../enums';\nimport type { LoggerService, Pipe } from '../../interfaces';\nimport type { Tree } from '../utils';\nimport type { TimerService } from '../../services';\n\n@injectable()\nexport class AppRuntime {\n    @inject(ControllerEventHandler) private readonly eventHandler: ControllerEventHandler;\n    @inject(ControllerRPCHandler) private readonly rpcHandler: ControllerRPCHandler;\n    @inject(GLOBAL_GUARDS) private readonly globalGuards: (Newable<Guard> | Guard)[];\n    @inject(GLOBAL_INTERCEPTORS) private readonly globalInterceptors: (Newable<Interceptor> | Interceptor)[];\n    @inject(GLOBAL_PIPES) private readonly globalPipes: (Newable<Pipe> | Pipe)[];\n    @inject(GLOBAL_ERROR_FILTERS) private readonly globalErrorFilters: (Newable<ErrorFilter> | ErrorFilter)[];\n    @inject(LOGGER_SERVICE) private readonly loggerService: LoggerService;\n    @inject(ENABLE_SHUTDOWN_HOOKS) @optional() private readonly enableShutdownHooks: boolean;\n\n    public async boot(resolvedTree: Tree<Module>) {\n        await resolvedTree.asyncTraverse(async (node) => {\n            const startTime = Date.now();\n            // Initialize module, controllers and providers.\n            const module = node.value;\n            module.instance = module.container.get<{ [key: string]: Function }>(module.metadata.classRef);\n            module.controllers.forEach(\n                (controller) => (controller.instance = module.container.get<{ [key: string]: Function }>(controller.metadata.classRef)),\n            );\n            [...module.metadata.internalProviders, ...module.metadata.externalProviders].forEach(([token]) =>\n                module.container.get<any>(token as any),\n            );\n\n            // Log module loaded.\n            this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~loaded ~lk~(${Date.now() - startTime}ms)`);\n            await this.runLifecycleMethod(module, 'onModuleInit');\n        });\n        // await this.runLifecycleMethods(resolvedTree, 'onModuleInit');\n        await this.runLifecycleMethods(resolvedTree, 'onAppBootstrap');\n\n        // Register event and rpc listeners.\n        resolvedTree.traverse((node) => {\n            const module = node.value;\n            module.controllers.forEach((controller) => {\n                const time = Date.now();\n                this.registerTimers(controller);\n                this.registerListeners(controller);\n                this.loggerService.log(\n                    `~lw~Controller ~lc~${controller.metadata.classRef.name} ~lw~timers and listeners registered ~lk~(${Date.now() - time}ms)`,\n                );\n            });\n        });\n    }\n\n    public async shutdown(resolvedTree: Tree<Module>) {\n        if (this.enableShutdownHooks) {\n            await this.runLifecycleMethods(resolvedTree, 'onModuleDestroy');\n            await this.runLifecycleMethods(resolvedTree, 'beforeAppShutdown');\n        }\n\n        await resolvedTree.asyncTraverse(async (node) => {\n            const module = node.value;\n            module.controllers.forEach((controller) => {\n                const timerService = controller.owner.container.get<TimerService>(TIMER_SERVICE);\n\n                // Destroy all timers.\n                timerService.everyticks.forEach((timer) => timer.destroy());\n                timerService.intervals.forEach((timer) => timer.destroy());\n                timerService.timeouts.forEach((timer) => timer.destroy());\n                timerService.crons.forEach((cron) => cron.stop());\n\n                // Destroy all script event handlers.\n                controller.eventHandlers.forEach((handler) => handler.destroy());\n                controller.rpcHandlers.forEach((handler) => handler.destroy());\n            });\n        });\n\n        // // Destroy all timers.\n        // this.timerService.everyticks.forEach((timer) => timer.destroy());\n        // this.timerService.intervals.forEach((timer) => timer.destroy());\n        // this.timerService.timeouts.forEach((timer) => timer.destroy());\n        // this.timerService.cronJobs.forEach((cronJob) => cronJob.stop());\n\n        // // Destroy all script event handlers.\n        // this.eventService.$localHandlers.forEach((handler) => handler.destroy());\n        // this.eventService.$internalHandlers.forEach((handler) => handler.destroy());\n        // this.eventService.$remoteHandlers.forEach((handler) => handler.destroy());\n\n        if (this.enableShutdownHooks) {\n            await this.runLifecycleMethods(resolvedTree, 'onAppShutdown');\n        }\n    }\n\n    private registerListeners(controller: Controller) {\n        const module = controller.owner;\n        controller.metadata.events.forEach((event) => {\n            const guards = [...this.globalGuards, ...module.metadata.guards, ...controller.metadata.guards, ...event.guards];\n            const interceptors = [\n                ...this.globalInterceptors,\n                ...module.metadata.interceptors,\n                ...controller.metadata.interceptors,\n                ...event.interceptors,\n            ];\n            const pipes = [...this.globalPipes, ...module.metadata.pipes, ...controller.metadata.pipes, ...event.pipes];\n            const mappedErrorFilters = this.mapErrorFilters([\n                ...this.globalErrorFilters,\n                ...module.metadata.errorFilters,\n                ...controller.metadata.errorFilters,\n                ...event.errorFilters,\n            ]);\n\n            const handler = this.eventHandler.registerEvent(guards, interceptors, pipes, mappedErrorFilters, controller, event);\n            controller.eventHandlers.push(handler);\n        });\n\n        controller.metadata.rpcs.forEach(async (rpc) => {\n            const guards = [...this.globalGuards, ...module.metadata.guards, ...controller.metadata.guards, ...rpc.guards];\n            const interceptors = [\n                ...this.globalInterceptors,\n                ...module.metadata.interceptors,\n                ...controller.metadata.interceptors,\n                ...rpc.interceptors,\n            ];\n            const pipes = [...this.globalPipes, ...module.metadata.pipes, ...controller.metadata.pipes, ...rpc.pipes];\n            const mappedErrorFilters = this.mapErrorFilters([\n                ...this.globalErrorFilters,\n                ...module.metadata.errorFilters,\n                ...controller.metadata.errorFilters,\n                ...rpc.errorFilters,\n            ]);\n\n            const handler = await this.rpcHandler.registerRPC(guards, interceptors, pipes, mappedErrorFilters, controller, rpc);\n            controller.rpcHandlers.push(handler);\n        });\n    }\n\n    public registerTimers(controller: Controller) {\n        const timerService = controller.owner.container.get<TimerService>(TIMER_SERVICE);\n\n        controller.metadata.timers.forEach((timer) => {\n            if (timer.type === 'cron') {\n                timerService.createCronJob(controller.instance[timer.method]!.bind(controller.instance), timer.options);\n            } else if (timer.type === 'everytick') {\n                timerService.createEveryTick(controller.instance[timer.method]!.bind(controller.instance), timer.name);\n            } else if (timer.type === 'interval') {\n                timerService.createInterval(\n                    controller.instance[timer.method]!.bind(controller.instance),\n                    timer.options.timeout,\n                    timer.name,\n                );\n            } else if (timer.type === 'timeout') {\n                timerService.createTimeout(controller.instance[timer.method]!.bind(controller.instance), timer.options.timeout, timer.name);\n            }\n        });\n    }\n\n    private mapErrorFilters(errorFilters: (Newable<ErrorFilter> | ErrorFilter)[]) {\n        const filterMap: [unknown | 'MANGO_ANY_ERROR', Newable<ErrorFilter> | ErrorFilter][] = [];\n\n        for (const filter of errorFilters) {\n            const errors = Reflect.getMetadata<any[]>(CoreMetadataKey.Catch, filter) ?? [];\n            if (errors.length === 0) {\n                errors.push('MANGO_ANY_ERROR');\n            }\n            for (const error of errors) {\n                if (!isNil(filterMap.find((filterError) => filterError[0] === error))) {\n                    this.loggerService.error('An error occurred while trying to map error filters.');\n                    throw new Error(ErrorMessage.ErrorAlreadyHandledByFilter);\n                }\n                filterMap.push([error, filter]);\n            }\n        }\n\n        return filterMap;\n    }\n\n    private async runLifecycleMethods(\n        resolvedTree: Tree<Module>,\n        method: 'onModuleInit' | 'onModuleDestroy' | 'onAppBootstrap' | 'beforeAppShutdown' | 'onAppShutdown',\n    ) {\n        return resolvedTree.asyncTraverse(async (node) => await this.runLifecycleMethod(node.value, method));\n    }\n\n    private async runLifecycleMethod(\n        module: Module,\n        method: 'onModuleInit' | 'onModuleDestroy' | 'onAppBootstrap' | 'beforeAppShutdown' | 'onAppShutdown',\n    ) {\n        await Promise.all(\n            module.controllers.map(async (controller) => {\n                if (!isObject(controller.instance) || isNil(controller.instance[method])) return;\n                await controller.instance[method]!();\n            }),\n        );\n        await Promise.all(\n            [...module.metadata.internalProviders, ...module.metadata.externalProviders].map(async ([token]) => {\n                const providerInstance = <{ [key: string]: Function }>module.container.get(token as any);\n                if (!isObject(providerInstance) || isNil(providerInstance[method])) return;\n                await providerInstance[method]!();\n            }),\n        );\n        if (!isObject(module.instance) || isNil(module.instance[method])) return;\n        await module.instance[method]!();\n    }\n}\n", "import type { LoggerService, Provider } from '../../interfaces';\nimport type { Newable } from '../../types';\nimport { isObject } from '../../utils';\nimport { CONTAINER_OPTIONS, GLOBAL_APP_CONTAINER } from '../constants';\nimport { Module, ModuleContainer } from '../module';\nimport { Container, inject, injectable, optional, type interfaces } from 'inversify';\nimport { LOGGER_SERVICE, MODULE_CONTAINER, TIMER_SERVICE } from '../../constants';\nimport type { Tree } from '../utils';\nimport { TimerService } from '../../services';\n\n@injectable()\nexport class ModuleDependencyBinder {\n    @inject(GLOBAL_APP_CONTAINER) private readonly globalAppContainer: Container;\n    @inject(LOGGER_SERVICE) private readonly loggerService: LoggerService;\n    @optional() @inject(CONTAINER_OPTIONS) private readonly containerOptions?: interfaces.ContainerOptions;\n\n    public async bind(resolvedTree: Tree<Module>) {\n        await resolvedTree.asyncTraverse(async (node) => {\n            const startTime = Date.now();\n\n            const module = node.value;\n            module.container = new ModuleContainer(module.metadata.container ?? this.containerOptions);\n            // Attach the global container to the module container, so it can be used to resolve dependencies.\n            module.container.parent = this.globalAppContainer;\n            this.globalAppContainer.bind(module.metadata.classRef).toSelf().inSingletonScope();\n\n            // If the module is global, we want to bind it to the global container.\n            if (module.metadata.global) {\n                // Bind external providers to the global container, so they can be injected in other modules.\n                for (const [_, provider] of module.metadata.externalProviders) {\n                    this.bindProvider(provider, this.globalAppContainer);\n                }\n            } else {\n                // If the module is not global, we want to bind it to its own container.\n                for (const [token, provider] of module.metadata.externalProviders) {\n                    this.bindProvider(provider, module.container);\n                    module.parent?.container.bind(token).toDynamicValue(() => module.container.get(token));\n                }\n                for (const importModule of module.repetitiveImports) {\n                    for (const [token] of importModule.metadata.externalProviders) {\n                        module.container.bind(token).toDynamicValue(() => importModule.container.get(token));\n                    }\n                }\n            }\n\n            // Bind internal providers.\n            for (const [_, provider] of module.metadata.internalProviders) {\n                this.bindProvider(provider, module.container);\n            }\n\n            // Bind container to itself so it can be injected.\n            module.container.bind(MODULE_CONTAINER).toConstantValue(module.container);\n\n            // Bind controllers to the container.\n            for (const classRef of module.metadata.controllers) {\n                module.container.bind(classRef).toSelf().inSingletonScope();\n            }\n\n            // Bind services to the container.\n            module.container.bind(TIMER_SERVICE).to(TimerService).inSingletonScope();\n\n            this.loggerService.log(\n                `~lw~Module ~lb~${module.metadata.classRef.name} ~lw~dependencies binded ~lk~(${Date.now() - startTime}ms)`,\n            );\n        });\n    }\n\n    private bindProvider(provider: Exclude<Provider, Newable>, container: Container) {\n        if ('useValue' in provider) {\n            container.bind(provider.provide).toConstantValue(provider.useValue);\n        } else if ('useFactory' in provider) {\n            const binding = container.bind(provider.provide).toDynamicValue((ctx) => {\n                const deps =\n                    provider.inject?.map((dep) => {\n                        if (isObject(dep) && 'token' in dep && 'optional' in dep) {\n                            try {\n                                return ctx.container.get(dep.token);\n                            } catch (err) {\n                                if (dep.optional) return undefined;\n                                this.loggerService.error('An error occurred while trying to resolve a dependency.');\n                                throw err;\n                            }\n                        }\n                        return ctx.container.get(dep);\n                    }) ?? [];\n                return provider.useFactory(...deps);\n            });\n            if (provider.scope === 'transient') binding.inTransientScope();\n            else if (provider.scope === 'request') binding.inRequestScope();\n            else binding.inSingletonScope();\n        } else if ('useClass' in provider) {\n            const binding = container.bind(provider.provide).to(provider.useClass);\n            if (provider.scope === 'transient') binding.inTransientScope();\n            else if (provider.scope === 'request') binding.inRequestScope();\n            else binding.inSingletonScope();\n        } else if ('useExisting' in provider) {\n            container.bind(provider.provide).toService(provider.useExisting);\n        }\n    }\n}\n", "import type { DynamicModule, LoggerService } from '../../interfaces';\nimport type { Newable } from '../../types';\nimport { Controller, ControllerMetadataReader } from '../controller';\nimport { Module, ModuleMetadataReader } from '../module';\nimport { inject, injectable } from 'inversify';\nimport { ErrorMessage } from '../../enums';\nimport { Tree, TreeNode } from '../utils';\nimport { LOGGER_SERVICE } from '../../constants';\nimport type { ModuleMetadata } from '../interfaces';\nimport { isNil } from '../../utils';\n\n@injectable()\nexport class ModuleTreeScanner {\n    @inject(ModuleMetadataReader) private readonly moduleMetadataReader: ModuleMetadataReader;\n    @inject(ControllerMetadataReader) private readonly controllerMetadataReader: ControllerMetadataReader;\n    @inject(LOGGER_SERVICE) private readonly loggerService: LoggerService;\n\n    public async scan(classRef: Newable | DynamicModule | Promise<DynamicModule>) {\n        const startTime = Date.now();\n        // Read module metadata\n        const moduleMetadata = await this.moduleMetadataReader.read(classRef);\n        // Create module instance and set metadata to it\n        const module = new Module();\n        module.metadata = moduleMetadata;\n        // Log module info\n        this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);\n        // Scan controllers in module\n        await this.scanControllers(module);\n        // Scan controllers in module\n        const moduleTree = new Tree(module);\n        const scannedModules = new Map<Newable | DynamicModule | Promise<DynamicModule>, Module>();\n        scannedModules.set(classRef, module);\n        // Scan imported modules\n        for (const importedModule of moduleMetadata.imports) {\n            await this.scanModules(moduleTree.root, importedModule, scannedModules);\n        }\n        return moduleTree;\n    }\n\n    private async scanModules(\n        parentNode: TreeNode<Module>,\n        classRef: Newable | DynamicModule | Promise<DynamicModule>,\n        scannedModules = new Map<Newable | DynamicModule | Promise<DynamicModule>, Module>(),\n    ) {\n        // Check if module is already imported\n        const scannedModule = scannedModules.get(classRef);\n        if (!isNil(scannedModule)) {\n            parentNode.value.repetitiveImports.add(scannedModule);\n            return;\n        }\n\n        const startTime = Date.now();\n\n        // Read module metadata\n        const moduleMetadata = await this.moduleMetadataReader.read(classRef);\n        // Check if there is a circular dependency\n        this.checkCircularDependency(parentNode.value.metadata, moduleMetadata);\n        // Create module instance\n        const module = new Module();\n        module.metadata = moduleMetadata;\n        module.parent = parentNode.value;\n        // Log module info\n        this.loggerService.log(`~lw~Module ~lb~${module.metadata.classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);\n        // Scan controllers in module\n        await this.scanControllers(module);\n        // Add module to tree\n        const treeNode = new TreeNode(module);\n        parentNode.addChild(treeNode);\n        // Add module to imported modules set to prevent unnecessary scanning\n        scannedModules.set(classRef, module);\n        // Scan imported modules recursively\n        for (const importModule of moduleMetadata.imports) {\n            await this.scanModules(treeNode, importModule, scannedModules);\n        }\n    }\n\n    private async scanControllers(module: Module) {\n        // Scan controllers\n        for (const classRef of module.metadata.controllers) {\n            const startTime = Date.now();\n            const controllerMetadata = await this.controllerMetadataReader.read(classRef);\n            const controller = new Controller();\n            controller.metadata = controllerMetadata;\n            controller.owner = module;\n            module.controllers.push(controller);\n\n            this.loggerService.log(`~lw~Controller ~lc~${classRef.name} ~lw~scanned ~lk~(${Date.now() - startTime}ms)`);\n        }\n    }\n\n    private async checkCircularDependency(parentMetadata: ModuleMetadata, moduleMetadata: ModuleMetadata) {\n        // Check if parent module is imported in module\n        if (moduleMetadata.imports.includes(parentMetadata.classRef)) {\n            // this.loggerService.error('An error occurred while scanning the module tree.');\n            throw new Error(ErrorMessage.CircularDependencyDetected);\n        }\n    }\n}\n", "import type { ScriptEventHandler } from '../../interfaces';\n\nexport class RageMPScriptEvent implements ScriptEventHandler {\n    constructor(\n        private eventName: string,\n        private listener: (...args: any[]) => void,\n    ) {}\n\n    destroy(): void {\n        mp.events.remove(this.eventName, this.listener);\n    }\n}\n", "import type { EventEmmiter, ScriptEventHandler } from '../../interfaces';\nimport { RageMPScriptEvent } from './ragemp-script-event-handler';\n\nexport class RageMPEventEmmiter implements EventEmmiter {\n    private mapEventsShared: Record<string, string> = {\n        // Map alt:V event names to RageMP equivalents\n        'entityColShapeEnter': 'playerEnterColshape',\n        'entityColShapeLeave': 'playerExitColshape',\n    };\n\n    constructor(private mapEvents: Record<string, string> = {}) {}\n\n    private getEventName(eventName: string): string {\n        return this.mapEventsShared[eventName] || this.mapEvents[eventName] || eventName;\n    }\n\n    emit(eventName: string, ...args: any[]): void {\n        mp.events.call(eventName, ...args);\n    }\n\n    on(eventName: string, listener: (...args: any[]) => void): ScriptEventHandler {\n        const mappedEventName = this.getEventName(eventName);\n        mp.events.add(mappedEventName, listener);\n        return new RageMPScriptEvent(mappedEventName, listener);\n    }\n\n    once(eventName: string, listener: (...args: any[]) => void): ScriptEventHandler {\n        const mappedEventName = this.getEventName(eventName);\n        const onceWrapper = (...args: any[]) => {\n            mp.events.remove(mappedEventName, onceWrapper);\n            listener(...args);\n        };\n        mp.events.add(mappedEventName, onceWrapper);\n        return new RageMPScriptEvent(mappedEventName, onceWrapper);\n    }\n\n    off(eventName: string, listener: (...args: any[]) => void): void {\n        mp.events.remove(eventName, listener);\n    }\n}\n", "import type { MultiplayerTimer } from '../../interfaces';\n\nexport class RageMPTimer implements MultiplayerTimer {\n    public lastTick = Date.now();\n    constructor(\n        public id: number,\n        public interval: number = 0,\n        public once: boolean,\n        public callback: Function,\n        private clearTimer: Function,\n    ) {}\n\n    destroy() {\n        this.clearTimer();\n    }\n}\n", "import type { MultiplayerTimer, MultiplayerTimers } from '../../interfaces';\nimport { RageMPTimer } from './ragemp-timer';\n\nexport class RageMPTimers implements MultiplayerTimers {\n    private timerIncrementer: number = 0;\n    private timers = new Map<number, MultiplayerTimer>();\n    private everyTickHandlers = new Map<number, { callback: Function; bound: Function }>();\n    private isEveryTickRunning = false;\n    private everyTickMainHandler: (() => void) | null = null;\n\n    public get all(): MultiplayerTimer[] {\n        return [...this.timers.values()];\n    }\n\n    public get warningThreshold(): number {\n        // RageMP doesn't have this feature\n        return 0;\n    }\n\n    public set warningThreshold(_value: number) {\n        // RageMP doesn't have this feature\n    }\n\n    public get sourceLocationFrameSkipCount(): number {\n        // RageMP doesn't have this feature\n        return 0;\n    }\n\n    public set sourceLocationFrameSkipCount(_value: number) {\n        // RageMP doesn't have this feature\n    }\n\n    getByID(id: number): MultiplayerTimer | null {\n        const timer = this.timers.get(id);\n        return timer ?? null;\n    }\n\n    private createTimer(\n        createTimer: (...args: any[]) => number,\n        clear: (id: number) => void,\n        callback: Function,\n        interval: number | undefined,\n        once: boolean,\n        ...args: unknown[]\n    ) {\n        const callbackBind = callback.bind(this, ...(Array.isArray(args) ? args : []));\n        const timerId = typeof interval === 'number' ? createTimer(callbackBind, interval) : createTimer(callbackBind);\n        const id = this.timerIncrementer++;\n\n        const rageMPTimer = new RageMPTimer(id, interval ?? 0, once, callbackBind, () => {\n            clear(timerId);\n            this.timers.delete(id);\n        });\n        this.timers.set(id, rageMPTimer);\n        return rageMPTimer;\n    }\n\n    setInterval(callback: Function, time: number, ...args: unknown[]) {\n        return this.createTimer(\n            (cb: Function, interval: number) => setInterval(cb as () => void, interval) as unknown as number,\n            (id: number) => clearInterval(id),\n            callback,\n            time,\n            false,\n            ...args\n        );\n    }\n\n    setTimeout(callback: Function, time: number, ...args: unknown[]) {\n        const id = this.timerIncrementer++;\n        const callbackBind = callback.bind(this, ...(Array.isArray(args) ? args : []));\n\n        const timerId = setTimeout(() => {\n            callbackBind();\n            this.timers.delete(id);\n        }, time) as unknown as number;\n\n        const rageMPTimer = new RageMPTimer(id, time, true, callbackBind, () => {\n            clearTimeout(timerId);\n            this.timers.delete(id);\n        });\n        this.timers.set(id, rageMPTimer);\n        return rageMPTimer;\n    }\n\n    everyTick(callback: Function, ...args: unknown[]) {\n        const id = this.timerIncrementer++;\n        const callbackBind = callback.bind(this, ...(Array.isArray(args) ? args : []));\n\n        this.everyTickHandlers.set(id, { callback, bound: callbackBind });\n\n        // Check if we're on client-side (render event exists) or server-side\n        const isClientSide = typeof mp !== 'undefined' && typeof (mp as any).browsers !== 'undefined';\n\n        // Start the tick loop if not already running\n        if (!this.isEveryTickRunning) {\n            this.isEveryTickRunning = true;\n\n            if (isClientSide) {\n                // Client-side: use render event for frame-accurate ticking\n                this.everyTickMainHandler = () => {\n                    for (const [, handler] of this.everyTickHandlers) {\n                        try {\n                            handler.bound();\n                        } catch (e) {\n                            mp.console.logError(`Error in everyTick handler: ${e}`);\n                        }\n                    }\n                };\n                mp.events.add('render', this.everyTickMainHandler);\n            } else {\n                // Server-side: use setInterval with minimal delay as approximation\n                const intervalHandler = () => {\n                    for (const [, handler] of this.everyTickHandlers) {\n                        try {\n                            handler.bound();\n                        } catch (e) {\n                            mp.console.logError(`Error in everyTick handler: ${e}`);\n                        }\n                    }\n                };\n                (this as any)._everyTickInterval = setInterval(intervalHandler, 0);\n            }\n        }\n\n        const rageMPTimer = new RageMPTimer(id, 0, false, callbackBind, () => {\n            this.everyTickHandlers.delete(id);\n            this.timers.delete(id);\n\n            // Stop the tick loop if no more handlers\n            if (this.everyTickHandlers.size === 0) {\n                if (isClientSide && this.everyTickMainHandler) {\n                    mp.events.remove('render', this.everyTickMainHandler);\n                    this.everyTickMainHandler = null;\n                } else if ((this as any)._everyTickInterval) {\n                    clearInterval((this as any)._everyTickInterval);\n                    (this as any)._everyTickInterval = null;\n                }\n                this.isEveryTickRunning = false;\n            }\n        });\n        this.timers.set(id, rageMPTimer);\n        return rageMPTimer;\n    }\n\n    nextTick(callback: Function, ...args: unknown[]) {\n        const id = this.timerIncrementer++;\n        const callbackBind = callback.bind(this, ...(Array.isArray(args) ? args : []));\n\n        // Check if we're on client-side (render event exists) or server-side\n        const isClientSide = typeof mp !== 'undefined' && typeof (mp as any).browsers !== 'undefined';\n\n        let timerId: any;\n\n        if (isClientSide) {\n            // Client-side: use render event for next frame\n            const handler = () => {\n                try {\n                    callbackBind();\n                } finally {\n                    mp.events.remove('render', handler);\n                    this.timers.delete(id);\n                }\n            };\n            mp.events.add('render', handler);\n\n            const rageMPTimer = new RageMPTimer(id, 0, true, callbackBind, () => {\n                mp.events.remove('render', handler);\n                this.timers.delete(id);\n            });\n            this.timers.set(id, rageMPTimer);\n            return rageMPTimer;\n        } else {\n            // Server-side: use setImmediate or setTimeout(0) for next tick\n            timerId = setTimeout(() => {\n                try {\n                    callbackBind();\n                } finally {\n                    this.timers.delete(id);\n                }\n            }, 0);\n\n            const rageMPTimer = new RageMPTimer(id, 0, true, callbackBind, () => {\n                clearTimeout(timerId);\n                this.timers.delete(id);\n            });\n            this.timers.set(id, rageMPTimer);\n            return rageMPTimer;\n        }\n    }\n\n    time(_name?: string) {\n        // RageMP doesn't have console.time equivalent\n        // Could implement custom timing if needed\n    }\n\n    timeEnd(_name?: string) {\n        // RageMP doesn't have console.timeEnd equivalent\n    }\n}\n", "import type { EventEmmiter, MultiplayerService, MultiplayerTimers } from '../../interfaces';\nimport { RageMPEventEmmiter } from './ragemp-event-emmiter';\nimport { RageMPTimers } from './ragemp-timers';\nimport { isObject } from '../../../utils';\n\nexport class RageMPMultiplayerService implements MultiplayerService {\n    readonly Timers: MultiplayerTimers;\n    readonly Events: EventEmmiter;\n\n    constructor() {\n        this.Events = new RageMPEventEmmiter();\n        this.Timers = new RageMPTimers();\n    }\n\n    parseInternalArgs<U = unknown, T = unknown>(\n        ...args: any\n    ): {\n        player?: U;\n        body?: T;\n    } {\n        const player = (isObject(args[0]) ? args[0] : undefined) as U;\n\n        return {\n            player,\n            body: args,\n        };\n    }\n\n    log(arg: any, ...args: any[]): void {\n        const message = [arg, ...args].map(a =>\n            typeof a === 'object' ? JSON.stringify(a) : String(a)\n        ).join(' ');\n        mp.console.logInfo(message);\n    }\n\n    logError(arg: any, ...args: any[]): void {\n        const message = [arg, ...args].map(a =>\n            typeof a === 'object' ? JSON.stringify(a) : String(a)\n        ).join(' ');\n        mp.console.logError(message);\n    }\n\n    logWarning(arg: any, ...args: any[]): void {\n        const message = [arg, ...args].map(a =>\n            typeof a === 'object' ? JSON.stringify(a) : String(a)\n        ).join(' ');\n        mp.console.logWarning(message);\n    }\n\n    logDebug(arg: any, ...args: any[]): void {\n        // RageMP doesn't have a dedicated debug log, use info\n        const message = [arg, ...args].map(a =>\n            typeof a === 'object' ? JSON.stringify(a) : String(a)\n        ).join(' ');\n        mp.console.logInfo(`[DEBUG] ${message}`);\n    }\n}\n", "import { validateErrorFilter, validateGuard, validateInterceptor, validatePipe } from '../schemas/events';\nimport {\n    INTERNAL_APP_CONTAINER,\n    GLOBAL_ERROR_FILTERS,\n    GLOBAL_GUARDS,\n    GLOBAL_INTERCEPTORS,\n    GLOBAL_PIPES,\n    ENABLE_SHUTDOWN_HOOKS,\n    PLUGINS,\n    GLOBAL_APP_CONTAINER,\n    APP_ENVIROMENT,\n    MANGO_REQUEST_FACTORY,\n    MANGO_RESPONSE_FACTORY,\n    EXECUTION_CONTEXT_FACTORY,\n    CONTAINER_OPTIONS,\n    MULTIPLAYER_SERVICE,\n} from './constants';\nimport type { Newable } from '../types';\nimport { inject, Container, injectable, type interfaces } from 'inversify';\nimport { App } from './app';\nimport type { ErrorFilter, Guard, Interceptor, MangoPlugin, MultiplayerService } from './interfaces';\nimport type { Pipe } from '../interfaces';\nimport {\n    ControllerEventHandler,\n    ControllerFlowHandler,\n    ControllerMetadataReader,\n    ControllerRPCHandler,\n    PipelineHandler,\n} from './controller';\nimport { Module, ModuleMetadataReader } from './module';\nimport { AppRuntime, ModuleDependencyBinder, ModuleTreeScanner } from './module-tree';\nimport { Controller } from './controller';\nimport { ExecutionContextBase, MangoRequestBase, MangoResponseBase } from './pipeline';\nimport type { ExecutionContextType } from './enums';\nimport { REFLECTOR_SERVICE } from '../constants';\nimport { ReflectorService } from '../services';\n\n@injectable()\nexport class AppBuilder<G extends Guard = Guard, I extends Interceptor = Interceptor, EF extends ErrorFilter = ErrorFilter> {\n    @inject(APP_ENVIROMENT) protected readonly enviroment: string;\n    @inject(INTERNAL_APP_CONTAINER) protected readonly internalAppContainer: Container;\n    @inject(MULTIPLAYER_SERVICE) protected readonly multiplayerService: MultiplayerService;\n    @inject(PLUGINS) protected readonly plugins: Newable<MangoPlugin>[];\n\n    private globalContainerOptions: interfaces.ContainerOptions = {};\n\n    public useGlobalGuards(...guards: (Newable<G> | G)[]) {\n        const validatedGuards: (Newable<G> | G)[] = [];\n        for (const guard of guards) {\n            const { valid, value, error } = validateGuard(guard);\n            if (!valid) throw new Error(error);\n            validatedGuards.push(value);\n        }\n\n        this.internalAppContainer.bind(GLOBAL_GUARDS).toConstantValue(validatedGuards);\n        return this;\n    }\n\n    public useGlobalInterceptors(...interceptors: (Newable<I> | I)[]) {\n        const validatedInterceptors: (Newable<I> | I)[] = [];\n        for (const interceptor of interceptors) {\n            const { valid, value, error } = validateInterceptor(interceptor);\n            if (!valid) throw new Error(error);\n            validatedInterceptors.push(value);\n        }\n\n        this.internalAppContainer.bind(GLOBAL_INTERCEPTORS).toConstantValue(validatedInterceptors);\n        return this;\n    }\n\n    public useGlobalPipes(...pipes: (Newable<Pipe> | Pipe)[]) {\n        const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n        for (const pipe of pipes) {\n            const { valid, value, error } = validatePipe(pipe);\n            if (!valid) throw new Error(error);\n            validatedPipes.push(value);\n        }\n\n        this.internalAppContainer.bind(GLOBAL_PIPES).toConstantValue(validatedPipes);\n        return this;\n    }\n\n    public useGlobalFilters(...filters: (Newable<EF> | EF)[]) {\n        const validatedFIlters: (Newable<EF> | EF)[] = [];\n        for (const filter of filters) {\n            const { valid, value, error } = validateErrorFilter(filter);\n            if (!valid) throw new Error(error);\n            validatedFIlters.push(value);\n        }\n\n        this.internalAppContainer.bind(GLOBAL_ERROR_FILTERS).toConstantValue(validatedFIlters);\n        return this;\n    }\n\n    public usePlugins(...plugins: Newable<MangoPlugin>[]) {\n        plugins.forEach((p) => this.internalAppContainer.bind(p).toSelf().inSingletonScope());\n        const internalPlugins = this.internalAppContainer.get<Newable<MangoPlugin>[]>(PLUGINS);\n        this.internalAppContainer.rebind(PLUGINS).toConstantValue([...internalPlugins, ...plugins]);\n        return this;\n    }\n\n    public enableShutdownHooks() {\n        this.internalAppContainer.bind(ENABLE_SHUTDOWN_HOOKS).toConstantValue(true);\n        return this;\n    }\n\n    public setContainerOptions(options: interfaces.ContainerOptions, onlyGlobal = false) {\n        this.globalContainerOptions = options;\n        if (onlyGlobal) return this;\n        this.internalAppContainer.bind(CONTAINER_OPTIONS).toConstantValue(options);\n        return this;\n    }\n\n    public async build() {\n        const globalAppContainer = new Container(this.globalContainerOptions);\n        // GLobal service bindings\n        globalAppContainer.bind(REFLECTOR_SERVICE).toConstantValue(ReflectorService);\n        globalAppContainer.bind(ReflectorService).toService(REFLECTOR_SERVICE);\n\n        // Multiplayer service bindings\n        globalAppContainer.bind(MULTIPLAYER_SERVICE).toConstantValue(this.multiplayerService);\n \n        // App bindings\n        this.internalAppContainer.bind(App).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(GLOBAL_APP_CONTAINER).toConstantValue(globalAppContainer);\n\n        // Module tree bindings\n        this.internalAppContainer.bind(ModuleTreeScanner).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(ModuleDependencyBinder).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(AppRuntime).toSelf().inSingletonScope();\n\n        // App bindings\n        this.internalAppContainer.bind(PipelineHandler).toSelf().inSingletonScope();\n\n        // Module bindings\n        this.internalAppContainer.bind(Module).toSelf().inTransientScope();\n        this.internalAppContainer.bind(ModuleMetadataReader).toSelf().inSingletonScope();\n\n        // Controller bindings\n        this.internalAppContainer.bind(Controller).toSelf().inTransientScope();\n        this.internalAppContainer.bind(ControllerMetadataReader).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(ControllerFlowHandler).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(ControllerEventHandler).toSelf().inSingletonScope();\n        this.internalAppContainer.bind(ControllerRPCHandler).toSelf().inSingletonScope();\n\n        // Mango Request and Response bindings\n        this.internalAppContainer.bind(MangoRequestBase).toSelf().inTransientScope();\n        this.internalAppContainer.bind(MANGO_REQUEST_FACTORY).toFactory((context) => {\n            return (body: unknown, player: PlayerMp) => {\n                const request = context.container.get(MangoRequestBase);\n                request.$body = body;\n                request.$player = player;\n                return request;\n            };\n        });\n        this.internalAppContainer.bind(MangoResponseBase).toSelf().inTransientScope();\n        this.internalAppContainer.bind(MANGO_RESPONSE_FACTORY).toFactory((context) => {\n            return () => {\n                return context.container.get(MangoResponseBase);\n            };\n        });\n        this.internalAppContainer.bind(ExecutionContextBase).toSelf().inTransientScope();\n        this.internalAppContainer.bind(EXECUTION_CONTEXT_FACTORY).toFactory((context) => {\n            return (\n                type: ExecutionContextType,\n                classRef: Newable,\n                handler: Function,\n                request: MangoRequestBase,\n                response: MangoResponseBase,\n                name: string,\n            ) => {\n                const executionContext = context.container.get(ExecutionContextBase);\n                executionContext.$type = type;\n                executionContext.$request = request;\n                executionContext.$response = response;\n                executionContext.$handler = handler;\n                executionContext.$classRef = classRef;\n                executionContext.$name = name;\n                return executionContext;\n            };\n        });\n\n        // Plugins bindings\n        for (const plugin of this.plugins) {\n            this.internalAppContainer.bind(plugin).toSelf().inSingletonScope();\n            const pluginInstance = this.internalAppContainer.get(plugin);\n            if (!pluginInstance.onBuild) continue;\n            await pluginInstance.onBuild();\n        }\n\n        if (!this.internalAppContainer.isBound(GLOBAL_GUARDS)) this.internalAppContainer.bind(GLOBAL_GUARDS).toConstantValue([]);\n        if (!this.internalAppContainer.isBound(GLOBAL_INTERCEPTORS))\n            this.internalAppContainer.bind(GLOBAL_INTERCEPTORS).toConstantValue([]);\n        if (!this.internalAppContainer.isBound(GLOBAL_PIPES)) this.internalAppContainer.bind(GLOBAL_PIPES).toConstantValue([]);\n        if (!this.internalAppContainer.isBound(GLOBAL_ERROR_FILTERS))\n            this.internalAppContainer.bind(GLOBAL_ERROR_FILTERS).toConstantValue([]);\n\n        return this.internalAppContainer.get(App);\n    }\n}\n", "import { Container, inject, injectable } from 'inversify';\nimport { ModuleDependencyBinder, ModuleTreeScanner } from './module-tree';\nimport { Module } from './module/module';\nimport type { Newable } from '../types';\nimport { INTERNAL_APP_CONTAINER, PLUGINS } from './constants';\nimport { AppRuntime } from './module-tree';\nimport type { MangoPlugin } from './interfaces/core/mango-plugin.interface';\nimport { ErrorMessage } from '../enums';\nimport type { Tree } from './utils';\nimport { type LoggerService } from '../interfaces';\nimport { LOGGER_SERVICE } from '../constants';\n\n@injectable()\nexport class App {\n    @inject(ModuleTreeScanner) private readonly moduleTreeScanner: ModuleTreeScanner;\n    @inject(ModuleDependencyBinder) private readonly moduleDependencyBinder: ModuleDependencyBinder;\n    @inject(AppRuntime) private readonly appRuntime: AppRuntime;\n    @inject(INTERNAL_APP_CONTAINER) private readonly internalAppContainer: Container;\n    @inject(PLUGINS) private readonly plugins: Newable<MangoPlugin>[];\n    @inject(LOGGER_SERVICE) private readonly loggerService: LoggerService;\n    private moduleTree: Tree<Module>;\n    private loaded = false;\n\n    public async start<T>(rootModule: Newable<T>) {\n        if (this.loaded) {\n            this.loggerService.error('Error occurred while starting the app.');\n            throw new Error(ErrorMessage.AppAlreadyLoaded);\n        }\n        this.loggerService.log('~lw~Starting app...');\n        await this.runPluginMethods('beforeStart');\n\n        this.loggerService.log('~lw~Scanning module tree...');\n        await this.runPluginMethods('beforeScan');\n        this.moduleTree = await this.moduleTreeScanner.scan(rootModule);\n        await this.runPluginMethods('afterScan');\n\n        this.loggerService.log('~lw~Binding module dependencies...');\n        await this.runPluginMethods('beforeBind');\n        await this.moduleDependencyBinder.bind(this.moduleTree);\n        await this.runPluginMethods('afterBind');\n\n        this.loggerService.log('~lw~Loading app...');\n        await this.runPluginMethods('beforeLoad');\n        await this.appRuntime.boot(this.moduleTree);\n        this.loaded = true;\n        await this.runPluginMethods('afterLoad');\n\n        this.loggerService.log('~lw~App loaded');\n\n        await this.runPluginMethods('afterStart');\n    }\n\n    public async stop() {\n        if (!this.loaded) {\n            this.loggerService.error('Error occurred while stopping the app.');\n            throw new Error(ErrorMessage.AppNotLoaded);\n        }\n        await this.runPluginMethods('beforeStop');\n        this.loggerService.log('~lw~Stopping app...');\n        await this.appRuntime.shutdown(this.moduleTree);\n        this.loaded = false;\n        this.loggerService.log('~lw~App stopped');\n        await this.runPluginMethods('afterStop');\n    }\n\n    private async runPluginMethods(method: keyof MangoPlugin) {\n        await Promise.all(\n            this.plugins.map(async (p) => {\n                const plugin = this.internalAppContainer.get(p);\n                if (!plugin[method]) return Promise.resolve();\n                return Promise.resolve(plugin[method]!());\n            }),\n        );\n    }\n}\n", "import { Container } from 'inversify';\nimport { APP_ENVIROMENT, INTERNAL_APP_CONTAINER, MULTIPLAYER_SERVICE, PLUGINS } from './constants';\nimport type { Newable } from '../types';\nimport type { MangoPlugin, MultiplayerService } from './interfaces';\nimport type { AppEnviroment } from './enums';\nimport type { AppBuilder } from './app-builder';\n\nexport async function createAppBuilder<T extends AppBuilder>({\n    enviroment,\n    plugins,\n    appBuilderInherit,\n    multiplayerService,\n}: {\n    enviroment: AppEnviroment;\n    plugins: Newable<MangoPlugin>[];\n    appBuilderInherit: Newable<T>;\n    multiplayerService?: MultiplayerService;\n}) {\n    const internalAppContainer = new Container();\n\n    if (multiplayerService) internalAppContainer.bind(MULTIPLAYER_SERVICE).toConstantValue(multiplayerService);\n    internalAppContainer.bind(INTERNAL_APP_CONTAINER).toConstantValue(internalAppContainer);\n    internalAppContainer.bind(APP_ENVIROMENT).toConstantValue(enviroment);\n    internalAppContainer.bind(PLUGINS).toConstantValue(plugins);\n    internalAppContainer.bind(appBuilderInherit).toSelf().inSingletonScope();\n\n    return internalAppContainer.get(appBuilderInherit);\n}\n", "import { isNil, isString } from '../utils';\nimport { CoreMetadataKey, type EventMetadata, type PipelineMetadata } from '../app';\nimport { ErrorMessage } from '../enums';\n\nexport function createEventDecorator(type: EventMetadata['type'], name?: string, webViewId?: string | number) {\n    return <MethodDecorator>((target: Object, method: string) => {\n        if (!isNil(name) && !isString(name)) {\n            throw new Error(ErrorMessage.EventNameMustBeString);\n        }\n\n        name = name ?? method;\n\n        const events =\n            Reflect.getMetadata<Omit<EventMetadata, 'params' | keyof PipelineMetadata>[]>(CoreMetadataKey.ControllerEvents, target) ?? [];\n\n        if (events.some((event) => event.method === method && event.name === name && event.type === type)) {\n            throw new Error(ErrorMessage.EventNameMustBeUnique);\n        }\n\n        Reflect.defineMetadata<Omit<EventMetadata, 'params' | keyof PipelineMetadata>[]>(\n            CoreMetadataKey.ControllerEvents,\n            [...events, { method, name, type, webViewId }],\n            target,\n        );\n    });\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function OnInternal(eventName: string) {\n    return createEventDecorator('onInternal', eventName);\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function OnWebView(id: string | number, eventName?: string) {\n    return createEventDecorator('onWebView', eventName, id);\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function On(eventName?: string) {\n    return createEventDecorator('on', eventName);\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function OnceInternal(eventName: string) {\n    return createEventDecorator('onceInternal', eventName);\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function Once(eventName?: string) {\n    return createEventDecorator('once', eventName);\n}\n", "import { createEventDecorator } from '../create-event-decorator';\n\nexport function OnceWebView(id: string | number, eventName?: string) {\n    return createEventDecorator('onceWebView', eventName, id);\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { Newable } from '../../types';\nimport type { MethodParameter } from '../../app/interfaces';\nimport { MethodParamType } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport type { Pipe } from '../../interfaces';\nimport { validatePipe } from '../../schemas';\n\nexport function Body(...pipes: (Newable<Pipe> | Pipe)[]) {\n    return <ParameterDecorator>((target: Object, method: string, index: number) => {\n        const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n        for (const pipe of pipes) {\n            const { valid, value, error } = validatePipe(pipe);\n            if (!valid) throw new Error(error);\n            validatedPipes.push(value);\n        }\n\n        const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n        if (params.some((param) => param.index === index)) {\n            throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n        }\n\n        const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n        const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n        Reflect.defineMetadata<MethodParameter[]>(\n            CoreMetadataKey.ControllerParams,\n            [...params, { index, method, pipes: validatedPipes, type: MethodParamType.Body, data: undefined, metatype }],\n            target,\n            method,\n        );\n    });\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { Newable } from '../../types';\nimport type { MethodParameter } from '../../app/interfaces';\nimport { MethodParamType } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport type { Pipe } from '../../interfaces';\nimport { isNumber } from '../../utils';\nimport { validatePipe } from '../../schemas';\n\nexport function Index(key: number, ...pipes: (Newable<Pipe> | Pipe)[]) {\n    return <ParameterDecorator>((target: Object, method: string, index: number) => {\n        if (!isNumber(key)) {\n            throw new Error(ErrorMessage.IndexKeyMustBeNumber);\n        }\n        const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n        for (const pipe of pipes) {\n            const { valid, value, error } = validatePipe(pipe);\n            if (!valid) throw new Error(error);\n            validatedPipes.push(value);\n        }\n\n        const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n        if (params.some((param) => param.index === index)) {\n            throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n        }\n\n        const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n        const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n        Reflect.defineMetadata<MethodParameter[]>(\n            CoreMetadataKey.ControllerParams,\n            [...params, { index, method, pipes: validatedPipes, type: MethodParamType.Index, data: key, metatype }],\n            target,\n            method,\n        );\n    });\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { Newable } from '../../types';\nimport type { MethodParameter } from '../../app/interfaces';\nimport { MethodParamType } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\n\nexport function Request() {\n    return <ParameterDecorator>((target: Object, method: string, index: number) => {\n        const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n        if (params.some((param) => param.index === index)) {\n            throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n        }\n\n        const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n        const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n        Reflect.defineMetadata<MethodParameter[]>(\n            CoreMetadataKey.ControllerParams,\n            [...params, { index, method, type: MethodParamType.Request, data: undefined, metatype }],\n            target,\n            method,\n        );\n    });\n}\n\nexport function Req() {\n    return Request();\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { Newable } from '../../types';\nimport type { MethodParameter } from '../../app/interfaces';\nimport { MethodParamType } from '../../app/enums';\nimport { isString } from '../../utils';\nimport { ErrorMessage } from '../../enums';\nimport type { Pipe } from '../../interfaces';\nimport { validatePipe } from '../../schemas';\n\nexport function Param(key: string, ...pipes: (Newable<Pipe> | Pipe)[]) {\n    return <ParameterDecorator>((target: Object, method: string, index: number) => {\n        if (!isString(key)) {\n            throw new Error(ErrorMessage.ParamKeyMustBeString);\n        }\n        const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n        for (const pipe of pipes) {\n            const { valid, value, error } = validatePipe(pipe);\n            if (!valid) throw new Error(error);\n            validatedPipes.push(value);\n        }\n\n        const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n        if (params.some((param) => param.index === index)) {\n            throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n        }\n\n        const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n        const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n        Reflect.defineMetadata<MethodParameter[]>(\n            CoreMetadataKey.ControllerParams,\n            [...params, { index, method, data: key, pipes: validatedPipes, type: MethodParamType.Param, metatype }],\n            target,\n            method,\n        );\n    });\n}\n", "import { CoreMetadataKey } from '../../app/enums';\nimport type { MethodParameter } from '../../app/interfaces';\nimport { MethodParamType } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport type { Newable } from '../../types';\n\nexport function Response() {\n    return <ParameterDecorator>((target: Object, method: string, index: number) => {\n        const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n        if (params.some((param) => param.index === index)) {\n            throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n        }\n\n        const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n        const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n        Reflect.defineMetadata<MethodParameter[]>(\n            CoreMetadataKey.ControllerParams,\n            [...params, { index, method, type: MethodParamType.Response, data: undefined, metatype }],\n            target,\n            method,\n        );\n    });\n}\n\nexport function Res() {\n    return Response();\n}\n", "import type { Guard } from '../../app/interfaces';\nimport type { Newable } from '../../types';\nimport { isNil } from '../../utils';\nimport { CoreMetadataKey } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport { validateGuard } from '../../schemas';\n\nexport function UseGuards(...guards: (Newable<Guard> | Guard)[]) {\n    return <ClassDecorator & MethodDecorator>((target: Object, method?: string, descriptor?: PropertyDescriptor) => {\n        const validatedGuards: (Newable<Guard> | Guard)[] = [];\n        for (const guard of guards) {\n            const { valid, value, error } = validateGuard(guard);\n            if (!valid) throw new Error(error);\n            validatedGuards.push(value);\n        }\n\n        if (!isNil(descriptor) && !isNil(descriptor.value)) {\n            if (guards.length === 0) {\n                throw new Error(ErrorMessage.AtLeastOneGuardRequired);\n            }\n\n            const methodGuards = Reflect.getMetadata<Newable<Guard>[]>(CoreMetadataKey.Guards, target.constructor, method) || [];\n            Reflect.defineMetadata(CoreMetadataKey.Guards, [...validatedGuards, ...methodGuards], target.constructor, method);\n            return descriptor;\n        }\n\n        if (guards.length === 0) {\n            throw new Error(ErrorMessage.AtLeastOneGuardRequired);\n        }\n\n        const classGuards = Reflect.getMetadata<Newable<Guard>[]>(CoreMetadataKey.Guards, target) || [];\n        Reflect.defineMetadata(CoreMetadataKey.Guards, [...validatedGuards, ...classGuards], target);\n        return target;\n    });\n}\n", "import type { Newable } from '../../types';\nimport type { Interceptor } from '../../app/interfaces';\nimport { isNil } from '../../utils';\nimport { CoreMetadataKey } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport { validateInterceptor } from '../../schemas';\n\nexport function UseInterceptors(...interceptors: (Newable<Interceptor> | Interceptor)[]) {\n    return <ClassDecorator & MethodDecorator>((target: Object, method?: string, descriptor?: PropertyDescriptor) => {\n        const validatedInterceptors: (Newable<Interceptor> | Interceptor)[] = [];\n        for (const interceptor of interceptors) {\n            const { valid, value, error } = validateInterceptor(interceptor);\n            if (!valid) throw new Error(error);\n            validatedInterceptors.push(value);\n        }\n\n        if (!isNil(descriptor) && !isNil(descriptor.value)) {\n            if (interceptors.length === 0) {\n                throw new Error(ErrorMessage.AtLeastOneInterceptorRequired);\n            }\n\n            const methodInterceptors =\n                Reflect.getMetadata<Newable<Interceptor>[]>(CoreMetadataKey.Interceptors, target.constructor, method) || [];\n            Reflect.defineMetadata(\n                CoreMetadataKey.Interceptors,\n                [...validatedInterceptors, ...methodInterceptors],\n                target.constructor,\n                method,\n            );\n            return descriptor;\n        }\n\n        if (interceptors.length === 0) {\n            throw new Error(ErrorMessage.AtLeastOneInterceptorRequired);\n        }\n\n        const classInterceptors = Reflect.getMetadata<Newable<Interceptor>[]>(CoreMetadataKey.Interceptors, target) || [];\n        Reflect.defineMetadata(CoreMetadataKey.Interceptors, [...validatedInterceptors, ...classInterceptors], target);\n        return target;\n    });\n}\n", "import type { Newable } from '../../types';\nimport { isNil } from '../../utils';\nimport { CoreMetadataKey } from '../../app/enums';\nimport { ErrorMessage } from '../../enums';\nimport type { Pipe } from '../../interfaces';\nimport { validatePipe } from '../../schemas';\n\nexport function UsePipes(...pipes: (Newable<Pipe> | Pipe)[]) {\n    return <ClassDecorator & MethodDecorator>((target: Object, method?: string, descriptor?: PropertyDescriptor) => {\n        const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n        for (const pipe of pipes) {\n            const { valid, value, error } = validatePipe(pipe);\n            if (!valid) throw new Error(error);\n            validatedPipes.push(value);\n        }\n\n        if (!isNil(descriptor) && !isNil(descriptor.value)) {\n            if (pipes.length === 0) {\n                throw new Error(ErrorMessage.AtLeastOnePipeRequired);\n            }\n\n            const methodPipes = Reflect.getMetadata<Newable<Pipe>[]>(CoreMetadataKey.Pipes, target.constructor, method) || [];\n            Reflect.defineMetadata(CoreMetadataKey.Pipes, [...validatedPipes, ...methodPipes], target.constructor, method);\n            return descriptor;\n        }\n\n        if (pipes.length === 0) {\n            throw new Error(ErrorMessage.AtLeastOnePipeRequired);\n        }\n\n        const classPipes = Reflect.getMetadata<Newable<Pipe>[]>(CoreMetadataKey.Pipes, target) || [];\n        Reflect.defineMetadata(CoreMetadataKey.Pipes, [...validatedPipes, ...classPipes], target);\n        return target;\n    });\n}\n", "import { isNil, isNumber, isString } from '../utils';\nimport { CoreMetadataKey, type PipelineMetadata, type RPCMetadata } from '../app';\nimport { ErrorMessage } from '../enums';\n\nexport function createRPCDecorator(type: RPCMetadata['type'], name?: string, webViewId?: string | number) {\n    return <MethodDecorator>((target: Object, method: string) => {\n        if (!isNil(webViewId) && !isString(webViewId) && !isNumber(webViewId)) {\n            throw new Error(ErrorMessage.WebViewIdMustBeStringOrNumber);\n        }\n\n        if (!isNil(name) && !isString(name)) {\n            throw new Error(ErrorMessage.RPCNameMustBeString);\n        }\n\n        name = name ?? method;\n\n        const rpcs =\n            Reflect.getMetadata<Omit<RPCMetadata, 'params' | keyof PipelineMetadata>[]>(CoreMetadataKey.ControllerRPCs, target) ?? [];\n\n        if (rpcs.some((rpc) => rpc.method === method && rpc.name === name && rpc.type === type)) {\n            throw new Error(ErrorMessage.RPCNameMustBeUnique);\n        }\n\n        Reflect.defineMetadata<Omit<RPCMetadata, 'params' | keyof PipelineMetadata>[]>(\n            CoreMetadataKey.ControllerRPCs,\n            [...rpcs, { method, name, type, webViewId }],\n            target,\n        );\n    });\n}\n", "import { createRPCDecorator } from '../create-rpc-decorator';\n\nexport function OnRequest(rpcName?: string) {\n    return createRPCDecorator('onRequest', rpcName);\n}\n", "import { createRPCDecorator } from '../create-rpc-decorator';\n\nexport function OnWebViewRequest(id: string | number, rpcName?: string) {\n    return createRPCDecorator('onWebViewRequest', rpcName, id);\n}\n", "import { CoreMetadataKey, type TimerMetadata } from '../app';\nimport { ErrorMessage } from '../enums';\nimport { isNil, isString } from '../utils';\n\nexport function createTimerDecorator(type: TimerMetadata['type'], name?: string, options?: TimerMetadata['options']) {\n    return <MethodDecorator>((target: Object, method: string) => {\n        if (!isNil(name) && !isString(name)) {\n            throw new Error(ErrorMessage.TimerNameMustBeString);\n        }\n\n        name = name ?? method;\n\n        const timers = Reflect.getMetadata<TimerMetadata[]>(CoreMetadataKey.Timers, target) ?? [];\n\n        if (timers.some((timer) => timer.method === method && timer.name === name && timer.type === type)) {\n            throw new Error(ErrorMessage.EventNameMustBeUnique);\n        }\n\n        Reflect.defineMetadata<TimerMetadata[]>(\n            CoreMetadataKey.Timers,\n            [...timers, <TimerMetadata>{ method, name, type, options }],\n            target,\n        );\n    });\n}\n", "import type { CronOptions } from 'croner';\nimport { createTimerDecorator } from '../create-timer.decorator';\n\nexport function Cron(pattern: string | Date, options: CronOptions = {}) {\n    return createTimerDecorator('cron', options.name, { pattern, ...options });\n}\n", "import { createTimerDecorator } from '../create-timer.decorator';\n\nexport function EveryTick(name?: string) {\n    return createTimerDecorator('everytick', name);\n}\n", "import { isString } from '../../utils';\nimport { createTimerDecorator } from '../create-timer.decorator';\n\nexport function Interval(timeout: number): MethodDecorator;\nexport function Interval(name: string, timeout: number): MethodDecorator;\nexport function Interval(nameOrTimeout: string | number, timeout?: number): MethodDecorator {\n    const [name, intervalTimeout] = isString(nameOrTimeout) ? [nameOrTimeout, timeout] : [undefined, nameOrTimeout];\n    return createTimerDecorator('interval', name, { timeout: intervalTimeout! });\n}\n", "import { isString } from '../../utils';\nimport { createTimerDecorator } from '../create-timer.decorator';\n\nexport function Timeout(timeout: number): MethodDecorator;\nexport function Timeout(name: string, value: number): MethodDecorator;\nexport function Timeout(nameOrTimeout: string | number, timeout?: number): MethodDecorator {\n    const [name, intervalTimeout] = isString(nameOrTimeout) ? [nameOrTimeout, timeout] : [undefined, nameOrTimeout];\n    return createTimerDecorator('timeout', name, { timeout: intervalTimeout! });\n}\n", "export function applyDecorators(...decorators: (ClassDecorator | MethodDecorator | PropertyDecorator)[]) {\n    return <TFunction extends Function, Y>(\n        target: TFunction | Object,\n        propertyKey: string | symbol,\n        descriptor: TypedPropertyDescriptor<Y>,\n    ) => {\n        for (const decorator of decorators) {\n            if (target instanceof Function && !descriptor) {\n                (<ClassDecorator>decorator)(target);\n                continue;\n            }\n            (<MethodDecorator | PropertyDecorator>decorator)(target, propertyKey, descriptor);\n        }\n    };\n}\n", "import type { ExecutionContext, MethodParameter } from '../app/interfaces';\nimport { CoreMetadataKey } from '../app/enums';\nimport type { Newable } from '../types';\nimport { MethodParamType } from '../app/enums';\nimport { ErrorMessage } from '../enums';\nimport type { Pipe } from '../interfaces';\nimport { validatePipe } from '../schemas';\n\nexport function createParamDecorator<TInput = unknown, TOutput = unknown>(factory: (data: TInput, ctx: ExecutionContext) => TOutput) {\n    return <TInput = unknown>(data?: TInput, ...pipes: (Newable<Pipe> | Pipe)[]) => {\n        return <ParameterDecorator>((target: Object, method: string, index: number) => {\n            const validatedPipes: (Newable<Pipe> | Pipe)[] = [];\n            for (const pipe of pipes) {\n                const { valid, value, error } = validatePipe(pipe);\n                if (!valid) throw new Error(error);\n                validatedPipes.push(value);\n            }\n\n            const params = Reflect.getMetadata<MethodParameter[]>(CoreMetadataKey.ControllerParams, target, method) ?? [];\n\n            if (params.some((param) => param.index === index)) {\n                throw new Error(ErrorMessage.MultipleDecoratorsOnSingleParameterNotAllowed);\n            }\n\n            const paramTypes = Reflect.getMetadata<Newable[]>('design:paramtypes', target, method);\n            const metatype = Array.isArray(paramTypes) ? paramTypes[index] : undefined;\n\n            Reflect.defineMetadata<MethodParameter[]>(\n                CoreMetadataKey.ControllerParams,\n                [\n                    ...params,\n                    {\n                        index,\n                        method,\n                        pipes: validatedPipes,\n                        type: MethodParamType.Custom,\n                        factory: <(data: unknown, context: ExecutionContext) => unknown>factory,\n                        data,\n                        metatype,\n                    },\n                ],\n                target,\n                method,\n            );\n        });\n    };\n}\n", "import { LazyServiceIdentifer, type interfaces } from 'inversify';\n\nexport function forwardRef<T = unknown>(fn: () => interfaces.ServiceIdentifier<T>) {\n    return new LazyServiceIdentifer<T>(fn);\n}\n", "import { inject, injectable } from 'inversify';\nimport { isString } from '../utils';\nimport { Cron, type CronOptions } from 'croner';\nimport { MULTIPLAYER_SERVICE, type MultiplayerService, type MultiplayerTimer } from '../app';\n\n@injectable()\nexport class TimerService {\n    @inject(MULTIPLAYER_SERVICE) private readonly multiplayerService: MultiplayerService;\n    private readonly $everyticks = new Map<string, MultiplayerTimer>();\n    private readonly $intervals = new Map<string, MultiplayerTimer>();\n    private readonly $timeouts = new Map<string, MultiplayerTimer>();\n    private readonly $crons = new Map<string, Cron>();\n\n    public get all() {\n        return this.multiplayerService.Timers.all;\n    }\n\n    public get everyticks() {\n        return [...this.$everyticks.values()];\n    }\n\n    public get intervals() {\n        return [...this.$intervals.values()];\n    }\n\n    public get timeouts() {\n        return [...this.$timeouts.values()];\n    }\n\n    public get crons() {\n        return [...this.$crons.values()];\n    }\n\n    public set warningThreshold(value: number) {\n        this.multiplayerService.Timers.warningThreshold = value;\n    }\n\n    public get warningThreshold() {\n        return this.multiplayerService.Timers.warningThreshold;\n    }\n\n    public set sourceLocationFrameSkipCount(value: number) {\n        this.multiplayerService.Timers.sourceLocationFrameSkipCount = value;\n    }\n\n    public get sourceLocationFrameSkipCount() {\n        return this.multiplayerService.Timers.sourceLocationFrameSkipCount;\n    }\n\n    public createCronJob(callback: Function, options: CronOptions & { pattern: string | Date }) {\n        const { pattern, ...cronOptions } = options;\n\n        const cron = Cron(pattern, cronOptions, callback);\n        if (isString(options.name)) this.$crons.set(options.name, cron);\n\n        return cron;\n    }\n\n    public createInterval(callback: Function, interval: number, name?: string) {\n        const timer = this.multiplayerService.Timers.setInterval(callback, interval);\n        if (isString(name)) this.$intervals.set(name, timer);\n        return timer;\n    }\n\n    public createTimeout(callback: Function, timeout: number, name?: string) {\n        const timer = this.multiplayerService.Timers.setTimeout(callback, timeout);\n        if (isString(name)) this.$timeouts.set(name, timer);\n        return timer;\n    }\n\n    public createEveryTick(callback: Function, name?: string) {\n        const timer = this.multiplayerService.Timers.everyTick(callback);\n        if (isString(name)) this.$everyticks.set(name, timer);\n        return timer;\n    }\n\n    public delete(type: 'cron' | 'everytick' | 'timeout' | 'interval', name: string) {\n        switch (type) {\n            case 'cron':\n                const cronJob = this.$crons.get(name);\n                if (cronJob) {\n                    cronJob.stop();\n                    this.$crons.delete(name);\n                }\n                break;\n            case 'everytick':\n                const everytick = this.$everyticks.get(name);\n                if (everytick) {\n                    everytick.destroy();\n                    this.$everyticks.delete(name);\n                }\n                break;\n            case 'interval':\n                const interval = this.$intervals.get(name);\n                if (interval) {\n                    interval.destroy();\n                    this.$intervals.delete(name);\n                }\n                break;\n            case 'timeout':\n                const timeout = this.$timeouts.get(name);\n                if (timeout) {\n                    timeout.destroy();\n                    this.$timeouts.delete(name);\n                }\n                break;\n        }\n    }\n\n    public getByName(type: 'cron' | 'everytick' | 'timeout' | 'interval', name: string) {\n        switch (type) {\n            case 'cron':\n                return this.$crons.get(name);\n            case 'everytick':\n                return this.$everyticks.get(name);\n            case 'interval':\n                return this.$intervals.get(name);\n            case 'timeout':\n                return this.$timeouts.get(name);\n        }\n    }\n\n    public getById(id: number) {\n        return this.multiplayerService.Timers.getByID(id);\n    }\n\n    public time(name?: string) {\n        return this.multiplayerService.Timers.time(name);\n    }\n\n    public timeEnd(name?: string) {\n        return this.multiplayerService.Timers.timeEnd(name);\n    }\n}\n"],
  "mappings": "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",
  "names": ["injectable", "injectable", "Controller", "options", "target", "Reflect", "hasMetadata", "CoreMetadataKey", "Error", "ErrorMessage", "DuplicateDecoratorUsage", "valid", "value", "error", "validateControllerOptions", "defineMetadata", "injectable", "Global", "target", "Reflect", "defineMetadata", "CoreMetadataKey", "GlobalModule", "inject", "Inject", "key", "target", "propertyKey", "paramIndex", "isNil", "validateInjectionToken", "valid", "Error", "ErrorMessage", "InvalidInjectionTokenSpecified", "token", "Reflect", "getMetadata", "InjectionTokenNotFound", "inject", "injectable", "Injectable", "options", "target", "Reflect", "hasMetadata", "CoreMetadataKey", "Error", "ErrorMessage", "DuplicateDecoratorUsage", "valid", "value", "error", "validateInjectableMetadata", "defineMetadata", "injectable", "injectable", "Module", "options", "target", "Reflect", "hasMetadata", "CoreMetadataKey", "Error", "ErrorMessage", "DuplicateDecoratorUsage", "valid", "value", "error", "validateModuleOptions", "defineMetadata", "injectable", "optional", "Optional", "target", "propertyKey", "paramIndex", "optional", "SetMetadata", "key", "value", "decoratorFactory", "target", "_method", "descriptor", "Reflect", "defineMetadata", "KEY", "Catch", "exceptions", "target", "Reflect", "hasMetadata", "CoreMetadataKey", "Error", "ErrorMessage", "DuplicateDecoratorUsage", "duplicates", "filter", "exception", "index", "indexOf", "length", "ExceptionHandlingConflict", "defineMetadata", "UseFilters", "filters", "target", "method", "descriptor", "validatedFilters", "filter", "valid", "value", "error", "validateErrorFilter", "Error", "push", "isNil", "length", "ErrorMessage", "AtLeastOneFilterRequired", "methodFilters", "Reflect", "getMetadata", "CoreMetadataKey", "ErrorFilters", "find", "includes", "DuplicateErrorFilterDetected", "defineMetadata", "classFilters", "inject", "injectable", "optional", "AppRuntime", "eventHandler", "rpcHandler", "globalGuards", "globalInterceptors", "globalPipes", "globalErrorFilters", "loggerService", "enableShutdownHooks", "boot", "resolvedTree", "asyncTraverse", "node", "startTime", "Date", "now", "module", "value", "instance", "container", "get", "metadata", "classRef", "controllers", "forEach", "controller", "internalProviders", "externalProviders", "token", "log", "name", "runLifecycleMethod", "runLifecycleMethods", "traverse", "time", "registerTimers", "registerListeners", "shutdown", "timerService", "owner", "TIMER_SERVICE", "everyticks", "timer", "destroy", "intervals", "timeouts", "crons", "cron", "stop", "eventHandlers", "handler", "rpcHandlers", "events", "event", "guards", "interceptors", "pipes", "mappedErrorFilters", "mapErrorFilters", "errorFilters", "registerEvent", "push", "rpcs", "rpc", "registerRPC", "timers", "type", "createCronJob", "method", "bind", "options", "createEveryTick", "createInterval", "timeout", "createTimeout", "filterMap", "filter", "errors", "Reflect", "getMetadata", "CoreMetadataKey", "Catch", "length", "error", "isNil", "find", "filterError", "Error", "ErrorMessage", "ErrorAlreadyHandledByFilter", "Promise", "all", "map", "isObject", "providerInstance", "Container", "inject", "injectable", "optional", "ModuleDependencyBinder", "globalAppContainer", "loggerService", "containerOptions", "bind", "resolvedTree", "asyncTraverse", "node", "startTime", "Date", "now", "module", "value", "container", "ModuleContainer", "metadata", "parent", "classRef", "toSelf", "inSingletonScope", "global", "_", "provider", "externalProviders", "bindProvider", "token", "toDynamicValue", "get", "importModule", "repetitiveImports", "internalProviders", "MODULE_CONTAINER", "toConstantValue", "controllers", "TIMER_SERVICE", "to", "TimerService", "log", "name", "provide", "useValue", "binding", "ctx", "deps", "inject", "map", "dep", "isObject", "err", "optional", "undefined", "error", "useFactory", "scope", "inTransientScope", "inRequestScope", "useClass", "toService", "useExisting", "inject", "injectable", "ModuleTreeScanner", "moduleMetadataReader", "controllerMetadataReader", "loggerService", "scan", "classRef", "startTime", "Date", "now", "moduleMetadata", "read", "module", "Module", "metadata", "log", "name", "scanControllers", "moduleTree", "Tree", "scannedModules", "Map", "set", "importedModule", "imports", "scanModules", "root", "parentNode", "scannedModule", "get", "isNil", "value", "repetitiveImports", "add", "checkCircularDependency", "parent", "treeNode", "TreeNode", "addChild", "importModule", "controllers", "controllerMetadata", "controller", "Controller", "owner", "push", "parentMetadata", "includes", "Error", "ErrorMessage", "CircularDependencyDetected", "RageMPScriptEvent", "eventName", "listener", "destroy", "mp", "events", "remove", "RageMPEventEmmiter", "mapEventsShared", "mapEvents", "getEventName", "eventName", "emit", "args", "mp", "events", "call", "on", "listener", "mappedEventName", "add", "RageMPScriptEvent", "once", "onceWrapper", "remove", "off", "RageMPTimer", "lastTick", "Date", "now", "id", "interval", "once", "callback", "clearTimer", "destroy", "RageMPTimers", "timerIncrementer", "timers", "Map", "everyTickHandlers", "isEveryTickRunning", "everyTickMainHandler", "all", "values", "warningThreshold", "_value", "sourceLocationFrameSkipCount", "getByID", "id", "timer", "get", "createTimer", "clear", "callback", "interval", "once", "args", "callbackBind", "bind", "Array", "isArray", "timerId", "rageMPTimer", "RageMPTimer", "delete", "set", "setInterval", "time", "cb", "clearInterval", "setTimeout", "clearTimeout", "everyTick", "bound", "isClientSide", "mp", "browsers", "handler", "e", "console", "logError", "events", "add", "intervalHandler", "_everyTickInterval", "size", "remove", "nextTick", "_name", "timeEnd", "RageMPMultiplayerService", "Timers", "Events", "RageMPEventEmmiter", "RageMPTimers", "parseInternalArgs", "args", "player", "isObject", "undefined", "body", "log", "arg", "message", "map", "a", "JSON", "stringify", "String", "join", "mp", "console", "logInfo", "logError", "logWarning", "logDebug", "inject", "Container", "injectable", "Container", "inject", "injectable", "App", "moduleTreeScanner", "moduleDependencyBinder", "appRuntime", "internalAppContainer", "plugins", "loggerService", "moduleTree", "loaded", "start", "rootModule", "error", "Error", "ErrorMessage", "AppAlreadyLoaded", "log", "runPluginMethods", "scan", "bind", "boot", "stop", "AppNotLoaded", "shutdown", "method", "Promise", "all", "map", "p", "plugin", "get", "resolve", "AppBuilder", "enviroment", "internalAppContainer", "multiplayerService", "plugins", "globalContainerOptions", "useGlobalGuards", "guards", "validatedGuards", "guard", "valid", "value", "error", "validateGuard", "Error", "push", "bind", "GLOBAL_GUARDS", "toConstantValue", "useGlobalInterceptors", "interceptors", "validatedInterceptors", "interceptor", "validateInterceptor", "GLOBAL_INTERCEPTORS", "useGlobalPipes", "pipes", "validatedPipes", "pipe", "validatePipe", "GLOBAL_PIPES", "useGlobalFilters", "filters", "validatedFIlters", "filter", "validateErrorFilter", "GLOBAL_ERROR_FILTERS", "usePlugins", "forEach", "p", "toSelf", "inSingletonScope", "internalPlugins", "get", "PLUGINS", "rebind", "enableShutdownHooks", "ENABLE_SHUTDOWN_HOOKS", "setContainerOptions", "options", "onlyGlobal", "CONTAINER_OPTIONS", "build", "globalAppContainer", "Container", "REFLECTOR_SERVICE", "ReflectorService", "toService", "MULTIPLAYER_SERVICE", "App", "GLOBAL_APP_CONTAINER", "ModuleTreeScanner", "ModuleDependencyBinder", "AppRuntime", "PipelineHandler", "Module", "inTransientScope", "ModuleMetadataReader", "Controller", "ControllerMetadataReader", "ControllerFlowHandler", "ControllerEventHandler", "ControllerRPCHandler", "MangoRequestBase", "MANGO_REQUEST_FACTORY", "toFactory", "context", "body", "player", "request", "container", "$body", "$player", "MangoResponseBase", "MANGO_RESPONSE_FACTORY", "ExecutionContextBase", "EXECUTION_CONTEXT_FACTORY", "type", "classRef", "handler", "response", "name", "executionContext", "$type", "$request", "$response", "$handler", "$classRef", "$name", "plugin", "pluginInstance", "onBuild", "isBound", "Container", "createAppBuilder", "enviroment", "plugins", "appBuilderInherit", "multiplayerService", "internalAppContainer", "Container", "bind", "MULTIPLAYER_SERVICE", "toConstantValue", "INTERNAL_APP_CONTAINER", "APP_ENVIROMENT", "PLUGINS", "toSelf", "inSingletonScope", "get", "createEventDecorator", "type", "name", "webViewId", "target", "method", "isNil", "isString", "Error", "ErrorMessage", "EventNameMustBeString", "events", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerEvents", "some", "event", "EventNameMustBeUnique", "defineMetadata", "OnInternal", "eventName", "createEventDecorator", "OnWebView", "id", "eventName", "createEventDecorator", "On", "eventName", "createEventDecorator", "OnceInternal", "eventName", "createEventDecorator", "Once", "eventName", "createEventDecorator", "OnceWebView", "id", "eventName", "createEventDecorator", "Body", "pipes", "target", "method", "index", "validatedPipes", "pipe", "valid", "value", "error", "validatePipe", "Error", "push", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "ErrorMessage", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "type", "MethodParamType", "data", "Index", "key", "pipes", "target", "method", "index", "isNumber", "Error", "ErrorMessage", "IndexKeyMustBeNumber", "validatedPipes", "pipe", "valid", "value", "error", "validatePipe", "push", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "type", "MethodParamType", "data", "Request", "target", "method", "index", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "Error", "ErrorMessage", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "type", "MethodParamType", "data", "Req", "Param", "key", "pipes", "target", "method", "index", "isString", "Error", "ErrorMessage", "ParamKeyMustBeString", "validatedPipes", "pipe", "valid", "value", "error", "validatePipe", "push", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "data", "type", "MethodParamType", "Response", "target", "method", "index", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "Error", "ErrorMessage", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "type", "MethodParamType", "data", "Res", "UseGuards", "guards", "target", "method", "descriptor", "validatedGuards", "guard", "valid", "value", "error", "validateGuard", "Error", "push", "isNil", "length", "ErrorMessage", "AtLeastOneGuardRequired", "methodGuards", "Reflect", "getMetadata", "CoreMetadataKey", "Guards", "defineMetadata", "classGuards", "UseInterceptors", "interceptors", "target", "method", "descriptor", "validatedInterceptors", "interceptor", "valid", "value", "error", "validateInterceptor", "Error", "push", "isNil", "length", "ErrorMessage", "AtLeastOneInterceptorRequired", "methodInterceptors", "Reflect", "getMetadata", "CoreMetadataKey", "Interceptors", "defineMetadata", "classInterceptors", "UsePipes", "pipes", "target", "method", "descriptor", "validatedPipes", "pipe", "valid", "value", "error", "validatePipe", "Error", "push", "isNil", "length", "ErrorMessage", "AtLeastOnePipeRequired", "methodPipes", "Reflect", "getMetadata", "CoreMetadataKey", "Pipes", "defineMetadata", "classPipes", "createRPCDecorator", "type", "name", "webViewId", "target", "method", "isNil", "isString", "isNumber", "Error", "ErrorMessage", "WebViewIdMustBeStringOrNumber", "RPCNameMustBeString", "rpcs", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerRPCs", "some", "rpc", "RPCNameMustBeUnique", "defineMetadata", "OnRequest", "rpcName", "createRPCDecorator", "OnWebViewRequest", "id", "rpcName", "createRPCDecorator", "createTimerDecorator", "type", "name", "options", "target", "method", "isNil", "isString", "Error", "ErrorMessage", "TimerNameMustBeString", "timers", "Reflect", "getMetadata", "CoreMetadataKey", "Timers", "some", "timer", "EventNameMustBeUnique", "defineMetadata", "Cron", "pattern", "options", "createTimerDecorator", "name", "EveryTick", "name", "createTimerDecorator", "Interval", "nameOrTimeout", "timeout", "name", "intervalTimeout", "isString", "undefined", "createTimerDecorator", "Timeout", "nameOrTimeout", "timeout", "name", "intervalTimeout", "isString", "undefined", "createTimerDecorator", "applyDecorators", "decorators", "target", "propertyKey", "descriptor", "decorator", "Function", "createParamDecorator", "factory", "data", "pipes", "target", "method", "index", "validatedPipes", "pipe", "valid", "value", "error", "validatePipe", "Error", "push", "params", "Reflect", "getMetadata", "CoreMetadataKey", "ControllerParams", "some", "param", "ErrorMessage", "MultipleDecoratorsOnSingleParameterNotAllowed", "paramTypes", "metatype", "Array", "isArray", "undefined", "defineMetadata", "type", "MethodParamType", "Custom", "LazyServiceIdentifer", "forwardRef", "fn", "LazyServiceIdentifer", "ReflectorService", "get", "metadataKey", "target", "Reflect", "getMetadata", "getAll", "targets", "map", "getAllAndMerge", "metadataCollection", "filter", "item", "undefined", "isEmpty", "reduce", "a", "b", "Array", "isArray", "concat", "isObject", "getAllAndOverride", "result", "createDecorator", "options", "key", "generateRandomId", "decoratorFn", "metadataValue", "descriptor", "value", "transform", "SetMetadata", "KEY", "inject", "injectable", "Cron", "TimerService", "multiplayerService", "$everyticks", "Map", "$intervals", "$timeouts", "$crons", "all", "Timers", "everyticks", "values", "intervals", "timeouts", "crons", "warningThreshold", "value", "sourceLocationFrameSkipCount", "createCronJob", "callback", "options", "pattern", "cronOptions", "cron", "Cron", "isString", "name", "set", "createInterval", "interval", "timer", "setInterval", "createTimeout", "timeout", "setTimeout", "createEveryTick", "everyTick", "delete", "type", "cronJob", "get", "stop", "everytick", "destroy", "getByName", "getById", "id", "getByID", "time", "timeEnd"]
}

|