@open-core/framework 0.1.0-alpha.1

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.
Files changed (281) hide show
  1. package/LICENSE +373 -0
  2. package/README.md +360 -0
  3. package/dist/client/client-bootstrap.d.ts +1 -0
  4. package/dist/client/client-bootstrap.js +50 -0
  5. package/dist/client/client-container.d.ts +2 -0
  6. package/dist/client/client-container.js +6 -0
  7. package/dist/client/client-core.d.ts +1 -0
  8. package/dist/client/client-core.js +7 -0
  9. package/dist/client/controllers/spawner.controller.d.ts +12 -0
  10. package/dist/client/controllers/spawner.controller.js +51 -0
  11. package/dist/client/decorators/controller.d.ts +3 -0
  12. package/dist/client/decorators/controller.js +14 -0
  13. package/dist/client/decorators/export.d.ts +7 -0
  14. package/dist/client/decorators/export.js +15 -0
  15. package/dist/client/decorators/gameEvent.d.ts +47 -0
  16. package/dist/client/decorators/gameEvent.js +54 -0
  17. package/dist/client/decorators/index.d.ts +10 -0
  18. package/dist/client/decorators/index.js +26 -0
  19. package/dist/client/decorators/interval.d.ts +7 -0
  20. package/dist/client/decorators/interval.js +15 -0
  21. package/dist/client/decorators/key.d.ts +2 -0
  22. package/dist/client/decorators/key.js +10 -0
  23. package/dist/client/decorators/localEvent.d.ts +7 -0
  24. package/dist/client/decorators/localEvent.js +15 -0
  25. package/dist/client/decorators/nui.d.ts +1 -0
  26. package/dist/client/decorators/nui.js +9 -0
  27. package/dist/client/decorators/onNet.d.ts +1 -0
  28. package/dist/client/decorators/onNet.js +9 -0
  29. package/dist/client/decorators/resourceLifecycle.d.ts +11 -0
  30. package/dist/client/decorators/resourceLifecycle.js +24 -0
  31. package/dist/client/decorators/tick.d.ts +1 -0
  32. package/dist/client/decorators/tick.js +9 -0
  33. package/dist/client/index.d.ts +7 -0
  34. package/dist/client/index.js +23 -0
  35. package/dist/client/interfaces/appearance.interface.d.ts +19 -0
  36. package/dist/client/interfaces/appearance.interface.js +2 -0
  37. package/dist/client/player/player.d.ts +262 -0
  38. package/dist/client/player/player.js +480 -0
  39. package/dist/client/player/player.loader.d.ts +1 -0
  40. package/dist/client/player/player.loader.js +22 -0
  41. package/dist/client/services/appearance.service.d.ts +6 -0
  42. package/dist/client/services/appearance.service.js +89 -0
  43. package/dist/client/services/blip.service.d.ts +112 -0
  44. package/dist/client/services/blip.service.js +215 -0
  45. package/dist/client/services/index.d.ts +9 -0
  46. package/dist/client/services/index.js +25 -0
  47. package/dist/client/services/marker.service.d.ts +94 -0
  48. package/dist/client/services/marker.service.js +153 -0
  49. package/dist/client/services/notification.service.d.ts +76 -0
  50. package/dist/client/services/notification.service.js +111 -0
  51. package/dist/client/services/ped.service.d.ts +182 -0
  52. package/dist/client/services/ped.service.js +302 -0
  53. package/dist/client/services/progress.service.d.ts +82 -0
  54. package/dist/client/services/progress.service.js +210 -0
  55. package/dist/client/services/spawn.service.d.ts +73 -0
  56. package/dist/client/services/spawn.service.js +261 -0
  57. package/dist/client/services/streaming.service.d.ts +165 -0
  58. package/dist/client/services/streaming.service.js +341 -0
  59. package/dist/client/services/textui.service.d.ts +82 -0
  60. package/dist/client/services/textui.service.js +156 -0
  61. package/dist/client/services/vehicle.service.d.ts +168 -0
  62. package/dist/client/services/vehicle.service.js +296 -0
  63. package/dist/client/system/metadata-client.keys.d.ts +13 -0
  64. package/dist/client/system/metadata-client.keys.js +16 -0
  65. package/dist/client/system/processors/export.processor.d.ts +7 -0
  66. package/dist/client/system/processors/export.processor.js +39 -0
  67. package/dist/client/system/processors/gameEvent.processor.d.ts +10 -0
  68. package/dist/client/system/processors/gameEvent.processor.js +58 -0
  69. package/dist/client/system/processors/interval.processor.d.ts +7 -0
  70. package/dist/client/system/processors/interval.processor.js +43 -0
  71. package/dist/client/system/processors/key.processor.d.ts +8 -0
  72. package/dist/client/system/processors/key.processor.js +27 -0
  73. package/dist/client/system/processors/localEvent.processor.d.ts +7 -0
  74. package/dist/client/system/processors/localEvent.processor.js +38 -0
  75. package/dist/client/system/processors/netEvent.processor.d.ts +7 -0
  76. package/dist/client/system/processors/netEvent.processor.js +38 -0
  77. package/dist/client/system/processors/nui.processor.d.ts +7 -0
  78. package/dist/client/system/processors/nui.processor.js +40 -0
  79. package/dist/client/system/processors/resourceLifecycle.processor.d.ts +9 -0
  80. package/dist/client/system/processors/resourceLifecycle.processor.js +69 -0
  81. package/dist/client/system/processors/tick.processor.d.ts +5 -0
  82. package/dist/client/system/processors/tick.processor.js +37 -0
  83. package/dist/client/system/processors.register.d.ts +1 -0
  84. package/dist/client/system/processors.register.js +27 -0
  85. package/dist/client/types/game-events.d.ts +126 -0
  86. package/dist/client/types/game-events.js +83 -0
  87. package/dist/client/types/index.d.ts +1 -0
  88. package/dist/client/types/index.js +17 -0
  89. package/dist/client/ui-bridge.d.ts +116 -0
  90. package/dist/client/ui-bridge.js +201 -0
  91. package/dist/index.d.ts +5 -0
  92. package/dist/index.js +41 -0
  93. package/dist/server/bootstrap.d.ts +16 -0
  94. package/dist/server/bootstrap.js +57 -0
  95. package/dist/server/bus/core-event-bus.d.ts +6 -0
  96. package/dist/server/bus/core-event-bus.js +31 -0
  97. package/dist/server/configs/api.config.d.ts +71 -0
  98. package/dist/server/configs/api.config.js +81 -0
  99. package/dist/server/configs/config.base.d.ts +63 -0
  100. package/dist/server/configs/config.base.js +64 -0
  101. package/dist/server/configs/index.d.ts +2 -0
  102. package/dist/server/configs/index.js +18 -0
  103. package/dist/server/container.d.ts +2 -0
  104. package/dist/server/container.js +6 -0
  105. package/dist/server/controllers/chat.controller.d.ts +10 -0
  106. package/dist/server/controllers/chat.controller.js +50 -0
  107. package/dist/server/controllers/command.controller.d.ts +7 -0
  108. package/dist/server/controllers/command.controller.js +47 -0
  109. package/dist/server/controllers/session.controller.d.ts +9 -0
  110. package/dist/server/controllers/session.controller.js +70 -0
  111. package/dist/server/core.d.ts +1 -0
  112. package/dist/server/core.js +7 -0
  113. package/dist/server/database/adapters/oxmysql.adapter.d.ts +89 -0
  114. package/dist/server/database/adapters/oxmysql.adapter.js +149 -0
  115. package/dist/server/database/database.contract.d.ts +128 -0
  116. package/dist/server/database/database.contract.js +29 -0
  117. package/dist/server/database/database.service.d.ts +216 -0
  118. package/dist/server/database/database.service.js +301 -0
  119. package/dist/server/database/index.d.ts +53 -0
  120. package/dist/server/database/index.js +70 -0
  121. package/dist/server/database/types.d.ts +67 -0
  122. package/dist/server/database/types.js +7 -0
  123. package/dist/server/database.d.ts +7 -0
  124. package/dist/server/database.js +23 -0
  125. package/dist/server/decorators/bind.d.ts +2 -0
  126. package/dist/server/decorators/bind.js +15 -0
  127. package/dist/server/decorators/command.d.ts +49 -0
  128. package/dist/server/decorators/command.js +23 -0
  129. package/dist/server/decorators/controller.d.ts +25 -0
  130. package/dist/server/decorators/controller.js +36 -0
  131. package/dist/server/decorators/export.d.ts +39 -0
  132. package/dist/server/decorators/export.js +47 -0
  133. package/dist/server/decorators/guard.d.ts +56 -0
  134. package/dist/server/decorators/guard.js +82 -0
  135. package/dist/server/decorators/index.d.ts +10 -0
  136. package/dist/server/decorators/index.js +29 -0
  137. package/dist/server/decorators/onFiveMEvent.d.ts +6 -0
  138. package/dist/server/decorators/onFiveMEvent.js +14 -0
  139. package/dist/server/decorators/onFrameworkEvent.d.ts +22 -0
  140. package/dist/server/decorators/onFrameworkEvent.js +29 -0
  141. package/dist/server/decorators/onNet.d.ts +58 -0
  142. package/dist/server/decorators/onNet.js +57 -0
  143. package/dist/server/decorators/onTick.d.ts +32 -0
  144. package/dist/server/decorators/onTick.js +40 -0
  145. package/dist/server/decorators/public.d.ts +27 -0
  146. package/dist/server/decorators/public.js +36 -0
  147. package/dist/server/decorators/requiresState.d.ts +56 -0
  148. package/dist/server/decorators/requiresState.js +63 -0
  149. package/dist/server/decorators/throttle.d.ts +48 -0
  150. package/dist/server/decorators/throttle.js +63 -0
  151. package/dist/server/decorators/utils.d.ts +57 -0
  152. package/dist/server/decorators/utils.js +63 -0
  153. package/dist/server/entities/index.d.ts +1 -0
  154. package/dist/server/entities/index.js +17 -0
  155. package/dist/server/entities/player.d.ts +157 -0
  156. package/dist/server/entities/player.js +217 -0
  157. package/dist/server/error-handler.d.ts +2 -0
  158. package/dist/server/error-handler.js +43 -0
  159. package/dist/server/helpers/resolve-method.d.ts +5 -0
  160. package/dist/server/helpers/resolve-method.js +18 -0
  161. package/dist/server/index.d.ts +10 -0
  162. package/dist/server/index.js +31 -0
  163. package/dist/server/loaders/exports.loader.d.ts +0 -0
  164. package/dist/server/loaders/exports.loader.js +23 -0
  165. package/dist/server/loaders/playerSession.loader.d.ts +1 -0
  166. package/dist/server/loaders/playerSession.loader.js +51 -0
  167. package/dist/server/services/access-control.service.d.ts +56 -0
  168. package/dist/server/services/access-control.service.js +99 -0
  169. package/dist/server/services/chat.service.d.ts +7 -0
  170. package/dist/server/services/chat.service.js +31 -0
  171. package/dist/server/services/command.service.d.ts +15 -0
  172. package/dist/server/services/command.service.js +77 -0
  173. package/dist/server/services/config.service.d.ts +75 -0
  174. package/dist/server/services/config.service.js +116 -0
  175. package/dist/server/services/default/default-security.handler.d.ts +6 -0
  176. package/dist/server/services/default/default-security.handler.js +26 -0
  177. package/dist/server/services/http/http.service.d.ts +50 -0
  178. package/dist/server/services/http/http.service.js +126 -0
  179. package/dist/server/services/index.d.ts +10 -0
  180. package/dist/server/services/index.js +26 -0
  181. package/dist/server/services/parallel/index.d.ts +49 -0
  182. package/dist/server/services/parallel/index.js +67 -0
  183. package/dist/server/services/parallel/parallel-compute.service.d.ts +132 -0
  184. package/dist/server/services/parallel/parallel-compute.service.js +449 -0
  185. package/dist/server/services/parallel/types.d.ts +188 -0
  186. package/dist/server/services/parallel/types.js +7 -0
  187. package/dist/server/services/parallel/worker-pool.d.ts +83 -0
  188. package/dist/server/services/parallel/worker-pool.js +350 -0
  189. package/dist/server/services/parallel/worker.d.ts +19 -0
  190. package/dist/server/services/parallel/worker.js +49 -0
  191. package/dist/server/services/persistence.service.d.ts +59 -0
  192. package/dist/server/services/persistence.service.js +166 -0
  193. package/dist/server/services/player.service.d.ts +96 -0
  194. package/dist/server/services/player.service.js +132 -0
  195. package/dist/server/services/rate-limiter.service.d.ts +5 -0
  196. package/dist/server/services/rate-limiter.service.js +39 -0
  197. package/dist/server/services/registers.d.ts +1 -0
  198. package/dist/server/services/registers.js +18 -0
  199. package/dist/server/setup.d.ts +9 -0
  200. package/dist/server/setup.js +28 -0
  201. package/dist/server/system/metadata-server.keys.d.ts +10 -0
  202. package/dist/server/system/metadata-server.keys.js +13 -0
  203. package/dist/server/system/processors/command.processor.d.ts +9 -0
  204. package/dist/server/system/processors/command.processor.js +30 -0
  205. package/dist/server/system/processors/coreEvent.processor.d.ts +7 -0
  206. package/dist/server/system/processors/coreEvent.processor.js +41 -0
  207. package/dist/server/system/processors/export.processor.d.ts +7 -0
  208. package/dist/server/system/processors/export.processor.js +30 -0
  209. package/dist/server/system/processors/fivemEvent.processor.d.ts +7 -0
  210. package/dist/server/system/processors/fivemEvent.processor.js +40 -0
  211. package/dist/server/system/processors/netEvent.processor.d.ts +11 -0
  212. package/dist/server/system/processors/netEvent.processor.js +103 -0
  213. package/dist/server/system/processors/tick.processor.d.ts +5 -0
  214. package/dist/server/system/processors/tick.processor.js +36 -0
  215. package/dist/server/system/processors.register.d.ts +1 -0
  216. package/dist/server/system/processors.register.js +23 -0
  217. package/dist/server/system/schema-generator.d.ts +2 -0
  218. package/dist/server/system/schema-generator.js +34 -0
  219. package/dist/server/templates/admin/admin.controller-template.d.ts +12 -0
  220. package/dist/server/templates/admin/admin.controller-template.js +2 -0
  221. package/dist/server/templates/auth/auth-provider.contract.d.ts +58 -0
  222. package/dist/server/templates/auth/auth-provider.contract.js +23 -0
  223. package/dist/server/templates/index.d.ts +8 -0
  224. package/dist/server/templates/index.js +21 -0
  225. package/dist/server/templates/persistence/index.d.ts +30 -0
  226. package/dist/server/templates/persistence/index.js +34 -0
  227. package/dist/server/templates/persistence/player-persistence.contract.d.ts +86 -0
  228. package/dist/server/templates/persistence/player-persistence.contract.js +52 -0
  229. package/dist/server/templates/repository/index.d.ts +57 -0
  230. package/dist/server/templates/repository/index.js +61 -0
  231. package/dist/server/templates/repository/repository.contract.d.ts +224 -0
  232. package/dist/server/templates/repository/repository.contract.js +342 -0
  233. package/dist/server/templates/repository/repository.types.d.ts +51 -0
  234. package/dist/server/templates/repository/repository.types.js +7 -0
  235. package/dist/server/templates/security/permission.types.d.ts +32 -0
  236. package/dist/server/templates/security/permission.types.js +2 -0
  237. package/dist/server/templates/security/principal-provider.contract.d.ts +43 -0
  238. package/dist/server/templates/security/principal-provider.contract.js +19 -0
  239. package/dist/server/templates/security/security-handler.contract.d.ts +5 -0
  240. package/dist/server/templates/security/security-handler.contract.js +6 -0
  241. package/dist/server/types/core-events.d.ts +22 -0
  242. package/dist/server/types/core-events.js +2 -0
  243. package/dist/server/types/security.types.d.ts +7 -0
  244. package/dist/server/types/security.types.js +2 -0
  245. package/dist/shared/index.d.ts +1 -0
  246. package/dist/shared/index.js +17 -0
  247. package/dist/shared/logger/core-logger.d.ts +35 -0
  248. package/dist/shared/logger/core-logger.js +52 -0
  249. package/dist/shared/logger/index.d.ts +11 -0
  250. package/dist/shared/logger/index.js +26 -0
  251. package/dist/shared/logger/logger.config.d.ts +47 -0
  252. package/dist/shared/logger/logger.config.js +33 -0
  253. package/dist/shared/logger/logger.service.d.ts +161 -0
  254. package/dist/shared/logger/logger.service.js +279 -0
  255. package/dist/shared/logger/logger.types.d.ts +85 -0
  256. package/dist/shared/logger/logger.types.js +74 -0
  257. package/dist/shared/logger/transports/buffered.transport.d.ts +88 -0
  258. package/dist/shared/logger/transports/buffered.transport.js +174 -0
  259. package/dist/shared/logger/transports/console.transport.d.ts +37 -0
  260. package/dist/shared/logger/transports/console.transport.js +134 -0
  261. package/dist/shared/logger/transports/index.d.ts +3 -0
  262. package/dist/shared/logger/transports/index.js +19 -0
  263. package/dist/shared/logger/transports/transport.interface.d.ts +40 -0
  264. package/dist/shared/logger/transports/transport.interface.js +2 -0
  265. package/dist/system/class-constructor.d.ts +1 -0
  266. package/dist/system/class-constructor.js +2 -0
  267. package/dist/system/decorator-processor.d.ts +4 -0
  268. package/dist/system/decorator-processor.js +2 -0
  269. package/dist/system/metadata.scanner.d.ts +7 -0
  270. package/dist/system/metadata.scanner.js +45 -0
  271. package/dist/utils/errors.d.ts +14 -0
  272. package/dist/utils/errors.js +25 -0
  273. package/dist/utils/index.d.ts +4 -0
  274. package/dist/utils/index.js +20 -0
  275. package/dist/utils/result.d.ts +12 -0
  276. package/dist/utils/result.js +10 -0
  277. package/dist/utils/rgb.d.ts +5 -0
  278. package/dist/utils/rgb.js +2 -0
  279. package/dist/utils/vector3.d.ts +13 -0
  280. package/dist/utils/vector3.js +27 -0
  281. package/package.json +98 -0
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.handleCommandError = handleCommandError;
4
+ const utils_1 = require("../utils");
5
+ const logger_1 = require("../shared/logger");
6
+ function normalizeError(error, origin) {
7
+ if ((0, utils_1.isAppError)(error)) {
8
+ return error;
9
+ }
10
+ if (error instanceof Error) {
11
+ return new utils_1.AppError('UNKNOWN', error.message, origin, { stack: error.stack });
12
+ }
13
+ return new utils_1.AppError('UNKNOWN', String(error), origin, { raw: error });
14
+ }
15
+ function handleCommandError(error, meta, playerId) {
16
+ const appError = normalizeError(error, 'server');
17
+ logger_1.loggers.command.error(`Command execution failed: /${meta.command}`, {
18
+ command: meta.command,
19
+ handler: meta.methodName,
20
+ playerId,
21
+ code: appError.code,
22
+ origin: appError.origin,
23
+ errorMessage: appError.message,
24
+ details: appError.details,
25
+ });
26
+ if (playerId !== null) {
27
+ switch (appError.code) {
28
+ case 'VALIDATION_ERROR':
29
+ case 'INSUFFICIENT_FUNDS':
30
+ case 'PERMISSION_DENIED':
31
+ case 'UNAUTHORIZED':
32
+ emitNet('chat:addMessage', playerId, {
33
+ args: ['^1Error', appError.message],
34
+ });
35
+ break;
36
+ default:
37
+ emitNet('chat:addMessage', playerId, {
38
+ args: ['^1Error', 'Ha ocurrido un error interno.'],
39
+ });
40
+ break;
41
+ }
42
+ }
43
+ }
@@ -0,0 +1,5 @@
1
+ export declare function resolveMethod(instance: Record<string, any>, methodName: string, errorMessage: string): {
2
+ handler: Function;
3
+ handlerName: string;
4
+ proto: any;
5
+ } | undefined;
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolveMethod = resolveMethod;
4
+ const logger_1 = require("../../shared/logger");
5
+ function resolveMethod(instance, methodName, errorMessage) {
6
+ const proto = Object.getPrototypeOf(instance);
7
+ const method = instance[methodName];
8
+ if (typeof method !== 'function') {
9
+ logger_1.loggers.scanner.error(errorMessage, {
10
+ className: instance.constructor.name,
11
+ methodName,
12
+ });
13
+ return;
14
+ }
15
+ const handler = method.bind(instance);
16
+ const handlerName = `${instance.constructor.name}.${methodName}`;
17
+ return { handler, handlerName, proto };
18
+ }
@@ -0,0 +1,10 @@
1
+ export * from './core';
2
+ export * from './decorators';
3
+ export * from './templates';
4
+ export * from './services';
5
+ export * from './entities';
6
+ export * from './configs';
7
+ export * from './setup';
8
+ export type * from './types/core-events';
9
+ import './controllers/command.controller';
10
+ import './controllers/chat.controller';
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ // Framework modules
18
+ __exportStar(require("./core"), exports);
19
+ __exportStar(require("./decorators"), exports);
20
+ __exportStar(require("./templates"), exports);
21
+ __exportStar(require("./services"), exports);
22
+ // Entities
23
+ __exportStar(require("./entities"), exports);
24
+ // Configs
25
+ __exportStar(require("./configs"), exports);
26
+ __exportStar(require("./setup"), exports);
27
+ // Controllers
28
+ require("./controllers/command.controller");
29
+ require("./controllers/chat.controller");
30
+ const container_1 = require("./container");
31
+ globalThis.oc_container = container_1.di;
File without changes
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ // import { di } from '../container'
3
+ // import { CommandService } from '../services/command.service'
4
+ // import { handleCommandError } from '../error-handler'
5
+ // export const exportsLoader = () => {
6
+ // const commandService = di.resolve(CommandService)
7
+ // exports('core:ExecuteCommand', async (src: number, name: string, args: string[], raw: string) => {
8
+ // try {
9
+ // await commandService.execute(Number(src), name, args, raw)
10
+ // return { ok: true }
11
+ // } catch (error) {
12
+ // handleCommandError(
13
+ // error,
14
+ // { name, methodName: 'ExportExecution', target: Object },
15
+ // Number(src),
16
+ // )
17
+ // return { ok: false }
18
+ // }
19
+ // })
20
+ // exports('core:GetCommands', () => {
21
+ // return commandService.getDefinitions()
22
+ // })
23
+ // }
@@ -0,0 +1 @@
1
+ export declare const playerSessionLoader: () => void;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.playerSessionLoader = void 0;
4
+ const tsyringe_1 = require("tsyringe");
5
+ const player_service_1 = require("../services/player.service");
6
+ const persistence_service_1 = require("../services/persistence.service");
7
+ const core_event_bus_1 = require("../bus/core-event-bus");
8
+ const logger_1 = require("../../shared/logger");
9
+ const playerSessionLoader = () => {
10
+ const playerManager = tsyringe_1.container.resolve(player_service_1.PlayerService);
11
+ const persistenceService = tsyringe_1.container.resolve(persistence_service_1.PlayerPersistenceService);
12
+ // Initialize persistence service (resolves provider if configured)
13
+ persistenceService.initialize();
14
+ on('playerJoining', async () => {
15
+ var _a;
16
+ const clientId = source;
17
+ const license = (_a = GetPlayerIdentifier(clientId.toString(), 0)) !== null && _a !== void 0 ? _a : undefined;
18
+ const player = playerManager.bind(clientId, { license });
19
+ logger_1.loggers.session.info(`Player session created`, {
20
+ clientId,
21
+ license: license !== null && license !== void 0 ? license : 'none',
22
+ });
23
+ // Load persisted data for the player
24
+ await persistenceService.handleSessionLoad(player);
25
+ (0, core_event_bus_1.emitCoreEvent)('core:playerSessionCreated', {
26
+ clientId,
27
+ license,
28
+ });
29
+ setImmediate(() => {
30
+ const currentPlayer = playerManager.getByClient(clientId);
31
+ if (!currentPlayer)
32
+ return;
33
+ (0, core_event_bus_1.emitCoreEvent)('core:playerFullyConnected', {
34
+ clientId,
35
+ license,
36
+ });
37
+ });
38
+ });
39
+ on('playerDropped', async (source) => {
40
+ const clientId = Number(source);
41
+ const player = playerManager.getByClient(clientId);
42
+ // Save player data before destroying session
43
+ if (player) {
44
+ await persistenceService.handleSessionSave(player);
45
+ }
46
+ playerManager.unbindByClient(clientId);
47
+ (0, core_event_bus_1.emitCoreEvent)('core:playerSessionDestroyed', { clientId });
48
+ logger_1.loggers.session.info(`Player session destroyed`, { clientId });
49
+ });
50
+ };
51
+ exports.playerSessionLoader = playerSessionLoader;
@@ -0,0 +1,56 @@
1
+ import { Server } from '../..';
2
+ import { PrincipalProviderContract } from '../templates';
3
+ /**
4
+ * **Core Security Service**
5
+ *
6
+ * This service acts as the central enforcement point for the Access Control system.
7
+ * It uses the configured `PrincipalProvider` to query roles and validates them against requirements.
8
+ *
9
+ * It is primarily used internally by the `@Guard` decorator, but can be injected
10
+ * into services to perform manual checks.
11
+ */
12
+ export declare class AccessControlService {
13
+ private readonly principalProvider;
14
+ constructor(principalProvider: PrincipalProviderContract);
15
+ /**
16
+ * Verifies if a player meets a minimum numeric rank requirement.
17
+ *
18
+ * @param player - The target player.
19
+ * @param minRank - The minimum numeric value required (Inclusive).
20
+ *
21
+ * @returns `true` if `Principal.rank >= minRank`.
22
+ *
23
+ * @throws {AppError} code `UNAUTHORIZED` if the player has no Principal (not logged in).
24
+ * @throws {AppError} code `NO_RANK_IN_PRINCIPAL` if the Principal exists but has no `rank` defined.
25
+ */
26
+ hasRank(player: Server.Player, minRank: number): Promise<boolean>;
27
+ /**
28
+ * Verifies if a player possesses a specific permission string.
29
+ *
30
+ * @remarks
31
+ * This method supports the **Wildcard ('*')** permission. If the principal has `'*'`
32
+ * in their permissions array, this method always returns `true`.
33
+ *
34
+ * @param player - The target player.
35
+ * @param permission - The specific permission key (e.g., `'admin.ban'`).
36
+ * @returns `true` if the player has the permission or the wildcard.
37
+ */
38
+ hasPermission(player: Server.Player, permission: string): Promise<boolean>;
39
+ /**
40
+ * **Strict Enforcement**
41
+ *
42
+ * Validates a set of requirements against a player. If any requirement fails,
43
+ * it throws an exception, halting the execution flow.
44
+ *
45
+ * Used primarily by the `@Guard` decorator logic.
46
+ *
47
+ * @param player - The server player to validate.
48
+ * @param requirements - An object containing rank and/or permission constraints.
49
+ *
50
+ * @throws {AppError} code `PERMISSION_DENIED` if validation fails.
51
+ */
52
+ enforce(player: Server.Player, requirements: {
53
+ minRank?: number;
54
+ permission?: string;
55
+ }): Promise<void>;
56
+ }
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.AccessControlService = void 0;
13
+ const tsyringe_1 = require("tsyringe");
14
+ const utils_1 = require("../../utils");
15
+ const templates_1 = require("../templates");
16
+ /**
17
+ * **Core Security Service**
18
+ *
19
+ * This service acts as the central enforcement point for the Access Control system.
20
+ * It uses the configured `PrincipalProvider` to query roles and validates them against requirements.
21
+ *
22
+ * It is primarily used internally by the `@Guard` decorator, but can be injected
23
+ * into services to perform manual checks.
24
+ */
25
+ let AccessControlService = class AccessControlService {
26
+ constructor(principalProvider) {
27
+ this.principalProvider = principalProvider;
28
+ }
29
+ /**
30
+ * Verifies if a player meets a minimum numeric rank requirement.
31
+ *
32
+ * @param player - The target player.
33
+ * @param minRank - The minimum numeric value required (Inclusive).
34
+ *
35
+ * @returns `true` if `Principal.rank >= minRank`.
36
+ *
37
+ * @throws {AppError} code `UNAUTHORIZED` if the player has no Principal (not logged in).
38
+ * @throws {AppError} code `NO_RANK_IN_PRINCIPAL` if the Principal exists but has no `rank` defined.
39
+ */
40
+ async hasRank(player, minRank) {
41
+ const principal = await this.principalProvider.getPrincipal(player);
42
+ if (!principal)
43
+ throw new utils_1.AppError('UNAUTHORIZED', 'No principal found', 'core');
44
+ if (principal.rank === undefined)
45
+ throw new utils_1.AppError('NO_RANK_IN_PRINCIPAL', "You're trying to compare a Principal rank, but there's no defined rank! ", 'core');
46
+ return principal.rank >= minRank;
47
+ }
48
+ /**
49
+ * Verifies if a player possesses a specific permission string.
50
+ *
51
+ * @remarks
52
+ * This method supports the **Wildcard ('*')** permission. If the principal has `'*'`
53
+ * in their permissions array, this method always returns `true`.
54
+ *
55
+ * @param player - The target player.
56
+ * @param permission - The specific permission key (e.g., `'admin.ban'`).
57
+ * @returns `true` if the player has the permission or the wildcard.
58
+ */
59
+ async hasPermission(player, permission) {
60
+ const principal = await this.principalProvider.getPrincipal(player);
61
+ if (!principal)
62
+ return false;
63
+ if (principal.permissions.includes('*'))
64
+ return true;
65
+ return principal.permissions.includes(permission);
66
+ }
67
+ /**
68
+ * **Strict Enforcement**
69
+ *
70
+ * Validates a set of requirements against a player. If any requirement fails,
71
+ * it throws an exception, halting the execution flow.
72
+ *
73
+ * Used primarily by the `@Guard` decorator logic.
74
+ *
75
+ * @param player - The server player to validate.
76
+ * @param requirements - An object containing rank and/or permission constraints.
77
+ *
78
+ * @throws {AppError} code `PERMISSION_DENIED` if validation fails.
79
+ */
80
+ async enforce(player, requirements) {
81
+ if (requirements.minRank !== undefined) {
82
+ const hasRank = await this.hasRank(player, requirements.minRank);
83
+ if (!hasRank) {
84
+ throw new utils_1.AppError('PERMISSION_DENIED', `Access Denied: Requires minimum rank level ${requirements.minRank}`, 'core');
85
+ }
86
+ }
87
+ if (requirements.permission) {
88
+ const hasPerm = await this.hasPermission(player, requirements.permission);
89
+ if (!hasPerm) {
90
+ throw new utils_1.AppError('PERMISSION_DENIED', `Access Denied: Missing required permission '${requirements.permission}'`, 'core');
91
+ }
92
+ }
93
+ }
94
+ };
95
+ exports.AccessControlService = AccessControlService;
96
+ exports.AccessControlService = AccessControlService = __decorate([
97
+ (0, tsyringe_1.injectable)(),
98
+ __metadata("design:paramtypes", [templates_1.PrincipalProviderContract])
99
+ ], AccessControlService);
@@ -0,0 +1,7 @@
1
+ import { Server } from '../..';
2
+ import { RGB } from '../../utils';
3
+ export declare class ChatService {
4
+ broadcast(message: string, author?: string, color?: RGB): void;
5
+ sendPrivate(player: Server.Player, message: string, author?: string, color?: RGB): void;
6
+ clearChat(player: Server.Player): void;
7
+ }
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.ChatService = void 0;
10
+ const tsyringe_1 = require("tsyringe");
11
+ let ChatService = class ChatService {
12
+ broadcast(message, author = 'SYSTEM', color = { r: 255, g: 255, b: 255 }) {
13
+ emitNet('core:chat:message', -1, {
14
+ args: [author, message],
15
+ color: color,
16
+ });
17
+ }
18
+ sendPrivate(player, message, author = 'Private', color = { r: 200, g: 200, b: 200 }) {
19
+ emitNet('core:chat:addMessage', player.clientID, {
20
+ args: [author, message],
21
+ color: color,
22
+ });
23
+ }
24
+ clearChat(player) {
25
+ emitNet('core:chat:clear', player.clientID);
26
+ }
27
+ };
28
+ exports.ChatService = ChatService;
29
+ exports.ChatService = ChatService = __decorate([
30
+ (0, tsyringe_1.injectable)()
31
+ ], ChatService);
@@ -0,0 +1,15 @@
1
+ import type { CommandMetadata } from '../decorators/command';
2
+ import { Server } from '../..';
3
+ import { SecurityHandlerContract } from '../templates/security/security-handler.contract';
4
+ export declare class CommandService {
5
+ private securityHandler;
6
+ constructor(securityHandler: SecurityHandlerContract);
7
+ private commands;
8
+ register(meta: CommandMetadata, handler: Function): void;
9
+ execute(player: Server.Player, commandName: string, args: string[], raw: string): Promise<void>;
10
+ getAllCommands(): {
11
+ command: string;
12
+ description: string;
13
+ usage: string;
14
+ }[];
15
+ }
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.CommandService = void 0;
16
+ const tsyringe_1 = require("tsyringe");
17
+ const utils_1 = require("../../utils");
18
+ const zod_1 = __importDefault(require("zod"));
19
+ const security_handler_contract_1 = require("../templates/security/security-handler.contract");
20
+ const logger_1 = require("../../shared/logger");
21
+ const schema_generator_1 = require("../system/schema-generator");
22
+ let CommandService = class CommandService {
23
+ constructor(securityHandler) {
24
+ this.securityHandler = securityHandler;
25
+ this.commands = new Map();
26
+ }
27
+ register(meta, handler) {
28
+ this.commands.set(meta.command.toLowerCase(), { meta, handler });
29
+ logger_1.loggers.command.debug(`Registered: /${meta.command}${meta.schema ? ' [Validated]' : ''}`);
30
+ }
31
+ async execute(player, commandName, args, raw) {
32
+ var _a;
33
+ const entry = this.commands.get(commandName.toLowerCase());
34
+ if (!entry) {
35
+ return;
36
+ }
37
+ const { meta, handler } = entry;
38
+ let validatedArgs = args;
39
+ // Use explicit schema or auto-generate from paramTypes
40
+ const schema = (_a = meta.schema) !== null && _a !== void 0 ? _a : (0, schema_generator_1.generateSchemaFromTypes)(meta.paramTypes);
41
+ if (schema) {
42
+ try {
43
+ validatedArgs = await schema.parseAsync(args);
44
+ }
45
+ catch (error) {
46
+ if (error instanceof zod_1.default.ZodError) {
47
+ throw new utils_1.AppError('VALIDATION_ERROR', `Incorrect usage: ${error.message}`, 'client', {
48
+ usage: meta.usage,
49
+ });
50
+ }
51
+ if (error instanceof utils_1.AppError) {
52
+ throw error;
53
+ }
54
+ if (error instanceof utils_1.SecurityError) {
55
+ this.securityHandler.handleViolation(player, error);
56
+ }
57
+ throw error;
58
+ }
59
+ }
60
+ await handler(player, validatedArgs, raw);
61
+ }
62
+ getAllCommands() {
63
+ return Array.from(this.commands.values()).map((c) => {
64
+ var _a, _b;
65
+ return ({
66
+ command: c.meta.command,
67
+ description: (_a = c.meta.description) !== null && _a !== void 0 ? _a : '',
68
+ usage: (_b = c.meta.usage) !== null && _b !== void 0 ? _b : '',
69
+ });
70
+ });
71
+ }
72
+ };
73
+ exports.CommandService = CommandService;
74
+ exports.CommandService = CommandService = __decorate([
75
+ (0, tsyringe_1.injectable)(),
76
+ __metadata("design:paramtypes", [security_handler_contract_1.SecurityHandlerContract])
77
+ ], CommandService);
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Generic configuration service for accessing FiveM Convars.
3
+ *
4
+ * Provides type-safe access to configuration values with automatic
5
+ * prefix handling and type conversion.
6
+ *
7
+ * All keys are automatically prefixed with `opencore_`.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * const config = di.resolve(ConfigService)
12
+ *
13
+ * // Get string value
14
+ * const apiUrl = config.get('api_url', 'http://localhost:3000')
15
+ *
16
+ * // Get number value
17
+ * const timeout = config.getNumber('timeout', 5000)
18
+ *
19
+ * // Get boolean value
20
+ * const debug = config.getBoolean('debug', false)
21
+ *
22
+ * // Get required value (throws if not set)
23
+ * const secretKey = config.getRequired('secret_key')
24
+ *
25
+ * // Get JSON value
26
+ * const settings = config.getJson('settings', { enabled: true })
27
+ * ```
28
+ *
29
+ * @scope Singleton
30
+ */
31
+ export declare class ConfigService {
32
+ private readonly PREFIX;
33
+ /**
34
+ * Gets a string configuration value.
35
+ *
36
+ * @param key - The configuration key (without prefix)
37
+ * @param defaultValue - Default value if not set
38
+ * @returns The configuration value or default
39
+ */
40
+ get(key: string, defaultValue: string): string;
41
+ /**
42
+ * Gets a numeric configuration value.
43
+ *
44
+ * @param key - The configuration key (without prefix)
45
+ * @param defaultValue - Default value if not set or invalid
46
+ * @returns The configuration value as number
47
+ */
48
+ getNumber(key: string, defaultValue: number): number;
49
+ /**
50
+ * Gets a boolean configuration value.
51
+ *
52
+ * Recognizes 'true', '1' as true, everything else as false.
53
+ *
54
+ * @param key - The configuration key (without prefix)
55
+ * @param defaultValue - Default value if not set
56
+ * @returns The configuration value as boolean
57
+ */
58
+ getBoolean(key: string, defaultValue: boolean): boolean;
59
+ /**
60
+ * Gets a required configuration value.
61
+ *
62
+ * @param key - The configuration key (without prefix)
63
+ * @returns The configuration value
64
+ * @throws Error if the value is not set
65
+ */
66
+ getRequired(key: string): string;
67
+ /**
68
+ * Gets a JSON configuration value.
69
+ *
70
+ * @param key - The configuration key (without prefix)
71
+ * @param defaultValue - Default value if not set or invalid JSON
72
+ * @returns The parsed JSON value or default
73
+ */
74
+ getJson<T>(key: string, defaultValue: T): T;
75
+ }