cyberia 3.1.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.
- package/.env.example +0 -2
- package/.github/workflows/engine-cyberia.cd.yml +10 -8
- package/.github/workflows/engine-cyberia.ci.yml +12 -29
- package/.github/workflows/ghpkg.ci.yml +4 -4
- package/.github/workflows/npmpkg.ci.yml +28 -11
- package/.github/workflows/publish.ci.yml +21 -2
- package/.github/workflows/pwa-microservices-template-page.cd.yml +4 -5
- package/.github/workflows/pwa-microservices-template-test.ci.yml +3 -3
- package/.github/workflows/release.cd.yml +13 -8
- package/CHANGELOG.md +433 -1
- package/CLI-HELP.md +57 -7
- package/Dockerfile +4 -2
- package/README.md +347 -22
- package/bin/build.js +5 -2
- package/bin/cyberia.js +1789 -112
- package/bin/deploy.js +177 -124
- package/bin/file.js +3 -0
- package/bin/index.js +1789 -112
- package/conf.js +64 -8
- package/deployment.yaml +92 -20
- package/hardhat/hardhat.config.js +13 -13
- package/hardhat/ignition/modules/ObjectLayerToken.js +1 -1
- package/hardhat/package-lock.json +2554 -5859
- package/hardhat/package.json +13 -22
- package/hardhat/scripts/deployObjectLayerToken.js +1 -1
- package/hardhat/test/ObjectLayerToken.js +4 -2
- package/hardhat/types/ethers-contracts/ObjectLayerToken.ts +690 -0
- package/hardhat/types/ethers-contracts/common.ts +92 -0
- package/hardhat/types/ethers-contracts/factories/ObjectLayerToken__factory.ts +1055 -0
- package/hardhat/types/ethers-contracts/factories/index.ts +4 -0
- package/hardhat/types/ethers-contracts/hardhat.d.ts +47 -0
- package/hardhat/types/ethers-contracts/index.ts +6 -0
- package/jsdoc.dd-cyberia.json +64 -55
- package/jsdoc.json +64 -55
- package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +5 -4
- package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +5 -4
- package/manifests/deployment/dd-cyberia-development/deployment.yaml +92 -20
- package/manifests/deployment/dd-cyberia-development/proxy.yaml +54 -18
- package/manifests/deployment/dd-default-development/deployment.yaml +2 -2
- package/manifests/deployment/dd-test-development/deployment.yaml +88 -74
- package/manifests/deployment/dd-test-development/proxy.yaml +13 -4
- package/manifests/deployment/playwright/deployment.yaml +1 -1
- package/nodemon.json +1 -1
- package/package.json +22 -16
- package/proxy.yaml +54 -18
- package/scripts/rhel-grpc-setup.sh +56 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +44 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +16 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.router.js +5 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +80 -7
- package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +93 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +36 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +29 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +51 -0
- package/src/api/cyberia-entity/cyberia-entity.controller.js +74 -0
- package/src/api/cyberia-entity/cyberia-entity.model.js +24 -0
- package/src/api/cyberia-entity/cyberia-entity.router.js +27 -0
- package/src/api/cyberia-entity/cyberia-entity.service.js +42 -0
- package/src/api/cyberia-instance/cyberia-fallback-world.js +368 -0
- package/src/api/cyberia-instance/cyberia-instance.controller.js +92 -0
- package/src/api/cyberia-instance/cyberia-instance.model.js +84 -0
- package/src/api/cyberia-instance/cyberia-instance.router.js +63 -0
- package/src/api/cyberia-instance/cyberia-instance.service.js +191 -0
- package/src/api/cyberia-instance/cyberia-portal-connector.js +486 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +74 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +413 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +228 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.router.js +27 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +42 -0
- package/src/api/cyberia-map/cyberia-map.controller.js +79 -0
- package/src/api/cyberia-map/cyberia-map.model.js +30 -0
- package/src/api/cyberia-map/cyberia-map.router.js +40 -0
- package/src/api/cyberia-map/cyberia-map.service.js +74 -0
- package/src/api/file/file.ref.json +18 -0
- package/src/api/ipfs/ipfs.controller.js +4 -25
- package/src/api/ipfs/ipfs.model.js +43 -34
- package/src/api/ipfs/ipfs.router.js +8 -13
- package/src/api/ipfs/ipfs.service.js +54 -102
- package/src/api/object-layer/README.md +347 -22
- package/src/api/object-layer/object-layer.router.js +30 -0
- package/src/api/object-layer/object-layer.service.js +114 -31
- package/src/api/user/user.service.js +8 -7
- package/src/cli/cluster.js +7 -7
- package/src/cli/db.js +710 -827
- package/src/cli/deploy.js +151 -93
- package/src/cli/env.js +29 -0
- package/src/cli/fs.js +5 -2
- package/src/cli/index.js +48 -2
- package/src/cli/kubectl.js +211 -0
- package/src/cli/release.js +284 -0
- package/src/cli/repository.js +438 -75
- package/src/cli/run.js +195 -35
- package/src/cli/secrets.js +73 -0
- package/src/cli/test.js +3 -3
- package/src/client/Cryptokoyn.index.js +3 -4
- package/src/client/CyberiaPortal.index.js +3 -4
- package/src/client/Default.index.js +3 -4
- package/src/client/Itemledger.index.js +3 -4
- package/src/client/Underpost.index.js +3 -4
- package/src/client/components/core/AppStore.js +69 -0
- package/src/client/components/core/CalendarCore.js +2 -2
- package/src/client/components/core/DropDown.js +137 -17
- package/src/client/components/core/Keyboard.js +2 -2
- package/src/client/components/core/LogIn.js +2 -2
- package/src/client/components/core/LogOut.js +2 -2
- package/src/client/components/core/Modal.js +0 -1
- package/src/client/components/core/Panel.js +0 -1
- package/src/client/components/core/PanelForm.js +19 -19
- package/src/client/components/core/SocketIo.js +82 -29
- package/src/client/components/core/SocketIoHandler.js +75 -0
- package/src/client/components/core/Stream.js +143 -95
- package/src/client/components/core/Webhook.js +40 -7
- package/src/client/components/cryptokoyn/AppStoreCryptokoyn.js +5 -0
- package/src/client/components/cryptokoyn/LogInCryptokoyn.js +3 -3
- package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +2 -2
- package/src/client/components/cryptokoyn/MenuCryptokoyn.js +3 -3
- package/src/client/components/cryptokoyn/SocketIoCryptokoyn.js +3 -51
- package/src/client/components/cyberia/InstanceEngineCyberia.js +700 -0
- package/src/client/components/cyberia/MapEngineCyberia.js +1359 -2
- package/src/client/components/cyberia/ObjectLayerEngineModal.js +17 -6
- package/src/client/components/cyberia/ObjectLayerEngineViewer.js +92 -54
- package/src/client/components/cyberia-portal/AppStoreCyberiaPortal.js +5 -0
- package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +216 -30
- package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +3 -3
- package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +2 -2
- package/src/client/components/cyberia-portal/MenuCyberiaPortal.js +40 -7
- package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +4 -0
- package/src/client/components/cyberia-portal/SocketIoCyberiaPortal.js +3 -49
- package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +4 -0
- package/src/client/components/default/AppStoreDefault.js +5 -0
- package/src/client/components/default/LogInDefault.js +3 -3
- package/src/client/components/default/LogOutDefault.js +2 -2
- package/src/client/components/default/MenuDefault.js +5 -5
- package/src/client/components/default/SocketIoDefault.js +3 -51
- package/src/client/components/itemledger/AppStoreItemledger.js +5 -0
- package/src/client/components/itemledger/LogInItemledger.js +3 -3
- package/src/client/components/itemledger/LogOutItemledger.js +2 -2
- package/src/client/components/itemledger/MenuItemledger.js +3 -3
- package/src/client/components/itemledger/SocketIoItemledger.js +3 -51
- package/src/client/components/underpost/AppStoreUnderpost.js +5 -0
- package/src/client/components/underpost/LogInUnderpost.js +3 -3
- package/src/client/components/underpost/LogOutUnderpost.js +2 -2
- package/src/client/components/underpost/MenuUnderpost.js +5 -5
- package/src/client/components/underpost/SocketIoUnderpost.js +3 -51
- package/src/client/services/core/core.service.js +20 -8
- package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +105 -0
- package/src/client/services/cyberia-entity/cyberia-entity.management.js +57 -0
- package/src/client/services/cyberia-entity/cyberia-entity.service.js +105 -0
- package/src/client/services/cyberia-instance/cyberia-instance.management.js +194 -0
- package/src/client/services/cyberia-instance/cyberia-instance.service.js +122 -0
- package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +105 -0
- package/src/client/services/cyberia-map/cyberia-map.management.js +193 -0
- package/src/client/services/cyberia-map/cyberia-map.service.js +126 -0
- package/src/client/services/instance/instance.management.js +2 -2
- package/src/client/services/ipfs/ipfs.service.js +3 -23
- package/src/client/services/object-layer/object-layer.management.js +3 -3
- package/src/client/services/object-layer/object-layer.service.js +21 -0
- package/src/client/services/user/user.management.js +2 -2
- package/src/client/ssr/pages/CyberiaServerMetrics.js +1 -1
- package/src/grpc/cyberia/OFF_CHAIN_ECONOMY.md +305 -0
- package/src/grpc/cyberia/README.md +326 -0
- package/src/grpc/cyberia/grpc-server.js +530 -0
- package/src/index.js +24 -1
- package/src/runtime/express/Dockerfile +4 -0
- package/src/runtime/express/Express.js +18 -1
- package/src/runtime/lampp/Dockerfile +13 -2
- package/src/runtime/lampp/Lampp.js +27 -4
- package/src/runtime/wp/Dockerfile +68 -0
- package/src/runtime/wp/Wp.js +639 -0
- package/src/server/auth.js +24 -1
- package/src/server/backup.js +37 -9
- package/src/server/client-build-docs.js +9 -2
- package/src/server/client-build.js +31 -31
- package/src/server/client-formatted.js +109 -57
- package/src/server/conf.js +24 -9
- package/src/server/cron.js +25 -23
- package/src/server/dns.js +2 -1
- package/src/server/ipfs-client.js +24 -1
- package/src/server/object-layer.js +149 -108
- package/src/server/peer.js +8 -0
- package/src/server/runtime.js +25 -1
- package/src/server/semantic-layer-generator-floor.js +359 -0
- package/src/server/semantic-layer-generator-skin.js +1294 -0
- package/src/server/semantic-layer-generator.js +116 -555
- package/src/server/start.js +2 -2
- package/src/ws/IoInterface.js +1 -10
- package/src/ws/IoServer.js +14 -33
- package/src/ws/core/channels/core.ws.chat.js +65 -20
- package/src/ws/core/channels/core.ws.mailer.js +113 -32
- package/src/ws/core/channels/core.ws.stream.js +90 -31
- package/src/ws/core/core.ws.connection.js +12 -33
- package/src/ws/core/core.ws.emit.js +10 -26
- package/src/ws/core/core.ws.server.js +25 -58
- package/src/ws/default/channels/default.ws.main.js +53 -12
- package/src/ws/default/default.ws.connection.js +26 -13
- package/src/ws/default/default.ws.server.js +30 -12
- package/src/client/components/cryptokoyn/CommonCryptokoyn.js +0 -29
- package/src/client/components/cryptokoyn/ElementsCryptokoyn.js +0 -38
- package/src/client/components/cyberia-portal/ElementsCyberiaPortal.js +0 -38
- package/src/client/components/default/ElementsDefault.js +0 -38
- package/src/client/components/itemledger/CommonItemledger.js +0 -29
- package/src/client/components/itemledger/ElementsItemledger.js +0 -38
- package/src/client/components/underpost/CommonUnderpost.js +0 -29
- package/src/client/components/underpost/ElementsUnderpost.js +0 -38
- package/src/ws/core/management/core.ws.chat.js +0 -8
- package/src/ws/core/management/core.ws.mailer.js +0 -16
- package/src/ws/core/management/core.ws.stream.js +0 -8
- package/src/ws/default/management/default.ws.main.js +0 -8
package/README.md
CHANGED
|
@@ -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
|
-
###
|
|
66
|
+
### Import specific items with `--import`
|
|
62
67
|
|
|
63
|
-
|
|
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
|
|
100
|
-
|
|
101
|
-
| `--seed <str>`
|
|
102
|
-
| `--count <n>`
|
|
103
|
-
| `--frame-index <n>` | `0`
|
|
104
|
-
| `--frame-count <n>` | `1`
|
|
105
|
-
| `--density <f>`
|
|
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
|
|
110
|
-
|
|
111
|
-
| `floor-desert`
|
|
112
|
-
| `floor-grass`
|
|
113
|
-
| `floor-water`
|
|
114
|
-
| `floor-stone`
|
|
115
|
-
| `floor-lava`
|
|
116
|
-
| `skin
|
|
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 |
|
package/bin/build.js
CHANGED
|
@@ -169,20 +169,22 @@ const { DefaultConf } = await import(`../conf.${confName}.js`);
|
|
|
169
169
|
packageJson.description = 'Cyberia Engine - Object Layer and Assets Management Microservice';
|
|
170
170
|
const { CyberiaDependencies } = await import(`../src/client/components/cyberia-portal/CommonCyberiaPortal.js`);
|
|
171
171
|
packageJson.dependencies = {
|
|
172
|
-
...
|
|
172
|
+
...originPackageJson.dependencies,
|
|
173
173
|
...CyberiaDependencies,
|
|
174
174
|
};
|
|
175
|
-
packageJson.overrides = originPackageJson.overrides;
|
|
176
175
|
fs.writeFileSync(`${basePath}/bin/index.js`, fs.readFileSync(`./bin/cyberia.js`, 'utf8'), 'utf8');
|
|
177
176
|
fs.copyFileSync(`./src/api/object-layer/README.md`, `${basePath}/README.md`);
|
|
178
177
|
fs.copySync(`./hardhat`, `${basePath}/hardhat`);
|
|
179
178
|
fs.copySync(`./hardhat/WHITE-PAPER.md`, `${basePath}/WHITE-PAPER.md`);
|
|
180
179
|
for (const path of [
|
|
180
|
+
'/src/grpc/cyberia',
|
|
181
181
|
'/src/client/ssr/pages/CyberiaServerMetrics.js',
|
|
182
182
|
'/src/server/object-layer.js',
|
|
183
183
|
'/src/server/atlas-sprite-sheet-generator.js',
|
|
184
184
|
'/src/server/shape-generator.js',
|
|
185
185
|
'/src/server/semantic-layer-generator.js',
|
|
186
|
+
'/src/server/semantic-layer-generator-floor.js',
|
|
187
|
+
'/src/server/semantic-layer-generator-skin.js',
|
|
186
188
|
'/test/shape-generator.test.js',
|
|
187
189
|
'/src/server/besu-genesis-generator.js',
|
|
188
190
|
'/.github/workflows/hardhat.ci.yml',
|
|
@@ -226,5 +228,6 @@ const { DefaultConf } = await import(`../conf.${confName}.js`);
|
|
|
226
228
|
if (fs.existsSync(`./src/ws/${confName.split('-')[1]}`)) {
|
|
227
229
|
fs.copySync(`./src/ws/${confName.split('-')[1]}`, `${basePath}/src/ws/${confName.split('-')[1]}`);
|
|
228
230
|
}
|
|
231
|
+
fs.copyFileSync(`.gitignore`, `${basePath}/.gitignore`);
|
|
229
232
|
shellExec(`cd ${basePath} && npm install --ignore-scripts`);
|
|
230
233
|
}
|