cyberia 3.2.5 → 3.2.9

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 (301) hide show
  1. package/.github/workflows/engine-cyberia.cd.yml +2 -2
  2. package/.github/workflows/release.cd.yml +1 -2
  3. package/CHANGELOG.md +351 -1
  4. package/CLI-HELP.md +40 -13
  5. package/Dockerfile +0 -4
  6. package/README.md +242 -497
  7. package/bin/build.js +19 -5
  8. package/bin/cyberia.js +1149 -240
  9. package/bin/deploy.js +570 -1
  10. package/bin/file.js +6 -0
  11. package/bin/index.js +1149 -240
  12. package/bin/vs.js +1 -1
  13. package/conf.js +67 -89
  14. package/deployment.yaml +4 -222
  15. package/hardhat/package-lock.json +32 -32
  16. package/hardhat/package.json +3 -3
  17. package/jsconfig.json +1 -1
  18. package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +2 -2
  19. package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +2 -2
  20. package/manifests/deployment/dd-cyberia-development/deployment.yaml +4 -222
  21. package/manifests/deployment/dd-cyberia-development/proxy.yaml +10 -118
  22. package/manifests/deployment/dd-default-development/deployment.yaml +2 -6
  23. package/manifests/deployment/dd-test-development/deployment.yaml +136 -66
  24. package/manifests/deployment/dd-test-development/proxy.yaml +41 -5
  25. package/package.json +23 -14
  26. package/proxy.yaml +10 -118
  27. package/scripts/k3s-node-setup.sh +2 -2
  28. package/scripts/nat-iptables.sh +103 -18
  29. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +18 -18
  30. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +7 -14
  31. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +76 -21
  32. package/src/api/core/core.controller.js +10 -10
  33. package/src/api/core/core.service.js +10 -10
  34. package/src/api/crypto/crypto.controller.js +8 -8
  35. package/src/api/crypto/crypto.service.js +8 -8
  36. package/src/api/cyberia-action/cyberia-action.controller.js +74 -0
  37. package/src/api/cyberia-action/cyberia-action.model.js +87 -0
  38. package/src/api/cyberia-action/cyberia-action.router.js +27 -0
  39. package/src/api/cyberia-action/cyberia-action.service.js +42 -0
  40. package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +13 -13
  41. package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +11 -11
  42. package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +2 -2
  43. package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +16 -16
  44. package/src/api/cyberia-entity/cyberia-entity.controller.js +10 -10
  45. package/src/api/cyberia-entity/cyberia-entity.service.js +10 -10
  46. package/src/api/cyberia-instance/cyberia-fallback-world.js +19 -209
  47. package/src/api/cyberia-instance/cyberia-instance.controller.js +14 -14
  48. package/src/api/cyberia-instance/cyberia-instance.model.js +3 -0
  49. package/src/api/cyberia-instance/cyberia-instance.service.js +22 -57
  50. package/src/api/cyberia-instance/cyberia-portal-connector.js +20 -246
  51. package/src/api/cyberia-instance/cyberia-world-generator.js +505 -0
  52. package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +10 -10
  53. package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +216 -55
  54. package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +4 -1
  55. package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +18 -14
  56. package/src/api/cyberia-map/cyberia-map.controller.js +10 -10
  57. package/src/api/cyberia-map/cyberia-map.service.js +10 -10
  58. package/src/api/cyberia-quest/cyberia-quest.controller.js +74 -0
  59. package/src/api/cyberia-quest/cyberia-quest.model.js +67 -0
  60. package/src/api/cyberia-quest/cyberia-quest.router.js +27 -0
  61. package/src/api/cyberia-quest/cyberia-quest.service.js +42 -0
  62. package/src/api/cyberia-quest-progress/cyberia-quest-progress.controller.js +74 -0
  63. package/src/api/cyberia-quest-progress/cyberia-quest-progress.model.js +49 -0
  64. package/src/api/cyberia-quest-progress/cyberia-quest-progress.router.js +27 -0
  65. package/src/api/cyberia-quest-progress/cyberia-quest-progress.service.js +42 -0
  66. package/src/api/default/default.controller.js +10 -10
  67. package/src/api/default/default.service.js +10 -10
  68. package/src/api/document/document.controller.js +12 -12
  69. package/src/api/document/document.model.js +10 -16
  70. package/src/api/file/file.controller.js +8 -8
  71. package/src/api/file/file.model.js +10 -10
  72. package/src/api/file/file.service.js +36 -36
  73. package/src/api/instance/instance.controller.js +10 -10
  74. package/src/api/instance/instance.model.js +4 -10
  75. package/src/api/instance/instance.service.js +10 -10
  76. package/src/api/ipfs/ipfs.controller.js +12 -12
  77. package/src/api/ipfs/ipfs.model.js +4 -13
  78. package/src/api/ipfs/ipfs.service.js +14 -28
  79. package/src/api/object-layer/object-layer.controller.js +12 -12
  80. package/src/api/object-layer/object-layer.model.js +4 -17
  81. package/src/api/object-layer/object-layer.service.js +12 -12
  82. package/src/api/object-layer-render-frames/object-layer-render-frames.controller.js +10 -10
  83. package/src/api/object-layer-render-frames/object-layer-render-frames.model.js +6 -16
  84. package/src/api/object-layer-render-frames/object-layer-render-frames.service.js +18 -14
  85. package/src/api/test/test.controller.js +8 -8
  86. package/src/api/test/test.service.js +8 -8
  87. package/src/api/user/guest.service.js +99 -0
  88. package/src/api/user/user.controller.js +6 -6
  89. package/src/api/user/user.model.js +8 -13
  90. package/src/api/user/user.service.js +3 -20
  91. package/src/cli/cluster.js +61 -14
  92. package/src/cli/db.js +47 -2
  93. package/src/cli/deploy.js +67 -35
  94. package/src/cli/fs.js +79 -8
  95. package/src/cli/image.js +43 -1
  96. package/src/cli/index.js +26 -1
  97. package/src/cli/release.js +57 -1
  98. package/src/cli/repository.js +69 -31
  99. package/src/cli/run.js +415 -36
  100. package/src/cli/ssh.js +1 -1
  101. package/src/cli/static.js +43 -115
  102. package/src/client/Cryptokoyn.index.js +18 -21
  103. package/src/client/CyberiaPortal.index.js +19 -23
  104. package/src/client/Default.index.js +21 -33
  105. package/src/client/Itemledger.index.js +20 -26
  106. package/src/client/Underpost.index.js +19 -23
  107. package/src/client/components/core/404.js +4 -4
  108. package/src/client/components/core/500.js +4 -4
  109. package/src/client/components/core/Account.js +73 -60
  110. package/src/client/components/core/AgGrid.js +23 -33
  111. package/src/client/components/core/Alert.js +12 -13
  112. package/src/client/components/core/AppStore.js +1 -1
  113. package/src/client/components/core/Auth.js +35 -37
  114. package/src/client/components/core/Badge.js +7 -13
  115. package/src/client/components/core/BtnIcon.js +15 -17
  116. package/src/client/components/core/CalendarCore.js +42 -63
  117. package/src/client/components/core/Chat.js +13 -15
  118. package/src/client/components/core/ClientEvents.js +87 -0
  119. package/src/client/components/core/ColorPaletteElement.js +309 -0
  120. package/src/client/components/core/Content.js +17 -14
  121. package/src/client/components/core/Css.js +15 -71
  122. package/src/client/components/core/CssCore.js +12 -16
  123. package/src/client/components/core/D3Chart.js +4 -4
  124. package/src/client/components/core/Docs.js +64 -91
  125. package/src/client/components/core/DropDown.js +69 -91
  126. package/src/client/components/core/EventBus.js +92 -0
  127. package/src/client/components/core/EventsUI.js +14 -17
  128. package/src/client/components/core/FileExplorer.js +96 -228
  129. package/src/client/components/core/FullScreen.js +47 -75
  130. package/src/client/components/core/Input.js +24 -69
  131. package/src/client/components/core/Keyboard.js +25 -18
  132. package/src/client/components/core/KeyboardAvoidance.js +145 -0
  133. package/src/client/components/core/LoadingAnimation.js +25 -31
  134. package/src/client/components/core/LogIn.js +41 -41
  135. package/src/client/components/core/LogOut.js +23 -14
  136. package/src/client/components/core/Modal.js +462 -178
  137. package/src/client/components/core/NotificationManager.js +14 -18
  138. package/src/client/components/core/Panel.js +54 -50
  139. package/src/client/components/core/PanelForm.js +25 -125
  140. package/src/client/components/core/Polyhedron.js +110 -214
  141. package/src/client/components/core/PublicProfile.js +39 -32
  142. package/src/client/components/core/Recover.js +48 -44
  143. package/src/client/components/core/Responsive.js +88 -32
  144. package/src/client/components/core/RichText.js +9 -18
  145. package/src/client/components/core/Router.js +24 -3
  146. package/src/client/components/core/SearchBox.js +37 -37
  147. package/src/client/components/core/SignUp.js +39 -30
  148. package/src/client/components/core/SocketIo.js +31 -2
  149. package/src/client/components/core/SocketIoHandler.js +6 -6
  150. package/src/client/components/core/ToggleSwitch.js +8 -20
  151. package/src/client/components/core/ToolTip.js +5 -17
  152. package/src/client/components/core/Translate.js +56 -59
  153. package/src/client/components/core/Validator.js +26 -16
  154. package/src/client/components/core/Wallet.js +15 -26
  155. package/src/client/components/core/Worker.js +163 -27
  156. package/src/client/components/core/windowGetDimensions.js +7 -7
  157. package/src/client/components/cryptokoyn/{MenuCryptokoyn.js → AppShellCryptokoyn.js} +57 -57
  158. package/src/client/components/cryptokoyn/CssCryptokoyn.js +15 -15
  159. package/src/client/components/cryptokoyn/LogInCryptokoyn.js +6 -4
  160. package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +6 -4
  161. package/src/client/components/cryptokoyn/RouterCryptokoyn.js +37 -0
  162. package/src/client/components/cryptokoyn/SettingsCryptokoyn.js +4 -4
  163. package/src/client/components/cryptokoyn/SignUpCryptokoyn.js +6 -4
  164. package/src/client/components/cyberia/InstanceEngineCyberia.js +141 -60
  165. package/src/client/components/cyberia/MapEngineCyberia.js +691 -214
  166. package/src/client/components/cyberia/ObjectLayerEngine.js +19 -0
  167. package/src/client/components/cyberia/ObjectLayerEngineModal.js +1204 -94
  168. package/src/client/components/cyberia/ObjectLayerEngineViewer.js +196 -298
  169. package/src/client/components/cyberia-portal/{MenuCyberiaPortal.js → AppShellCyberiaPortal.js} +102 -102
  170. package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +305 -61
  171. package/src/client/components/cyberia-portal/CssCyberiaPortal.js +15 -15
  172. package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +6 -4
  173. package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +6 -4
  174. package/src/client/components/cyberia-portal/MainBodyCyberiaPortal.js +4 -4
  175. package/src/client/components/cyberia-portal/RouterCyberiaPortal.js +60 -0
  176. package/src/client/components/cyberia-portal/SettingsCyberiaPortal.js +4 -4
  177. package/src/client/components/cyberia-portal/SignUpCyberiaPortal.js +6 -4
  178. package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +4 -4
  179. package/src/client/components/default/{MenuDefault.js → AppShellDefault.js} +87 -87
  180. package/src/client/components/default/CssDefault.js +12 -12
  181. package/src/client/components/default/LogInDefault.js +6 -4
  182. package/src/client/components/default/LogOutDefault.js +6 -4
  183. package/src/client/components/default/RouterDefault.js +47 -0
  184. package/src/client/components/default/SettingsDefault.js +4 -4
  185. package/src/client/components/default/SignUpDefault.js +6 -4
  186. package/src/client/components/default/TranslateDefault.js +3 -3
  187. package/src/client/components/itemledger/{MenuItemledger.js → AppShellItemledger.js} +57 -57
  188. package/src/client/components/itemledger/CssItemledger.js +15 -15
  189. package/src/client/components/itemledger/LogInItemledger.js +6 -4
  190. package/src/client/components/itemledger/LogOutItemledger.js +6 -4
  191. package/src/client/components/itemledger/RouterItemledger.js +38 -0
  192. package/src/client/components/itemledger/SettingsItemledger.js +4 -4
  193. package/src/client/components/itemledger/SignUpItemledger.js +6 -4
  194. package/src/client/components/itemledger/TranslateItemledger.js +3 -3
  195. package/src/client/components/underpost/{MenuUnderpost.js → AppShellUnderpost.js} +88 -88
  196. package/src/client/components/underpost/CssUnderpost.js +14 -14
  197. package/src/client/components/underpost/CyberpunkBloggerUnderpost.js +4 -4
  198. package/src/client/components/underpost/DocumentSearchProvider.js +1 -1
  199. package/src/client/components/underpost/LabGalleryUnderpost.js +12 -15
  200. package/src/client/components/underpost/LogInUnderpost.js +6 -4
  201. package/src/client/components/underpost/LogOutUnderpost.js +6 -4
  202. package/src/client/components/underpost/RouterUnderpost.js +45 -0
  203. package/src/client/components/underpost/SettingsUnderpost.js +4 -4
  204. package/src/client/components/underpost/SignUpUnderpost.js +6 -4
  205. package/src/client/components/underpost/TranslateUnderpost.js +4 -4
  206. package/src/client/public/cyberia-docs/ACTION-SYSTEM.md +235 -0
  207. package/src/client/public/cyberia-docs/ARCHITECTURE.md +443 -0
  208. package/src/client/public/cyberia-docs/CYBERIA-CLI.md +417 -0
  209. package/src/client/public/cyberia-docs/CYBERIA-CLIENT.md +313 -0
  210. package/src/client/public/cyberia-docs/CYBERIA-SERVER.md +260 -0
  211. package/src/client/public/cyberia-docs/ENTITY-PROFILE.md +241 -0
  212. package/src/client/public/cyberia-docs/HARDHAT-MODULE.md +300 -0
  213. package/src/client/public/cyberia-docs/OFF-CHAIN-ECONOMY.md +279 -0
  214. package/src/client/public/cyberia-docs/QUEST-SYSTEM.md +206 -0
  215. package/src/client/public/cyberia-docs/ROADMAP.md +240 -0
  216. package/src/client/public/cyberia-docs/WHITE-PAPER.md +732 -0
  217. package/src/client/services/atlas-sprite-sheet/atlas-sprite-sheet.service.js +14 -20
  218. package/src/client/services/core/core.service.js +17 -49
  219. package/src/client/services/crypto/crypto.service.js +8 -13
  220. package/src/client/services/cyberia-action/cyberia-action.service.js +99 -0
  221. package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +10 -16
  222. package/src/client/services/cyberia-entity/cyberia-entity.management.js +5 -5
  223. package/src/client/services/cyberia-entity/cyberia-entity.service.js +10 -16
  224. package/src/client/services/cyberia-instance/cyberia-instance.management.js +6 -6
  225. package/src/client/services/cyberia-instance/cyberia-instance.service.js +12 -18
  226. package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +10 -16
  227. package/src/client/services/cyberia-map/cyberia-map.management.js +6 -6
  228. package/src/client/services/cyberia-map/cyberia-map.service.js +12 -18
  229. package/src/client/services/cyberia-quest/cyberia-quest.service.js +99 -0
  230. package/src/client/services/cyberia-quest-progress/cyberia-quest-progress.service.js +99 -0
  231. package/src/client/services/default/default.management.js +159 -267
  232. package/src/client/services/default/default.service.js +10 -16
  233. package/src/client/services/document/document.service.js +14 -19
  234. package/src/client/services/file/file.service.js +8 -13
  235. package/src/client/services/instance/instance.management.js +5 -5
  236. package/src/client/services/instance/instance.service.js +10 -15
  237. package/src/client/services/ipfs/ipfs.service.js +12 -18
  238. package/src/client/services/object-layer/object-layer.management.js +12 -12
  239. package/src/client/services/object-layer/object-layer.service.js +20 -26
  240. package/src/client/services/object-layer-render-frames/object-layer-render-frames.service.js +10 -16
  241. package/src/client/services/test/test.service.js +8 -13
  242. package/src/client/services/user/guest.service.js +86 -0
  243. package/src/client/services/user/user.management.js +5 -5
  244. package/src/client/services/user/user.service.js +14 -20
  245. package/src/client/ssr/body/404.js +3 -3
  246. package/src/client/ssr/body/500.js +3 -3
  247. package/src/client/ssr/body/CacheControl.js +5 -2
  248. package/src/client/ssr/body/DefaultSplashScreen.js +19 -12
  249. package/src/client/ssr/body/UnderpostDefaultSplashScreen.js +13 -6
  250. package/src/client/ssr/head/PwaItemledger.js +197 -60
  251. package/src/client/ssr/mailer/DefaultRecoverEmail.js +19 -20
  252. package/src/client/ssr/mailer/DefaultVerifyEmail.js +15 -16
  253. package/src/client/ssr/offline/Maintenance.js +12 -11
  254. package/src/client/ssr/offline/NoNetworkConnection.js +3 -3
  255. package/src/client/ssr/pages/Test.js +2 -2
  256. package/src/client/sw/core.sw.js +212 -0
  257. package/src/grpc/cyberia/grpc-server.js +179 -67
  258. package/src/index.js +1 -1
  259. package/src/runtime/cyberia-client/Dockerfile +80 -0
  260. package/src/runtime/cyberia-server/Dockerfile +37 -0
  261. package/src/runtime/express/Dockerfile +4 -4
  262. package/src/runtime/lampp/Dockerfile +8 -7
  263. package/src/runtime/wp/Dockerfile +11 -17
  264. package/src/server/atlas-sprite-sheet-generator.js +4 -2
  265. package/src/server/client-build-docs.js +45 -46
  266. package/src/server/client-build.js +334 -60
  267. package/src/server/client-formatted.js +47 -16
  268. package/src/server/conf.js +5 -4
  269. package/src/server/data-query.js +32 -20
  270. package/src/server/dns.js +22 -0
  271. package/src/server/ipfs-client.js +232 -91
  272. package/src/server/object-layer.js +1 -6
  273. package/src/server/process.js +13 -27
  274. package/src/server/semantic-layer-generator-floor.js +11 -51
  275. package/src/server/semantic-layer-generator-resource.js +259 -0
  276. package/src/server/semantic-layer-generator-skin.js +41 -171
  277. package/src/server/semantic-layer-generator.js +122 -14
  278. package/src/server/shape-generator.js +108 -0
  279. package/src/server/start.js +17 -3
  280. package/src/server/valkey.js +141 -235
  281. package/tsconfig.docs.json +15 -0
  282. package/typedoc.dd-cyberia.json +29 -0
  283. package/typedoc.json +29 -0
  284. package/WHITE-PAPER.md +0 -1540
  285. package/hardhat/README.md +0 -531
  286. package/hardhat/WHITE-PAPER.md +0 -1540
  287. package/jsdoc.dd-cyberia.json +0 -68
  288. package/jsdoc.json +0 -68
  289. package/src/api/object-layer/README.md +0 -672
  290. package/src/client/components/core/ColorPalette.js +0 -5267
  291. package/src/client/components/core/JoyStick.js +0 -80
  292. package/src/client/components/cryptokoyn/RoutesCryptokoyn.js +0 -39
  293. package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +0 -62
  294. package/src/client/components/cyberia-portal/ServerCyberiaPortal.js +0 -136
  295. package/src/client/components/default/RoutesDefault.js +0 -49
  296. package/src/client/components/itemledger/RoutesItemledger.js +0 -40
  297. package/src/client/components/underpost/RoutesUnderpost.js +0 -47
  298. package/src/client/sw/default.sw.js +0 -127
  299. package/src/client/sw/template.sw.js +0 -84
  300. package/src/grpc/cyberia/OFF_CHAIN_ECONOMY.md +0 -305
  301. package/src/grpc/cyberia/README.md +0 -326
@@ -27,7 +27,7 @@ const logger = loggerFactory(import.meta);
27
27
  * @namespace FileServiceServer.FileServiceDto
28
28
  * @memberof FileServiceServer
29
29
  */
30
- const FileServiceDto = {
30
+ class FileServiceDto {
31
31
  /**
32
32
  * Returns file metadata only (no buffer data).
33
33
  * Used for list responses and API integration.
@@ -36,7 +36,7 @@ const FileServiceDto = {
36
36
  * @param {Object} file - File document from database.
37
37
  * @returns {Object|null} File metadata object, or null if file is falsy.
38
38
  */
39
- toMetadata: (file) => {
39
+ static toMetadata = (file) => {
40
40
  if (!file) return null;
41
41
  return {
42
42
  _id: file._id,
@@ -48,7 +48,7 @@ const FileServiceDto = {
48
48
  createdAt: file.createdAt,
49
49
  updatedAt: file.updatedAt,
50
50
  };
51
- },
51
+ };
52
52
 
53
53
  /**
54
54
  * Transforms array of files to metadata only.
@@ -57,10 +57,10 @@ const FileServiceDto = {
57
57
  * @param {Array} files - Array of file documents.
58
58
  * @returns {Array} Array of file metadata objects.
59
59
  */
60
- toMetadataArray: (files) => {
60
+ static toMetadataArray = (files) => {
61
61
  if (!Array.isArray(files)) return [];
62
62
  return files.map((file) => FileServiceDto.toMetadata(file));
63
- },
63
+ };
64
64
 
65
65
  /**
66
66
  * Ensures UTF-8 encoding for filenames.
@@ -70,14 +70,14 @@ const FileServiceDto = {
70
70
  * @param {string} filename - Raw filename from upload.
71
71
  * @returns {string} UTF-8 encoded filename.
72
72
  */
73
- normalizeFilename: (filename) => {
73
+ static normalizeFilename = (filename) => {
74
74
  if (!filename) return '';
75
75
  // Ensure string and normalize to UTF-8
76
76
  let normalized = String(filename);
77
77
  // Replace any incorrectly encoded sequences
78
78
  normalized = Buffer.from(normalized, 'utf8').toString('utf8');
79
79
  return normalized;
80
- },
80
+ };
81
81
 
82
82
  /**
83
83
  * Get select fields for metadata-only queries.
@@ -86,17 +86,17 @@ const FileServiceDto = {
86
86
  * @memberof FileServiceServer.FileServiceDto
87
87
  * @returns {string} Space-separated list of field names for metadata selection.
88
88
  */
89
- metadataSelect: () => {
89
+ static metadataSelect = () => {
90
90
  return '_id name mimetype size encoding md5 cid createdAt updatedAt';
91
- },
92
- };
91
+ };
92
+ }
93
93
 
94
94
  /**
95
95
  * File Factory for file extraction, upload, and creation utilities.
96
96
  * @namespace FileServiceServer.FileFactory
97
97
  * @memberof FileServiceServer
98
98
  */
99
- const FileFactory = {
99
+ class FileFactory {
100
100
  /**
101
101
  * Extract files from request.
102
102
  * Handles both standard 'file' field and custom fields.
@@ -105,7 +105,7 @@ const FileFactory = {
105
105
  * @param {Object} req - Express request object with files.
106
106
  * @returns {Array} Array of extracted file objects.
107
107
  */
108
- filesExtract: (req) => {
108
+ static filesExtract = (req) => {
109
109
  const files = [];
110
110
  if (!req.files || Object.keys(req.files).length === 0) {
111
111
  return files;
@@ -139,7 +139,7 @@ const FileFactory = {
139
139
  }
140
140
 
141
141
  return files;
142
- },
142
+ };
143
143
 
144
144
  /**
145
145
  * Upload files to database with UTF-8 encoding.
@@ -150,7 +150,7 @@ const FileFactory = {
150
150
  * @param {import('mongoose').Model} File - Mongoose File model.
151
151
  * @returns {Promise<Array>} Array of uploaded file metadata objects.
152
152
  */
153
- upload: async function (req, File) {
153
+ static async upload(req, File) {
154
154
  const results = FileFactory.filesExtract(req);
155
155
  let index = -1;
156
156
 
@@ -172,7 +172,7 @@ const FileFactory = {
172
172
  }
173
173
 
174
174
  return results;
175
- },
175
+ }
176
176
 
177
177
  /**
178
178
  * Convert string to hexadecimal.
@@ -181,9 +181,9 @@ const FileFactory = {
181
181
  * @param {string} [raw=''] - Raw string to convert.
182
182
  * @returns {string} Hexadecimal representation of the string.
183
183
  */
184
- hex: (raw = '') => {
184
+ static hex = (raw = '') => {
185
185
  return Buffer.from(raw, 'utf8').toString('hex');
186
- },
186
+ };
187
187
 
188
188
  /**
189
189
  * Get MIME type from file path based on extension.
@@ -192,7 +192,7 @@ const FileFactory = {
192
192
  * @param {string} path - File path or filename with extension.
193
193
  * @returns {string} MIME type string.
194
194
  */
195
- getMymeTypeFromPath: (path) => {
195
+ static getMymeTypeFromPath = (path) => {
196
196
  const ext = String(path || '')
197
197
  .toLowerCase()
198
198
  .split('.')
@@ -210,7 +210,7 @@ const FileFactory = {
210
210
  json: 'application/json',
211
211
  };
212
212
  return mimeTypes[ext] || 'application/octet-stream';
213
- },
213
+ };
214
214
 
215
215
  /**
216
216
  * Create file object with proper encoding.
@@ -220,7 +220,7 @@ const FileFactory = {
220
220
  * @param {string} [name=''] - File name.
221
221
  * @returns {Object} File object with name, data, size, encoding, mimetype, and md5.
222
222
  */
223
- create: (data = Buffer.from([]), name = '') => {
223
+ static create = (data = Buffer.from([]), name = '') => {
224
224
  const normalizedName = FileServiceDto.normalizeFilename(name);
225
225
 
226
226
  return {
@@ -234,8 +234,8 @@ const FileFactory = {
234
234
  md5: crypto.createHash('md5').update(data).digest('hex'),
235
235
  cid: undefined,
236
236
  };
237
- },
238
- };
237
+ };
238
+ }
239
239
 
240
240
  /**
241
241
  * File cleanup utilities for preventing orphaned files.
@@ -244,7 +244,7 @@ const FileFactory = {
244
244
  * @namespace FileServiceServer.FileCleanup
245
245
  * @memberof FileServiceServer
246
246
  */
247
- const FileCleanup = {
247
+ class FileCleanup {
248
248
  /**
249
249
  * Clean up old file references when document fields are updated.
250
250
  * Deletes old files that are being replaced by new file IDs.
@@ -258,7 +258,7 @@ const FileCleanup = {
258
258
  * @param {import('mongoose').Model} options.File - Mongoose File model.
259
259
  * @returns {Promise<Array>} Array of deleted file IDs.
260
260
  */
261
- cleanupReplacedFiles: async ({ oldDoc, newData, fileFields, File }) => {
261
+ static cleanupReplacedFiles = async ({ oldDoc, newData, fileFields, File }) => {
262
262
  const deletedFileIds = [];
263
263
 
264
264
  for (const field of fileFields) {
@@ -281,7 +281,7 @@ const FileCleanup = {
281
281
  }
282
282
 
283
283
  return deletedFileIds;
284
- },
284
+ };
285
285
 
286
286
  /**
287
287
  * Delete all files referenced in a document.
@@ -297,7 +297,7 @@ const FileCleanup = {
297
297
  * @param {import('mongoose').Model} options.File - Mongoose File model.
298
298
  * @returns {Promise<Array>} Array of deleted file IDs.
299
299
  */
300
- deleteDocumentFiles: async ({ doc, fileFields, File }) => {
300
+ static deleteDocumentFiles = async ({ doc, fileFields, File }) => {
301
301
  const deletedFileIds = [];
302
302
 
303
303
  for (const field of fileFields) {
@@ -318,15 +318,15 @@ const FileCleanup = {
318
318
  }
319
319
 
320
320
  return deletedFileIds;
321
- },
322
- };
321
+ };
322
+ }
323
323
 
324
324
  /**
325
325
  * File Service for handling REST API file operations.
326
326
  * @namespace FileServiceServer.FileService
327
327
  * @memberof FileServiceServer
328
328
  */
329
- const FileService = {
329
+ class FileService {
330
330
  /**
331
331
  * POST - Upload files.
332
332
  * Returns metadata-only response (no buffer data).
@@ -338,7 +338,7 @@ const FileService = {
338
338
  * @param {Object} options - Request options containing host and path.
339
339
  * @returns {Promise<Array>} Array of uploaded file metadata objects.
340
340
  */
341
- post: async (req, res, options) => {
341
+ static post = async (req, res, options) => {
342
342
  // Check that user is authenticated and not a guest
343
343
  if (!req.auth || !req.auth.user || req.auth.user.role === 'guest') {
344
344
  throw new Error('Authentication required. Guest users cannot upload files.');
@@ -349,7 +349,7 @@ const FileService = {
349
349
 
350
350
  const uploadedFiles = await FileFactory.upload(req, File);
351
351
  return FileServiceDto.toMetadataArray(uploadedFiles);
352
- },
352
+ };
353
353
 
354
354
  /**
355
355
  * GET - Retrieve files.
@@ -365,7 +365,7 @@ const FileService = {
365
365
  * @returns {Promise<Array|Buffer>} Array of file metadata objects or Buffer for blob endpoint.
366
366
  * @throws {Error} If file not found or user not authorized.
367
367
  */
368
- get: async (req, res, options) => {
368
+ static get = async (req, res, options) => {
369
369
  /** @type {import('./file.model.js').FileModel} */
370
370
  const File = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.File;
371
371
  /** @type {import('../document/document.model.js').DocumentModel} */
@@ -467,7 +467,7 @@ const FileService = {
467
467
  return FileServiceDto.toMetadataArray(files);
468
468
  }
469
469
  }
470
- },
470
+ };
471
471
 
472
472
  /**
473
473
  * DELETE - Remove files.
@@ -480,7 +480,7 @@ const FileService = {
480
480
  * @returns {Promise<Object>} Deleted file metadata object.
481
481
  * @throws {Error} If file not found.
482
482
  */
483
- delete: async (req, res, options) => {
483
+ static delete = async (req, res, options) => {
484
484
  /** @type {import('./file.model.js').FileModel} */
485
485
  const File = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.File;
486
486
 
@@ -491,7 +491,7 @@ const FileService = {
491
491
  }
492
492
 
493
493
  return FileServiceDto.toMetadata(result);
494
- },
495
- };
494
+ };
495
+ }
496
496
 
497
497
  export { FileService, FileFactory, FileServiceDto, FileCleanup };
@@ -3,8 +3,8 @@ import { InstanceService } from './instance.service.js';
3
3
 
4
4
  const logger = loggerFactory(import.meta);
5
5
 
6
- const InstanceController = {
7
- post: async (req, res, options) => {
6
+ class InstanceController {
7
+ static post = async (req, res, options) => {
8
8
  try {
9
9
  const result = await InstanceService.post(req, res, options);
10
10
  return res.status(200).json({
@@ -18,8 +18,8 @@ const InstanceController = {
18
18
  message: error.message,
19
19
  });
20
20
  }
21
- },
22
- get: async (req, res, options) => {
21
+ };
22
+ static get = async (req, res, options) => {
23
23
  try {
24
24
  const result = await InstanceService.get(req, res, options);
25
25
  return res.status(200).json({
@@ -33,8 +33,8 @@ const InstanceController = {
33
33
  message: error.message,
34
34
  });
35
35
  }
36
- },
37
- put: async (req, res, options) => {
36
+ };
37
+ static put = async (req, res, options) => {
38
38
  try {
39
39
  const result = await InstanceService.put(req, res, options);
40
40
  return res.status(200).json({
@@ -48,8 +48,8 @@ const InstanceController = {
48
48
  message: error.message,
49
49
  });
50
50
  }
51
- },
52
- delete: async (req, res, options) => {
51
+ };
52
+ static delete = async (req, res, options) => {
53
53
  try {
54
54
  const result = await InstanceService.delete(req, res, options);
55
55
  return res.status(200).json({
@@ -63,7 +63,7 @@ const InstanceController = {
63
63
  message: error.message,
64
64
  });
65
65
  }
66
- },
67
- };
66
+ };
67
+ }
68
68
 
69
69
  export { InstanceController };
@@ -1,7 +1,5 @@
1
1
  import { Schema, model, Types } from 'mongoose';
2
-
3
2
  // https://mongoosejs.com/docs/2.7.x/docs/schematypes.html
4
-
5
3
  const InstanceSchema = new Schema(
6
4
  {
7
5
  deployId: { type: String },
@@ -20,9 +18,8 @@ const InstanceSchema = new Schema(
20
18
  timestamps: true,
21
19
  },
22
20
  );
23
-
24
- const InstanceDto = {
25
- populate: {
21
+ class InstanceDto {
22
+ static populate = {
26
23
  get: () => {
27
24
  return {
28
25
  path: 'userId',
@@ -30,11 +27,8 @@ const InstanceDto = {
30
27
  select: '_id email',
31
28
  };
32
29
  },
33
- },
34
- };
35
-
30
+ };
31
+ }
36
32
  const InstanceModel = model('Instance', InstanceSchema);
37
-
38
33
  const ProviderSchema = InstanceSchema;
39
-
40
34
  export { InstanceSchema, InstanceModel, ProviderSchema, InstanceDto };
@@ -5,13 +5,13 @@ import { InstanceDto } from './instance.model.js';
5
5
 
6
6
  const logger = loggerFactory(import.meta);
7
7
 
8
- const InstanceService = {
9
- post: async (req, res, options) => {
8
+ class InstanceService {
9
+ static post = async (req, res, options) => {
10
10
  /** @type {import('./instance.model.js').InstanceModel} */
11
11
  const Instance = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Instance;
12
12
  return await new Instance(req.body).save();
13
- },
14
- get: async (req, res, options) => {
13
+ };
14
+ static get = async (req, res, options) => {
15
15
  /** @type {import('./instance.model.js').InstanceModel} */
16
16
  const Instance = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Instance;
17
17
 
@@ -58,18 +58,18 @@ const InstanceService = {
58
58
  return { data: dataUser, total: totalUser, page, totalPages: Math.ceil(totalUser / limit) };
59
59
  }
60
60
  }
61
- },
62
- put: async (req, res, options) => {
61
+ };
62
+ static put = async (req, res, options) => {
63
63
  /** @type {import('./instance.model.js').InstanceModel} */
64
64
  const Instance = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Instance;
65
65
  return await Instance.findByIdAndUpdate(req.params.id, req.body);
66
- },
67
- delete: async (req, res, options) => {
66
+ };
67
+ static delete = async (req, res, options) => {
68
68
  /** @type {import('./instance.model.js').InstanceModel} */
69
69
  const Instance = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Instance;
70
70
  if (req.params.id) return await Instance.findByIdAndDelete(req.params.id);
71
71
  else return await Instance.deleteMany();
72
- },
73
- };
72
+ };
73
+ }
74
74
 
75
75
  export { InstanceService };
@@ -3,8 +3,8 @@ import { IpfsService } from './ipfs.service.js';
3
3
 
4
4
  const logger = loggerFactory(import.meta);
5
5
 
6
- const IpfsController = {
7
- post: async (req, res, options) => {
6
+ class IpfsController {
7
+ static post = async (req, res, options) => {
8
8
  try {
9
9
  const result = await IpfsService.post(req, res, options);
10
10
  return res.status(200).json({
@@ -18,8 +18,8 @@ const IpfsController = {
18
18
  message: error.message,
19
19
  });
20
20
  }
21
- },
22
- get: async (req, res, options) => {
21
+ };
22
+ static get = async (req, res, options) => {
23
23
  try {
24
24
  const { page, limit } = req.query;
25
25
  const result = await IpfsService.get(
@@ -38,8 +38,8 @@ const IpfsController = {
38
38
  message: error.message,
39
39
  });
40
40
  }
41
- },
42
- put: async (req, res, options) => {
41
+ };
42
+ static put = async (req, res, options) => {
43
43
  try {
44
44
  const result = await IpfsService.put(req, res, options);
45
45
  return res.status(200).json({
@@ -53,8 +53,8 @@ const IpfsController = {
53
53
  message: error.message,
54
54
  });
55
55
  }
56
- },
57
- delete: async (req, res, options) => {
56
+ };
57
+ static delete = async (req, res, options) => {
58
58
  try {
59
59
  const result = await IpfsService.delete(req, res, options);
60
60
  return res.status(200).json({
@@ -68,8 +68,8 @@ const IpfsController = {
68
68
  message: error.message,
69
69
  });
70
70
  }
71
- },
72
- verify: async (req, res, options) => {
71
+ };
72
+ static verify = async (req, res, options) => {
73
73
  try {
74
74
  const result = await IpfsService.verify(req, res, options);
75
75
  return res.status(200).json({ status: 'success', data: result });
@@ -77,7 +77,7 @@ const IpfsController = {
77
77
  logger.error(error, error.stack);
78
78
  return res.status(400).json({ status: 'error', message: error.message });
79
79
  }
80
- },
81
- };
80
+ };
81
+ }
82
82
 
83
83
  export { IpfsController };
@@ -21,9 +21,7 @@
21
21
  * @module src/api/ipfs/ipfs.model.js
22
22
  * @namespace IpfsModel
23
23
  */
24
-
25
24
  import { Schema, model } from 'mongoose';
26
-
27
25
  const IpfsSchema = new Schema(
28
26
  {
29
27
  cid: {
@@ -50,22 +48,16 @@ const IpfsSchema = new Schema(
50
48
  timestamps: true,
51
49
  },
52
50
  );
53
-
54
51
  // One DB record per (CID, resourceType) pair.
55
52
  IpfsSchema.index({ cid: 1, resourceType: 1 }, { unique: true });
56
-
57
53
  // Fast look-ups for health-check and garbage-collection by type.
58
54
  IpfsSchema.index({ resourceType: 1 });
59
-
60
55
  // Fast look-ups for targeted MFS cleanup.
61
56
  IpfsSchema.index({ mfsPath: 1 });
62
-
63
57
  const IpfsModel = model('Ipfs', IpfsSchema);
64
-
65
58
  const ProviderSchema = IpfsSchema;
66
-
67
- const IpfsDto = {
68
- select: {
59
+ class IpfsDto {
60
+ static select = {
69
61
  get: () => ({
70
62
  _id: 1,
71
63
  cid: 1,
@@ -74,7 +66,6 @@ const IpfsDto = {
74
66
  createdAt: 1,
75
67
  updatedAt: 1,
76
68
  }),
77
- },
78
- };
79
-
69
+ };
70
+ }
80
71
  export { IpfsSchema, IpfsModel, ProviderSchema, IpfsDto };
@@ -3,9 +3,7 @@ import { loggerFactory } from '../../server/logger.js';
3
3
  import { DataQuery } from '../../server/data-query.js';
4
4
  import { IpfsClient } from '../../server/ipfs-client.js';
5
5
  import { IpfsDto } from './ipfs.model.js';
6
-
7
6
  const logger = loggerFactory(import.meta);
8
-
9
7
  /**
10
8
  * Upsert a CID registry entry.
11
9
  * Called by asset services (ObjectLayer, AtlasSpriteSheet) after a successful
@@ -28,7 +26,6 @@ const createPinRecord = async ({ cid, resourceType, mfsPath = '', options }) =>
28
26
  logger.info(`IPFS registry upserted – CID: ${cid}, type: ${resourceType}, mfsPath: ${mfsPath}`);
29
27
  return record;
30
28
  };
31
-
32
29
  /**
33
30
  * Remove all DB registry entries for a CID, then best-effort unpin from the IPFS node.
34
31
  * Always deletes DB records first so the registry stays clean even if the node is down.
@@ -47,22 +44,18 @@ const removePinRecordsAndUnpin = async (cid, options) => {
47
44
  logger.warn(`Best-effort IPFS unpin failed for CID ${cid}: ${err.message}`);
48
45
  }
49
46
  };
50
-
51
- const IpfsService = {
47
+ class IpfsService {
52
48
  /** Expose helpers so other modules can import them directly. */
53
- createPinRecord,
54
- removePinRecordsAndUnpin,
55
-
49
+ static createPinRecord = createPinRecord;
50
+ static removePinRecordsAndUnpin = removePinRecordsAndUnpin;
56
51
  // ──────────────────────────────────────────────
57
52
  // Standard CRUD
58
53
  // ──────────────────────────────────────────────
59
-
60
- post: async (req, res, options) => {
54
+ static post = async (req, res, options) => {
61
55
  const Ipfs = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Ipfs;
62
56
  return await new Ipfs(req.body).save();
63
- },
64
-
65
- get: async (req, res, options) => {
57
+ };
58
+ static get = async (req, res, options) => {
66
59
  const Ipfs = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Ipfs;
67
60
  if (req.params.id) {
68
61
  return await Ipfs.findById(req.params.id).select(IpfsDto.select.get());
@@ -74,14 +67,12 @@ const IpfsService = {
74
67
  ]);
75
68
  const totalPages = Math.ceil(total / limit);
76
69
  return { data, total, page, totalPages };
77
- },
78
-
79
- put: async (req, res, options) => {
70
+ };
71
+ static put = async (req, res, options) => {
80
72
  const Ipfs = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Ipfs;
81
73
  return await Ipfs.findByIdAndUpdate(req.params.id, req.body, { returnDocument: 'after' });
82
- },
83
-
84
- delete: async (req, res, options) => {
74
+ };
75
+ static delete = async (req, res, options) => {
85
76
  const Ipfs = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Ipfs;
86
77
  if (req.params.id) {
87
78
  const record = await Ipfs.findById(req.params.id);
@@ -101,12 +92,10 @@ const IpfsService = {
101
92
  return null;
102
93
  }
103
94
  return await Ipfs.deleteMany();
104
- },
105
-
95
+ };
106
96
  // ──────────────────────────────────────────────
107
97
  // Health / audit
108
98
  // ──────────────────────────────────────────────
109
-
110
99
  /**
111
100
  * GET /ipfs/verify
112
101
  *
@@ -117,10 +106,9 @@ const IpfsService = {
117
106
  * Response shape:
118
107
  * { total, pinned, unpinned, errors, entries: [{ cid, resourceType, mfsPath, pinned, error? }] }
119
108
  */
120
- verify: async (req, res, options) => {
109
+ static verify = async (req, res, options) => {
121
110
  const Ipfs = DataBaseProvider.instance[`${options.host}${options.path}`].mongoose.models.Ipfs;
122
111
  const records = await Ipfs.find({}).select(IpfsDto.select.get()).lean();
123
-
124
112
  let pinned = 0;
125
113
  let unpinned = 0;
126
114
  let errors = 0;
@@ -137,9 +125,7 @@ const IpfsService = {
137
125
  }
138
126
  }),
139
127
  );
140
-
141
128
  return { total: records.length, pinned, unpinned, errors, entries };
142
- },
143
- };
144
-
129
+ };
130
+ }
145
131
  export { IpfsService, createPinRecord, removePinRecordsAndUnpin };
@@ -3,8 +3,8 @@ import { ObjectLayerService } from './object-layer.service.js';
3
3
 
4
4
  const logger = loggerFactory(import.meta);
5
5
 
6
- const ObjectLayerController = {
7
- post: async (req, res, options) => {
6
+ class ObjectLayerController {
7
+ static post = async (req, res, options) => {
8
8
  try {
9
9
  const result = await ObjectLayerService.post(req, res, options);
10
10
  return res.status(200).json({
@@ -18,8 +18,8 @@ const ObjectLayerController = {
18
18
  message: error.message,
19
19
  });
20
20
  }
21
- },
22
- get: async (req, res, options) => {
21
+ };
22
+ static get = async (req, res, options) => {
23
23
  try {
24
24
  if (req && req.headers && req.headers.origin) {
25
25
  res.set('Access-Control-Allow-Origin', req.headers.origin);
@@ -37,8 +37,8 @@ const ObjectLayerController = {
37
37
  message: error.message,
38
38
  });
39
39
  }
40
- },
41
- generateWebp: async (req, res, options) => {
40
+ };
41
+ static generateWebp = async (req, res, options) => {
42
42
  try {
43
43
  const result = await ObjectLayerService.generateWebp(req, res, options);
44
44
  if (req && req.headers && req.headers.origin) {
@@ -59,8 +59,8 @@ const ObjectLayerController = {
59
59
  message: error.message,
60
60
  });
61
61
  }
62
- },
63
- put: async (req, res, options) => {
62
+ };
63
+ static put = async (req, res, options) => {
64
64
  try {
65
65
  const result = await ObjectLayerService.put(req, res, options);
66
66
  return res.status(200).json({
@@ -74,8 +74,8 @@ const ObjectLayerController = {
74
74
  message: error.message,
75
75
  });
76
76
  }
77
- },
78
- delete: async (req, res, options) => {
77
+ };
78
+ static delete = async (req, res, options) => {
79
79
  try {
80
80
  const result = await ObjectLayerService.delete(req, res, options);
81
81
  return res.status(200).json({
@@ -89,7 +89,7 @@ const ObjectLayerController = {
89
89
  message: error.message,
90
90
  });
91
91
  }
92
- },
93
- };
92
+ };
93
+ }
94
94
 
95
95
  export { ObjectLayerController };