cyberia 3.0.3 → 3.2.5

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 (296) hide show
  1. package/{.env.production → .env.example} +20 -4
  2. package/.github/workflows/engine-cyberia.cd.yml +43 -10
  3. package/.github/workflows/engine-cyberia.ci.yml +48 -26
  4. package/.github/workflows/ghpkg.ci.yml +5 -5
  5. package/.github/workflows/gitlab.ci.yml +1 -1
  6. package/.github/workflows/hardhat.ci.yml +82 -0
  7. package/.github/workflows/npmpkg.ci.yml +60 -14
  8. package/.github/workflows/publish.ci.yml +26 -7
  9. package/.github/workflows/publish.cyberia.ci.yml +5 -5
  10. package/.github/workflows/pwa-microservices-template-page.cd.yml +6 -7
  11. package/.github/workflows/pwa-microservices-template-test.ci.yml +4 -4
  12. package/.github/workflows/release.cd.yml +14 -8
  13. package/.vscode/extensions.json +9 -8
  14. package/.vscode/settings.json +3 -2
  15. package/CHANGELOG.md +643 -1
  16. package/CLI-HELP.md +132 -57
  17. package/Dockerfile +4 -2
  18. package/README.md +347 -22
  19. package/WHITE-PAPER.md +1540 -0
  20. package/bin/build.js +21 -12
  21. package/bin/cyberia.js +2640 -106
  22. package/bin/deploy.js +258 -372
  23. package/bin/file.js +5 -1
  24. package/bin/index.js +2640 -106
  25. package/bin/vs.js +3 -3
  26. package/conf.js +169 -105
  27. package/deployment.yaml +236 -20
  28. package/hardhat/.env.example +31 -0
  29. package/hardhat/README.md +531 -0
  30. package/hardhat/WHITE-PAPER.md +1540 -0
  31. package/hardhat/contracts/ObjectLayerToken.sol +391 -0
  32. package/hardhat/deployments/.gitkeep +0 -0
  33. package/hardhat/deployments/hardhat-ObjectLayerToken.json +11 -0
  34. package/hardhat/hardhat.config.js +136 -0
  35. package/hardhat/ignition/modules/ObjectLayerToken.js +21 -0
  36. package/hardhat/networks/besu-object-layer.network.json +138 -0
  37. package/hardhat/package-lock.json +4323 -0
  38. package/hardhat/package.json +36 -0
  39. package/hardhat/scripts/deployObjectLayerToken.js +98 -0
  40. package/hardhat/test/ObjectLayerToken.js +592 -0
  41. package/hardhat/types/ethers-contracts/ObjectLayerToken.ts +690 -0
  42. package/hardhat/types/ethers-contracts/common.ts +92 -0
  43. package/hardhat/types/ethers-contracts/factories/ObjectLayerToken__factory.ts +1055 -0
  44. package/hardhat/types/ethers-contracts/factories/index.ts +4 -0
  45. package/hardhat/types/ethers-contracts/hardhat.d.ts +47 -0
  46. package/hardhat/types/ethers-contracts/index.ts +6 -0
  47. package/jsdoc.dd-cyberia.json +68 -0
  48. package/jsdoc.json +65 -49
  49. package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +5 -4
  50. package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +5 -4
  51. package/manifests/deployment/dd-cyberia-development/deployment.yaml +562 -0
  52. package/manifests/deployment/dd-cyberia-development/proxy.yaml +297 -0
  53. package/manifests/deployment/dd-cyberia-development/pv-pvc.yaml +132 -0
  54. package/manifests/deployment/dd-default-development/deployment.yaml +2 -2
  55. package/manifests/deployment/dd-test-development/deployment.yaml +88 -74
  56. package/manifests/deployment/dd-test-development/proxy.yaml +13 -4
  57. package/manifests/deployment/playwright/deployment.yaml +1 -1
  58. package/manifests/pv-pvc-dd.yaml +1 -1
  59. package/nodemon.json +1 -1
  60. package/package.json +60 -48
  61. package/proxy.yaml +118 -10
  62. package/pv-pvc.yaml +132 -0
  63. package/scripts/k3s-node-setup.sh +1 -1
  64. package/scripts/ports-ls.sh +2 -0
  65. package/scripts/rhel-grpc-setup.sh +56 -0
  66. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +47 -1
  67. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +17 -2
  68. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.router.js +5 -0
  69. package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +80 -7
  70. package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +93 -0
  71. package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +36 -0
  72. package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +29 -0
  73. package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +51 -0
  74. package/src/api/cyberia-entity/cyberia-entity.controller.js +74 -0
  75. package/src/api/cyberia-entity/cyberia-entity.model.js +24 -0
  76. package/src/api/cyberia-entity/cyberia-entity.router.js +27 -0
  77. package/src/api/cyberia-entity/cyberia-entity.service.js +42 -0
  78. package/src/api/cyberia-instance/cyberia-fallback-world.js +368 -0
  79. package/src/api/cyberia-instance/cyberia-instance.controller.js +92 -0
  80. package/src/api/cyberia-instance/cyberia-instance.model.js +84 -0
  81. package/src/api/cyberia-instance/cyberia-instance.router.js +63 -0
  82. package/src/api/cyberia-instance/cyberia-instance.service.js +191 -0
  83. package/src/api/cyberia-instance/cyberia-portal-connector.js +486 -0
  84. package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +74 -0
  85. package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +413 -0
  86. package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +228 -0
  87. package/src/api/cyberia-instance-conf/cyberia-instance-conf.router.js +27 -0
  88. package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +42 -0
  89. package/src/api/cyberia-map/cyberia-map.controller.js +79 -0
  90. package/src/api/cyberia-map/cyberia-map.model.js +30 -0
  91. package/src/api/cyberia-map/cyberia-map.router.js +40 -0
  92. package/src/api/cyberia-map/cyberia-map.service.js +74 -0
  93. package/src/api/document/document.service.js +1 -1
  94. package/src/api/file/file.controller.js +3 -1
  95. package/src/api/file/file.ref.json +18 -0
  96. package/src/api/file/file.service.js +28 -5
  97. package/src/api/ipfs/ipfs.controller.js +4 -25
  98. package/src/api/ipfs/ipfs.model.js +43 -34
  99. package/src/api/ipfs/ipfs.router.js +8 -13
  100. package/src/api/ipfs/ipfs.service.js +56 -104
  101. package/src/api/object-layer/README.md +347 -22
  102. package/src/api/object-layer/object-layer.controller.js +6 -2
  103. package/src/api/object-layer/object-layer.model.js +12 -8
  104. package/src/api/object-layer/object-layer.router.js +698 -42
  105. package/src/api/object-layer/object-layer.service.js +119 -37
  106. package/src/api/object-layer-render-frames/object-layer-render-frames.model.js +1 -2
  107. package/src/api/user/user.router.js +10 -5
  108. package/src/api/user/user.service.js +15 -14
  109. package/src/cli/baremetal.js +6 -10
  110. package/src/cli/cloud-init.js +0 -3
  111. package/src/cli/cluster.js +7 -7
  112. package/src/cli/db.js +723 -857
  113. package/src/cli/deploy.js +215 -105
  114. package/src/cli/env.js +34 -5
  115. package/src/cli/fs.js +5 -4
  116. package/src/cli/image.js +0 -3
  117. package/src/cli/index.js +83 -15
  118. package/src/cli/kubectl.js +211 -0
  119. package/src/cli/monitor.js +5 -6
  120. package/src/cli/release.js +284 -0
  121. package/src/cli/repository.js +708 -62
  122. package/src/cli/run.js +371 -151
  123. package/src/cli/secrets.js +73 -2
  124. package/src/cli/ssh.js +1 -1
  125. package/src/cli/test.js +3 -3
  126. package/src/client/Cryptokoyn.index.js +3 -4
  127. package/src/client/CyberiaPortal.index.js +3 -4
  128. package/src/client/Default.index.js +3 -4
  129. package/src/client/Itemledger.index.js +4 -963
  130. package/src/client/Underpost.index.js +3 -4
  131. package/src/client/components/core/AgGrid.js +20 -5
  132. package/src/client/components/core/Alert.js +2 -2
  133. package/src/client/components/core/AppStore.js +69 -0
  134. package/src/client/components/core/CalendarCore.js +2 -2
  135. package/src/client/components/core/Content.js +22 -3
  136. package/src/client/components/core/Docs.js +30 -6
  137. package/src/client/components/core/DropDown.js +137 -17
  138. package/src/client/components/core/FileExplorer.js +71 -4
  139. package/src/client/components/core/Input.js +1 -1
  140. package/src/client/components/core/Keyboard.js +2 -2
  141. package/src/client/components/core/LogIn.js +2 -2
  142. package/src/client/components/core/LogOut.js +2 -2
  143. package/src/client/components/core/Modal.js +20 -7
  144. package/src/client/components/core/Panel.js +0 -1
  145. package/src/client/components/core/PanelForm.js +19 -19
  146. package/src/client/components/core/RichText.js +1 -2
  147. package/src/client/components/core/SocketIo.js +82 -29
  148. package/src/client/components/core/SocketIoHandler.js +75 -0
  149. package/src/client/components/core/Stream.js +143 -95
  150. package/src/client/components/core/Webhook.js +40 -7
  151. package/src/client/components/cryptokoyn/AppStoreCryptokoyn.js +5 -0
  152. package/src/client/components/cryptokoyn/LogInCryptokoyn.js +3 -3
  153. package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +2 -2
  154. package/src/client/components/cryptokoyn/MenuCryptokoyn.js +3 -3
  155. package/src/client/components/cryptokoyn/SocketIoCryptokoyn.js +3 -51
  156. package/src/client/components/cyberia/InstanceEngineCyberia.js +700 -0
  157. package/src/client/components/cyberia/MapEngineCyberia.js +1359 -2
  158. package/src/client/components/cyberia/ObjectLayerEngineModal.js +17 -6
  159. package/src/client/components/cyberia/ObjectLayerEngineViewer.js +92 -54
  160. package/src/client/components/cyberia-portal/AppStoreCyberiaPortal.js +5 -0
  161. package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +217 -30
  162. package/src/client/components/cyberia-portal/CssCyberiaPortal.js +44 -2
  163. package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +3 -4
  164. package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +2 -2
  165. package/src/client/components/cyberia-portal/MenuCyberiaPortal.js +104 -9
  166. package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +5 -0
  167. package/src/client/components/cyberia-portal/SocketIoCyberiaPortal.js +3 -49
  168. package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +4 -0
  169. package/src/client/components/default/AppStoreDefault.js +5 -0
  170. package/src/client/components/default/LogInDefault.js +3 -3
  171. package/src/client/components/default/LogOutDefault.js +2 -2
  172. package/src/client/components/default/MenuDefault.js +5 -5
  173. package/src/client/components/default/SocketIoDefault.js +3 -51
  174. package/src/client/components/itemledger/AppStoreItemledger.js +5 -0
  175. package/src/client/components/itemledger/LogInItemledger.js +3 -3
  176. package/src/client/components/itemledger/LogOutItemledger.js +2 -2
  177. package/src/client/components/itemledger/MenuItemledger.js +3 -3
  178. package/src/client/components/itemledger/SocketIoItemledger.js +3 -51
  179. package/src/client/components/underpost/AppStoreUnderpost.js +5 -0
  180. package/src/client/components/underpost/CssUnderpost.js +59 -0
  181. package/src/client/components/underpost/LogInUnderpost.js +6 -3
  182. package/src/client/components/underpost/LogOutUnderpost.js +4 -2
  183. package/src/client/components/underpost/MenuUnderpost.js +104 -18
  184. package/src/client/components/underpost/RoutesUnderpost.js +2 -0
  185. package/src/client/components/underpost/SocketIoUnderpost.js +3 -51
  186. package/src/client/public/cryptokoyn/assets/logo/base-icon.png +0 -0
  187. package/src/client/public/cryptokoyn/browserconfig.xml +12 -0
  188. package/src/client/public/cryptokoyn/microdata.json +85 -0
  189. package/src/client/public/cryptokoyn/site.webmanifest +57 -0
  190. package/src/client/public/cryptokoyn/sitemap +3 -3
  191. package/src/client/public/default/sitemap +3 -3
  192. package/src/client/public/itemledger/browserconfig.xml +2 -2
  193. package/src/client/public/itemledger/manifest.webmanifest +4 -4
  194. package/src/client/public/itemledger/microdata.json +71 -0
  195. package/src/client/public/itemledger/sitemap +3 -3
  196. package/src/client/public/itemledger/yandex-browser-manifest.json +2 -2
  197. package/src/client/public/test/sitemap +3 -3
  198. package/src/client/services/core/core.service.js +20 -8
  199. package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +105 -0
  200. package/src/client/services/cyberia-entity/cyberia-entity.management.js +57 -0
  201. package/src/client/services/cyberia-entity/cyberia-entity.service.js +105 -0
  202. package/src/client/services/cyberia-instance/cyberia-instance.management.js +194 -0
  203. package/src/client/services/cyberia-instance/cyberia-instance.service.js +122 -0
  204. package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +105 -0
  205. package/src/client/services/cyberia-map/cyberia-map.management.js +193 -0
  206. package/src/client/services/cyberia-map/cyberia-map.service.js +126 -0
  207. package/src/client/services/instance/instance.management.js +2 -2
  208. package/src/client/services/ipfs/ipfs.service.js +3 -23
  209. package/src/client/services/object-layer/object-layer.management.js +3 -3
  210. package/src/client/services/object-layer/object-layer.service.js +21 -0
  211. package/src/client/services/user/user.management.js +2 -2
  212. package/src/client/ssr/body/404.js +15 -11
  213. package/src/client/ssr/body/500.js +15 -11
  214. package/src/client/ssr/body/SwaggerDarkMode.js +285 -0
  215. package/src/client/ssr/head/PwaItemledger.js +60 -0
  216. package/src/client/ssr/offline/NoNetworkConnection.js +11 -10
  217. package/src/client/ssr/pages/CyberiaServerMetrics.js +1 -1
  218. package/src/client/ssr/pages/Test.js +11 -10
  219. package/src/client.build.js +0 -3
  220. package/src/client.dev.js +0 -3
  221. package/src/db/DataBaseProvider.js +17 -2
  222. package/src/db/mariadb/MariaDB.js +14 -9
  223. package/src/db/mongo/MongooseDB.js +17 -1
  224. package/src/grpc/cyberia/OFF_CHAIN_ECONOMY.md +305 -0
  225. package/src/grpc/cyberia/README.md +326 -0
  226. package/src/grpc/cyberia/grpc-server.js +530 -0
  227. package/src/index.js +24 -1
  228. package/src/proxy.js +0 -3
  229. package/src/runtime/express/Dockerfile +4 -0
  230. package/src/runtime/express/Express.js +33 -10
  231. package/src/runtime/lampp/Dockerfile +13 -2
  232. package/src/runtime/lampp/Lampp.js +33 -17
  233. package/src/runtime/wp/Dockerfile +68 -0
  234. package/src/runtime/wp/Wp.js +639 -0
  235. package/src/server/auth.js +36 -15
  236. package/src/server/backup.js +39 -12
  237. package/src/server/besu-genesis-generator.js +1630 -0
  238. package/src/server/client-build-docs.js +133 -17
  239. package/src/server/client-build-live.js +9 -18
  240. package/src/server/client-build.js +229 -101
  241. package/src/server/client-dev-server.js +14 -13
  242. package/src/server/client-formatted.js +109 -57
  243. package/src/server/conf.js +391 -164
  244. package/src/server/cron.js +27 -24
  245. package/src/server/dns.js +29 -12
  246. package/src/server/downloader.js +0 -2
  247. package/src/server/ipfs-client.js +24 -1
  248. package/src/server/logger.js +27 -9
  249. package/src/server/object-layer.js +217 -103
  250. package/src/server/peer.js +8 -2
  251. package/src/server/process.js +1 -50
  252. package/src/server/proxy.js +4 -8
  253. package/src/server/runtime.js +30 -9
  254. package/src/server/semantic-layer-generator-floor.js +359 -0
  255. package/src/server/semantic-layer-generator-skin.js +1294 -0
  256. package/src/server/semantic-layer-generator.js +116 -555
  257. package/src/server/ssr.js +0 -3
  258. package/src/server/start.js +19 -12
  259. package/src/server/tls.js +0 -2
  260. package/src/server.js +0 -4
  261. package/src/ws/IoInterface.js +1 -10
  262. package/src/ws/IoServer.js +14 -33
  263. package/src/ws/core/channels/core.ws.chat.js +65 -20
  264. package/src/ws/core/channels/core.ws.mailer.js +113 -32
  265. package/src/ws/core/channels/core.ws.stream.js +90 -31
  266. package/src/ws/core/core.ws.connection.js +12 -33
  267. package/src/ws/core/core.ws.emit.js +10 -26
  268. package/src/ws/core/core.ws.server.js +25 -58
  269. package/src/ws/default/channels/default.ws.main.js +53 -12
  270. package/src/ws/default/default.ws.connection.js +26 -13
  271. package/src/ws/default/default.ws.server.js +30 -12
  272. package/.env.development +0 -43
  273. package/.env.test +0 -43
  274. package/hardhat/contracts/CryptoKoyn.sol +0 -59
  275. package/hardhat/contracts/ItemLedger.sol +0 -73
  276. package/hardhat/contracts/Lock.sol +0 -34
  277. package/hardhat/hardhat.config.cjs +0 -45
  278. package/hardhat/ignition/modules/Lock.js +0 -18
  279. package/hardhat/networks/cryptokoyn-itemledger.network.json +0 -29
  280. package/hardhat/scripts/deployCryptokoyn.cjs +0 -25
  281. package/hardhat/scripts/deployItemledger.cjs +0 -25
  282. package/hardhat/test/Lock.js +0 -126
  283. package/hardhat/white-paper.md +0 -581
  284. package/src/client/components/cryptokoyn/CommonCryptokoyn.js +0 -29
  285. package/src/client/components/cryptokoyn/ElementsCryptokoyn.js +0 -38
  286. package/src/client/components/cyberia-portal/ElementsCyberiaPortal.js +0 -38
  287. package/src/client/components/default/ElementsDefault.js +0 -38
  288. package/src/client/components/itemledger/CommonItemledger.js +0 -29
  289. package/src/client/components/itemledger/ElementsItemledger.js +0 -38
  290. package/src/client/components/underpost/CommonUnderpost.js +0 -29
  291. package/src/client/components/underpost/ElementsUnderpost.js +0 -38
  292. package/src/ws/core/management/core.ws.chat.js +0 -8
  293. package/src/ws/core/management/core.ws.mailer.js +0 -16
  294. package/src/ws/core/management/core.ws.stream.js +0 -8
  295. package/src/ws/default/management/default.ws.main.js +0 -8
  296. package/white-paper.md +0 -581
@@ -32,6 +32,11 @@ Key features:
32
32
  - Generates SHA256 hash using `fast-json-stable-stringify` for deterministic serialization.
33
33
  - Reconstructs PNG frames from stored tile data for debugging.
34
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.
35
40
 
36
41
  ## Getting Started
37
42
 
@@ -58,16 +63,28 @@ Ensure your required environment variables (e.g., `DEFAULT_DEPLOY_ID`, `DEFAULT_
58
63
 
59
64
  The CLI is executed from the project root via the `cyberia.js` script.
60
65
 
61
- ### Process and import object-layer assets
66
+ ### Import specific items with `--import`
62
67
 
63
- This will iterate asset folders for the given types and store processed objects in MongoDB.
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.
64
81
 
65
82
  ```bash
66
83
  # Process specific types (comma-separated)
67
- cyberia ol --import skin,floor
84
+ cyberia ol --import-types skin,floor
68
85
 
69
- # Process all recognized types
70
- cyberia ol --import all
86
+ # Process all recognized types (skips items that already exist in the database)
87
+ cyberia ol --import-types all
71
88
  ```
72
89
 
73
90
  ### Procedural generation with `--generate`
@@ -92,28 +109,51 @@ cyberia ol floor-stone --generate --seed cobble-99 --count 4 --density 0.6
92
109
 
93
110
  # Lava flow, 3-frame animation
94
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
124
+
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
127
+
128
+ # Skin: shaved / bald head (no hair at all)
129
+ cyberia ol skin-shaved --generate --seed hero-bald-1 --frame-count 4
95
130
  ```
96
131
 
97
132
  **`--generate` options:**
98
133
 
99
- | Option | Default | Description |
100
- |---|---|---|
101
- | `--seed <str>` | auto UUID | Deterministic seed string. Same seed → same output. |
102
- | `--count <n>` | `3` | Shape element count multiplier per layer. |
103
- | `--frame-index <n>` | `0` | Starting frame index. |
104
- | `--frame-count <n>` | `1` | Number of consecutive frames to generate. |
105
- | `--density <f>` | `0.5` | Overall density factor (`0`–`1`). Lower = sparser. |
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. |
106
141
 
107
142
  **Available semantic item-id prefixes:**
108
143
 
109
- | Prefix | Type | Tags | Palette |
110
- |---|---|---|---|
111
- | `floor-desert` | floor | sand, dune, arid | warm ochres, sand tones |
112
- | `floor-grass` | floor | grass, meadow, earth | greens, earth browns |
113
- | `floor-water` | floor | water, ocean, wave | blues, foam whites |
114
- | `floor-stone` | floor | stone, rock, cobble | greys, warm/cool stone |
115
- | `floor-lava` | floor | lava, magma, fire | reds, oranges, dark crust |
116
- | `skin-*` | skin | character, body | skin tones, clothing darks |
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 |
117
157
 
118
158
  #### How generation works
119
159
 
@@ -168,6 +208,64 @@ cyberia ol floor-desert --generate --seed fx-42 # variant A
168
208
  cyberia ol floor-desert --generate --seed fx-99 # variant B (same style, different arrangement)
169
209
  ```
170
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
+ ```
268
+
171
269
  ## Visualize a processed frame
172
270
 
173
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]`.
@@ -185,6 +283,7 @@ cyberia ol anon --show-frame 04_1 # left_idle (second frame)
185
283
  ```
186
284
 
187
285
  **Valid direction codes:**
286
+
188
287
  - `08`: down_idle, none_idle, default_idle
189
288
  - `18`: down_walking
190
289
  - `02`: up_idle
@@ -195,6 +294,7 @@ cyberia ol anon --show-frame 04_1 # left_idle (second frame)
195
294
  - `16`: right_walking, up_right_walking, down_right_walking
196
295
 
197
296
  This command:
297
+
198
298
  - Finds the ObjectLayer by item-id
199
299
  - Loads the associated ObjectLayerRenderFrames document
200
300
  - Reconstructs the PNG from the stored `frame_matrix` and `map_color`
@@ -216,6 +316,7 @@ cyberia ol anon --to-atlas-sprite-sheet 4096
216
316
  ```
217
317
 
218
318
  This command:
319
+
219
320
  - Finds the ObjectLayer by item-id or MongoDB `_id`
220
321
  - Loads the associated ObjectLayerRenderFrames document
221
322
  - **Auto-calculates optimal atlas dimensions** based on total frame count (8 directions × all animation modes)
@@ -226,6 +327,7 @@ This command:
226
327
  - Uses power-of-2 dimensions for GPU efficiency
227
328
 
228
329
  **Atlas Dimension Calculation:**
330
+
229
331
  - **Auto (default)**: Dynamically calculates optimal size based on:
230
332
  - Total number of frames across all directions and modes
231
333
  - Individual frame dimensions
@@ -234,6 +336,7 @@ This command:
234
336
  - **Manual override**: Specify exact dimension (e.g., `--to-atlas-sprite-sheet 4096`)
235
337
 
236
338
  **Common Atlas Sizes:**
339
+
237
340
  - **1024x1024**: ~6-10 frames
238
341
  - **2048x2048**: ~20-40 frames (typical for character sprites)
239
342
  - **4096x4096**: ~80-160 frames (complex animations)
@@ -252,6 +355,7 @@ cyberia ol anon --show-atlas-sprite-sheet
252
355
  ```
253
356
 
254
357
  This command:
358
+
255
359
  - Finds the ObjectLayer by item-id
256
360
  - Retrieves the associated AtlasSpriteSheet via top-level `atlasSpriteSheetId` or by matching `metadata.itemKey`
257
361
  - Saves it temporarily to disk
@@ -266,7 +370,7 @@ Process assets from source files through to atlas generation:
266
370
 
267
371
  ```bash
268
372
  # 1. Import object layers from asset directories
269
- cyberia ol --import skin
373
+ cyberia ol --import-types skin
270
374
 
271
375
  # 2. Verify a specific frame was imported correctly
272
376
  cyberia ol anon --show-frame 08_0
@@ -337,7 +441,7 @@ cyberia ol anon --show-frame 16_0 # right_walking
337
441
 
338
442
  ```bash
339
443
  # Import multiple types at once
340
- cyberia ol --import skin,floor,weapon
444
+ cyberia ol --import-types skin,floor,weapon
341
445
 
342
446
  # Process individual items
343
447
  cyberia ol sword --show-frame 08_0
@@ -345,3 +449,224 @@ cyberia ol sword --to-atlas-sprite-sheet
345
449
  cyberia ol shield --show-frame 08_0
346
450
  cyberia ol shield --to-atlas-sprite-sheet
347
451
  ```
452
+
453
+ ### Full Rebuild with Cleanup
454
+
455
+ Drop all data, clean static assets, and re-import everything:
456
+
457
+ ```bash
458
+ # 1. Drop all object layers with IPFS cleanup and static asset removal
459
+ cyberia ol --drop --client-public --git-clean
460
+
461
+ # 2. Re-import all asset types
462
+ cyberia ol --import-types all
463
+
464
+ # 3. Verify
465
+ cyberia ol anon --show-frame 08_0
466
+ ```
467
+
468
+ ### Targeted Drop and Re-import
469
+
470
+ Drop and re-import specific items without affecting others:
471
+
472
+ ```bash
473
+ # 1. Drop specific items and their static folders
474
+ cyberia ol anon,skin --drop --client-public
475
+
476
+ # 2. Re-import only those items
477
+ cyberia ol anon,skin --import
478
+
479
+ # 3. Regenerate atlas for each
480
+ cyberia ol anon --to-atlas-sprite-sheet
481
+ cyberia ol skin --to-atlas-sprite-sheet
482
+ ```
483
+
484
+ ## Blockchain Operations (`chain`)
485
+
486
+ The `chain` command group manages Hyperledger Besu IBFT2 network deployment and ERC-1155 token operations for on-chain object layer registration.
487
+
488
+ ### Deploy Besu IBFT2 Network
489
+
490
+ Deploys a private Besu IBFT2 network to Kubernetes.
491
+
492
+ ```bash
493
+ # Deploy with defaults (4 validators, chain-id 777771)
494
+ cyberia chain deploy
495
+
496
+ # Custom configuration
497
+ cyberia chain deploy --validators 6 --chain-id 888881 --block-period 3
498
+
499
+ # Pull container images first
500
+ cyberia chain deploy --pull-image
501
+ ```
502
+
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
522
+
523
+ ```bash
524
+ # Remove network (keep keys and manifests)
525
+ cyberia chain remove
526
+
527
+ # Full cleanup
528
+ cyberia chain remove --clean-keys --clean-manifests
529
+ ```
530
+
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 |
536
+
537
+ ### Generate Manifests Without Deploying
538
+
539
+ ```bash
540
+ cyberia chain generate-manifests --validators 6 --output-dir ./manifests/besu
541
+ ```
542
+
543
+ Accepts the same options as `deploy` plus `--output-dir <dir>` (default: `./manifests/besu`).
544
+
545
+ ### Deploy ERC-1155 Contract
546
+
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
+ ```
558
+
559
+ ### Register Object Layer Item On-Chain
560
+
561
+ Registers an object layer as an ERC-1155 token with its canonical CID.
562
+
563
+ ```bash
564
+ # Register with CID resolved from MongoDB (recommended)
565
+ cyberia chain register --item-id hatchet --from-db
566
+
567
+ # Register with explicit CID
568
+ cyberia chain register --item-id hatchet --metadata-cid bafk...
569
+
570
+ # Semi-fungible with supply
571
+ cyberia chain register --item-id wood --from-db --supply 500000
572
+ ```
573
+
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 |
583
+
584
+ ### Batch Register Multiple Items
585
+
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
595
+
596
+ ```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
602
+
603
+ # Burn tokens
604
+ cyberia chain burn --address 0xHolder --token-id 1 --amount 10
605
+ ```
606
+
607
+ ### Query Status and Balances
608
+
609
+ ```bash
610
+ # Full network and contract status
611
+ cyberia chain status
612
+
613
+ # Query token balance
614
+ cyberia chain balance --address 0xAddress --token-id 0
615
+ ```
616
+
617
+ ### Key Management
618
+
619
+ ```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
625
+
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)
632
+
633
+ ```bash
634
+ cyberia chain pause
635
+ cyberia chain unpause
636
+ ```
637
+
638
+ ## Workflow Import (`run-workflow`)
639
+
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
+ ```
650
+
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 |
@@ -21,7 +21,9 @@ const ObjectLayerController = {
21
21
  },
22
22
  get: async (req, res, options) => {
23
23
  try {
24
- res.setHeader('Access-Control-Allow-Origin', '*');
24
+ if (req && req.headers && req.headers.origin) {
25
+ res.set('Access-Control-Allow-Origin', req.headers.origin);
26
+ } else res.setHeader('Access-Control-Allow-Origin', '*');
25
27
  res.setHeader('Cross-Origin-Resource-Policy', 'cross-origin');
26
28
  const result = await ObjectLayerService.get(req, res, options);
27
29
  return res.status(200).json({
@@ -39,7 +41,9 @@ const ObjectLayerController = {
39
41
  generateWebp: async (req, res, options) => {
40
42
  try {
41
43
  const result = await ObjectLayerService.generateWebp(req, res, options);
42
- res.setHeader('Access-Control-Allow-Origin', '*');
44
+ if (req && req.headers && req.headers.origin) {
45
+ res.set('Access-Control-Allow-Origin', req.headers.origin);
46
+ } else res.setHeader('Access-Control-Allow-Origin', '*');
43
47
  res.setHeader('Cross-Origin-Resource-Policy', 'cross-origin');
44
48
  res.setHeader('Content-Type', 'image/webp');
45
49
  res.setHeader(
@@ -49,18 +49,22 @@ const ItemSchema = new Schema(
49
49
  /**
50
50
  * @typedef {Object} Ledger
51
51
  * Blockchain protocol metadata linking the visual object-layer prefab to its economic reality.
52
- * @property {string} type - The token standard or off-chain designation (ERC20, ERC721, OFF_CHAIN).
53
- * @property {string} address - The Solidity smart contract address.
52
+ * Uses ERC-1155 as the single multi-token standard for both fungible (CryptoKoyn) and
53
+ * non-fungible / semi-fungible Object Layer items within one contract.
54
+ * @property {string} type - The token standard or off-chain designation (ERC1155, OFF_CHAIN).
55
+ * @property {string} address - The Solidity smart contract address (ObjectLayerToken).
56
+ * @property {string} tokenId - The uint256 ERC-1155 token ID (derived from keccak256 of the item identifier).
54
57
  * @memberof CyberiaObjectLayerModel
55
58
  */
56
59
  const LedgerSchema = new Schema(
57
60
  {
58
61
  type: {
59
62
  type: String,
60
- enum: ['ERC20', 'ERC721', 'OFF_CHAIN'],
63
+ enum: ['ERC1155', 'OFF_CHAIN'],
61
64
  required: true,
62
65
  },
63
- address: { type: String }, // Solidity contract address
66
+ address: { type: String }, // ObjectLayerToken ERC-1155 contract address
67
+ tokenId: { type: String, default: '' }, // uint256 ERC-1155 token ID (hex or decimal string)
64
68
  },
65
69
  { _id: false },
66
70
  );
@@ -96,8 +100,9 @@ const RenderSchema = new Schema(
96
100
  * @property {string} data.item.description - Description of the item
97
101
  * @property {boolean} data.item.activable - Whether the item can be activated
98
102
  * @property {Object} data.ledger - Blockchain protocol metadata linking the visual object-layer prefab to its economic reality
99
- * @property {string} data.ledger.type - The token standard or off-chain designation (ERC20, ERC721, OFF_CHAIN).
100
- * @property {string} data.ledger.address - The Solidity smart contract address.
103
+ * @property {string} data.ledger.type - The token standard or off-chain designation (ERC1155, OFF_CHAIN).
104
+ * @property {string} data.ledger.address - The ObjectLayerToken ERC-1155 smart contract address.
105
+ * @property {string} data.ledger.tokenId - The uint256 ERC-1155 token ID (hex or decimal string).
101
106
  * @property {Object} data.render - IPFS content identifiers for the consolidated atlas sprite sheet
102
107
  * @property {string} data.render.cid - IPFS Content Identifier for the consolidated atlas sprite sheet PNG
103
108
  * @property {string} data.render.metadataCid - IPFS Content Identifier for the atlas sprite sheet metadata JSON (fast-json-stable-stringify)
@@ -155,13 +160,12 @@ ObjectLayerSchema.index(
155
160
  );
156
161
 
157
162
  // Pre-save hook to ensure data consistency
158
- ObjectLayerSchema.pre('save', function (next) {
163
+ ObjectLayerSchema.pre('save', function () {
159
164
  // Ensure all required fields are present
160
165
  if (!this.data.stats || !this.data.item || !this.sha256) {
161
166
  throw new Error('Missing required fields');
162
167
  }
163
168
  // cid (object layer data JSON) and data.render.cid (atlas PNG) are optional – default to ''
164
- next();
165
169
  });
166
170
 
167
171
  // Create and export the model