@ragemp-mango/core 1.1.0 → 1.2.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.
@@ -108,12 +108,20 @@ declare class App {
108
108
  private runPluginMethods;
109
109
  }
110
110
 
111
+ interface AppBuilderConfig {
112
+ enviroment: AppEnviroment;
113
+ internalAppContainer: Container;
114
+ multiplayerService: MultiplayerService;
115
+ plugins: Newable<MangoPlugin>[];
116
+ }
117
+
111
118
  declare class AppBuilder<G extends Guard = Guard, I extends Interceptor = Interceptor, EF extends ErrorFilter = ErrorFilter> {
112
- protected readonly enviroment: string;
119
+ protected readonly enviroment: AppEnviroment;
113
120
  protected readonly internalAppContainer: Container;
114
121
  protected readonly multiplayerService: MultiplayerService;
115
122
  protected readonly plugins: Newable<MangoPlugin>[];
116
123
  private globalContainerOptions;
124
+ constructor(config: AppBuilderConfig);
117
125
  useGlobalGuards(...guards: (Newable<G> | G)[]): this;
118
126
  useGlobalInterceptors(...interceptors: (Newable<I> | I)[]): this;
119
127
  useGlobalPipes(...pipes: (Newable<Pipe> | Pipe)[]): this;
@@ -127,7 +135,7 @@ declare class AppBuilder<G extends Guard = Guard, I extends Interceptor = Interc
127
135
  declare function createAppBuilder<T extends AppBuilder>({ enviroment, plugins, appBuilderInherit, multiplayerService, }: {
128
136
  enviroment: AppEnviroment;
129
137
  plugins: Newable<MangoPlugin>[];
130
- appBuilderInherit: Newable<T>;
138
+ appBuilderInherit: new (config: AppBuilderConfig) => T;
131
139
  multiplayerService?: MultiplayerService;
132
140
  }): Promise<T>;
133
141
 
package/dist/app/index.js CHANGED
@@ -10,7 +10,7 @@ import {
10
10
  RageMPTimer,
11
11
  RageMPTimers,
12
12
  createAppBuilder
13
- } from "../chunk-UEGF22IW.js";
13
+ } from "../chunk-BQFJLVDO.js";
14
14
  import {
15
15
  Module,
16
16
  ModuleContainer,
@@ -2,7 +2,7 @@ import {
2
2
  AppRuntime,
3
3
  ModuleDependencyBinder,
4
4
  ModuleTreeScanner
5
- } from "../../chunk-UEGF22IW.js";
5
+ } from "../../chunk-BQFJLVDO.js";
6
6
  import "../../chunk-73LIJA6X.js";
7
7
  import "../../chunk-AO6BXG54.js";
8
8
  import "../../chunk-2ADQZWQE.js";
@@ -0,0 +1,170 @@
1
+ import {
2
+ RPC_RESULT_HANDLER_NOT_FOUND,
3
+ RPC_RESULT_TIMEOUT,
4
+ RPC_RESULT_UNKNOWN
5
+ } from "./chunk-HK7QTFPA.js";
6
+ import {
7
+ MangoError
8
+ } from "./chunk-6YEWPMZJ.js";
9
+ import {
10
+ ErrorMessage,
11
+ RPCResultStatus
12
+ } from "./chunk-DXPVUDXD.js";
13
+ import {
14
+ LOGGER_SERVICE
15
+ } from "./chunk-DJZCOYB3.js";
16
+ import {
17
+ __name
18
+ } from "./chunk-7QVYU63E.js";
19
+
20
+ // src/app/services/base-event.service.ts
21
+ import { injectable } from "inversify";
22
+ function _ts_decorate(decorators, target, key, desc) {
23
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
24
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
25
+ 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;
26
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
27
+ }
28
+ __name(_ts_decorate, "_ts_decorate");
29
+ function _ts_metadata(k, v) {
30
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
31
+ }
32
+ __name(_ts_metadata, "_ts_metadata");
33
+ var BaseEventService = class {
34
+ static {
35
+ __name(this, "BaseEventService");
36
+ }
37
+ $eventEmmiter;
38
+ $localHandlers = /* @__PURE__ */ new Set();
39
+ $internalHandlers = /* @__PURE__ */ new Set();
40
+ $remoteHandlers = /* @__PURE__ */ new Set();
41
+ $internalEventNames = /* @__PURE__ */ new Set();
42
+ constructor($eventEmmiter) {
43
+ this.$eventEmmiter = $eventEmmiter;
44
+ }
45
+ on(eventName, callback) {
46
+ const wrapper = /* @__PURE__ */ __name((...args) => callback(args[0]), "wrapper");
47
+ const eventHandler = this.$eventEmmiter.on(eventName, wrapper);
48
+ this.$localHandlers.add(eventHandler);
49
+ return eventHandler;
50
+ }
51
+ once(eventName, callback) {
52
+ const wrapper = /* @__PURE__ */ __name((...args) => callback(args[0]), "wrapper");
53
+ const eventHandler = this.$eventEmmiter.once(eventName, wrapper);
54
+ this.$localHandlers.add(eventHandler);
55
+ return eventHandler;
56
+ }
57
+ emit(eventName, body) {
58
+ this.$eventEmmiter.emit(eventName, body);
59
+ }
60
+ $onInternal(eventName, handler) {
61
+ if (!this.$internalEventNames.has(eventName)) {
62
+ throw new Error(ErrorMessage.InvalidInternalEventName);
63
+ }
64
+ const eventHandler = this.$eventEmmiter.on(eventName, handler);
65
+ this.$internalHandlers.add(eventHandler);
66
+ return eventHandler;
67
+ }
68
+ $onceInternal(eventName, handler) {
69
+ if (!this.$internalEventNames.has(eventName)) {
70
+ throw new Error(ErrorMessage.InvalidInternalEventName);
71
+ }
72
+ const eventHandler = this.$eventEmmiter.once(eventName, handler);
73
+ this.$internalHandlers.add(eventHandler);
74
+ return eventHandler;
75
+ }
76
+ };
77
+ BaseEventService = _ts_decorate([
78
+ injectable(),
79
+ _ts_metadata("design:type", Function),
80
+ _ts_metadata("design:paramtypes", [
81
+ typeof EventEmmiter === "undefined" ? Object : EventEmmiter
82
+ ])
83
+ ], BaseEventService);
84
+
85
+ // src/app/services/base-rpc.service.ts
86
+ import { inject, injectable as injectable2 } from "inversify";
87
+ function _ts_decorate2(decorators, target, key, desc) {
88
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
89
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
90
+ 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;
91
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
92
+ }
93
+ __name(_ts_decorate2, "_ts_decorate");
94
+ function _ts_metadata2(k, v) {
95
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
96
+ }
97
+ __name(_ts_metadata2, "_ts_metadata");
98
+ var BaseRPCService = class {
99
+ static {
100
+ __name(this, "BaseRPCService");
101
+ }
102
+ $loggerService;
103
+ $TIMEOUT = 2e3;
104
+ $localHandlers = /* @__PURE__ */ new Map();
105
+ async call(rpcName, body, options = {
106
+ timeout: this.$TIMEOUT
107
+ }) {
108
+ return new Promise(async (resolve) => {
109
+ const handler = this.$localHandlers.get(rpcName)?.handler;
110
+ if (!handler) {
111
+ return resolve(RPC_RESULT_HANDLER_NOT_FOUND);
112
+ }
113
+ const timeoutId = setTimeout(() => {
114
+ resolve(RPC_RESULT_TIMEOUT);
115
+ }, options.timeout ?? this.$TIMEOUT);
116
+ try {
117
+ const result = await handler(body);
118
+ clearTimeout(timeoutId);
119
+ resolve({
120
+ success: true,
121
+ status: RPCResultStatus.Success,
122
+ body: result
123
+ });
124
+ } catch (error) {
125
+ clearTimeout(timeoutId);
126
+ if (error instanceof MangoError) {
127
+ return resolve({
128
+ success: false,
129
+ status: error.status,
130
+ error: {
131
+ message: error.message,
132
+ details: error.details
133
+ }
134
+ });
135
+ }
136
+ resolve(RPC_RESULT_UNKNOWN);
137
+ }
138
+ });
139
+ }
140
+ onRequest(rpcName, handler) {
141
+ if (this.$localHandlers.has(rpcName)) {
142
+ this.$loggerService.error("An error occurred while trying to register RPC.");
143
+ throw new Error(ErrorMessage.RPCHandlerAlreadyExists);
144
+ }
145
+ const rpcHandler = {
146
+ destroy: /* @__PURE__ */ __name(() => {
147
+ rpcHandler.valid = false;
148
+ this.$localHandlers.delete(rpcName);
149
+ }, "destroy"),
150
+ rpcName,
151
+ handler,
152
+ valid: true
153
+ };
154
+ this.$localHandlers.set(rpcName, rpcHandler);
155
+ return rpcHandler;
156
+ }
157
+ };
158
+ _ts_decorate2([
159
+ inject(LOGGER_SERVICE),
160
+ _ts_metadata2("design:type", typeof LoggerService === "undefined" ? Object : LoggerService)
161
+ ], BaseRPCService.prototype, "$loggerService", void 0);
162
+ BaseRPCService = _ts_decorate2([
163
+ injectable2()
164
+ ], BaseRPCService);
165
+
166
+ export {
167
+ BaseEventService,
168
+ BaseRPCService
169
+ };
170
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/app/services/base-event.service.ts", "../src/app/services/base-rpc.service.ts"],
  "sourcesContent": ["import { injectable } from 'inversify';\nimport { ErrorMessage } from '../../enums';\nimport type { EventEmmiter, ScriptEventHandler } from '../interfaces';\nimport type { EventHandler } from '../../interfaces';\n\n@injectable()\nexport abstract class BaseEventService<T extends Record<string, any>> {\n    protected readonly $localHandlers: Set<ScriptEventHandler> = new Set();\n    protected readonly $internalHandlers: Set<ScriptEventHandler> = new Set();\n    protected readonly $remoteHandlers: Set<ScriptEventHandler> = new Set();\n    protected $internalEventNames = new Set<string>();\n    constructor(protected $eventEmmiter: EventEmmiter) {}\n\n    public on<E extends keyof T>(eventName: E, callback: (body: Parameters<T[E]>[0]) => ReturnType<T[E]>): ScriptEventHandler;\n    public on<E extends string>(eventName: Exclude<E, keyof T>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;\n    public on<E extends string>(eventName: Exclude<E, keyof T>, callback: (body: unknown) => void | Promise<void>) {\n        const wrapper = (...args: any[]) => callback(args[0]);\n        const eventHandler = <ScriptEventHandler>this.$eventEmmiter.on(eventName, wrapper);\n        this.$localHandlers.add(eventHandler);\n        return eventHandler;\n    }\n    public once<E extends keyof T>(eventName: E, callback: (body: Parameters<T[E]>[0]) => ReturnType<T[E]>): ScriptEventHandler;\n    public once<E extends string>(eventName: Exclude<E, keyof T>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;\n    public once<E extends string>(eventName: Exclude<E, keyof T>, callback: (body: unknown) => void | Promise<void>) {\n        const wrapper = (...args: any[]) => callback(args[0]);\n        const eventHandler = <ScriptEventHandler>this.$eventEmmiter.once(eventName, wrapper);\n        this.$localHandlers.add(eventHandler);\n        return eventHandler;\n    }\n\n    public emit<E extends keyof T>(eventName: E, body?: T[E]): void;\n    public emit<E extends string>(eventName: E, body?: unknown): void;\n    public emit<E extends string>(eventName: E, body?: unknown) {\n        this.$eventEmmiter.emit(eventName, body);\n    }\n\n    protected $onInternal(eventName: string, handler: (body: unknown) => void | Promise<void>) {\n        if (!this.$internalEventNames.has(eventName)) {\n            throw new Error(ErrorMessage.InvalidInternalEventName);\n        }\n        const eventHandler = <EventHandler>this.$eventEmmiter.on(eventName, handler);\n        this.$internalHandlers.add(eventHandler);\n        return eventHandler;\n    }\n\n    protected $onceInternal(eventName: string, handler: (body: unknown) => void | Promise<void>) {\n        if (!this.$internalEventNames.has(eventName)) {\n            throw new Error(ErrorMessage.InvalidInternalEventName);\n        }\n        const eventHandler = <ScriptEventHandler>this.$eventEmmiter.once(eventName, handler);\n        this.$internalHandlers.add(eventHandler);\n        return eventHandler;\n    }\n}\n", "import { inject, injectable } from 'inversify';\nimport type { RPCResult, RPCCallOptions, ScriptRPCHandler, LoggerService } from '../../interfaces';\nimport { RPC_RESULT_HANDLER_NOT_FOUND, RPC_RESULT_TIMEOUT, RPC_RESULT_UNKNOWN } from '../../app/constants';\nimport { ErrorMessage, RPCResultStatus } from '../../enums';\nimport { MangoError } from '../../errors';\nimport { LOGGER_SERVICE } from '../../constants';\n\n@injectable()\nexport class BaseRPCService<T extends Record<string, any>> {\n    @inject(LOGGER_SERVICE) protected readonly $loggerService: LoggerService;\n    protected readonly $TIMEOUT = 2000;\n    private readonly $localHandlers = new Map<string, ScriptRPCHandler>();\n\n    public async call<E extends keyof T>(\n        rpcName: E,\n        body?: Parameters<T[E]>[0],\n        options?: RPCCallOptions,\n    ): Promise<RPCResult<ReturnType<T[E]>>>;\n    public async call<E extends string>(rpcName: E, body?: unknown, options?: RPCCallOptions): Promise<RPCResult<unknown>>;\n    public async call<E extends string>(rpcName: E, body?: unknown, options: RPCCallOptions = { timeout: this.$TIMEOUT }) {\n        return new Promise(async (resolve) => {\n            const handler = this.$localHandlers.get(<string>rpcName)?.handler;\n            if (!handler) {\n                return resolve(RPC_RESULT_HANDLER_NOT_FOUND);\n            }\n\n            const timeoutId = setTimeout(() => {\n                resolve(RPC_RESULT_TIMEOUT);\n            }, options.timeout ?? this.$TIMEOUT);\n\n            try {\n                const result = await handler(body);\n                clearTimeout(timeoutId);\n                resolve({ success: true, status: RPCResultStatus.Success, body: result });\n            } catch (error) {\n                clearTimeout(timeoutId);\n\n                if (error instanceof MangoError) {\n                    return resolve({\n                        success: false,\n                        status: error.status,\n                        error: { message: error.message, details: error.details },\n                    });\n                }\n\n                resolve(RPC_RESULT_UNKNOWN);\n            }\n        });\n    }\n    public onRequest<E extends keyof T>(rpcName: E, handler: (body: Parameters<T[E]>[0]) => ReturnType<T[E]>): ScriptRPCHandler;\n    public onRequest<E extends string>(rpcName: E, handler: (body: unknown) => unknown | Promise<unknown>): ScriptRPCHandler;\n    public onRequest<E extends string>(rpcName: E, handler: (body: unknown) => unknown | Promise<unknown>) {\n        if (this.$localHandlers.has(rpcName)) {\n            this.$loggerService.error('An error occurred while trying to register RPC.');\n            throw new Error(ErrorMessage.RPCHandlerAlreadyExists);\n        }\n\n        const rpcHandler: ScriptRPCHandler = {\n            destroy: () => {\n                // @ts-ignore\n                rpcHandler.valid = false;\n                this.$localHandlers.delete(rpcName);\n            },\n            rpcName: rpcName,\n            handler,\n            valid: true,\n        };\n\n        this.$localHandlers.set(rpcName, rpcHandler);\n\n        return rpcHandler;\n    }\n}\n"],
  "mappings": "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",
  "names": ["injectable", "BaseEventService", "$localHandlers", "Set", "$internalHandlers", "$remoteHandlers", "$internalEventNames", "$eventEmmiter", "on", "eventName", "callback", "wrapper", "args", "eventHandler", "add", "once", "emit", "body", "$onInternal", "handler", "has", "Error", "ErrorMessage", "InvalidInternalEventName", "$onceInternal", "inject", "injectable", "BaseRPCService", "$loggerService", "$TIMEOUT", "$localHandlers", "Map", "call", "rpcName", "body", "options", "timeout", "Promise", "resolve", "handler", "get", "RPC_RESULT_HANDLER_NOT_FOUND", "timeoutId", "setTimeout", "RPC_RESULT_TIMEOUT", "result", "clearTimeout", "success", "status", "RPCResultStatus", "Success", "error", "MangoError", "message", "details", "RPC_RESULT_UNKNOWN", "onRequest", "has", "Error", "ErrorMessage", "RPCHandlerAlreadyExists", "rpcHandler", "destroy", "valid", "delete", "set"]
}
