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.
- package/.github/workflows/engine-cyberia.cd.yml +8 -2
- package/.github/workflows/npmpkg.ci.yml +1 -0
- package/.github/workflows/pwa-microservices-template-test.ci.yml +1 -1
- package/.github/workflows/release.cd.yml +2 -2
- package/.vscode/extensions.json +9 -9
- package/.vscode/settings.json +20 -4
- package/CHANGELOG.md +563 -1
- package/CLI-HELP.md +130 -34
- package/Dockerfile +0 -4
- package/README.md +194 -607
- package/bin/build.js +42 -12
- package/bin/build.template.js +187 -0
- package/bin/cyberia.js +1367 -281
- package/bin/deploy.js +582 -3
- package/bin/index.js +1367 -281
- package/bump.config.js +26 -0
- package/conf.js +195 -111
- package/deployment.yaml +6 -222
- package/hardhat/package-lock.json +118 -149
- package/hardhat/package.json +5 -4
- package/jsconfig.json +1 -1
- package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +2 -2
- package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +2 -2
- package/manifests/deployment/dd-cyberia-development/deployment.yaml +6 -222
- package/manifests/deployment/dd-cyberia-development/proxy.yaml +10 -118
- package/manifests/deployment/dd-default-development/deployment.yaml +2 -6
- package/manifests/deployment/dd-test-development/deployment.yaml +138 -66
- package/manifests/deployment/dd-test-development/proxy.yaml +41 -5
- package/manifests/kind-config-dev.yaml +8 -0
- package/manifests/lxd/lxd-admin-profile.yaml +12 -3
- package/manifests/mongodb/pv-pvc.yaml +44 -8
- package/manifests/mongodb/statefulset.yaml +55 -68
- package/manifests/mongodb-4.4/headless-service.yaml +10 -0
- package/manifests/mongodb-4.4/kustomization.yaml +3 -1
- package/manifests/mongodb-4.4/mongodb-nodeport.yaml +17 -0
- package/manifests/mongodb-4.4/pv-pvc.yaml +10 -14
- package/manifests/mongodb-4.4/statefulset.yaml +79 -0
- package/manifests/mongodb-4.4/storage-class.yaml +9 -0
- package/manifests/valkey/statefulset.yaml +1 -1
- package/manifests/valkey/valkey-nodeport.yaml +17 -0
- package/package.json +45 -24
- package/proxy.yaml +10 -118
- package/scripts/ipxe-setup.sh +52 -49
- package/scripts/k3s-node-setup.sh +83 -48
- package/scripts/lxd-vm-setup.sh +193 -8
- package/scripts/maas-nat-firewalld.sh +145 -0
- package/scripts/nat-iptables.sh +103 -18
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +18 -18
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +7 -14
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.router.js +38 -33
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +91 -36
- package/src/api/core/core.controller.js +10 -10
- package/src/api/core/core.router.js +19 -14
- package/src/api/core/core.service.js +15 -15
- package/src/api/crypto/crypto.controller.js +8 -8
- package/src/api/crypto/crypto.router.js +18 -12
- package/src/api/crypto/crypto.service.js +11 -11
- package/src/api/cyberia-action/cyberia-action.controller.js +74 -0
- package/src/api/cyberia-action/cyberia-action.model.js +87 -0
- package/src/api/cyberia-action/cyberia-action.router.js +31 -0
- package/src/api/cyberia-action/cyberia-action.service.js +42 -0
- package/src/api/cyberia-client-hints/cyberia-client-hints.controller.js +74 -0
- package/src/api/cyberia-client-hints/cyberia-client-hints.model.js +99 -0
- package/src/api/cyberia-client-hints/cyberia-client-hints.router.js +98 -0
- package/src/api/cyberia-client-hints/cyberia-client-hints.service.js +152 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +13 -13
- package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +11 -11
- package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +25 -20
- package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +22 -22
- package/src/api/cyberia-entity/cyberia-entity.controller.js +10 -10
- package/src/api/cyberia-entity/cyberia-entity.router.js +22 -18
- package/src/api/cyberia-entity/cyberia-entity.service.js +15 -15
- package/src/api/cyberia-instance/cyberia-fallback-world.js +83 -198
- package/src/api/cyberia-instance/cyberia-instance.controller.js +14 -14
- package/src/api/cyberia-instance/cyberia-instance.model.js +3 -0
- package/src/api/cyberia-instance/cyberia-instance.router.js +57 -52
- package/src/api/cyberia-instance/cyberia-instance.service.js +32 -67
- package/src/api/cyberia-instance/cyberia-portal-connector.js +20 -246
- package/src/api/cyberia-instance/cyberia-world-generator.js +505 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +10 -10
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +18 -49
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.router.js +22 -18
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +19 -15
- package/src/api/cyberia-map/cyberia-map.controller.js +10 -10
- package/src/api/cyberia-map/cyberia-map.router.js +35 -30
- package/src/api/cyberia-map/cyberia-map.service.js +17 -17
- package/src/api/cyberia-quest/cyberia-quest.controller.js +74 -0
- package/src/api/cyberia-quest/cyberia-quest.model.js +67 -0
- package/src/api/cyberia-quest/cyberia-quest.router.js +31 -0
- package/src/api/cyberia-quest/cyberia-quest.service.js +42 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.controller.js +74 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.model.js +49 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.router.js +31 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.service.js +42 -0
- package/src/api/cyberia-server-defaults/cyberia-server-defaults.js +451 -0
- package/src/api/default/default.controller.js +10 -10
- package/src/api/default/default.router.js +22 -18
- package/src/api/default/default.service.js +15 -15
- package/src/api/document/document.controller.js +12 -12
- package/src/api/document/document.model.js +10 -16
- package/src/api/document/document.router.js +28 -23
- package/src/api/document/document.service.js +100 -23
- package/src/api/file/file.controller.js +8 -8
- package/src/api/file/file.model.js +10 -10
- package/src/api/file/file.router.js +19 -13
- package/src/api/file/file.service.js +45 -43
- package/src/api/instance/instance.controller.js +10 -10
- package/src/api/instance/instance.model.js +4 -10
- package/src/api/instance/instance.router.js +29 -24
- package/src/api/instance/instance.service.js +16 -16
- package/src/api/ipfs/ipfs.controller.js +12 -12
- package/src/api/ipfs/ipfs.model.js +4 -13
- package/src/api/ipfs/ipfs.router.js +21 -16
- package/src/api/ipfs/ipfs.service.js +22 -36
- package/src/api/object-layer/object-layer.controller.js +12 -12
- package/src/api/object-layer/object-layer.model.js +4 -17
- package/src/api/object-layer/object-layer.router.js +512 -507
- package/src/api/object-layer/object-layer.service.js +29 -26
- package/src/api/object-layer-render-frames/object-layer-render-frames.controller.js +10 -10
- package/src/api/object-layer-render-frames/object-layer-render-frames.model.js +6 -16
- package/src/api/object-layer-render-frames/object-layer-render-frames.router.js +22 -18
- package/src/api/object-layer-render-frames/object-layer-render-frames.service.js +19 -15
- package/src/api/test/test.controller.js +8 -8
- package/src/api/test/test.router.js +17 -12
- package/src/api/test/test.service.js +8 -8
- package/src/api/types.js +24 -0
- package/src/api/user/guest.service.js +100 -0
- package/src/api/user/user.controller.js +6 -6
- package/src/api/user/user.model.js +8 -13
- package/src/api/user/user.router.js +297 -288
- package/src/api/user/user.service.js +103 -55
- package/src/cli/baremetal.js +132 -101
- package/src/cli/cluster.js +732 -217
- package/src/cli/db.js +106 -62
- package/src/cli/deploy.js +260 -149
- package/src/cli/fs.js +90 -9
- package/src/cli/image.js +43 -1
- package/src/cli/index.js +106 -16
- package/src/cli/ipfs.js +4 -6
- package/src/cli/kubectl.js +4 -1
- package/src/cli/lxd.js +1099 -223
- package/src/cli/monitor.js +9 -3
- package/src/cli/release.js +336 -86
- package/src/cli/repository.js +136 -53
- package/src/cli/run.js +599 -76
- package/src/cli/secrets.js +11 -2
- package/src/cli/ssh.js +1 -1
- package/src/cli/static.js +43 -115
- package/src/cli/test.js +9 -3
- package/src/client/Cryptokoyn.index.js +18 -21
- package/src/client/CyberiaPortal.index.js +19 -23
- package/src/client/Default.index.js +30 -36
- package/src/client/Itemledger.index.js +20 -26
- package/src/client/Underpost.index.js +19 -23
- package/src/client/components/core/404.js +4 -4
- package/src/client/components/core/500.js +4 -4
- package/src/client/components/core/Account.js +73 -60
- package/src/client/components/core/AgGrid.js +23 -33
- package/src/client/components/core/Alert.js +12 -13
- package/src/client/components/core/AppStore.js +1 -1
- package/src/client/components/core/Auth.js +40 -37
- package/src/client/components/core/Badge.js +7 -13
- package/src/client/components/core/BtnIcon.js +15 -17
- package/src/client/components/core/CalendarCore.js +42 -63
- package/src/client/components/core/Chat.js +13 -15
- package/src/client/components/core/ClientEvents.js +163 -0
- package/src/client/components/core/ColorPaletteElement.js +309 -0
- package/src/client/components/core/Content.js +17 -14
- package/src/client/components/core/Css.js +15 -71
- package/src/client/components/core/CssCore.js +12 -16
- package/src/client/components/core/D3Chart.js +4 -4
- package/src/client/components/core/Docs.js +64 -91
- package/src/client/components/core/DropDown.js +69 -91
- package/src/client/components/core/EventBus.js +96 -0
- package/src/client/components/core/EventsUI.js +14 -17
- package/src/client/components/core/FileExplorer.js +96 -228
- package/src/client/components/core/FullScreen.js +47 -75
- package/src/client/components/core/Input.js +24 -69
- package/src/client/components/core/Keyboard.js +25 -18
- package/src/client/components/core/KeyboardAvoidance.js +145 -0
- package/src/client/components/core/LoadingAnimation.js +25 -31
- package/src/client/components/core/LogIn.js +41 -41
- package/src/client/components/core/LogOut.js +23 -14
- package/src/client/components/core/Modal.js +544 -219
- package/src/client/components/core/NotificationManager.js +14 -18
- package/src/client/components/core/Panel.js +54 -50
- package/src/client/components/core/PanelForm.js +81 -177
- package/src/client/components/core/Polyhedron.js +110 -214
- package/src/client/components/core/PublicProfile.js +39 -32
- package/src/client/components/core/Recover.js +48 -44
- package/src/client/components/core/Responsive.js +88 -32
- package/src/client/components/core/RichText.js +9 -18
- package/src/client/components/core/Router.js +24 -3
- package/src/client/components/core/SearchBox.js +37 -37
- package/src/client/components/core/SignUp.js +39 -30
- package/src/client/components/core/SocketIo.js +31 -2
- package/src/client/components/core/SocketIoHandler.js +6 -6
- package/src/client/components/core/ToggleSwitch.js +8 -20
- package/src/client/components/core/ToolTip.js +5 -17
- package/src/client/components/core/Translate.js +56 -59
- package/src/client/components/core/Validator.js +26 -16
- package/src/client/components/core/Wallet.js +15 -26
- package/src/client/components/core/Worker.js +211 -276
- package/src/client/components/core/windowGetDimensions.js +7 -7
- package/src/client/components/cryptokoyn/{MenuCryptokoyn.js → AppShellCryptokoyn.js} +57 -57
- package/src/client/components/cryptokoyn/CssCryptokoyn.js +15 -15
- package/src/client/components/cryptokoyn/LogInCryptokoyn.js +6 -4
- package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +6 -4
- package/src/client/components/cryptokoyn/RouterCryptokoyn.js +37 -0
- package/src/client/components/cryptokoyn/SettingsCryptokoyn.js +4 -4
- package/src/client/components/cryptokoyn/SignUpCryptokoyn.js +6 -4
- package/src/client/components/cyberia/InstanceEngineCyberia.js +141 -60
- package/src/client/components/cyberia/MapEngineCyberia.js +691 -214
- package/src/client/components/cyberia/ObjectLayerEngine.js +19 -0
- package/src/client/components/cyberia/ObjectLayerEngineModal.js +1204 -94
- package/src/client/components/cyberia/ObjectLayerEngineViewer.js +196 -298
- package/src/client/components/cyberia/SharedDefaultsCyberia.js +330 -0
- package/src/client/components/cyberia-portal/{MenuCyberiaPortal.js → AppShellCyberiaPortal.js} +102 -102
- package/src/client/components/cyberia-portal/CssCyberiaPortal.js +15 -15
- package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +6 -4
- package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +6 -4
- package/src/client/components/cyberia-portal/MainBodyCyberiaPortal.js +4 -4
- package/src/client/components/cyberia-portal/RouterCyberiaPortal.js +60 -0
- package/src/client/components/cyberia-portal/SettingsCyberiaPortal.js +4 -4
- package/src/client/components/cyberia-portal/SignUpCyberiaPortal.js +6 -4
- package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +4 -4
- package/src/client/components/default/{MenuDefault.js → AppShellDefault.js} +87 -87
- package/src/client/components/default/CssDefault.js +12 -12
- package/src/client/components/default/LogInDefault.js +6 -4
- package/src/client/components/default/LogOutDefault.js +6 -4
- package/src/client/components/default/RouterDefault.js +47 -0
- package/src/client/components/default/SettingsDefault.js +4 -4
- package/src/client/components/default/SignUpDefault.js +6 -4
- package/src/client/components/default/TranslateDefault.js +3 -3
- package/src/client/components/itemledger/{MenuItemledger.js → AppShellItemledger.js} +57 -57
- package/src/client/components/itemledger/CssItemledger.js +15 -15
- package/src/client/components/itemledger/LogInItemledger.js +6 -4
- package/src/client/components/itemledger/LogOutItemledger.js +6 -4
- package/src/client/components/itemledger/RouterItemledger.js +38 -0
- package/src/client/components/itemledger/SettingsItemledger.js +4 -4
- package/src/client/components/itemledger/SignUpItemledger.js +6 -4
- package/src/client/components/itemledger/TranslateItemledger.js +3 -3
- package/src/client/components/underpost/{MenuUnderpost.js → AppShellUnderpost.js} +88 -88
- package/src/client/components/underpost/CssUnderpost.js +14 -14
- package/src/client/components/underpost/CyberpunkBloggerUnderpost.js +4 -4
- package/src/client/components/underpost/DocumentSearchProvider.js +1 -1
- package/src/client/components/underpost/LabGalleryUnderpost.js +12 -15
- package/src/client/components/underpost/LogInUnderpost.js +6 -4
- package/src/client/components/underpost/LogOutUnderpost.js +6 -4
- package/src/client/components/underpost/RouterUnderpost.js +45 -0
- package/src/client/components/underpost/SettingsUnderpost.js +4 -4
- package/src/client/components/underpost/SignUpUnderpost.js +6 -4
- package/src/client/components/underpost/TranslateUnderpost.js +4 -4
- package/src/client/public/cyberia-docs/ACTION-SYSTEM.md +235 -0
- package/src/client/public/cyberia-docs/ARCHITECTURE.md +83 -0
- package/src/client/public/cyberia-docs/CYBERIA-CLI.md +204 -0
- package/src/client/public/cyberia-docs/CYBERIA-CLIENT.md +291 -0
- package/src/client/public/cyberia-docs/CYBERIA-SERVER.md +278 -0
- package/src/client/public/cyberia-docs/CYBERIA.md +259 -0
- package/src/client/public/cyberia-docs/ENTITY-PROFILE.md +241 -0
- package/src/client/public/cyberia-docs/HARDHAT-MODULE.md +300 -0
- package/src/client/public/cyberia-docs/OFF-CHAIN-ECONOMY.md +279 -0
- package/src/client/public/cyberia-docs/QUEST-SYSTEM.md +206 -0
- package/src/client/public/cyberia-docs/ROADMAP.md +240 -0
- package/src/client/public/cyberia-docs/UNDERPOST-PLATFORM.md +106 -0
- package/src/client/public/cyberia-docs/WHITE-PAPER.md +732 -0
- package/src/client/services/atlas-sprite-sheet/atlas-sprite-sheet.service.js +14 -20
- package/src/client/services/core/core.service.js +17 -49
- package/src/client/services/crypto/crypto.service.js +8 -13
- package/src/client/services/cyberia-action/cyberia-action.service.js +99 -0
- package/src/client/services/cyberia-client-hints/cyberia-client-hints.service.js +99 -0
- package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +10 -16
- package/src/client/services/cyberia-entity/cyberia-entity.management.js +5 -5
- package/src/client/services/cyberia-entity/cyberia-entity.service.js +10 -16
- package/src/client/services/cyberia-instance/cyberia-instance.management.js +6 -6
- package/src/client/services/cyberia-instance/cyberia-instance.service.js +12 -18
- package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +10 -16
- package/src/client/services/cyberia-map/cyberia-map.management.js +6 -6
- package/src/client/services/cyberia-map/cyberia-map.service.js +12 -18
- package/src/client/services/cyberia-quest/cyberia-quest.service.js +99 -0
- package/src/client/services/cyberia-quest-progress/cyberia-quest-progress.service.js +99 -0
- package/src/client/services/default/default.management.js +159 -267
- package/src/client/services/default/default.service.js +10 -16
- package/src/client/services/document/document.service.js +14 -19
- package/src/client/services/file/file.service.js +8 -13
- package/src/client/services/instance/instance.management.js +5 -5
- package/src/client/services/instance/instance.service.js +10 -15
- package/src/client/services/ipfs/ipfs.service.js +12 -18
- package/src/client/services/object-layer/object-layer.management.js +12 -12
- package/src/client/services/object-layer/object-layer.service.js +20 -26
- package/src/client/services/object-layer-render-frames/object-layer-render-frames.service.js +10 -16
- package/src/client/services/test/test.service.js +8 -13
- package/src/client/services/user/guest.service.js +86 -0
- package/src/client/services/user/user.management.js +5 -5
- package/src/client/services/user/user.service.js +14 -20
- package/src/client/ssr/body/404.js +3 -3
- package/src/client/ssr/body/500.js +3 -3
- package/src/client/ssr/body/CacheControl.js +5 -2
- package/src/client/ssr/body/DefaultSplashScreen.js +19 -12
- package/src/client/ssr/body/UnderpostDefaultSplashScreen.js +13 -6
- package/src/client/ssr/head/PwaItemledger.js +197 -60
- package/src/client/ssr/mailer/DefaultRecoverEmail.js +19 -20
- package/src/client/ssr/mailer/DefaultVerifyEmail.js +15 -16
- package/src/client/ssr/views/CyberiaServerMetrics.js +982 -0
- package/src/client/ssr/{offline → views}/Maintenance.js +12 -11
- package/src/client/ssr/{offline → views}/NoNetworkConnection.js +3 -3
- package/src/client/ssr/{pages → views}/Test.js +2 -2
- package/src/client/sw/core.sw.js +274 -0
- package/src/db/DataBaseProvider.js +115 -15
- package/src/db/mariadb/MariaDB.js +2 -1
- package/src/db/mongo/MongoBootstrap.js +657 -0
- package/src/db/mongo/MongooseDB.js +129 -21
- package/src/grpc/cyberia/grpc-server.js +185 -105
- package/src/index.js +1 -1
- package/src/runtime/cyberia-client/Dockerfile +101 -0
- package/src/runtime/cyberia-client/Dockerfile.dev +82 -0
- package/src/runtime/cyberia-server/Dockerfile +62 -0
- package/src/runtime/cyberia-server/Dockerfile.dev +71 -0
- package/src/runtime/express/Dockerfile +4 -4
- package/src/runtime/express/Express.js +2 -2
- package/src/runtime/lampp/Dockerfile +8 -7
- package/src/runtime/wp/Dockerfile +11 -17
- package/src/runtime/wp/Wp.js +8 -5
- package/src/server/atlas-sprite-sheet-generator.js +4 -2
- package/src/server/auth.js +2 -2
- package/src/server/client-build-docs.js +46 -47
- package/src/server/client-build.js +371 -132
- package/src/server/client-formatted.js +47 -16
- package/src/server/conf.js +91 -87
- package/src/server/data-query.js +32 -20
- package/src/server/dns.js +22 -0
- package/src/server/ipfs-client.js +232 -91
- package/src/server/object-layer.js +1 -6
- package/src/server/process.js +192 -45
- package/src/server/proxy.js +9 -2
- package/src/server/runtime.js +1 -1
- package/src/server/semantic-layer-generator-floor.js +11 -51
- package/src/server/semantic-layer-generator-resource.js +259 -0
- package/src/server/semantic-layer-generator-skin.js +41 -171
- package/src/server/semantic-layer-generator.js +122 -14
- package/src/server/shape-generator.js +108 -0
- package/src/server/start.js +34 -8
- package/src/server/valkey.js +143 -235
- package/src/ws/IoInterface.js +16 -16
- package/src/ws/core/channels/core.ws.chat.js +11 -11
- package/src/ws/core/channels/core.ws.mailer.js +29 -29
- package/src/ws/core/channels/core.ws.stream.js +19 -19
- package/src/ws/core/core.ws.connection.js +8 -8
- package/src/ws/core/core.ws.server.js +6 -5
- package/src/ws/default/channels/default.ws.main.js +10 -10
- package/src/ws/default/default.ws.connection.js +4 -4
- package/src/ws/default/default.ws.server.js +4 -3
- package/tsconfig.docs.json +15 -0
- package/typedoc.dd-cyberia.json +29 -0
- package/typedoc.json +29 -0
- package/WHITE-PAPER.md +0 -1540
- package/bin/file.js +0 -196
- package/bin/vs.js +0 -74
- package/bin/zed.js +0 -84
- package/hardhat/README.md +0 -531
- package/hardhat/WHITE-PAPER.md +0 -1540
- package/jsdoc.dd-cyberia.json +0 -68
- package/jsdoc.json +0 -68
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +0 -413
- package/src/api/object-layer/README.md +0 -672
- package/src/client/components/core/ColorPalette.js +0 -5267
- package/src/client/components/core/JoyStick.js +0 -80
- package/src/client/components/cryptokoyn/RoutesCryptokoyn.js +0 -39
- package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +0 -223
- package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +0 -62
- package/src/client/components/cyberia-portal/ServerCyberiaPortal.js +0 -136
- package/src/client/components/default/RoutesDefault.js +0 -49
- package/src/client/components/itemledger/RoutesItemledger.js +0 -40
- package/src/client/components/underpost/RoutesUnderpost.js +0 -47
- package/src/client/ssr/email/DefaultRecoverEmail.js +0 -21
- package/src/client/ssr/email/DefaultVerifyEmail.js +0 -17
- package/src/client/ssr/pages/CyberiaServerMetrics.js +0 -461
- package/src/client/sw/default.sw.js +0 -127
- package/src/client/sw/template.sw.js +0 -84
- package/src/grpc/cyberia/OFF_CHAIN_ECONOMY.md +0 -305
- 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
|
-
<
|
|
8
|
-
|
|
9
|
-
<h2>Network Object Layer Engine CLI</h2>
|
|
10
|
-
|
|
11
|
-
[](https://www.npmjs.com/package/cyberia) [](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
|
-
|
|
126
|
-
cyberia ol skin-natural --generate --seed hero-nat-5 --frame-count 4
|
|
5
|
+
<h1>CYBERIA</h1>
|
|
127
6
|
|
|
128
|
-
|
|
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
|
-
|
|
9
|
+
_Stackable Rendering Layers as a Unified Tokenized Reality_
|
|
205
10
|
|
|
206
|
-
|
|
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
|
+
[](https://www.npmjs.org/package/cyberia)
|
|
268
12
|
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
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
|
-
|
|
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
|
-
|
|
24
|
+
## Ecosystem at a glance
|
|
441
25
|
|
|
442
|
-
```
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
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
|
-
|
|
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
|
-
|
|
77
|
+
---
|
|
456
78
|
|
|
457
|
-
|
|
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
|
-
|
|
462
|
-
|
|
81
|
+
Every deployed client ships as a static application shell with PWA support. The pipeline has exactly two
|
|
82
|
+
inputs:
|
|
463
83
|
|
|
464
|
-
|
|
465
|
-
|
|
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
|
-
|
|
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
|
-
|
|
90
|
+
Runtime service-worker behavior:
|
|
471
91
|
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
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
|
-
|
|
477
|
-
|
|
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
|
-
|
|
480
|
-
cyberia ol anon --to-atlas-sprite-sheet
|
|
481
|
-
cyberia ol skin --to-atlas-sprite-sheet
|
|
482
|
-
```
|
|
102
|
+
---
|
|
483
103
|
|
|
484
|
-
##
|
|
104
|
+
## 3. Cyberia MMO extension
|
|
485
105
|
|
|
486
|
-
|
|
106
|
+
### Responsibility split
|
|
487
107
|
|
|
488
|
-
|
|
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
|
-
|
|
114
|
+
Two boundaries are non-negotiable:
|
|
491
115
|
|
|
492
|
-
|
|
493
|
-
|
|
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
|
-
|
|
497
|
-
cyberia chain deploy --validators 6 --chain-id 888881 --block-period 3
|
|
119
|
+
### Data flow
|
|
498
120
|
|
|
499
|
-
|
|
500
|
-
cyberia
|
|
121
|
+
```text
|
|
122
|
+
engine-cyberia ──gRPC──▶ cyberia-server ──WebSocket──▶ cyberia-client
|
|
123
|
+
engine-cyberia ──REST──────────────────────────────▶ cyberia-client
|
|
501
124
|
```
|
|
502
125
|
|
|
503
|
-
|
|
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
|
-
|
|
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
|
-
|
|
528
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
```
|
|
540
|
-
|
|
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
|
-
|
|
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
|
-
|
|
170
|
+
---
|
|
546
171
|
|
|
547
|
-
|
|
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
|
-
|
|
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
|
-
|
|
177
|
+
### Platform (underpost)
|
|
562
178
|
|
|
563
179
|
```bash
|
|
564
|
-
#
|
|
565
|
-
|
|
180
|
+
# Bootstrap a new app (local app serves on http://localhost:4001)
|
|
181
|
+
underpost new app-name
|
|
566
182
|
|
|
567
|
-
#
|
|
568
|
-
|
|
183
|
+
# Build the client bundle / static + PWA output
|
|
184
|
+
underpost client
|
|
185
|
+
npm run build # node bin client
|
|
569
186
|
|
|
570
|
-
#
|
|
571
|
-
|
|
187
|
+
# Deploy and operate
|
|
188
|
+
underpost deploy <deploy-id>
|
|
189
|
+
underpost monitor
|
|
572
190
|
```
|
|
573
191
|
|
|
574
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
#
|
|
598
|
-
cyberia
|
|
599
|
-
|
|
600
|
-
#
|
|
601
|
-
cyberia
|
|
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
|
-
#
|
|
604
|
-
cyberia
|
|
605
|
-
|
|
212
|
+
# Instance data
|
|
213
|
+
cyberia instance FOREST --export ./backup
|
|
214
|
+
cyberia instance FOREST --import ./backup
|
|
215
|
+
cyberia instance FOREST --drop
|
|
606
216
|
|
|
607
|
-
|
|
217
|
+
# Presentation hints
|
|
218
|
+
cyberia client-hints cyberia-main --seed-defaults
|
|
608
219
|
|
|
609
|
-
|
|
610
|
-
|
|
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
|
-
#
|
|
614
|
-
cyberia
|
|
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
|
-
###
|
|
233
|
+
### Run the MMO services
|
|
618
234
|
|
|
619
235
|
```bash
|
|
620
|
-
#
|
|
621
|
-
|
|
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
|
-
#
|
|
627
|
-
cyberia
|
|
628
|
-
cyberia
|
|
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
|
-
|
|
634
|
-
cyberia
|
|
635
|
-
cyberia
|
|
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
|
-
|
|
248
|
+
---
|
|
639
249
|
|
|
640
|
-
|
|
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
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
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.
|