cyberia 3.2.5 → 3.2.12

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 (381) hide show
  1. package/.github/workflows/engine-cyberia.cd.yml +8 -2
  2. package/.github/workflows/npmpkg.ci.yml +1 -0
  3. package/.github/workflows/pwa-microservices-template-test.ci.yml +1 -1
  4. package/.github/workflows/release.cd.yml +2 -2
  5. package/.vscode/extensions.json +9 -9
  6. package/.vscode/settings.json +20 -4
  7. package/CHANGELOG.md +563 -1
  8. package/CLI-HELP.md +130 -34
  9. package/Dockerfile +0 -4
  10. package/README.md +194 -607
  11. package/bin/build.js +42 -12
  12. package/bin/build.template.js +187 -0
  13. package/bin/cyberia.js +1367 -281
  14. package/bin/deploy.js +582 -3
  15. package/bin/index.js +1367 -281
  16. package/bump.config.js +26 -0
  17. package/conf.js +195 -111
  18. package/deployment.yaml +6 -222
  19. package/hardhat/package-lock.json +118 -149
  20. package/hardhat/package.json +5 -4
  21. package/jsconfig.json +1 -1
  22. package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +2 -2
  23. package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +2 -2
  24. package/manifests/deployment/dd-cyberia-development/deployment.yaml +6 -222
  25. package/manifests/deployment/dd-cyberia-development/proxy.yaml +10 -118
  26. package/manifests/deployment/dd-default-development/deployment.yaml +2 -6
  27. package/manifests/deployment/dd-test-development/deployment.yaml +138 -66
  28. package/manifests/deployment/dd-test-development/proxy.yaml +41 -5
  29. package/manifests/kind-config-dev.yaml +8 -0
  30. package/manifests/lxd/lxd-admin-profile.yaml +12 -3
  31. package/manifests/mongodb/pv-pvc.yaml +44 -8
  32. package/manifests/mongodb/statefulset.yaml +55 -68
  33. package/manifests/mongodb-4.4/headless-service.yaml +10 -0
  34. package/manifests/mongodb-4.4/kustomization.yaml +3 -1
  35. package/manifests/mongodb-4.4/mongodb-nodeport.yaml +17 -0
  36. package/manifests/mongodb-4.4/pv-pvc.yaml +10 -14
  37. package/manifests/mongodb-4.4/statefulset.yaml +79 -0
  38. package/manifests/mongodb-4.4/storage-class.yaml +9 -0
  39. package/manifests/valkey/statefulset.yaml +1 -1
  40. package/manifests/valkey/valkey-nodeport.yaml +17 -0
  41. package/package.json +45 -24
  42. package/proxy.yaml +10 -118
  43. package/scripts/ipxe-setup.sh +52 -49
  44. package/scripts/k3s-node-setup.sh +83 -48
  45. package/scripts/lxd-vm-setup.sh +193 -8
  46. package/scripts/maas-nat-firewalld.sh +145 -0
  47. package/scripts/nat-iptables.sh +103 -18
  48. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +18 -18
  49. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +7 -14
  50. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.router.js +38 -33
  51. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +91 -36
  52. package/src/api/core/core.controller.js +10 -10
  53. package/src/api/core/core.router.js +19 -14
  54. package/src/api/core/core.service.js +15 -15
  55. package/src/api/crypto/crypto.controller.js +8 -8
  56. package/src/api/crypto/crypto.router.js +18 -12
  57. package/src/api/crypto/crypto.service.js +11 -11
  58. package/src/api/cyberia-action/cyberia-action.controller.js +74 -0
  59. package/src/api/cyberia-action/cyberia-action.model.js +87 -0
  60. package/src/api/cyberia-action/cyberia-action.router.js +31 -0
  61. package/src/api/cyberia-action/cyberia-action.service.js +42 -0
  62. package/src/api/cyberia-client-hints/cyberia-client-hints.controller.js +74 -0
  63. package/src/api/cyberia-client-hints/cyberia-client-hints.model.js +99 -0
  64. package/src/api/cyberia-client-hints/cyberia-client-hints.router.js +98 -0
  65. package/src/api/cyberia-client-hints/cyberia-client-hints.service.js +152 -0
  66. package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +13 -13
  67. package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +11 -11
  68. package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +25 -20
  69. package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +22 -22
  70. package/src/api/cyberia-entity/cyberia-entity.controller.js +10 -10
  71. package/src/api/cyberia-entity/cyberia-entity.router.js +22 -18
  72. package/src/api/cyberia-entity/cyberia-entity.service.js +15 -15
  73. package/src/api/cyberia-instance/cyberia-fallback-world.js +83 -198
  74. package/src/api/cyberia-instance/cyberia-instance.controller.js +14 -14
  75. package/src/api/cyberia-instance/cyberia-instance.model.js +3 -0
  76. package/src/api/cyberia-instance/cyberia-instance.router.js +57 -52
  77. package/src/api/cyberia-instance/cyberia-instance.service.js +32 -67
  78. package/src/api/cyberia-instance/cyberia-portal-connector.js +20 -246
  79. package/src/api/cyberia-instance/cyberia-world-generator.js +505 -0
  80. package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +10 -10
  81. package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +18 -49
  82. package/src/api/cyberia-instance-conf/cyberia-instance-conf.router.js +22 -18
  83. package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +19 -15
  84. package/src/api/cyberia-map/cyberia-map.controller.js +10 -10
  85. package/src/api/cyberia-map/cyberia-map.router.js +35 -30
  86. package/src/api/cyberia-map/cyberia-map.service.js +17 -17
  87. package/src/api/cyberia-quest/cyberia-quest.controller.js +74 -0
  88. package/src/api/cyberia-quest/cyberia-quest.model.js +67 -0
  89. package/src/api/cyberia-quest/cyberia-quest.router.js +31 -0
  90. package/src/api/cyberia-quest/cyberia-quest.service.js +42 -0
  91. package/src/api/cyberia-quest-progress/cyberia-quest-progress.controller.js +74 -0
  92. package/src/api/cyberia-quest-progress/cyberia-quest-progress.model.js +49 -0
  93. package/src/api/cyberia-quest-progress/cyberia-quest-progress.router.js +31 -0
  94. package/src/api/cyberia-quest-progress/cyberia-quest-progress.service.js +42 -0
  95. package/src/api/cyberia-server-defaults/cyberia-server-defaults.js +451 -0
  96. package/src/api/default/default.controller.js +10 -10
  97. package/src/api/default/default.router.js +22 -18
  98. package/src/api/default/default.service.js +15 -15
  99. package/src/api/document/document.controller.js +12 -12
  100. package/src/api/document/document.model.js +10 -16
  101. package/src/api/document/document.router.js +28 -23
  102. package/src/api/document/document.service.js +100 -23
  103. package/src/api/file/file.controller.js +8 -8
  104. package/src/api/file/file.model.js +10 -10
  105. package/src/api/file/file.router.js +19 -13
  106. package/src/api/file/file.service.js +45 -43
  107. package/src/api/instance/instance.controller.js +10 -10
  108. package/src/api/instance/instance.model.js +4 -10
  109. package/src/api/instance/instance.router.js +29 -24
  110. package/src/api/instance/instance.service.js +16 -16
  111. package/src/api/ipfs/ipfs.controller.js +12 -12
  112. package/src/api/ipfs/ipfs.model.js +4 -13
  113. package/src/api/ipfs/ipfs.router.js +21 -16
  114. package/src/api/ipfs/ipfs.service.js +22 -36
  115. package/src/api/object-layer/object-layer.controller.js +12 -12
  116. package/src/api/object-layer/object-layer.model.js +4 -17
  117. package/src/api/object-layer/object-layer.router.js +512 -507
  118. package/src/api/object-layer/object-layer.service.js +29 -26
  119. package/src/api/object-layer-render-frames/object-layer-render-frames.controller.js +10 -10
  120. package/src/api/object-layer-render-frames/object-layer-render-frames.model.js +6 -16
  121. package/src/api/object-layer-render-frames/object-layer-render-frames.router.js +22 -18
  122. package/src/api/object-layer-render-frames/object-layer-render-frames.service.js +19 -15
  123. package/src/api/test/test.controller.js +8 -8
  124. package/src/api/test/test.router.js +17 -12
  125. package/src/api/test/test.service.js +8 -8
  126. package/src/api/types.js +24 -0
  127. package/src/api/user/guest.service.js +100 -0
  128. package/src/api/user/user.controller.js +6 -6
  129. package/src/api/user/user.model.js +8 -13
  130. package/src/api/user/user.router.js +297 -288
  131. package/src/api/user/user.service.js +103 -55
  132. package/src/cli/baremetal.js +132 -101
  133. package/src/cli/cluster.js +732 -217
  134. package/src/cli/db.js +106 -62
  135. package/src/cli/deploy.js +260 -149
  136. package/src/cli/fs.js +90 -9
  137. package/src/cli/image.js +43 -1
  138. package/src/cli/index.js +106 -16
  139. package/src/cli/ipfs.js +4 -6
  140. package/src/cli/kubectl.js +4 -1
  141. package/src/cli/lxd.js +1099 -223
  142. package/src/cli/monitor.js +9 -3
  143. package/src/cli/release.js +336 -86
  144. package/src/cli/repository.js +136 -53
  145. package/src/cli/run.js +599 -76
  146. package/src/cli/secrets.js +11 -2
  147. package/src/cli/ssh.js +1 -1
  148. package/src/cli/static.js +43 -115
  149. package/src/cli/test.js +9 -3
  150. package/src/client/Cryptokoyn.index.js +18 -21
  151. package/src/client/CyberiaPortal.index.js +19 -23
  152. package/src/client/Default.index.js +30 -36
  153. package/src/client/Itemledger.index.js +20 -26
  154. package/src/client/Underpost.index.js +19 -23
  155. package/src/client/components/core/404.js +4 -4
  156. package/src/client/components/core/500.js +4 -4
  157. package/src/client/components/core/Account.js +73 -60
  158. package/src/client/components/core/AgGrid.js +23 -33
  159. package/src/client/components/core/Alert.js +12 -13
  160. package/src/client/components/core/AppStore.js +1 -1
  161. package/src/client/components/core/Auth.js +40 -37
  162. package/src/client/components/core/Badge.js +7 -13
  163. package/src/client/components/core/BtnIcon.js +15 -17
  164. package/src/client/components/core/CalendarCore.js +42 -63
  165. package/src/client/components/core/Chat.js +13 -15
  166. package/src/client/components/core/ClientEvents.js +163 -0
  167. package/src/client/components/core/ColorPaletteElement.js +309 -0
  168. package/src/client/components/core/Content.js +17 -14
  169. package/src/client/components/core/Css.js +15 -71
  170. package/src/client/components/core/CssCore.js +12 -16
  171. package/src/client/components/core/D3Chart.js +4 -4
  172. package/src/client/components/core/Docs.js +64 -91
  173. package/src/client/components/core/DropDown.js +69 -91
  174. package/src/client/components/core/EventBus.js +96 -0
  175. package/src/client/components/core/EventsUI.js +14 -17
  176. package/src/client/components/core/FileExplorer.js +96 -228
  177. package/src/client/components/core/FullScreen.js +47 -75
  178. package/src/client/components/core/Input.js +24 -69
  179. package/src/client/components/core/Keyboard.js +25 -18
  180. package/src/client/components/core/KeyboardAvoidance.js +145 -0
  181. package/src/client/components/core/LoadingAnimation.js +25 -31
  182. package/src/client/components/core/LogIn.js +41 -41
  183. package/src/client/components/core/LogOut.js +23 -14
  184. package/src/client/components/core/Modal.js +544 -219
  185. package/src/client/components/core/NotificationManager.js +14 -18
  186. package/src/client/components/core/Panel.js +54 -50
  187. package/src/client/components/core/PanelForm.js +81 -177
  188. package/src/client/components/core/Polyhedron.js +110 -214
  189. package/src/client/components/core/PublicProfile.js +39 -32
  190. package/src/client/components/core/Recover.js +48 -44
  191. package/src/client/components/core/Responsive.js +88 -32
  192. package/src/client/components/core/RichText.js +9 -18
  193. package/src/client/components/core/Router.js +24 -3
  194. package/src/client/components/core/SearchBox.js +37 -37
  195. package/src/client/components/core/SignUp.js +39 -30
  196. package/src/client/components/core/SocketIo.js +31 -2
  197. package/src/client/components/core/SocketIoHandler.js +6 -6
  198. package/src/client/components/core/ToggleSwitch.js +8 -20
  199. package/src/client/components/core/ToolTip.js +5 -17
  200. package/src/client/components/core/Translate.js +56 -59
  201. package/src/client/components/core/Validator.js +26 -16
  202. package/src/client/components/core/Wallet.js +15 -26
  203. package/src/client/components/core/Worker.js +211 -276
  204. package/src/client/components/core/windowGetDimensions.js +7 -7
  205. package/src/client/components/cryptokoyn/{MenuCryptokoyn.js → AppShellCryptokoyn.js} +57 -57
  206. package/src/client/components/cryptokoyn/CssCryptokoyn.js +15 -15
  207. package/src/client/components/cryptokoyn/LogInCryptokoyn.js +6 -4
  208. package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +6 -4
  209. package/src/client/components/cryptokoyn/RouterCryptokoyn.js +37 -0
  210. package/src/client/components/cryptokoyn/SettingsCryptokoyn.js +4 -4
  211. package/src/client/components/cryptokoyn/SignUpCryptokoyn.js +6 -4
  212. package/src/client/components/cyberia/InstanceEngineCyberia.js +141 -60
  213. package/src/client/components/cyberia/MapEngineCyberia.js +691 -214
  214. package/src/client/components/cyberia/ObjectLayerEngine.js +19 -0
  215. package/src/client/components/cyberia/ObjectLayerEngineModal.js +1204 -94
  216. package/src/client/components/cyberia/ObjectLayerEngineViewer.js +196 -298
  217. package/src/client/components/cyberia/SharedDefaultsCyberia.js +330 -0
  218. package/src/client/components/cyberia-portal/{MenuCyberiaPortal.js → AppShellCyberiaPortal.js} +102 -102
  219. package/src/client/components/cyberia-portal/CssCyberiaPortal.js +15 -15
  220. package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +6 -4
  221. package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +6 -4
  222. package/src/client/components/cyberia-portal/MainBodyCyberiaPortal.js +4 -4
  223. package/src/client/components/cyberia-portal/RouterCyberiaPortal.js +60 -0
  224. package/src/client/components/cyberia-portal/SettingsCyberiaPortal.js +4 -4
  225. package/src/client/components/cyberia-portal/SignUpCyberiaPortal.js +6 -4
  226. package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +4 -4
  227. package/src/client/components/default/{MenuDefault.js → AppShellDefault.js} +87 -87
  228. package/src/client/components/default/CssDefault.js +12 -12
  229. package/src/client/components/default/LogInDefault.js +6 -4
  230. package/src/client/components/default/LogOutDefault.js +6 -4
  231. package/src/client/components/default/RouterDefault.js +47 -0
  232. package/src/client/components/default/SettingsDefault.js +4 -4
  233. package/src/client/components/default/SignUpDefault.js +6 -4
  234. package/src/client/components/default/TranslateDefault.js +3 -3
  235. package/src/client/components/itemledger/{MenuItemledger.js → AppShellItemledger.js} +57 -57
  236. package/src/client/components/itemledger/CssItemledger.js +15 -15
  237. package/src/client/components/itemledger/LogInItemledger.js +6 -4
  238. package/src/client/components/itemledger/LogOutItemledger.js +6 -4
  239. package/src/client/components/itemledger/RouterItemledger.js +38 -0
  240. package/src/client/components/itemledger/SettingsItemledger.js +4 -4
  241. package/src/client/components/itemledger/SignUpItemledger.js +6 -4
  242. package/src/client/components/itemledger/TranslateItemledger.js +3 -3
  243. package/src/client/components/underpost/{MenuUnderpost.js → AppShellUnderpost.js} +88 -88
  244. package/src/client/components/underpost/CssUnderpost.js +14 -14
  245. package/src/client/components/underpost/CyberpunkBloggerUnderpost.js +4 -4
  246. package/src/client/components/underpost/DocumentSearchProvider.js +1 -1
  247. package/src/client/components/underpost/LabGalleryUnderpost.js +12 -15
  248. package/src/client/components/underpost/LogInUnderpost.js +6 -4
  249. package/src/client/components/underpost/LogOutUnderpost.js +6 -4
  250. package/src/client/components/underpost/RouterUnderpost.js +45 -0
  251. package/src/client/components/underpost/SettingsUnderpost.js +4 -4
  252. package/src/client/components/underpost/SignUpUnderpost.js +6 -4
  253. package/src/client/components/underpost/TranslateUnderpost.js +4 -4
  254. package/src/client/public/cyberia-docs/ACTION-SYSTEM.md +235 -0
  255. package/src/client/public/cyberia-docs/ARCHITECTURE.md +83 -0
  256. package/src/client/public/cyberia-docs/CYBERIA-CLI.md +204 -0
  257. package/src/client/public/cyberia-docs/CYBERIA-CLIENT.md +291 -0
  258. package/src/client/public/cyberia-docs/CYBERIA-SERVER.md +278 -0
  259. package/src/client/public/cyberia-docs/CYBERIA.md +259 -0
  260. package/src/client/public/cyberia-docs/ENTITY-PROFILE.md +241 -0
  261. package/src/client/public/cyberia-docs/HARDHAT-MODULE.md +300 -0
  262. package/src/client/public/cyberia-docs/OFF-CHAIN-ECONOMY.md +279 -0
  263. package/src/client/public/cyberia-docs/QUEST-SYSTEM.md +206 -0
  264. package/src/client/public/cyberia-docs/ROADMAP.md +240 -0
  265. package/src/client/public/cyberia-docs/UNDERPOST-PLATFORM.md +106 -0
  266. package/src/client/public/cyberia-docs/WHITE-PAPER.md +732 -0
  267. package/src/client/services/atlas-sprite-sheet/atlas-sprite-sheet.service.js +14 -20
  268. package/src/client/services/core/core.service.js +17 -49
  269. package/src/client/services/crypto/crypto.service.js +8 -13
  270. package/src/client/services/cyberia-action/cyberia-action.service.js +99 -0
  271. package/src/client/services/cyberia-client-hints/cyberia-client-hints.service.js +99 -0
  272. package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +10 -16
  273. package/src/client/services/cyberia-entity/cyberia-entity.management.js +5 -5
  274. package/src/client/services/cyberia-entity/cyberia-entity.service.js +10 -16
  275. package/src/client/services/cyberia-instance/cyberia-instance.management.js +6 -6
  276. package/src/client/services/cyberia-instance/cyberia-instance.service.js +12 -18
  277. package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +10 -16
  278. package/src/client/services/cyberia-map/cyberia-map.management.js +6 -6
  279. package/src/client/services/cyberia-map/cyberia-map.service.js +12 -18
  280. package/src/client/services/cyberia-quest/cyberia-quest.service.js +99 -0
  281. package/src/client/services/cyberia-quest-progress/cyberia-quest-progress.service.js +99 -0
  282. package/src/client/services/default/default.management.js +159 -267
  283. package/src/client/services/default/default.service.js +10 -16
  284. package/src/client/services/document/document.service.js +14 -19
  285. package/src/client/services/file/file.service.js +8 -13
  286. package/src/client/services/instance/instance.management.js +5 -5
  287. package/src/client/services/instance/instance.service.js +10 -15
  288. package/src/client/services/ipfs/ipfs.service.js +12 -18
  289. package/src/client/services/object-layer/object-layer.management.js +12 -12
  290. package/src/client/services/object-layer/object-layer.service.js +20 -26
  291. package/src/client/services/object-layer-render-frames/object-layer-render-frames.service.js +10 -16
  292. package/src/client/services/test/test.service.js +8 -13
  293. package/src/client/services/user/guest.service.js +86 -0
  294. package/src/client/services/user/user.management.js +5 -5
  295. package/src/client/services/user/user.service.js +14 -20
  296. package/src/client/ssr/body/404.js +3 -3
  297. package/src/client/ssr/body/500.js +3 -3
  298. package/src/client/ssr/body/CacheControl.js +5 -2
  299. package/src/client/ssr/body/DefaultSplashScreen.js +19 -12
  300. package/src/client/ssr/body/UnderpostDefaultSplashScreen.js +13 -6
  301. package/src/client/ssr/head/PwaItemledger.js +197 -60
  302. package/src/client/ssr/mailer/DefaultRecoverEmail.js +19 -20
  303. package/src/client/ssr/mailer/DefaultVerifyEmail.js +15 -16
  304. package/src/client/ssr/views/CyberiaServerMetrics.js +982 -0
  305. package/src/client/ssr/{offline → views}/Maintenance.js +12 -11
  306. package/src/client/ssr/{offline → views}/NoNetworkConnection.js +3 -3
  307. package/src/client/ssr/{pages → views}/Test.js +2 -2
  308. package/src/client/sw/core.sw.js +274 -0
  309. package/src/db/DataBaseProvider.js +115 -15
  310. package/src/db/mariadb/MariaDB.js +2 -1
  311. package/src/db/mongo/MongoBootstrap.js +657 -0
  312. package/src/db/mongo/MongooseDB.js +129 -21
  313. package/src/grpc/cyberia/grpc-server.js +185 -105
  314. package/src/index.js +1 -1
  315. package/src/runtime/cyberia-client/Dockerfile +101 -0
  316. package/src/runtime/cyberia-client/Dockerfile.dev +82 -0
  317. package/src/runtime/cyberia-server/Dockerfile +62 -0
  318. package/src/runtime/cyberia-server/Dockerfile.dev +71 -0
  319. package/src/runtime/express/Dockerfile +4 -4
  320. package/src/runtime/express/Express.js +2 -2
  321. package/src/runtime/lampp/Dockerfile +8 -7
  322. package/src/runtime/wp/Dockerfile +11 -17
  323. package/src/runtime/wp/Wp.js +8 -5
  324. package/src/server/atlas-sprite-sheet-generator.js +4 -2
  325. package/src/server/auth.js +2 -2
  326. package/src/server/client-build-docs.js +46 -47
  327. package/src/server/client-build.js +371 -132
  328. package/src/server/client-formatted.js +47 -16
  329. package/src/server/conf.js +91 -87
  330. package/src/server/data-query.js +32 -20
  331. package/src/server/dns.js +22 -0
  332. package/src/server/ipfs-client.js +232 -91
  333. package/src/server/object-layer.js +1 -6
  334. package/src/server/process.js +192 -45
  335. package/src/server/proxy.js +9 -2
  336. package/src/server/runtime.js +1 -1
  337. package/src/server/semantic-layer-generator-floor.js +11 -51
  338. package/src/server/semantic-layer-generator-resource.js +259 -0
  339. package/src/server/semantic-layer-generator-skin.js +41 -171
  340. package/src/server/semantic-layer-generator.js +122 -14
  341. package/src/server/shape-generator.js +108 -0
  342. package/src/server/start.js +34 -8
  343. package/src/server/valkey.js +143 -235
  344. package/src/ws/IoInterface.js +16 -16
  345. package/src/ws/core/channels/core.ws.chat.js +11 -11
  346. package/src/ws/core/channels/core.ws.mailer.js +29 -29
  347. package/src/ws/core/channels/core.ws.stream.js +19 -19
  348. package/src/ws/core/core.ws.connection.js +8 -8
  349. package/src/ws/core/core.ws.server.js +6 -5
  350. package/src/ws/default/channels/default.ws.main.js +10 -10
  351. package/src/ws/default/default.ws.connection.js +4 -4
  352. package/src/ws/default/default.ws.server.js +4 -3
  353. package/tsconfig.docs.json +15 -0
  354. package/typedoc.dd-cyberia.json +29 -0
  355. package/typedoc.json +29 -0
  356. package/WHITE-PAPER.md +0 -1540
  357. package/bin/file.js +0 -196
  358. package/bin/vs.js +0 -74
  359. package/bin/zed.js +0 -84
  360. package/hardhat/README.md +0 -531
  361. package/hardhat/WHITE-PAPER.md +0 -1540
  362. package/jsdoc.dd-cyberia.json +0 -68
  363. package/jsdoc.json +0 -68
  364. package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +0 -413
  365. package/src/api/object-layer/README.md +0 -672
  366. package/src/client/components/core/ColorPalette.js +0 -5267
  367. package/src/client/components/core/JoyStick.js +0 -80
  368. package/src/client/components/cryptokoyn/RoutesCryptokoyn.js +0 -39
  369. package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +0 -223
  370. package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +0 -62
  371. package/src/client/components/cyberia-portal/ServerCyberiaPortal.js +0 -136
  372. package/src/client/components/default/RoutesDefault.js +0 -49
  373. package/src/client/components/itemledger/RoutesItemledger.js +0 -40
  374. package/src/client/components/underpost/RoutesUnderpost.js +0 -47
  375. package/src/client/ssr/email/DefaultRecoverEmail.js +0 -21
  376. package/src/client/ssr/email/DefaultVerifyEmail.js +0 -17
  377. package/src/client/ssr/pages/CyberiaServerMetrics.js +0 -461
  378. package/src/client/sw/default.sw.js +0 -127
  379. package/src/client/sw/template.sw.js +0 -84
  380. package/src/grpc/cyberia/OFF_CHAIN_ECONOMY.md +0 -305
  381. package/src/grpc/cyberia/README.md +0 -326
package/README.md CHANGED
@@ -1,672 +1,259 @@
1
- <p align="center">
2
- <img src="https://www.cyberiaonline.com/assets/splash/apple-touch-icon-precomposed.png" alt="CYBERIA Network Object Layer Engine CLI"/>
3
- </p>
4
-
5
1
  <div align="center">
6
2
 
7
- <h1>cyberia</h1>
8
-
9
- <h2>Network Object Layer Engine CLI</h2>
10
-
11
- [![Downloads](https://img.shields.io/npm/dm/cyberia.svg)](https://www.npmjs.com/package/cyberia) [![Version](https://img.shields.io/npm/v/cyberia.svg)](https://www.npmjs.org/package/cyberia)
12
-
13
- </div>
14
-
15
- This Command Line Interface (CLI) is a core tool for the **Cyberia Network Object Layer Engine**, specifically designed for processing, generating, and managing game assets, primarily **Object Layer** elements like skins, floors, and weapons.
16
-
17
- It handles image asset quantization, generates data matrices and color palettes, creates separate render frame documents, and persists the resulting structured data into the game's database with top-level references to render frames and atlas sprite sheets.
18
-
19
- ## What this tool does
20
-
21
- The CLI scans the local asset folders (`./src/client/public/cyberia/assets/{type}/{id}/{direction}/{frame}`), quantizes images to a tile matrix and color palette, creates separate ObjectLayerRenderFrames documents, and persists the resulting object-layer documents with references to your configured MongoDB. It also supports reconstructing a visual PNG from the stored matrix for inspection.
22
-
23
- Key features:
24
-
25
- - Walks the asset directory structure and processes PNG/GIF files.
26
- - Produces `frame_matrix` and `map_color` arrays from images.
27
- - **Procedurally generates object layers** from semantic item-id descriptors with deterministic seeds and temporal coherence.
28
- - Saves processed objects to the `ObjectLayer` model with top-level references to `ObjectLayerRenderFrames`.
29
- - Creates separate `ObjectLayerRenderFrames` documents for render data.
30
- - Links ObjectLayers to AtlasSpriteSheet documents via top-level `atlasSpriteSheetId`.
31
- - Generates unique UUID v4 seeds (via `crypto.randomUUID()`) for SHA256 hash uniqueness.
32
- - Generates SHA256 hash using `fast-json-stable-stringify` for deterministic serialization.
33
- - Reconstructs PNG frames from stored tile data for debugging.
34
- - Writes static asset PNGs, atlas sprite sheets, and metadata to the conventional directory structure.
35
- - **Drop and cleanup** — removes ObjectLayer, RenderFrames, AtlasSpriteSheet, File documents and unpins IPFS CIDs. Supports targeted drop (specific items) or full drop.
36
- - **Static asset cleanup** — optionally removes client-side static asset folders and runs git-clean on the asset directory.
37
- - **IPFS integration** — pins CIDs to IPFS Cluster and Kubo, manages MFS paths, and unpins on drop.
38
- - **Blockchain integration** — deploys Besu IBFT2 networks, manages ERC-1155 tokens (register, mint, transfer, burn), and resolves canonical CIDs from MongoDB for on-chain registration.
39
- - **Cut-over consistency** — stages all IPFS operations, file creation, and atlas generation in-memory before atomically updating live MongoDB documents.
40
-
41
- ## Getting Started
42
-
43
- ### Prerequisites
44
-
45
- You must have the following installed in your environment:
46
-
47
- - **Node.js** (v24.10.0 recommended)
48
- - **npm** or **yarn**
49
- - **MongoDB** (or access to the configured MongoDB instance)
50
-
51
- ### **Installation**
52
-
53
- ```bash
54
-
55
- npm install -g cyberia
56
- ```
57
-
58
- ### **Environment Setup**
59
-
60
- Ensure your required environment variables (e.g., `DEFAULT_DEPLOY_ID`, `DEFAULT_DEPLOY_HOST`, `DEFAULT_DEPLOY_PATH`) are correctly configured, typically in a .env file, to point the CLI to the correct database instance defined in conf.server.json.
61
-
62
- ## Usage
63
-
64
- The CLI is executed from the project root via the `cyberia.js` script.
65
-
66
- ### Import specific items with `--import`
67
-
68
- Import one or more object layers by item-id. The CLI searches all asset type directories for matching items.
69
-
70
- ```bash
71
- # Import a single item
72
- cyberia ol hatchet --import
73
-
74
- # Import multiple items (comma-separated)
75
- cyberia ol hatchet,sword,shield --import
76
- ```
77
-
78
- ### Batch import by type with `--import-types`
79
-
80
- Iterate asset folders for the given types and store processed objects in MongoDB.
81
-
82
- ```bash
83
- # Process specific types (comma-separated)
84
- cyberia ol --import-types skin,floor
85
-
86
- # Process all recognized types (skips items that already exist in the database)
87
- cyberia ol --import-types all
88
- ```
89
-
90
- ### Procedural generation with `--generate`
91
-
92
- Produces semantically consistent object layers with controlled, reproducible variation and short-term temporal coherence (consecutive frames stay visually consistent). Uses the parametric shape generator and object layer engine under the hood.
93
-
94
- ```bash
95
- # Generate a desert floor tile (single frame, auto seed)
96
- cyberia ol floor-desert --generate
97
-
98
- # Full control: 3 frames, explicit seed, density
99
- cyberia ol floor-desert --generate --count 3 --seed fx-42 --frame-index 0 --frame-count 3 --density 0.5
100
-
101
- # Grass terrain, sparse, 5 frames
102
- cyberia ol floor-grass --generate --seed meadow-7 --frame-count 5 --density 0.3
103
-
104
- # Water surface, dense, high element count
105
- cyberia ol floor-water --generate --seed ocean-1 --count 5 --density 0.8 --frame-count 4
106
-
107
- # Stone cobblestone
108
- cyberia ol floor-stone --generate --seed cobble-99 --count 4 --density 0.6
109
-
110
- # Lava flow, 3-frame animation
111
- cyberia ol floor-lava --generate --seed magma-3 --frame-count 3 --density 0.7
112
-
113
- # Skin: random skin tone and hair
114
- cyberia ol skin-random --generate --seed hero-1 --frame-count 4
115
-
116
- # Skin: dark skin only
117
- cyberia ol skin-dark --generate --seed hero-dark-7
118
-
119
- # Skin: light/pale skin only
120
- cyberia ol skin-light --generate --seed hero-light-3 --frame-count 4
121
-
122
- # Skin: any skin tone with vivid (blue/red/green…) hair
123
- cyberia ol skin-vivid --generate --seed hero-vivid-2
3
+ <img src="https://www.cyberiaonline.com/assets/splash/apple-touch-icon-precomposed.png" alt="CYBERIA Network Object Layer Engine"/>
124
4
 
125
- # Skin: any skin tone with natural hair only (brown, blond, grey…)
126
- cyberia ol skin-natural --generate --seed hero-nat-5 --frame-count 4
5
+ <h1>CYBERIA</h1>
127
6
 
128
- # Skin: shaved / bald head (no hair at all)
129
- cyberia ol skin-shaved --generate --seed hero-bald-1 --frame-count 4
130
- ```
131
-
132
- **`--generate` options:**
133
-
134
- | Option | Default | Description |
135
- | ------------------- | --------- | --------------------------------------------------- |
136
- | `--seed <str>` | auto UUID | Deterministic seed string. Same seed → same output. |
137
- | `--count <n>` | `3` | Shape element count multiplier per layer. |
138
- | `--frame-index <n>` | `0` | Starting frame index. |
139
- | `--frame-count <n>` | `1` | Number of consecutive frames to generate. |
140
- | `--density <f>` | `0.5` | Overall density factor (`0`–`1`). Lower = sparser. |
141
-
142
- **Available semantic item-id prefixes:**
143
-
144
- | Prefix | Type | Tags | Palette |
145
- | -------------- | ----- | -------------------- | -------------------------- |
146
- | `floor-desert` | floor | sand, dune, arid | warm ochres, sand tones |
147
- | `floor-grass` | floor | grass, meadow, earth | greens, earth browns |
148
- | `floor-water` | floor | water, ocean, wave | blues, foam whites |
149
- | `floor-stone` | floor | stone, rock, cobble | greys, warm/cool stone |
150
- | `floor-lava` | floor | lava, magma, fire | reds, oranges, dark crust |
151
- | `skin-random` | skin | character, body | any skin tone, any hair |
152
- | `skin-dark` | skin | character, body | dark/melanin-rich skin only |
153
- | `skin-light` | skin | character, body | light/pale skin only |
154
- | `skin-vivid` | skin | character, body | any skin + vivid hair (blue, red…) |
155
- | `skin-natural` | skin | character, body | any skin + natural hair (brown…) |
156
- | `skin-shaved` | skin | character, body | any skin, bald/shaved head |
157
-
158
- #### How generation works
159
-
160
- Each item-id maps to a **semantic descriptor** that provides `semanticTags`, `paletteHints`, `preferredShapes`, and named **layer specs** (e.g. `base`, `dunes`, `rocks`, `tufts` for `floor-desert`).
161
-
162
- **Seed derivation** — deterministic at every level:
163
-
164
- ```
165
- layerSeed = hash(seed + ':' + itemId + ':' + layerKey)
166
- frameSeed = hash(layerSeed + ':' + frameIndex)
167
- ```
168
-
169
- **Temporal coherence** — shape topology (which shapes, how many, where) is locked to `layerSeed` and never changes between frames. Only smooth, low-frequency noise perturbations (position jitter, slight rotation/scale wobble) are derived from `frameSeed`, so frame N and N+1 differ by ~2% of cells.
170
-
171
- **Layer naming** — every generated layer gets an id: `<itemId>-<layerKey>` (e.g. `floor-desert-dunes`).
172
-
173
- **Generation pipeline per layer:**
174
-
175
- 1. Pick generator type (`noise-field` for base fills, `shape` for element placement).
176
- 2. Select palette colors deterministically from `paletteHints` with per-element `colorShift`.
177
- 3. For shape layers: pick shape via weighted `preferredShapes`, compute stable base transform `(x, y, scale, rotation)`, apply frame-level smooth noise.
178
- 4. Stamp shapes onto a 24×24 grid via `intCoords` rasterization from the parametric shape generator.
179
- 5. Composite all layers into a final `frame_matrix` + unified `colors` palette.
180
-
181
- **Variability factors per layer:**
182
- `scaleVariance`, `rotationVariance`, `colorShift`, `jitter`, `noiseLevel`, `detailLevel`, `sparsity` — small, deterministic variations that keep each generation unique but semantically coherent.
183
-
184
- #### What `--generate` persists
185
-
186
- The full pipeline runs automatically:
187
-
188
- 1. **Static assets** — PNGs written to `./src/client/public/cyberia/assets/{type}/{itemId}/{dirCode}/{frame}.png` + `metadata.json`.
189
- 2. **MongoDB** — `ObjectLayerRenderFrames` + `ObjectLayer` documents created with SHA-256 hash.
190
- 3. **Atlas sprite sheet** — generated, saved to `File` + `AtlasSpriteSheet` collections, and linked via `atlasSpriteSheetId`.
191
-
192
- #### Reproducibility example
193
-
194
- Running the same command twice produces byte-identical output:
195
-
196
- ```bash
197
- # Run 1
198
- cyberia ol floor-desert --generate --seed fx-42 --count 3 --frame-count 2
199
-
200
- # Run 2 (identical output)
201
- cyberia ol floor-desert --generate --seed fx-42 --count 3 --frame-count 2
202
- ```
7
+ **Network Object Layers**
203
8
 
204
- Different seeds produce different but semantically consistent results:
9
+ _Stackable Rendering Layers as a Unified Tokenized Reality_
205
10
 
206
- ```bash
207
- cyberia ol floor-desert --generate --seed fx-42 # variant A
208
- cyberia ol floor-desert --generate --seed fx-99 # variant B (same style, different arrangement)
209
- ```
210
-
211
- ### Drop and cleanup with `--drop`
212
-
213
- Removes object layer data from MongoDB and IPFS. Supports both targeted (specific items) and full drop.
214
-
215
- ```bash
216
- # Drop specific items by item-id
217
- cyberia ol anon,skin --drop
218
-
219
- # Drop all object layers before re-importing
220
- cyberia ol --drop --import-types all
221
- ```
222
-
223
- **What `--drop` removes per item:**
224
-
225
- - `ObjectLayer` document
226
- - `ObjectLayerRenderFrames` document
227
- - `AtlasSpriteSheet` document
228
- - Associated `File` documents
229
- - IPFS CID pins (objectLayer.cid, render.cid, render.metadataCid, AtlasSpriteSheet.cid) from both IPFS Cluster and Kubo
230
- - MFS paths (`/object-layer/{itemKey}`)
231
-
232
- **`--drop` companion flags:**
233
-
234
- | Flag | Description |
235
- | ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------- |
236
- | `--client-public` | Also remove static asset folders: `./src/client/public/cyberia/assets/{type}/{itemId}/` and `./public/{host}{path}/assets/{type}/{itemId}/` |
237
- | `--git-clean` | Run `underpost run clean .` on the `src/client/public/cyberia` directory to remove untracked files |
238
-
239
- ```bash
240
- # Drop items and remove their static asset folders
241
- cyberia ol anon --drop --client-public
242
-
243
- # Full rebuild: drop everything, clean assets, re-import all
244
- cyberia ol --drop --git-clean --import-types all
245
- ```
246
-
247
- ### Environment and database flags
248
-
249
- These flags apply to both `ol` and `chain` commands where database or environment access is needed.
250
-
251
- | Flag | Default | Description |
252
- | ---------------------------- | -------- | ----------------------------------------------------------------------------- |
253
- | `--env-path <path>` | `./.env` | Path to .env file (e.g., `./engine-private/conf/dd-cyberia/.env.development`) |
254
- | `--mongo-host <host>` | — | MongoDB host override |
255
- | `--storage-file-path <path>` | — | Storage file path override (JSON filter for selective import) |
256
- | `--dev` | `false` | Force development environment (loads `.env.development` for IPFS localhost) |
257
-
258
- ```bash
259
- # Import using a specific environment
260
- cyberia ol --import-types all --env-path ./engine-private/conf/dd-cyberia/.env.development
261
-
262
- # Use development IPFS localhost
263
- cyberia ol anon --import --dev
264
-
265
- # Override MongoDB host
266
- cyberia ol --import-types skin --mongo-host mongodb://localhost:27017
267
- ```
11
+ [![Version](https://img.shields.io/npm/v/cyberia.svg)](https://www.npmjs.org/package/cyberia)
268
12
 
269
- ## Visualize a processed frame
270
-
271
- Reconstructs and opens a PNG from the database-stored frame data. Requires item-id as the first positional argument, followed by direction and frame index in the format `[direction]_[frameIndex]`.
272
-
273
- ```bash
274
- # Show frame with default direction and frame (08_0)
275
- cyberia ol anon --show-frame
276
-
277
- # Show specific direction and frame
278
- cyberia ol anon --show-frame 08_0
279
-
280
- # Show different directions
281
- cyberia ol anon --show-frame 02_0 # up_idle
282
- cyberia ol anon --show-frame 04_1 # left_idle (second frame)
283
- ```
284
-
285
- **Valid direction codes:**
286
-
287
- - `08`: down_idle, none_idle, default_idle
288
- - `18`: down_walking
289
- - `02`: up_idle
290
- - `12`: up_walking
291
- - `04`: left_idle, up_left_idle, down_left_idle
292
- - `14`: left_walking, up_left_walking, down_left_walking
293
- - `06`: right_idle, up_right_idle, down_right_idle
294
- - `16`: right_walking, up_right_walking, down_right_walking
295
-
296
- This command:
297
-
298
- - Finds the ObjectLayer by item-id
299
- - Loads the associated ObjectLayerRenderFrames document
300
- - Reconstructs the PNG from the stored `frame_matrix` and `map_color`
301
- - Saves it temporarily to disk as `{item-id}_{direction}_{frame}.png`
302
- - Opens it with Firefox for visual inspection
303
-
304
- ### Generate Atlas Sprite Sheet
305
-
306
- Consolidates all frames (8 directions, multiple modes) from an object layer's render frames into a single optimized PNG atlas with metadata.
307
-
308
- ```bash
309
- # Generate atlas sprite sheet with auto-calculated dimensions (recommended)
310
- cyberia ol anon --to-atlas-sprite-sheet
311
-
312
- # Generate atlas with custom dimensions (manual override)
313
- cyberia ol anon --to-atlas-sprite-sheet 4096
314
-
315
-
316
- ```
317
-
318
- This command:
319
-
320
- - Finds the ObjectLayer by item-id or MongoDB `_id`
321
- - Loads the associated ObjectLayerRenderFrames document
322
- - **Auto-calculates optimal atlas dimensions** based on total frame count (8 directions × all animation modes)
323
- - Generates a consolidated PNG with all animation frames properly arranged
324
- - Stores the PNG in the File collection
325
- - Creates/updates an AtlasSpriteSheet document with frame positions
326
- - Updates the ObjectLayer with top-level `atlasSpriteSheetId` reference
327
- - Uses power-of-2 dimensions for GPU efficiency
328
-
329
- **Atlas Dimension Calculation:**
330
-
331
- - **Auto (default)**: Dynamically calculates optimal size based on:
332
- - Total number of frames across all directions and modes
333
- - Individual frame dimensions
334
- - Grid layout to minimize wasted space
335
- - Power-of-2 optimization (1024, 2048, 4096, etc.)
336
- - **Manual override**: Specify exact dimension (e.g., `--to-atlas-sprite-sheet 4096`)
337
-
338
- **Common Atlas Sizes:**
339
-
340
- - **1024x1024**: ~6-10 frames
341
- - **2048x2048**: ~20-40 frames (typical for character sprites)
342
- - **4096x4096**: ~80-160 frames (complex animations)
343
- - **8192x8192**: Maximum, for extreme cases
344
-
345
- The tool automatically warns if frames exceed the specified dimension and suggests a larger size.
346
-
347
- ### View Atlas Sprite Sheet
348
-
349
- Opens the consolidated atlas sprite sheet PNG for inspection.
350
-
351
- ```bash
352
- # Show atlas sprite sheet by item-id
353
- cyberia ol anon --show-atlas-sprite-sheet
354
-
355
- ```
356
-
357
- This command:
358
-
359
- - Finds the ObjectLayer by item-id
360
- - Retrieves the associated AtlasSpriteSheet via top-level `atlasSpriteSheetId` or by matching `metadata.itemKey`
361
- - Saves it temporarily to disk
362
- - Opens it with Firefox for visual inspection
363
- - Displays atlas dimensions in the console
364
-
365
- ## Common Workflows
366
-
367
- ### Complete Asset Processing Pipeline
368
-
369
- Process assets from source files through to atlas generation:
370
-
371
- ```bash
372
- # 1. Import object layers from asset directories
373
- cyberia ol --import-types skin
374
-
375
- # 2. Verify a specific frame was imported correctly
376
- cyberia ol anon --show-frame 08_0
377
-
378
- # 3. Generate optimized atlas sprite sheet
379
- cyberia ol anon --to-atlas-sprite-sheet
380
-
381
- # 4. View the generated atlas
382
- cyberia ol anon --show-atlas-sprite-sheet
383
- ```
384
-
385
- ### Procedural Generation Pipeline
386
-
387
- Generate an object layer entirely from a semantic descriptor — no source PNGs needed:
388
-
389
- ```bash
390
- # 1. Generate a 3-frame desert floor with explicit seed
391
- cyberia ol floor-desert --generate --seed fx-42 --frame-count 3 --density 0.5
392
-
393
- # 2. Inspect the generated frame
394
- cyberia ol floor-desert --show-frame 08_0
395
-
396
- # 3. View the auto-generated atlas
397
- cyberia ol floor-desert --show-atlas-sprite-sheet
398
- ```
399
-
400
- ### Batch Procedural Generation
401
-
402
- Generate a full tileset family with consistent seeds:
403
-
404
- ```bash
405
- cyberia ol floor-desert --generate --seed world-1 --frame-count 3
406
- cyberia ol floor-grass --generate --seed world-1 --frame-count 3
407
- cyberia ol floor-water --generate --seed world-1 --frame-count 4
408
- cyberia ol floor-stone --generate --seed world-1 --frame-count 2
409
- cyberia ol floor-lava --generate --seed world-1 --frame-count 3
410
- ```
411
-
412
- ### Exploring Seed Variations
413
-
414
- ```bash
415
- # Same item, different seeds — compare visual output
416
- cyberia ol floor-desert --generate --seed alpha --frame-count 1
417
- cyberia ol floor-desert --generate --seed beta --frame-count 1
418
- cyberia ol floor-desert --generate --seed gamma --frame-count 1
419
-
420
- # Inspect each
421
- cyberia ol floor-desert --show-frame 08_0
422
- ```
423
-
424
- ### Debugging Asset Issues
13
+ </div>
14
+ Cyberia is an MMORPG extension built on the Underpost Platform. The platform owns the
15
+ toolchain, deployment surface, PWA delivery, and base infrastructure. Cyberia adds a three-service MMO
16
+ runtime: `engine-cyberia`, `cyberia-server`, and `cyberia-client`.
17
+
18
+ `engine-cyberia` is the **sidecar-backed data layer**: a Node.js sidecar that owns content,
19
+ validation, persistence, the gRPC/REST data services, and asset metadata. It backs the authoritative
20
+ Go server and the WASM client with data — it does not run the simulation or the presentation.
425
21
 
426
- ```bash
427
- # Check if frame data is correct for all directions
428
- cyberia ol anon --show-frame 08_0 # down_idle
429
- cyberia ol anon --show-frame 02_0 # up_idle
430
- cyberia ol anon --show-frame 04_0 # left_idle
431
- cyberia ol anon --show-frame 06_0 # right_idle
432
-
433
- # Verify walking animations
434
- cyberia ol anon --show-frame 18_0 # down_walking
435
- cyberia ol anon --show-frame 12_0 # up_walking
436
- cyberia ol anon --show-frame 14_0 # left_walking
437
- cyberia ol anon --show-frame 16_0 # right_walking
438
- ```
22
+ ---
439
23
 
440
- ### Working with Multiple Items
24
+ ## Ecosystem at a glance
441
25
 
442
- ```bash
443
- # Import multiple types at once
444
- cyberia ol --import-types skin,floor,weapon
445
-
446
- # Process individual items
447
- cyberia ol sword --show-frame 08_0
448
- cyberia ol sword --to-atlas-sprite-sheet
449
- cyberia ol shield --show-frame 08_0
450
- cyberia ol shield --to-atlas-sprite-sheet
451
- ```
26
+ ```text
27
+ ┌───────────────────────────────────────────────┐
28
+ │ UNDERPOST PLATFORM │
29
+ │ toolchain · deploy · PWA build · static │
30
+ │ delivery · cluster/image/db · monitoring │
31
+ │ │
32
+ │ underpost CLI ──▶ builds & deploys all │
33
+ └───────────────────────────────────────────────┘
34
+ │ hosts / delivers
35
+
36
+ ╔═══════════════════════════════ CYBERIA MMO ══════════════════════════════════╗
37
+ ║ ║
38
+ ║ ┌──────────────────┐ gRPC ┌──────────────────┐ WebSocket ║
39
+ ║ │ engine-cyberia │ ────────▶ │ cyberia-server │ ───────────┐ ║
40
+ ║ │ (Node.js) │ │ (Go) │ │ ║
41
+ ║ │ │ │ │ ▼ ║
42
+ ║ │ content │ │ authoritative │ ┌──────────────────┐ ║
43
+ ║ │ validation │ │ simulation │ │ cyberia-client │ ║
44
+ ║ │ persistence │ │ world tick │ │ (C / WASM) │ ║
45
+ ║ │ gRPC/REST data │ │ AOI replication │ │ │ ║
46
+ ║ │ asset metadata │ │ │ │ rendering │ ║
47
+ ║ └──────────────────┘ └──────────────────┘ │ input │ ║
48
+ ║ │ │ prediction │ ║
49
+ ║ └──────────────── REST (content/assets) ─────▶│ presentation │ ║
50
+ ║ └──────────────────┘ ║
51
+ ╚═══════════════════════════════════════════════════════════════════════════════╝
452
52
 
453
- ### Full Rebuild with Cleanup
53
+ One source of truth per concern:
54
+ content & world config ── engine-cyberia
55
+ real-time world state ── cyberia-server
56
+ presentation & input ── cyberia-client
57
+ ```
58
+
59
+ ---
60
+
61
+ ## 1. Toolchain and base infrastructure
62
+
63
+ Underpost Platform is the operational backbone and the source of truth for deploy IDs, runtime
64
+ selection, host/path layout, generated client assets, and environment resolution.
65
+
66
+ | Area | What it owns |
67
+ | --------------- | ------------------------------------------------------------------------------------ |
68
+ | Toolchain | `underpost` CLI, build, deploy, release, metadata, secrets, environment selection |
69
+ | Infrastructure | bare metal, LXD, Kubernetes, K3s, kubeadm, images, SSH, runners |
70
+ | Data operations | MongoDB, MariaDB where needed, backups, cron, monitoring |
71
+ | Delivery | static build, SSR views, PWA packaging, service worker generation, host/path routing |
72
+
73
+ `underpost` is the shared control surface for everything infrastructural. Cyberia-specific work belongs
74
+ in the `cyberia` CLI, never in parallel platform commands. When a concern already exists in `underpost`,
75
+ reuse it instead of forking a Cyberia variant.
454
76
 
455
- Drop all data, clean static assets, and re-import everything:
77
+ ---
456
78
 
457
- ```bash
458
- # 1. Drop all object layers with IPFS cleanup and static asset removal
459
- cyberia ol --drop --client-public --git-clean
79
+ ## 2. PWA workflow
460
80
 
461
- # 2. Re-import all asset types
462
- cyberia ol --import-types all
81
+ Every deployed client ships as a static application shell with PWA support. The pipeline has exactly two
82
+ inputs:
463
83
 
464
- # 3. Verify
465
- cyberia ol anon --show-frame 08_0
466
- ```
84
+ - the deploy `ssr` configuration in `conf.dd-*.js` (or `conf.ssr.json`)
85
+ - the service worker source in `src/client/sw/core.sw.js`
467
86
 
468
- ### Targeted Drop and Re-import
87
+ Everything else `index.html` pages, `sw.js`, the precache list — is **generated** during the client
88
+ build. Treat them as outputs only; never hand-edit them.
469
89
 
470
- Drop and re-import specific items without affecting others:
90
+ Runtime service-worker behavior:
471
91
 
472
- ```bash
473
- # 1. Drop specific items and their static folders
474
- cyberia ol anon,skin --drop --client-public
92
+ | Request | Strategy |
93
+ | ------------- | -------------------------------- |
94
+ | static assets | stale-while-revalidate |
95
+ | API `GET` | network-first + short cache |
96
+ | API mutations | network-only + background replay |
97
+ | navigation | network-first + fallback shells |
475
98
 
476
- # 2. Re-import only those items
477
- cyberia ol anon,skin --import
99
+ Fallback selection: offline network offline fallback view; origin/server failure → maintenance
100
+ fallback view. Only fallback-marked views are guaranteed precached.
478
101
 
479
- # 3. Regenerate atlas for each
480
- cyberia ol anon --to-atlas-sprite-sheet
481
- cyberia ol skin --to-atlas-sprite-sheet
482
- ```
102
+ ---
483
103
 
484
- ## Blockchain Operations (`chain`)
104
+ ## 3. Cyberia MMO extension
485
105
 
486
- The `chain` command group manages Hyperledger Besu IBFT2 network deployment and ERC-1155 token operations for on-chain object layer registration.
106
+ ### Responsibility split
487
107
 
488
- ### Deploy Besu IBFT2 Network
108
+ | Service | Owns | Must not own |
109
+ | ---------------- | ------------------------------------------------------------------------- | --------------------------------------------- |
110
+ | `engine-cyberia` | content, validation, persistence, gRPC/REST data services, asset metadata | authoritative simulation, render policy |
111
+ | `cyberia-server` | authoritative simulation, world tick, gameplay mutation, AOI replication | content authority, presentation metadata |
112
+ | `cyberia-client` | rendering, input, prediction, interpolation, presentation | authoritative world state, gameplay authority |
489
113
 
490
- Deploys a private Besu IBFT2 network to Kubernetes.
114
+ Two boundaries are non-negotiable:
491
115
 
492
- ```bash
493
- # Deploy with defaults (4 validators, chain-id 777771)
494
- cyberia chain deploy
116
+ - Do not move authoritative logic into the client.
117
+ - Do not move content-authority logic into the Go runtime.
495
118
 
496
- # Custom configuration
497
- cyberia chain deploy --validators 6 --chain-id 888881 --block-period 3
119
+ ### Data flow
498
120
 
499
- # Pull container images first
500
- cyberia chain deploy --pull-image
121
+ ```text
122
+ engine-cyberia ──gRPC──▶ cyberia-server ──WebSocket──▶ cyberia-client
123
+ engine-cyberia ──REST──────────────────────────────▶ cyberia-client
501
124
  ```
502
125
 
503
- **`deploy` options:**
504
-
505
- | Option | Default | Description |
506
- | --------------------------- | -------------------------- | -------------------------------------------------- |
507
- | `--validators <count>` | `4` | Number of IBFT2 validators |
508
- | `--chain-id <id>` | `777771` | Chain ID for the network |
509
- | `--block-period <seconds>` | `5` | IBFT2 block period in seconds |
510
- | `--epoch-length <length>` | `30000` | IBFT2 epoch length |
511
- | `--coinbase-address <addr>` | auto-detect | Coinbase deployer address |
512
- | `--besu-image <image>` | `hyperledger/besu:24.12.1` | Besu container image |
513
- | `--curl-image <image>` | `curlimages/curl:8.11.1` | Curl init container image |
514
- | `--node-port-rpc <port>` | `30545` | NodePort for external JSON-RPC access |
515
- | `--node-port-ws <port>` | `30546` | NodePort for external WebSocket access |
516
- | `--namespace <ns>` | `besu` | Kubernetes namespace for Besu resources |
517
- | `--pull-image` | `false` | Pull Besu container images before deployment |
518
- | `--skip-generate` | `false` | Skip manifest generation, use existing manifests |
519
- | `--skip-wait` | `false` | Skip waiting for validators to reach Running state |
520
-
521
- ### Remove Besu Network
126
+ ### `engine-cyberia` as the sidecar-backed data layer
522
127
 
523
- ```bash
524
- # Remove network (keep keys and manifests)
525
- cyberia chain remove
128
+ `engine-cyberia` is the only Cyberia service that owns content-backed data and asset metadata.
526
129
 
527
- # Full cleanup
528
- cyberia chain remove --clean-keys --clean-manifests
529
- ```
130
+ - Boot-time world configuration flows from `engine-cyberia` to `cyberia-server` over gRPC `GetFullInstance`.
131
+ - Client-facing assets, object layers, dialogues, and presentation hints flow from `engine-cyberia` to `cyberia-client` over REST.
132
+ - Simulation never migrates into the sidecar, and presentation policy never migrates out of the client.
530
133
 
531
- | Option | Default | Description |
532
- | ------------------- | ------- | --------------------------------------------------- |
533
- | `--namespace <ns>` | `besu` | Kubernetes namespace for Besu resources |
534
- | `--clean-keys` | `false` | Also remove generated validator keys |
535
- | `--clean-manifests` | `false` | Also remove the generated manifests/besu/ directory |
134
+ ### Runtime / health model
536
135
 
537
- ### Generate Manifests Without Deploying
136
+ Three supervised processes run in parallel, each with its own monitor and reconnect loop. Gameplay is live only when all three are healthy at once.
538
137
 
539
- ```bash
540
- cyberia chain generate-manifests --validators 6 --output-dir ./manifests/besu
138
+ ```text
139
+ ┌──────────────────────────────────────────────────────────────┐
140
+ │ SUPERVISION (parallel) │
141
+ │ │
142
+ │ engine-cyberia cyberia-server cyberia-client │
143
+ │ ┌────────────┐ ┌────────────┐ ┌────────────┐ │
144
+ │ │ monitor │ │ monitor │ │ monitor │ │
145
+ │ │ +reconnect │ │ +reconnect │ │ +reconnect │ │
146
+ │ └─────┬──────┘ └─────┬──────┘ └─────┬──────┘ │
147
+ │ │ │ │ │
148
+ │ └──────────┬──────────┴──────────┬──────────┘ │
149
+ │ ▼ ▼ │
150
+ │ all three up & connected? │
151
+ └────────────────────────────┬─────────────────────────────────┘
152
+
153
+ ┌─────────────────────┼─────────────────────┐
154
+ ▼ ▼ ▼
155
+ ┌───────────┐ ┌───────────┐ ┌───────────┐
156
+ │ HEALTHY │ │ DEGRADED │ │ STANDBY │
157
+ │ all 3 up │ │ ≥1 service│ │ gameplay │
158
+ │ gameplay │ │ reconnect-│ │ paused │
159
+ │ live │ │ ing / down│ │ until all │
160
+ │ │ │ │ │ 3 healthy │
161
+ └───────────┘ └───────────┘ └───────────┘
541
162
  ```
542
163
 
543
- Accepts the same options as `deploy` plus `--output-dir <dir>` (default: `./manifests/besu`).
164
+ | State | Meaning |
165
+ | ---------- | -------------------------------------------------------------------- |
166
+ | `healthy` | all three Cyberia services are up and connected |
167
+ | `degraded` | at least one service is reconnecting or unavailable |
168
+ | `standby` | gameplay is paused because the full three-service set is not healthy |
544
169
 
545
- ### Deploy ERC-1155 Contract
170
+ ---
546
171
 
547
- ```bash
548
- cyberia chain deploy-contract
549
- cyberia chain deploy-contract --network besu-k8s
550
- ```
551
-
552
- ### Compile and Test Contracts
553
-
554
- ```bash
555
- cyberia chain compile
556
- cyberia chain test
557
- ```
172
+ ## User commands
558
173
 
559
- ### Register Object Layer Item On-Chain
174
+ Use `underpost` for platform, infrastructure, build, and deploy. Use `cyberia` for MMO content and
175
+ extension workflows. Both share the same helpers — never duplicate config, env, or path logic.
560
176
 
561
- Registers an object layer as an ERC-1155 token with its canonical CID.
177
+ ### Platform (underpost)
562
178
 
563
179
  ```bash
564
- # Register with CID resolved from MongoDB (recommended)
565
- cyberia chain register --item-id hatchet --from-db
180
+ # Bootstrap a new app (local app serves on http://localhost:4001)
181
+ underpost new app-name
566
182
 
567
- # Register with explicit CID
568
- cyberia chain register --item-id hatchet --metadata-cid bafk...
183
+ # Build the client bundle / static + PWA output
184
+ underpost client
185
+ npm run build # node bin client
569
186
 
570
- # Semi-fungible with supply
571
- cyberia chain register --item-id wood --from-db --supply 500000
187
+ # Deploy and operate
188
+ underpost deploy <deploy-id>
189
+ underpost monitor
572
190
  ```
573
191
 
574
- | Option | Default | Required | Description |
575
- | ---------------------- | ---------- | -------- | ------------------------------------------------------- |
576
- | `--item-id <itemId>` | — | yes | Human-readable item identifier |
577
- | `--metadata-cid <cid>` | — | — | IPFS metadata CID (ignored when `--from-db` is set) |
578
- | `--from-db` | `false` | — | Resolve canonical CID from MongoDB ObjectLayer document |
579
- | `--supply <supply>` | `1` | — | Initial token supply (1 = NFT, >1 = semi-fungible) |
580
- | `--network <network>` | `besu-k8s` | — | Hardhat network name |
581
- | `--env-path <path>` | `./.env` | — | Path to .env file |
582
- | `--mongo-host <host>` | — | — | MongoDB host override |
192
+ ### Cyberia (cyberia) `bin/cyberia.js`
583
193
 
584
- ### Batch Register Multiple Items
194
+ | Group | Command | Purpose |
195
+ | -------------- | -------------------------------------- | -------------------------------------------------------- |
196
+ | `ol` | `cyberia ol [item-id]` | ObjectLayer import, procedural generation, atlas/sprite |
197
+ | `instance` | `cyberia instance [instance-code]` | export / import / drop a Cyberia instance and its data |
198
+ | `client-hints` | `cyberia client-hints [instance-code]` | per-instance presentation hints (palette, camera, icons) |
199
+ | `chain` | `cyberia chain <sub>` | Hyperledger Besu + ERC-1155 ObjectLayerToken lifecycle |
200
+ | `run-workflow` | `cyberia run-workflow <name>` | named maintenance/build scripts from `scripts/` |
585
201
 
586
- ```bash
587
- # Batch register with CIDs from MongoDB
588
- cyberia chain batch-register --from-db --items '[{"itemId":"wood","supply":500000},{"itemId":"hatchet","supply":1}]'
589
-
590
- # Batch register with explicit CIDs
591
- cyberia chain batch-register --items '[{"itemId":"wood","cid":"bafk...","supply":500000}]'
592
- ```
593
-
594
- ### Mint, Transfer, and Burn Tokens
202
+ Common examples:
595
203
 
596
204
  ```bash
597
- # Mint additional tokens
598
- cyberia chain mint --token-id 1 --to 0xAddress --amount 100
599
-
600
- # Transfer tokens
601
- cyberia chain transfer --from 0xSender --to 0xRecipient --token-id 1 --amount 50
205
+ # Object layer content
206
+ cyberia ol hatchet,sword --import # import specific items
207
+ cyberia ol --import-types skin,floors # batch import by type (or: all)
208
+ cyberia ol floor-desert --generate --seed fx-42 # procedural generation
209
+ cyberia ol hatchet --to-atlas-sprite-sheet # build atlas sprite sheet
210
+ cyberia ol --drop --client-public # drop data + static asset folders
602
211
 
603
- # Burn tokens
604
- cyberia chain burn --address 0xHolder --token-id 1 --amount 10
605
- ```
212
+ # Instance data
213
+ cyberia instance FOREST --export ./backup
214
+ cyberia instance FOREST --import ./backup
215
+ cyberia instance FOREST --drop
606
216
 
607
- ### Query Status and Balances
217
+ # Presentation hints
218
+ cyberia client-hints cyberia-main --seed-defaults
608
219
 
609
- ```bash
610
- # Full network and contract status
220
+ # Chain / token lifecycle
221
+ cyberia chain deploy --chain-id 777771
611
222
  cyberia chain status
223
+ cyberia chain register / mint / transfer / burn / pause / unpause
612
224
 
613
- # Query token balance
614
- cyberia chain balance --address 0xAddress --token-id 0
225
+ # Named workflows
226
+ cyberia run-workflow import-default-items
227
+ cyberia run-workflow seed-skill-config --instance-code default
228
+ cyberia run-workflow seed-dialogues
229
+ cyberia run-workflow build-manifest
230
+ cyberia run-workflow build-server-dashboard
615
231
  ```
616
232
 
617
- ### Key Management
233
+ ### Run the MMO services
618
234
 
619
235
  ```bash
620
- # Generate a new Ethereum key pair
621
- cyberia chain key-gen
622
-
623
- # Generate and persist keys
624
- cyberia chain key-gen --save
236
+ # engine-cyberia (Node.js data/content services)
237
+ npm start # node src/server
625
238
 
626
- # Set coinbase deployer key
627
- cyberia chain set-coinbase --from-file ./engine-private/eth-networks/besu/0xAddr.key.json
628
- cyberia chain set-coinbase --private-key 0xHexKey
629
- ```
630
-
631
- ### Pause / Unpause Token Transfers (Emergency)
239
+ # cyberia-server (Go authoritative simulation)
240
+ cd cyberia-server && go run main.go # dev
241
+ cd cyberia-server && go build -o cyberia-server . && ./cyberia-server
632
242
 
633
- ```bash
634
- cyberia chain pause
635
- cyberia chain unpause
243
+ # cyberia-client (C / WASM presentation)
244
+ cd cyberia-client && make -f Web.mk clean && make -f Web.mk web
245
+ cd cyberia-client && make -f Web.mk serve-development # serves on :8082
636
246
  ```
637
247
 
638
- ## Workflow Import (`run-workflow`)
248
+ ---
639
249
 
640
- ### Import Default Items
641
-
642
- Imports default Object Layer items from a JSON configuration file into MongoDB.
643
-
644
- ```bash
645
- cyberia run-workflow import-default-items
646
-
647
- # Use development environment
648
- cyberia run-workflow import-default-items --dev
649
- ```
250
+ ## Operational guardrails
650
251
 
651
- ## Complete `ol` Command Reference
652
-
653
- | Flag | Type | Default | Description |
654
- | ------------------------------- | ------- | ----------- | ---------------------------------------------------------- |
655
- | `--import` | boolean | `false` | Import specific item(s) passed as comma-separated argument |
656
- | `--import-types [type]` | string | — | Batch import by type: `skin`, `floors`, or `all` |
657
- | `--show-frame [dir_frame]` | string | `08_0` | View object layer frame (direction_frameIndex) |
658
- | `--to-atlas-sprite-sheet [dim]` | number | auto | Generate atlas sprite sheet, optionally specify dimension |
659
- | `--show-atlas-sprite-sheet` | boolean | `false` | Display the atlas sprite sheet PNG for an item |
660
- | `--generate` | boolean | `false` | Generate procedural object layers from semantic item-id |
661
- | `--seed <str>` | string | random UUID | Deterministic seed for `--generate` |
662
- | `--count <n>` | number | `3` | Shape element count multiplier for `--generate` |
663
- | `--frame-index <n>` | number | `0` | Starting frame index for `--generate` |
664
- | `--frame-count <n>` | number | `1` | Number of frames for `--generate` |
665
- | `--density <f>` | number | `0.5` | Density factor (0–1) for `--generate` |
666
- | `--drop` | boolean | `false` | Drop existing data (targeted or full) |
667
- | `--client-public` | boolean | `false` | With `--drop`, remove static asset folders |
668
- | `--git-clean` | boolean | `false` | With `--drop`, run underpost clean on cyberia assets |
669
- | `--dev` | boolean | `false` | Force development environment |
670
- | `--env-path <path>` | string | `./.env` | Path to .env file |
671
- | `--mongo-host <host>` | string | — | MongoDB host override |
672
- | `--storage-file-path <path>` | string | — | Storage file path override |
252
+ - Prefer one source of truth for config, deploy IDs, runtime selection, startup behavior, and generated assets.
253
+ - Reuse existing helpers and conventions instead of creating parallel implementations.
254
+ - Do not duplicate parsing, env resolution, or path normalization logic across modules.
255
+ - Treat generated artifacts (`sw.js`, static pages, atlases, README, manifests) as outputs only.
256
+ - Host-level changes must be idempotent, reversible, and explicit; validate before mutating; keep
257
+ orchestration scripts safe to rerun.
258
+ - `engine-private/` is a private external dependency. Reference it only as private input; never assume
259
+ its contents exist locally.