@hashgraphonline/standards-sdk 0.1.143 → 0.1.144-feat-solana-register.canary.5001619.81
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/dist/cjs/hcs-10/base-client.d.ts.map +1 -1
- package/dist/cjs/hcs-10/sdk.d.ts +8 -0
- package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-11/client.d.ts +2 -2
- package/dist/cjs/hcs-11/client.d.ts.map +1 -1
- package/dist/cjs/hcs-11/person-builder.d.ts +1 -0
- package/dist/cjs/hcs-11/person-builder.d.ts.map +1 -1
- package/dist/cjs/hcs-11/types.d.ts +1 -0
- package/dist/cjs/hcs-11/types.d.ts.map +1 -1
- package/dist/cjs/hcs-12/rendering/resource-manager.d.ts.map +1 -1
- package/dist/cjs/hcs-12/validation/schemas.d.ts +8 -8
- package/dist/cjs/hcs-14/issuers/hiero.d.ts.map +1 -1
- package/dist/cjs/hcs-15/browser.d.ts +2 -0
- package/dist/cjs/hcs-15/browser.d.ts.map +1 -1
- package/dist/cjs/hcs-15/sdk.d.ts +7 -1
- package/dist/cjs/hcs-15/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-15/tx.d.ts +4 -0
- package/dist/cjs/hcs-15/tx.d.ts.map +1 -1
- package/dist/cjs/hcs-15/types.d.ts +16 -1
- package/dist/cjs/hcs-15/types.d.ts.map +1 -1
- package/dist/cjs/hcs-16/browser.d.ts +11 -2
- package/dist/cjs/hcs-16/browser.d.ts.map +1 -1
- package/dist/cjs/hcs-16/sdk.d.ts +62 -1
- package/dist/cjs/hcs-16/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-16/tx.d.ts +21 -3
- package/dist/cjs/hcs-16/tx.d.ts.map +1 -1
- package/dist/cjs/hcs-17/base-client.d.ts +1 -0
- package/dist/cjs/hcs-17/base-client.d.ts.map +1 -1
- package/dist/cjs/hcs-17/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-17/tx.d.ts +2 -0
- package/dist/cjs/hcs-17/tx.d.ts.map +1 -1
- package/dist/cjs/hcs-17/types.d.ts +4 -0
- package/dist/cjs/hcs-17/types.d.ts.map +1 -1
- package/dist/cjs/hcs-21/types.d.ts +75 -75
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/services/registry-broker/client/adapters.d.ts +20 -0
- package/dist/cjs/services/registry-broker/client/adapters.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/agents.d.ts +16 -0
- package/dist/cjs/services/registry-broker/client/agents.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/base-client.d.ts +70 -0
- package/dist/cjs/services/registry-broker/client/base-client.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/chat-history.d.ts +23 -0
- package/dist/cjs/services/registry-broker/client/chat-history.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/chat.d.ts +33 -0
- package/dist/cjs/services/registry-broker/client/chat.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/credits.d.ts +40 -0
- package/dist/cjs/services/registry-broker/client/credits.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/encrypted-chat-manager.d.ts +35 -0
- package/dist/cjs/services/registry-broker/client/encrypted-chat-manager.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/encryption.d.ts +33 -0
- package/dist/cjs/services/registry-broker/client/encryption.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/errors.d.ts +19 -0
- package/dist/cjs/services/registry-broker/client/errors.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/feedback.d.ts +2 -0
- package/dist/cjs/services/registry-broker/client/feedback.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/ledger-auth.d.ts +10 -0
- package/dist/cjs/services/registry-broker/client/ledger-auth.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/search.d.ts +19 -0
- package/dist/cjs/services/registry-broker/client/search.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client/utils.d.ts +21 -0
- package/dist/cjs/services/registry-broker/client/utils.d.ts.map +1 -0
- package/dist/cjs/services/registry-broker/client.d.ts +2 -205
- package/dist/cjs/services/registry-broker/client.d.ts.map +1 -1
- package/dist/cjs/services/registry-broker/private-key-signer.d.ts +1 -0
- package/dist/cjs/services/registry-broker/private-key-signer.d.ts.map +1 -1
- package/dist/cjs/services/registry-broker/schemas.d.ts +2509 -816
- package/dist/cjs/services/registry-broker/schemas.d.ts.map +1 -1
- package/dist/cjs/services/registry-broker/types.d.ts +64 -2
- package/dist/cjs/services/registry-broker/types.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +3 -3
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/cjs/utils/crypto-abstraction.d.ts.map +1 -1
- package/dist/cjs/utils/crypto-env.d.ts.map +1 -1
- package/dist/cjs/utils/dynamic-import.d.ts +5 -1
- package/dist/cjs/utils/dynamic-import.d.ts.map +1 -1
- package/dist/cjs/utils/hash-adapter.d.ts.map +1 -1
- package/dist/es/hcs-10/base-client.d.ts.map +1 -1
- package/dist/es/hcs-10/sdk.d.ts +8 -0
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/hcs-11/client.d.ts +2 -2
- package/dist/es/hcs-11/client.d.ts.map +1 -1
- package/dist/es/hcs-11/person-builder.d.ts +1 -0
- package/dist/es/hcs-11/person-builder.d.ts.map +1 -1
- package/dist/es/hcs-11/types.d.ts +1 -0
- package/dist/es/hcs-11/types.d.ts.map +1 -1
- package/dist/es/hcs-12/rendering/resource-manager.d.ts.map +1 -1
- package/dist/es/hcs-12/validation/schemas.d.ts +8 -8
- package/dist/es/hcs-14/issuers/hiero.d.ts.map +1 -1
- package/dist/es/hcs-15/browser.d.ts +2 -0
- package/dist/es/hcs-15/browser.d.ts.map +1 -1
- package/dist/es/hcs-15/sdk.d.ts +7 -1
- package/dist/es/hcs-15/sdk.d.ts.map +1 -1
- package/dist/es/hcs-15/tx.d.ts +4 -0
- package/dist/es/hcs-15/tx.d.ts.map +1 -1
- package/dist/es/hcs-15/types.d.ts +16 -1
- package/dist/es/hcs-15/types.d.ts.map +1 -1
- package/dist/es/hcs-16/browser.d.ts +11 -2
- package/dist/es/hcs-16/browser.d.ts.map +1 -1
- package/dist/es/hcs-16/sdk.d.ts +62 -1
- package/dist/es/hcs-16/sdk.d.ts.map +1 -1
- package/dist/es/hcs-16/tx.d.ts +21 -3
- package/dist/es/hcs-16/tx.d.ts.map +1 -1
- package/dist/es/hcs-17/base-client.d.ts +1 -0
- package/dist/es/hcs-17/base-client.d.ts.map +1 -1
- package/dist/es/hcs-17/sdk.d.ts.map +1 -1
- package/dist/es/hcs-17/tx.d.ts +2 -0
- package/dist/es/hcs-17/tx.d.ts.map +1 -1
- package/dist/es/hcs-17/types.d.ts +4 -0
- package/dist/es/hcs-17/types.d.ts.map +1 -1
- package/dist/es/hcs-21/types.d.ts +75 -75
- package/dist/es/index.d.ts.map +1 -1
- package/dist/es/services/registry-broker/client/adapters.d.ts +20 -0
- package/dist/es/services/registry-broker/client/adapters.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/agents.d.ts +16 -0
- package/dist/es/services/registry-broker/client/agents.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/base-client.d.ts +70 -0
- package/dist/es/services/registry-broker/client/base-client.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/chat-history.d.ts +23 -0
- package/dist/es/services/registry-broker/client/chat-history.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/chat.d.ts +33 -0
- package/dist/es/services/registry-broker/client/chat.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/credits.d.ts +40 -0
- package/dist/es/services/registry-broker/client/credits.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/encrypted-chat-manager.d.ts +35 -0
- package/dist/es/services/registry-broker/client/encrypted-chat-manager.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/encryption.d.ts +33 -0
- package/dist/es/services/registry-broker/client/encryption.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/errors.d.ts +19 -0
- package/dist/es/services/registry-broker/client/errors.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/feedback.d.ts +2 -0
- package/dist/es/services/registry-broker/client/feedback.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/ledger-auth.d.ts +10 -0
- package/dist/es/services/registry-broker/client/ledger-auth.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/search.d.ts +19 -0
- package/dist/es/services/registry-broker/client/search.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client/utils.d.ts +21 -0
- package/dist/es/services/registry-broker/client/utils.d.ts.map +1 -0
- package/dist/es/services/registry-broker/client.d.ts +2 -205
- package/dist/es/services/registry-broker/client.d.ts.map +1 -1
- package/dist/es/services/registry-broker/private-key-signer.d.ts +1 -0
- package/dist/es/services/registry-broker/private-key-signer.d.ts.map +1 -1
- package/dist/es/services/registry-broker/schemas.d.ts +2509 -816
- package/dist/es/services/registry-broker/schemas.d.ts.map +1 -1
- package/dist/es/services/registry-broker/types.d.ts +64 -2
- package/dist/es/services/registry-broker/types.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +148 -133
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es10.js +70 -90
- package/dist/es/standards-sdk.es10.js.map +1 -1
- package/dist/es/standards-sdk.es100.js +229 -26
- package/dist/es/standards-sdk.es100.js.map +1 -1
- package/dist/es/standards-sdk.es101.js +109 -228
- package/dist/es/standards-sdk.es101.js.map +1 -1
- package/dist/es/standards-sdk.es102.js +15 -94
- package/dist/es/standards-sdk.es102.js.map +1 -1
- package/dist/es/standards-sdk.es103.js +80 -30
- package/dist/es/standards-sdk.es103.js.map +1 -1
- package/dist/es/standards-sdk.es104.js +27 -80
- package/dist/es/standards-sdk.es104.js.map +1 -1
- package/dist/es/standards-sdk.es105.js +136 -25
- package/dist/es/standards-sdk.es105.js.map +1 -1
- package/dist/es/standards-sdk.es106.js +27 -140
- package/dist/es/standards-sdk.es106.js.map +1 -1
- package/dist/es/standards-sdk.es107.js +20 -27
- package/dist/es/standards-sdk.es107.js.map +1 -1
- package/dist/es/standards-sdk.es108.js +156 -18
- package/dist/es/standards-sdk.es108.js.map +1 -1
- package/dist/es/standards-sdk.es109.js +198 -148
- package/dist/es/standards-sdk.es109.js.map +1 -1
- package/dist/es/standards-sdk.es11.js +121 -45
- package/dist/es/standards-sdk.es11.js.map +1 -1
- package/dist/es/standards-sdk.es110.js +747 -160
- package/dist/es/standards-sdk.es110.js.map +1 -1
- package/dist/es/standards-sdk.es111.js +9 -786
- package/dist/es/standards-sdk.es111.js.map +1 -1
- package/dist/es/standards-sdk.es112.js +567 -13
- package/dist/es/standards-sdk.es112.js.map +1 -1
- package/dist/es/standards-sdk.es113.js +576 -541
- package/dist/es/standards-sdk.es113.js.map +1 -1
- package/dist/es/standards-sdk.es114.js +12 -601
- package/dist/es/standards-sdk.es114.js.map +1 -1
- package/dist/es/standards-sdk.es115.js +2 -13
- package/dist/es/standards-sdk.es115.js.map +1 -1
- package/dist/es/standards-sdk.es116.js +87 -2
- package/dist/es/standards-sdk.es116.js.map +1 -1
- package/dist/es/standards-sdk.es117.js +37 -80
- package/dist/es/standards-sdk.es117.js.map +1 -1
- package/dist/es/standards-sdk.es118.js +2 -39
- package/dist/es/standards-sdk.es118.js.map +1 -1
- package/dist/es/standards-sdk.es119.js +231 -2
- package/dist/es/standards-sdk.es119.js.map +1 -1
- package/dist/es/standards-sdk.es12.js +60 -159
- package/dist/es/standards-sdk.es12.js.map +1 -1
- package/dist/es/standards-sdk.es120.js +1110 -193
- package/dist/es/standards-sdk.es120.js.map +1 -1
- package/dist/es/standards-sdk.es121.js +225 -1059
- package/dist/es/standards-sdk.es121.js.map +1 -1
- package/dist/es/standards-sdk.es122.js +419 -303
- package/dist/es/standards-sdk.es122.js.map +1 -1
- package/dist/es/standards-sdk.es123.js +351 -418
- package/dist/es/standards-sdk.es123.js.map +1 -1
- package/dist/es/standards-sdk.es124.js +872 -347
- package/dist/es/standards-sdk.es124.js.map +1 -1
- package/dist/es/standards-sdk.es125.js +182 -854
- package/dist/es/standards-sdk.es125.js.map +1 -1
- package/dist/es/standards-sdk.es126.js +1512 -153
- package/dist/es/standards-sdk.es126.js.map +1 -1
- package/dist/es/standards-sdk.es127.js +157 -1547
- package/dist/es/standards-sdk.es127.js.map +1 -1
- package/dist/es/standards-sdk.es128.js +184 -2190
- package/dist/es/standards-sdk.es128.js.map +1 -1
- package/dist/es/standards-sdk.es129.js +100 -63
- package/dist/es/standards-sdk.es129.js.map +1 -1
- package/dist/es/standards-sdk.es13.js +200 -60
- package/dist/es/standards-sdk.es13.js.map +1 -1
- package/dist/es/standards-sdk.es130.js +112 -78
- package/dist/es/standards-sdk.es130.js.map +1 -1
- package/dist/es/standards-sdk.es131.js +232 -144
- package/dist/es/standards-sdk.es131.js.map +1 -1
- package/dist/es/standards-sdk.es132.js +181 -8
- package/dist/es/standards-sdk.es132.js.map +1 -1
- package/dist/es/standards-sdk.es133.js +118 -82
- package/dist/es/standards-sdk.es133.js.map +1 -1
- package/dist/es/standards-sdk.es134.js +322 -61
- package/dist/es/standards-sdk.es134.js.map +1 -1
- package/dist/es/standards-sdk.es135.js +464 -28
- package/dist/es/standards-sdk.es135.js.map +1 -1
- package/dist/es/standards-sdk.es136.js +14 -135
- package/dist/es/standards-sdk.es136.js.map +1 -1
- package/dist/es/standards-sdk.es137.js +78 -39
- package/dist/es/standards-sdk.es137.js.map +1 -1
- package/dist/es/standards-sdk.es138.js +85 -764
- package/dist/es/standards-sdk.es138.js.map +1 -1
- package/dist/es/standards-sdk.es139.js +135 -12250
- package/dist/es/standards-sdk.es139.js.map +1 -1
- package/dist/es/standards-sdk.es14.js +149 -178
- package/dist/es/standards-sdk.es14.js.map +1 -1
- package/dist/es/standards-sdk.es140.js +7 -56
- package/dist/es/standards-sdk.es140.js.map +1 -1
- package/dist/es/standards-sdk.es141.js +72 -68
- package/dist/es/standards-sdk.es141.js.map +1 -1
- package/dist/es/standards-sdk.es142.js +61 -13
- package/dist/es/standards-sdk.es142.js.map +1 -1
- package/dist/es/standards-sdk.es143.js +30 -172
- package/dist/es/standards-sdk.es143.js.map +1 -1
- package/dist/es/standards-sdk.es144.js +34 -322
- package/dist/es/standards-sdk.es144.js.map +1 -1
- package/dist/es/standards-sdk.es145.js +28 -346
- package/dist/es/standards-sdk.es145.js.map +1 -1
- package/dist/es/standards-sdk.es146.js +112 -427
- package/dist/es/standards-sdk.es146.js.map +1 -1
- package/dist/es/standards-sdk.es147.js +40 -329
- package/dist/es/standards-sdk.es147.js.map +1 -1
- package/dist/es/standards-sdk.es148.js +958 -76
- package/dist/es/standards-sdk.es148.js.map +1 -1
- package/dist/es/standards-sdk.es149.js +12292 -0
- package/dist/es/standards-sdk.es149.js.map +1 -0
- package/dist/es/standards-sdk.es15.js +152 -151
- package/dist/es/standards-sdk.es15.js.map +1 -1
- package/dist/es/standards-sdk.es150.js +59 -0
- package/dist/es/standards-sdk.es150.js.map +1 -0
- package/dist/es/standards-sdk.es151.js +87 -0
- package/dist/es/standards-sdk.es151.js.map +1 -0
- package/dist/es/standards-sdk.es152.js +20 -0
- package/dist/es/standards-sdk.es152.js.map +1 -0
- package/dist/es/standards-sdk.es153.js +175 -0
- package/dist/es/standards-sdk.es153.js.map +1 -0
- package/dist/es/standards-sdk.es154.js +325 -0
- package/dist/es/standards-sdk.es154.js.map +1 -0
- package/dist/es/standards-sdk.es155.js +349 -0
- package/dist/es/standards-sdk.es155.js.map +1 -0
- package/dist/es/standards-sdk.es156.js +456 -0
- package/dist/es/standards-sdk.es156.js.map +1 -0
- package/dist/es/standards-sdk.es157.js +334 -0
- package/dist/es/standards-sdk.es157.js.map +1 -0
- package/dist/es/standards-sdk.es158.js +79 -0
- package/dist/es/standards-sdk.es158.js.map +1 -0
- package/dist/es/standards-sdk.es159.js +242 -0
- package/dist/es/standards-sdk.es159.js.map +1 -0
- package/dist/es/standards-sdk.es16.js +917 -136
- package/dist/es/standards-sdk.es16.js.map +1 -1
- package/dist/es/standards-sdk.es160.js +247 -0
- package/dist/es/standards-sdk.es160.js.map +1 -0
- package/dist/es/standards-sdk.es17.js +23 -938
- package/dist/es/standards-sdk.es17.js.map +1 -1
- package/dist/es/standards-sdk.es18.js +2422 -24
- package/dist/es/standards-sdk.es18.js.map +1 -1
- package/dist/es/standards-sdk.es19.js +826 -2075
- package/dist/es/standards-sdk.es19.js.map +1 -1
- package/dist/es/standards-sdk.es2.js +654 -189
- package/dist/es/standards-sdk.es2.js.map +1 -1
- package/dist/es/standards-sdk.es20.js +205 -1086
- package/dist/es/standards-sdk.es20.js.map +1 -1
- package/dist/es/standards-sdk.es21.js +858 -221
- package/dist/es/standards-sdk.es21.js.map +1 -1
- package/dist/es/standards-sdk.es22.js +179 -903
- package/dist/es/standards-sdk.es22.js.map +1 -1
- package/dist/es/standards-sdk.es23.js +164 -179
- package/dist/es/standards-sdk.es23.js.map +1 -1
- package/dist/es/standards-sdk.es24.js +62 -118
- package/dist/es/standards-sdk.es24.js.map +1 -1
- package/dist/es/standards-sdk.es25.js +377 -52
- package/dist/es/standards-sdk.es25.js.map +1 -1
- package/dist/es/standards-sdk.es26.js +36 -394
- package/dist/es/standards-sdk.es26.js.map +1 -1
- package/dist/es/standards-sdk.es27.js +901 -50
- package/dist/es/standards-sdk.es27.js.map +1 -1
- package/dist/es/standards-sdk.es28.js +134 -897
- package/dist/es/standards-sdk.es28.js.map +1 -1
- package/dist/es/standards-sdk.es29.js +7 -134
- package/dist/es/standards-sdk.es29.js.map +1 -1
- package/dist/es/standards-sdk.es3.js +63 -680
- package/dist/es/standards-sdk.es3.js.map +1 -1
- package/dist/es/standards-sdk.es30.js +344 -7
- package/dist/es/standards-sdk.es30.js.map +1 -1
- package/dist/es/standards-sdk.es31.js +302 -287
- package/dist/es/standards-sdk.es31.js.map +1 -1
- package/dist/es/standards-sdk.es32.js +94 -322
- package/dist/es/standards-sdk.es32.js.map +1 -1
- package/dist/es/standards-sdk.es33.js +458 -101
- package/dist/es/standards-sdk.es33.js.map +1 -1
- package/dist/es/standards-sdk.es34.js +132 -451
- package/dist/es/standards-sdk.es34.js.map +1 -1
- package/dist/es/standards-sdk.es35.js +216 -130
- package/dist/es/standards-sdk.es35.js.map +1 -1
- package/dist/es/standards-sdk.es36.js +274 -191
- package/dist/es/standards-sdk.es36.js.map +1 -1
- package/dist/es/standards-sdk.es37.js +148 -87
- package/dist/es/standards-sdk.es37.js.map +1 -1
- package/dist/es/standards-sdk.es38.js +183 -320
- package/dist/es/standards-sdk.es38.js.map +1 -1
- package/dist/es/standards-sdk.es39.js +238 -161
- package/dist/es/standards-sdk.es39.js.map +1 -1
- package/dist/es/standards-sdk.es4.js +425 -63
- package/dist/es/standards-sdk.es4.js.map +1 -1
- package/dist/es/standards-sdk.es40.js +136 -254
- package/dist/es/standards-sdk.es40.js.map +1 -1
- package/dist/es/standards-sdk.es41.js +225 -176
- package/dist/es/standards-sdk.es41.js.map +1 -1
- package/dist/es/standards-sdk.es42.js +199 -261
- package/dist/es/standards-sdk.es42.js.map +1 -1
- package/dist/es/standards-sdk.es43.js +237 -199
- package/dist/es/standards-sdk.es43.js.map +1 -1
- package/dist/es/standards-sdk.es44.js +209 -201
- package/dist/es/standards-sdk.es44.js.map +1 -1
- package/dist/es/standards-sdk.es45.js +305 -201
- package/dist/es/standards-sdk.es45.js.map +1 -1
- package/dist/es/standards-sdk.es46.js +371 -261
- package/dist/es/standards-sdk.es46.js.map +1 -1
- package/dist/es/standards-sdk.es47.js +316 -371
- package/dist/es/standards-sdk.es47.js.map +1 -1
- package/dist/es/standards-sdk.es48.js +404 -336
- package/dist/es/standards-sdk.es48.js.map +1 -1
- package/dist/es/standards-sdk.es49.js +83 -449
- package/dist/es/standards-sdk.es49.js.map +1 -1
- package/dist/es/standards-sdk.es5.js +232 -354
- package/dist/es/standards-sdk.es5.js.map +1 -1
- package/dist/es/standards-sdk.es50.js +179 -89
- package/dist/es/standards-sdk.es50.js.map +1 -1
- package/dist/es/standards-sdk.es51.js +231 -165
- package/dist/es/standards-sdk.es51.js.map +1 -1
- package/dist/es/standards-sdk.es52.js +25 -262
- package/dist/es/standards-sdk.es52.js.map +1 -1
- package/dist/es/standards-sdk.es53.js +56 -26
- package/dist/es/standards-sdk.es53.js.map +1 -1
- package/dist/es/standards-sdk.es54.js +12 -57
- package/dist/es/standards-sdk.es54.js.map +1 -1
- package/dist/es/standards-sdk.es55.js +49 -12
- package/dist/es/standards-sdk.es55.js.map +1 -1
- package/dist/es/standards-sdk.es56.js +115 -43
- package/dist/es/standards-sdk.es56.js.map +1 -1
- package/dist/es/standards-sdk.es57.js +42 -115
- package/dist/es/standards-sdk.es57.js.map +1 -1
- package/dist/es/standards-sdk.es58.js +52 -43
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +36 -50
- package/dist/es/standards-sdk.es59.js.map +1 -1
- package/dist/es/standards-sdk.es6.js +125 -246
- package/dist/es/standards-sdk.es6.js.map +1 -1
- package/dist/es/standards-sdk.es60.js +207 -39
- package/dist/es/standards-sdk.es60.js.map +1 -1
- package/dist/es/standards-sdk.es61.js +24 -195
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es62.js +87 -25
- package/dist/es/standards-sdk.es62.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +3 -51
- package/dist/es/standards-sdk.es63.js.map +1 -1
- package/dist/es/standards-sdk.es64.js +100 -3
- package/dist/es/standards-sdk.es64.js.map +1 -1
- package/dist/es/standards-sdk.es65.js +61 -62
- package/dist/es/standards-sdk.es65.js.map +1 -1
- package/dist/es/standards-sdk.es66.js +17 -98
- package/dist/es/standards-sdk.es66.js.map +1 -1
- package/dist/es/standards-sdk.es67.js +77 -19
- package/dist/es/standards-sdk.es67.js.map +1 -1
- package/dist/es/standards-sdk.es68.js +458 -77
- package/dist/es/standards-sdk.es68.js.map +1 -1
- package/dist/es/standards-sdk.es69.js +106 -240
- package/dist/es/standards-sdk.es69.js.map +1 -1
- package/dist/es/standards-sdk.es7.js +28 -183
- package/dist/es/standards-sdk.es7.js.map +1 -1
- package/dist/es/standards-sdk.es70.js +170 -286
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +71 -207
- package/dist/es/standards-sdk.es71.js.map +1 -1
- package/dist/es/standards-sdk.es72.js +71 -72
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es73.js +143 -71
- package/dist/es/standards-sdk.es73.js.map +1 -1
- package/dist/es/standards-sdk.es74.js +62 -136
- package/dist/es/standards-sdk.es74.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +380 -45
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +222 -130
- package/dist/es/standards-sdk.es76.js.map +1 -1
- package/dist/es/standards-sdk.es77.js +320 -444
- package/dist/es/standards-sdk.es77.js.map +1 -1
- package/dist/es/standards-sdk.es78.js +88 -364
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es79.js +125 -89
- package/dist/es/standards-sdk.es79.js.map +1 -1
- package/dist/es/standards-sdk.es8.js +80 -29
- package/dist/es/standards-sdk.es8.js.map +1 -1
- package/dist/es/standards-sdk.es80.js +8 -125
- package/dist/es/standards-sdk.es80.js.map +1 -1
- package/dist/es/standards-sdk.es81.js +45 -6
- package/dist/es/standards-sdk.es81.js.map +1 -1
- package/dist/es/standards-sdk.es82.js +98 -44
- package/dist/es/standards-sdk.es82.js.map +1 -1
- package/dist/es/standards-sdk.es83.js +331 -84
- package/dist/es/standards-sdk.es83.js.map +1 -1
- package/dist/es/standards-sdk.es84.js +93 -160
- package/dist/es/standards-sdk.es84.js.map +1 -1
- package/dist/es/standards-sdk.es85.js +55 -275
- package/dist/es/standards-sdk.es85.js.map +1 -1
- package/dist/es/standards-sdk.es86.js +43 -55
- package/dist/es/standards-sdk.es86.js.map +1 -1
- package/dist/es/standards-sdk.es87.js +145 -22
- package/dist/es/standards-sdk.es87.js.map +1 -1
- package/dist/es/standards-sdk.es88.js +34 -47
- package/dist/es/standards-sdk.es88.js.map +1 -1
- package/dist/es/standards-sdk.es89.js +22 -57
- package/dist/es/standards-sdk.es89.js.map +1 -1
- package/dist/es/standards-sdk.es9.js +104 -80
- package/dist/es/standards-sdk.es9.js.map +1 -1
- package/dist/es/standards-sdk.es90.js +23 -28
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es91.js +238 -23
- package/dist/es/standards-sdk.es91.js.map +1 -1
- package/dist/es/standards-sdk.es92.js +265 -152
- package/dist/es/standards-sdk.es92.js.map +1 -1
- package/dist/es/standards-sdk.es93.js +95 -68
- package/dist/es/standards-sdk.es93.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +124 -136
- package/dist/es/standards-sdk.es94.js.map +1 -1
- package/dist/es/standards-sdk.es95.js +42 -138
- package/dist/es/standards-sdk.es95.js.map +1 -1
- package/dist/es/standards-sdk.es96.js +259 -42
- package/dist/es/standards-sdk.es96.js.map +1 -1
- package/dist/es/standards-sdk.es97.js +82 -243
- package/dist/es/standards-sdk.es97.js.map +1 -1
- package/dist/es/standards-sdk.es98.js +48 -47
- package/dist/es/standards-sdk.es98.js.map +1 -1
- package/dist/es/standards-sdk.es99.js +29 -100
- package/dist/es/standards-sdk.es99.js.map +1 -1
- package/dist/es/utils/crypto-abstraction.d.ts.map +1 -1
- package/dist/es/utils/crypto-env.d.ts.map +1 -1
- package/dist/es/utils/dynamic-import.d.ts +5 -1
- package/dist/es/utils/dynamic-import.d.ts.map +1 -1
- package/dist/es/utils/hash-adapter.d.ts.map +1 -1
- package/package.json +16 -16
- package/dist/cjs/patches/topic-autorenew-patch.d.ts +0 -2
- package/dist/cjs/patches/topic-autorenew-patch.d.ts.map +0 -1
- package/dist/es/patches/topic-autorenew-patch.d.ts +0 -2
- package/dist/es/patches/topic-autorenew-patch.d.ts.map +0 -1
|
@@ -1,134 +1,491 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
this.
|
|
1
|
+
import { RegistryType } from "./standards-sdk.es29.js";
|
|
2
|
+
import { BaseRegistry } from "./standards-sdk.es30.js";
|
|
3
|
+
import { validateAssemblyMessage } from "./standards-sdk.es42.js";
|
|
4
|
+
import { ZodError } from "zod";
|
|
5
|
+
class AssemblyRegistry extends BaseRegistry {
|
|
6
|
+
constructor(networkType, logger, topicId, client) {
|
|
7
|
+
super(networkType, logger, RegistryType.ASSEMBLY, topicId, client);
|
|
8
|
+
this.assemblyStates = /* @__PURE__ */ new Map();
|
|
9
9
|
}
|
|
10
10
|
/**
|
|
11
|
-
*
|
|
11
|
+
* Override getTopicMemo to indicate indexed registry
|
|
12
12
|
*/
|
|
13
|
-
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
13
|
+
getTopicMemo() {
|
|
14
|
+
const indexed = 0;
|
|
15
|
+
const ttl = 60;
|
|
16
|
+
const type = this.registryType;
|
|
17
|
+
return `hcs-12:${indexed}:${ttl}:${type}`;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Register a new assembly
|
|
21
|
+
*/
|
|
22
|
+
async register(registration) {
|
|
23
|
+
return this.submitMessage(registration);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Create a new assembly topic
|
|
27
|
+
*/
|
|
28
|
+
async createAssemblyTopic() {
|
|
29
|
+
const topicId = await this.createRegistryTopic();
|
|
30
|
+
this.topicId = topicId;
|
|
31
|
+
return topicId;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Add an action to the assembly
|
|
35
|
+
*/
|
|
36
|
+
async addAction(message) {
|
|
37
|
+
return this.submitMessage(message);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Add a block to the assembly
|
|
41
|
+
*/
|
|
42
|
+
async addBlock(message) {
|
|
43
|
+
return this.submitMessage(message);
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Update assembly metadata
|
|
47
|
+
*/
|
|
48
|
+
async update(message) {
|
|
49
|
+
return this.submitMessage(message);
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Submit any assembly operation message
|
|
53
|
+
*/
|
|
54
|
+
async submitMessage(message) {
|
|
55
|
+
this.validateMessage(message);
|
|
56
|
+
if (!this.topicId) {
|
|
57
|
+
throw new Error("Assembly topic ID not found");
|
|
40
58
|
}
|
|
59
|
+
if (!this.client) {
|
|
60
|
+
throw new Error("Client not found");
|
|
61
|
+
}
|
|
62
|
+
this.logger.info("Submitting assembly message to HCS", {
|
|
63
|
+
topicId: this.topicId,
|
|
64
|
+
op: message.op
|
|
65
|
+
});
|
|
66
|
+
const result = await this.client.submitMessage(
|
|
67
|
+
this.topicId,
|
|
68
|
+
JSON.stringify(message)
|
|
69
|
+
);
|
|
70
|
+
const sequenceNumber = result.sequenceNumber;
|
|
71
|
+
if (!sequenceNumber) {
|
|
72
|
+
throw new Error("No sequence number returned from submission");
|
|
73
|
+
}
|
|
74
|
+
const entry = {
|
|
75
|
+
id: sequenceNumber.toString(),
|
|
76
|
+
sequenceNumber,
|
|
77
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
78
|
+
submitter: "getHashConnect" in this.client ? (await this.client.getAccountAndSigner()).accountId : this.client.getOperatorAccountId(),
|
|
79
|
+
data: message
|
|
80
|
+
};
|
|
81
|
+
this.entries.set(entry.id, entry);
|
|
82
|
+
await this.processMessage(entry);
|
|
83
|
+
this.logger.info("Assembly message processed", {
|
|
84
|
+
op: message.op,
|
|
85
|
+
sequenceNumber
|
|
86
|
+
});
|
|
87
|
+
return sequenceNumber.toString();
|
|
41
88
|
}
|
|
42
89
|
/**
|
|
43
|
-
*
|
|
90
|
+
* Process a message to update assembly state
|
|
44
91
|
*/
|
|
45
|
-
async
|
|
46
|
-
const
|
|
47
|
-
if (
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
92
|
+
async processMessage(entry) {
|
|
93
|
+
const message = entry.data;
|
|
94
|
+
if (!this.topicId) return;
|
|
95
|
+
let state = this.assemblyStates.get(this.topicId);
|
|
96
|
+
switch (message.op) {
|
|
97
|
+
case "register":
|
|
98
|
+
const reg = message;
|
|
99
|
+
state = {
|
|
100
|
+
topicId: this.topicId,
|
|
101
|
+
name: reg.name,
|
|
102
|
+
version: reg.version,
|
|
103
|
+
description: reg.description,
|
|
104
|
+
tags: reg.tags,
|
|
105
|
+
author: reg.author,
|
|
106
|
+
actions: [],
|
|
107
|
+
blocks: [],
|
|
108
|
+
created: entry.timestamp,
|
|
109
|
+
updated: entry.timestamp
|
|
110
|
+
};
|
|
111
|
+
this.assemblyStates.set(this.topicId, state);
|
|
112
|
+
break;
|
|
113
|
+
case "add-action":
|
|
114
|
+
if (!state) {
|
|
115
|
+
this.logger.warn("Cannot add action without assembly registration");
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
const addAction = message;
|
|
119
|
+
const action = {
|
|
120
|
+
t_id: addAction.t_id,
|
|
121
|
+
alias: addAction.alias,
|
|
122
|
+
config: addAction.config,
|
|
123
|
+
data: addAction.data
|
|
124
|
+
};
|
|
125
|
+
state.actions.push(action);
|
|
126
|
+
state.updated = entry.timestamp;
|
|
127
|
+
break;
|
|
128
|
+
case "add-block":
|
|
129
|
+
if (!state) {
|
|
130
|
+
this.logger.warn("Cannot add block without assembly registration");
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
const addBlock = message;
|
|
134
|
+
const block = {
|
|
135
|
+
block_t_id: addBlock.block_t_id,
|
|
136
|
+
actions: addBlock.actions,
|
|
137
|
+
attributes: addBlock.attributes,
|
|
138
|
+
children: addBlock.children,
|
|
139
|
+
data: addBlock.data
|
|
140
|
+
};
|
|
141
|
+
state.blocks.push(block);
|
|
142
|
+
state.updated = entry.timestamp;
|
|
143
|
+
break;
|
|
144
|
+
case "update":
|
|
145
|
+
if (!state) {
|
|
146
|
+
this.logger.warn("Cannot update without assembly registration");
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
const update = message;
|
|
150
|
+
if (update.description !== void 0) {
|
|
151
|
+
state.description = update.description;
|
|
152
|
+
}
|
|
153
|
+
if (update.tags !== void 0) {
|
|
154
|
+
state.tags = update.tags;
|
|
155
|
+
}
|
|
156
|
+
state.updated = entry.timestamp;
|
|
157
|
+
break;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Get the current state of an assembly
|
|
162
|
+
*/
|
|
163
|
+
async getAssemblyState(topicId) {
|
|
164
|
+
const targetTopicId = topicId || this.topicId;
|
|
165
|
+
if (!targetTopicId || !this.client) return null;
|
|
166
|
+
let state = this.assemblyStates.get(targetTopicId);
|
|
167
|
+
if (state) return state;
|
|
168
|
+
if (targetTopicId === this.topicId && this.entries.size > 0) {
|
|
169
|
+
this.logger.debug("Building state from existing entries", {
|
|
170
|
+
topicId: targetTopicId,
|
|
171
|
+
entriesCount: this.entries.size
|
|
52
172
|
});
|
|
53
|
-
|
|
54
|
-
|
|
173
|
+
this.assemblyStates.clear();
|
|
174
|
+
for (const entry of this.entries.values()) {
|
|
175
|
+
this.processAssemblyMessage(targetTopicId, entry);
|
|
55
176
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
62
|
-
|
|
177
|
+
const builtState = this.assemblyStates.get(targetTopicId) || null;
|
|
178
|
+
this.logger.debug("Built state from entries", {
|
|
179
|
+
topicId: targetTopicId,
|
|
180
|
+
hasState: !!builtState,
|
|
181
|
+
name: builtState?.name
|
|
182
|
+
});
|
|
183
|
+
return builtState;
|
|
184
|
+
}
|
|
185
|
+
this.logger.info("Syncing assembly state from topic", {
|
|
186
|
+
topicId: targetTopicId
|
|
187
|
+
});
|
|
188
|
+
try {
|
|
189
|
+
const messages = await this.client.mirrorNode.getTopicMessagesByFilter(
|
|
190
|
+
targetTopicId,
|
|
191
|
+
{
|
|
192
|
+
order: "asc",
|
|
193
|
+
limit: 1e3
|
|
194
|
+
}
|
|
195
|
+
);
|
|
196
|
+
const messageArray = Array.isArray(messages) ? messages : [];
|
|
197
|
+
this.logger.info("Processing assembly messages", {
|
|
198
|
+
topicId: targetTopicId,
|
|
199
|
+
messageCount: messageArray.length
|
|
200
|
+
});
|
|
201
|
+
for (const msg of messageArray) {
|
|
202
|
+
try {
|
|
203
|
+
let data;
|
|
204
|
+
if (msg.message) {
|
|
205
|
+
try {
|
|
206
|
+
let messageContent;
|
|
207
|
+
const isServerEnvironment = typeof window === "undefined";
|
|
208
|
+
if (isServerEnvironment) {
|
|
209
|
+
messageContent = Buffer.from(
|
|
210
|
+
msg.message,
|
|
211
|
+
"base64"
|
|
212
|
+
).toString("utf-8");
|
|
213
|
+
} else {
|
|
214
|
+
messageContent = new TextDecoder().decode(
|
|
215
|
+
Uint8Array.from(
|
|
216
|
+
atob(msg.message),
|
|
217
|
+
(c) => c.charCodeAt(0)
|
|
218
|
+
)
|
|
219
|
+
);
|
|
220
|
+
}
|
|
221
|
+
data = JSON.parse(messageContent);
|
|
222
|
+
this.logger.debug("Successfully parsed message", {
|
|
223
|
+
sequenceNumber: msg.sequence_number,
|
|
224
|
+
op: data.op,
|
|
225
|
+
p: data.p
|
|
226
|
+
});
|
|
227
|
+
} catch (error) {
|
|
228
|
+
this.logger.debug("Failed to decode/parse message", {
|
|
229
|
+
sequenceNumber: msg.sequence_number,
|
|
230
|
+
error
|
|
231
|
+
});
|
|
232
|
+
continue;
|
|
233
|
+
}
|
|
234
|
+
} else {
|
|
235
|
+
continue;
|
|
236
|
+
}
|
|
237
|
+
if (data.p !== "hcs-12") {
|
|
238
|
+
this.logger.debug("Skipping non-HCS-12 message", {
|
|
239
|
+
sequenceNumber: msg.sequence_number,
|
|
240
|
+
protocol: data.p
|
|
241
|
+
});
|
|
242
|
+
continue;
|
|
243
|
+
}
|
|
244
|
+
const entry = {
|
|
245
|
+
id: msg.sequence_number.toString(),
|
|
246
|
+
sequenceNumber: msg.sequence_number,
|
|
247
|
+
timestamp: msg.consensus_timestamp || (/* @__PURE__ */ new Date()).toISOString(),
|
|
248
|
+
submitter: msg.payer_account_id || "unknown",
|
|
249
|
+
data
|
|
250
|
+
};
|
|
251
|
+
this.processAssemblyMessage(targetTopicId, entry);
|
|
252
|
+
this.logger.debug("Processed message for assembly", {
|
|
253
|
+
topicId: targetTopicId,
|
|
254
|
+
sequenceNumber: entry.sequenceNumber,
|
|
255
|
+
op: entry.data.op
|
|
256
|
+
});
|
|
257
|
+
} catch (error) {
|
|
258
|
+
this.logger.warn("Failed to parse assembly message", {
|
|
259
|
+
sequenceNumber: msg.sequence_number,
|
|
260
|
+
error
|
|
261
|
+
});
|
|
262
|
+
}
|
|
63
263
|
}
|
|
64
|
-
this.
|
|
65
|
-
|
|
264
|
+
const finalState = this.assemblyStates.get(targetTopicId) || null;
|
|
265
|
+
this.logger.info("Assembly state after sync", {
|
|
266
|
+
topicId: targetTopicId,
|
|
267
|
+
hasState: !!finalState,
|
|
268
|
+
name: finalState?.name,
|
|
269
|
+
version: finalState?.version,
|
|
270
|
+
actionsCount: finalState?.actions?.length || 0,
|
|
271
|
+
blocksCount: finalState?.blocks?.length || 0
|
|
272
|
+
});
|
|
273
|
+
return finalState;
|
|
66
274
|
} catch (error) {
|
|
67
|
-
this.logger.error("Failed to
|
|
68
|
-
|
|
69
|
-
error
|
|
275
|
+
this.logger.error("Failed to sync assembly state", {
|
|
276
|
+
topicId: targetTopicId,
|
|
277
|
+
error
|
|
70
278
|
});
|
|
71
|
-
|
|
279
|
+
return null;
|
|
72
280
|
}
|
|
73
281
|
}
|
|
74
282
|
/**
|
|
75
|
-
*
|
|
283
|
+
* Process a message for a specific assembly topic
|
|
76
284
|
*/
|
|
77
|
-
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
|
|
285
|
+
processAssemblyMessage(topicId, entry) {
|
|
286
|
+
const message = entry.data;
|
|
287
|
+
let state = this.assemblyStates.get(topicId);
|
|
288
|
+
this.logger.debug("Processing assembly message", {
|
|
289
|
+
topicId,
|
|
290
|
+
op: message.op,
|
|
291
|
+
hasState: !!state
|
|
292
|
+
});
|
|
293
|
+
switch (message.op) {
|
|
294
|
+
case "register":
|
|
295
|
+
const reg = message;
|
|
296
|
+
state = {
|
|
297
|
+
topicId,
|
|
298
|
+
name: reg.name,
|
|
299
|
+
version: reg.version,
|
|
300
|
+
description: reg.description,
|
|
301
|
+
tags: reg.tags,
|
|
302
|
+
author: reg.author,
|
|
303
|
+
actions: [],
|
|
304
|
+
blocks: [],
|
|
305
|
+
created: entry.timestamp,
|
|
306
|
+
updated: entry.timestamp
|
|
307
|
+
};
|
|
308
|
+
this.assemblyStates.set(topicId, state);
|
|
309
|
+
this.logger.debug("Assembly registered", {
|
|
310
|
+
topicId,
|
|
311
|
+
name: reg.name,
|
|
312
|
+
version: reg.version
|
|
313
|
+
});
|
|
314
|
+
break;
|
|
315
|
+
case "add-action":
|
|
316
|
+
if (!state) {
|
|
317
|
+
this.logger.warn("Cannot add action without assembly registration");
|
|
318
|
+
return;
|
|
319
|
+
}
|
|
320
|
+
const addAction = message;
|
|
321
|
+
const action = {
|
|
322
|
+
t_id: addAction.t_id,
|
|
323
|
+
alias: addAction.alias,
|
|
324
|
+
config: addAction.config,
|
|
325
|
+
data: addAction.data
|
|
326
|
+
};
|
|
327
|
+
state.actions.push(action);
|
|
328
|
+
state.updated = entry.timestamp;
|
|
329
|
+
break;
|
|
330
|
+
case "add-block":
|
|
331
|
+
if (!state) {
|
|
332
|
+
this.logger.warn("Cannot add block without assembly registration");
|
|
333
|
+
return;
|
|
334
|
+
}
|
|
335
|
+
const addBlock = message;
|
|
336
|
+
const block = {
|
|
337
|
+
block_t_id: addBlock.block_t_id,
|
|
338
|
+
actions: addBlock.actions,
|
|
339
|
+
attributes: addBlock.attributes,
|
|
340
|
+
children: addBlock.children,
|
|
341
|
+
data: addBlock.data
|
|
342
|
+
};
|
|
343
|
+
state.blocks.push(block);
|
|
344
|
+
state.updated = entry.timestamp;
|
|
345
|
+
break;
|
|
346
|
+
case "update":
|
|
347
|
+
if (!state) {
|
|
348
|
+
this.logger.warn("Cannot update without assembly registration");
|
|
349
|
+
return;
|
|
350
|
+
}
|
|
351
|
+
const update = message;
|
|
352
|
+
if (update.description !== void 0) {
|
|
353
|
+
state.description = update.description;
|
|
354
|
+
}
|
|
355
|
+
if (update.tags !== void 0) {
|
|
356
|
+
state.tags = update.tags;
|
|
357
|
+
}
|
|
358
|
+
state.updated = entry.timestamp;
|
|
359
|
+
break;
|
|
360
|
+
}
|
|
81
361
|
}
|
|
82
362
|
/**
|
|
83
|
-
*
|
|
363
|
+
* Override sync to rebuild state from all messages
|
|
84
364
|
*/
|
|
85
|
-
async
|
|
86
|
-
if (!this.
|
|
87
|
-
|
|
365
|
+
async sync() {
|
|
366
|
+
if (!this.topicId || !this.client) {
|
|
367
|
+
this.logger.warn("Cannot sync without topic ID and client");
|
|
368
|
+
return;
|
|
88
369
|
}
|
|
370
|
+
this.entries.clear();
|
|
371
|
+
this.assemblyStates.delete(this.topicId);
|
|
372
|
+
this.logger.info("Syncing assembly messages", {
|
|
373
|
+
topicId: this.topicId
|
|
374
|
+
});
|
|
89
375
|
try {
|
|
90
|
-
const
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
throw new Error("Failed to inscribe block template");
|
|
97
|
-
}
|
|
98
|
-
const fullDefinition = {
|
|
99
|
-
...definition,
|
|
100
|
-
template_t_id: templateResult.topic_id
|
|
101
|
-
};
|
|
102
|
-
const definitionBuffer = Buffer.from(JSON.stringify(fullDefinition));
|
|
103
|
-
const definitionResult = await this.client.inscribeFile(
|
|
104
|
-
definitionBuffer,
|
|
105
|
-
`block-${definition.name}-definition.json`
|
|
376
|
+
const messages = await this.client.mirrorNode.getTopicMessagesByFilter(
|
|
377
|
+
this.topicId,
|
|
378
|
+
{
|
|
379
|
+
order: "asc",
|
|
380
|
+
limit: 1e3
|
|
381
|
+
}
|
|
106
382
|
);
|
|
107
|
-
|
|
108
|
-
|
|
383
|
+
const messageArray = Array.isArray(messages) ? messages : [];
|
|
384
|
+
this.logger.info("Processing assembly messages", {
|
|
385
|
+
topicId: this.topicId,
|
|
386
|
+
messageCount: messageArray.length
|
|
387
|
+
});
|
|
388
|
+
for (const msg of messageArray) {
|
|
389
|
+
try {
|
|
390
|
+
let data;
|
|
391
|
+
if (msg.message) {
|
|
392
|
+
try {
|
|
393
|
+
let messageContent;
|
|
394
|
+
const isServerEnvironment = typeof window === "undefined";
|
|
395
|
+
if (isServerEnvironment) {
|
|
396
|
+
messageContent = Buffer.from(
|
|
397
|
+
msg.message,
|
|
398
|
+
"base64"
|
|
399
|
+
).toString("utf-8");
|
|
400
|
+
} else {
|
|
401
|
+
messageContent = new TextDecoder().decode(
|
|
402
|
+
Uint8Array.from(
|
|
403
|
+
atob(msg.message),
|
|
404
|
+
(c) => c.charCodeAt(0)
|
|
405
|
+
)
|
|
406
|
+
);
|
|
407
|
+
}
|
|
408
|
+
data = JSON.parse(messageContent);
|
|
409
|
+
} catch (error) {
|
|
410
|
+
this.logger.debug("Failed to decode/parse message in sync", {
|
|
411
|
+
sequenceNumber: msg.sequence_number,
|
|
412
|
+
error
|
|
413
|
+
});
|
|
414
|
+
continue;
|
|
415
|
+
}
|
|
416
|
+
} else if (msg.raw_content) {
|
|
417
|
+
try {
|
|
418
|
+
data = JSON.parse(msg.raw_content);
|
|
419
|
+
} catch {
|
|
420
|
+
continue;
|
|
421
|
+
}
|
|
422
|
+
} else {
|
|
423
|
+
const msgAny = msg;
|
|
424
|
+
if (msgAny.p && msgAny.op) {
|
|
425
|
+
data = { ...msgAny };
|
|
426
|
+
delete data.consensus_timestamp;
|
|
427
|
+
delete data.sequence_number;
|
|
428
|
+
delete data.payer_account_id;
|
|
429
|
+
delete data.topic_id;
|
|
430
|
+
delete data.running_hash;
|
|
431
|
+
delete data.running_hash_version;
|
|
432
|
+
delete data.chunk_info;
|
|
433
|
+
delete data.created;
|
|
434
|
+
delete data.payer;
|
|
435
|
+
} else {
|
|
436
|
+
continue;
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
if (data.p !== "hcs-12") {
|
|
440
|
+
continue;
|
|
441
|
+
}
|
|
442
|
+
const entry = {
|
|
443
|
+
id: msg.sequence_number.toString(),
|
|
444
|
+
sequenceNumber: msg.sequence_number,
|
|
445
|
+
timestamp: msg.consensus_timestamp || (/* @__PURE__ */ new Date()).toISOString(),
|
|
446
|
+
submitter: msg.payer_account_id || "unknown",
|
|
447
|
+
data
|
|
448
|
+
};
|
|
449
|
+
this.entries.set(entry.id, entry);
|
|
450
|
+
await this.processMessage(entry);
|
|
451
|
+
this.logger.debug("Processed sync message", {
|
|
452
|
+
sequenceNumber: entry.sequenceNumber,
|
|
453
|
+
op: entry.data.op
|
|
454
|
+
});
|
|
455
|
+
} catch (error) {
|
|
456
|
+
this.logger.warn("Failed to parse assembly message", {
|
|
457
|
+
sequenceNumber: msg.sequence_number,
|
|
458
|
+
error
|
|
459
|
+
});
|
|
460
|
+
}
|
|
109
461
|
}
|
|
110
|
-
this.
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
definitionTopicId: definitionResult.topic_id,
|
|
114
|
-
templateTopicId: templateResult.topic_id
|
|
115
|
-
};
|
|
116
|
-
} catch (error) {
|
|
117
|
-
this.logger.error("Failed to store block", {
|
|
118
|
-
error: error.message
|
|
462
|
+
this.logger.info("Assembly sync completed", {
|
|
463
|
+
topicId: this.topicId,
|
|
464
|
+
messageCount: messageArray.length
|
|
119
465
|
});
|
|
120
|
-
|
|
466
|
+
} catch (error) {
|
|
467
|
+
this.logger.error("Failed to sync assembly", { error });
|
|
468
|
+
throw error;
|
|
121
469
|
}
|
|
122
470
|
}
|
|
123
471
|
/**
|
|
124
|
-
*
|
|
472
|
+
* Validate an assembly message
|
|
125
473
|
*/
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
474
|
+
validateMessage(message) {
|
|
475
|
+
try {
|
|
476
|
+
validateAssemblyMessage(message);
|
|
477
|
+
} catch (error) {
|
|
478
|
+
if (error instanceof ZodError) {
|
|
479
|
+
const issues = error.errors.map(
|
|
480
|
+
(e) => `${e.path.join(".")}: ${e.message}`
|
|
481
|
+
);
|
|
482
|
+
throw new Error(`Assembly validation failed: ${issues.join("; ")}`);
|
|
483
|
+
}
|
|
484
|
+
throw error;
|
|
485
|
+
}
|
|
129
486
|
}
|
|
130
487
|
}
|
|
131
488
|
export {
|
|
132
|
-
|
|
489
|
+
AssemblyRegistry
|
|
133
490
|
};
|
|
134
491
|
//# sourceMappingURL=standards-sdk.es33.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es33.js","sources":["../../src/hcs-12/registries/block-loader.ts"],"sourcesContent":["/**\n * Block Loader for HCS-12\n *\n * Loads block definitions and templates from HCS-1 storage.\n * Blocks are not stored in a registry but directly via HCS-1.\n */\n\nimport { ILogger, Logger } from '../../utils/logger';\nimport { NetworkType } from '../../utils/types';\nimport { BlockDefinition } from '../types';\nimport type { HCS12Client } from '../sdk';\nimport type { HCS12BrowserClient } from '../browser';\nimport { HRLResolver } from '../../utils/hrl-resolver';\n\n/**\n * Loader for HCS-1 stored block definitions\n */\nexport class BlockLoader {\n private logger: ILogger;\n private networkType: NetworkType;\n private client?: HCS12Client | HCS12BrowserClient;\n private blockCache: Map<string, BlockDefinition> = new Map();\n private templateCache: Map<string, string> = new Map();\n\n constructor(\n networkType: NetworkType,\n logger: ILogger,\n client?: HCS12Client | HCS12BrowserClient,\n ) {\n this.networkType = networkType;\n this.logger = logger;\n this.client = client;\n }\n\n /**\n * Load a block definition from HCS-1\n */\n async loadBlockDefinition(blockTopicId: string): Promise<BlockDefinition> {\n const cached = this.blockCache.get(blockTopicId);\n if (cached) return cached;\n\n try {\n const hrlResolver = new HRLResolver();\n const result = await hrlResolver.resolve(blockTopicId, {\n network: this.networkType,\n });\n\n if (!result.content) {\n throw new Error(`Block definition not found: ${blockTopicId}`);\n }\n\n let blockDefinition: BlockDefinition;\n\n if (\n typeof result.content === 'object' &&\n result.content !== null &&\n !(result.content instanceof ArrayBuffer)\n ) {\n blockDefinition = result.content as BlockDefinition;\n } else {\n blockDefinition = JSON.parse(\n typeof result.content === 'string'\n ? result.content\n : result.content.toString(),\n ) as BlockDefinition;\n }\n this.blockCache.set(blockTopicId, blockDefinition);\n\n return blockDefinition;\n } catch (error) {\n this.logger.error('Failed to load block definition', {\n blockTopicId,\n error: error.message,\n });\n throw new Error(`Failed to load block definition: ${error.message}`);\n }\n }\n\n /**\n * Load a block template from HCS-1\n */\n async loadBlockTemplate(templateTopicId: string): Promise<string> {\n const cached = this.templateCache.get(templateTopicId);\n if (cached) return cached;\n\n try {\n const hrlResolver = new HRLResolver();\n const result = await hrlResolver.resolve(templateTopicId, {\n network: this.networkType,\n });\n\n if (!result.content) {\n throw new Error(`Block template not found: ${templateTopicId}`);\n }\n\n let template: string;\n\n if (typeof result.content === 'string') {\n template = result.content;\n } else if (\n typeof result.content === 'object' &&\n result.content !== null\n ) {\n template =\n (result.content as any).text || JSON.stringify(result.content);\n } else {\n template = result.content.toString();\n }\n\n this.templateCache.set(templateTopicId, template);\n\n return template;\n } catch (error) {\n this.logger.error('Failed to load block template', {\n templateTopicId,\n error: error.message,\n });\n throw new Error(`Failed to load block template: ${error.message}`);\n }\n }\n\n /**\n * Load a complete block (definition + template)\n */\n async loadBlock(blockTopicId: string): Promise<{\n definition: BlockDefinition;\n template: string;\n }> {\n const definition = await this.loadBlockDefinition(blockTopicId);\n const template = await this.loadBlockTemplate(definition.template_t_id);\n\n return { definition, template };\n }\n\n /**\n * Store a block definition and template via HCS-1\n */\n async storeBlock(\n template: string,\n definition: Omit<BlockDefinition, 'template_t_id'>,\n ): Promise<{\n definitionTopicId: string;\n templateTopicId: string;\n }> {\n if (!this.client || !('inscribeFile' in this.client)) {\n throw new Error('Client does not support inscription');\n }\n\n try {\n const templateBuffer = Buffer.from(template);\n const templateResult = await this.client.inscribeFile(\n templateBuffer,\n `block-${definition.name}-template.html`,\n );\n\n if (!templateResult?.topic_id) {\n throw new Error('Failed to inscribe block template');\n }\n\n const fullDefinition: BlockDefinition = {\n ...definition,\n template_t_id: templateResult.topic_id,\n };\n\n const definitionBuffer = Buffer.from(JSON.stringify(fullDefinition));\n const definitionResult = await this.client.inscribeFile(\n definitionBuffer,\n `block-${definition.name}-definition.json`,\n );\n\n if (!definitionResult?.topic_id) {\n throw new Error('Failed to inscribe block definition');\n }\n\n this.blockCache.set(definitionResult.topic_id, fullDefinition);\n this.templateCache.set(templateResult.topic_id, template);\n\n return {\n definitionTopicId: definitionResult.topic_id,\n templateTopicId: templateResult.topic_id,\n };\n } catch (error) {\n this.logger.error('Failed to store block', {\n error: error.message,\n });\n throw new Error(`Failed to store block: ${error.message}`);\n }\n }\n\n /**\n * Clear all caches\n */\n clearCache(): void {\n this.blockCache.clear();\n this.templateCache.clear();\n }\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es33.js","sources":["../../src/hcs-12/registries/assembly-registry.ts"],"sourcesContent":["/**\n * Assembly Registry Implementation for HCS-12\n *\n * Manages assembly topics where each topic represents one assembly.\n * Processes operations sequentially to build assembly state.\n */\n\nimport { ILogger, Logger } from '../../utils/logger';\nimport { NetworkType } from '../../utils/types';\nimport {\n RegistryType,\n AssemblyRegistryEntry,\n AssemblyState,\n AssemblyRegistration,\n AssemblyAddAction,\n AssemblyAddBlock,\n AssemblyUpdate,\n AssemblyMessage,\n AssemblyAction,\n AssemblyBlock,\n} from '../types';\nimport { BaseRegistry } from './base-registry';\nimport type { HCS12Client } from '../sdk';\nimport type { HCS12BrowserClient } from '../browser';\nimport { validateAssemblyMessage } from '../validation/schemas';\nimport { ZodError } from 'zod';\n\n/**\n * Registry for HashLink assemblies\n */\nexport class AssemblyRegistry extends BaseRegistry {\n private assemblyStates: Map<string, AssemblyState> = new Map();\n\n constructor(\n networkType: NetworkType,\n logger: ILogger,\n topicId?: string,\n client?: HCS12Client | HCS12BrowserClient,\n ) {\n super(networkType, logger, RegistryType.ASSEMBLY, topicId, client);\n }\n\n /**\n * Override getTopicMemo to indicate indexed registry\n */\n getTopicMemo(): string {\n const indexed = 0;\n const ttl = 60;\n const type = this.registryType;\n return `hcs-12:${indexed}:${ttl}:${type}`;\n }\n\n /**\n * Register a new assembly\n */\n async register(registration: AssemblyRegistration): Promise<string> {\n return this.submitMessage(registration);\n }\n\n /**\n * Create a new assembly topic\n */\n async createAssemblyTopic(): Promise<string> {\n const topicId = await this.createRegistryTopic();\n this.topicId = topicId;\n return topicId;\n }\n\n /**\n * Add an action to the assembly\n */\n async addAction(message: AssemblyAddAction): Promise<string> {\n return this.submitMessage(message);\n }\n\n /**\n * Add a block to the assembly\n */\n async addBlock(message: AssemblyAddBlock): Promise<string> {\n return this.submitMessage(message);\n }\n\n /**\n * Update assembly metadata\n */\n async update(message: AssemblyUpdate): Promise<string> {\n return this.submitMessage(message);\n }\n\n /**\n * Submit any assembly operation message\n */\n async submitMessage(message: AssemblyMessage): Promise<string> {\n this.validateMessage(message);\n\n if (!this.topicId) {\n throw new Error('Assembly topic ID not found');\n }\n\n if (!this.client) {\n throw new Error('Client not found');\n }\n\n this.logger.info('Submitting assembly message to HCS', {\n topicId: this.topicId,\n op: message.op,\n });\n\n const result = await this.client.submitMessage(\n this.topicId,\n JSON.stringify(message),\n );\n\n const sequenceNumber = result.sequenceNumber;\n if (!sequenceNumber) {\n throw new Error('No sequence number returned from submission');\n }\n\n const entry: AssemblyRegistryEntry = {\n id: sequenceNumber.toString(),\n sequenceNumber,\n timestamp: new Date().toISOString(),\n submitter:\n 'getHashConnect' in this.client\n ? (await (this.client as HCS12BrowserClient).getAccountAndSigner())\n .accountId\n : this.client.getOperatorAccountId(),\n data: message,\n };\n\n this.entries.set(entry.id, entry);\n\n await this.processMessage(entry);\n\n this.logger.info('Assembly message processed', {\n op: message.op,\n sequenceNumber,\n });\n\n return sequenceNumber.toString();\n }\n\n /**\n * Process a message to update assembly state\n */\n private async processMessage(entry: AssemblyRegistryEntry): Promise<void> {\n const message = entry.data as AssemblyMessage;\n\n if (!this.topicId) return;\n\n let state = this.assemblyStates.get(this.topicId);\n\n switch (message.op) {\n case 'register':\n const reg = message as AssemblyRegistration;\n state = {\n topicId: this.topicId,\n name: reg.name,\n version: reg.version,\n description: reg.description,\n tags: reg.tags,\n author: reg.author,\n actions: [],\n blocks: [],\n created: entry.timestamp,\n updated: entry.timestamp,\n };\n this.assemblyStates.set(this.topicId, state);\n break;\n\n case 'add-action':\n if (!state) {\n this.logger.warn('Cannot add action without assembly registration');\n return;\n }\n const addAction = message as AssemblyAddAction;\n const action: AssemblyAction = {\n t_id: addAction.t_id,\n alias: addAction.alias,\n config: addAction.config,\n data: addAction.data,\n };\n state.actions.push(action);\n state.updated = entry.timestamp;\n break;\n\n case 'add-block':\n if (!state) {\n this.logger.warn('Cannot add block without assembly registration');\n return;\n }\n const addBlock = message as AssemblyAddBlock;\n const block: AssemblyBlock = {\n block_t_id: addBlock.block_t_id,\n actions: addBlock.actions,\n attributes: addBlock.attributes,\n children: addBlock.children,\n data: addBlock.data,\n };\n state.blocks.push(block);\n state.updated = entry.timestamp;\n break;\n\n case 'update':\n if (!state) {\n this.logger.warn('Cannot update without assembly registration');\n return;\n }\n const update = message as AssemblyUpdate;\n if (update.description !== undefined) {\n state.description = update.description;\n }\n if (update.tags !== undefined) {\n state.tags = update.tags;\n }\n state.updated = entry.timestamp;\n break;\n }\n }\n\n /**\n * Get the current state of an assembly\n */\n async getAssemblyState(topicId?: string): Promise<AssemblyState | null> {\n const targetTopicId = topicId || this.topicId;\n if (!targetTopicId || !this.client) return null;\n\n let state = this.assemblyStates.get(targetTopicId);\n if (state) return state;\n\n if (targetTopicId === this.topicId && this.entries.size > 0) {\n this.logger.debug('Building state from existing entries', {\n topicId: targetTopicId,\n entriesCount: this.entries.size,\n });\n this.assemblyStates.clear();\n for (const entry of this.entries.values()) {\n this.processAssemblyMessage(targetTopicId, entry);\n }\n const builtState = this.assemblyStates.get(targetTopicId) || null;\n this.logger.debug('Built state from entries', {\n topicId: targetTopicId,\n hasState: !!builtState,\n name: builtState?.name,\n });\n return builtState;\n }\n\n this.logger.info('Syncing assembly state from topic', {\n topicId: targetTopicId,\n });\n\n try {\n const messages = await this.client.mirrorNode.getTopicMessagesByFilter(\n targetTopicId,\n {\n order: 'asc',\n limit: 1000,\n },\n );\n\n const messageArray = Array.isArray(messages) ? messages : [];\n\n this.logger.info('Processing assembly messages', {\n topicId: targetTopicId,\n messageCount: messageArray.length,\n });\n\n for (const msg of messageArray) {\n try {\n let data: any;\n\n if ((msg as any).message) {\n try {\n let messageContent: string;\n const isServerEnvironment = typeof window === 'undefined';\n\n if (isServerEnvironment) {\n messageContent = Buffer.from(\n (msg as any).message,\n 'base64',\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob((msg as any).message), c =>\n c.charCodeAt(0),\n ),\n );\n }\n\n data = JSON.parse(messageContent);\n this.logger.debug('Successfully parsed message', {\n sequenceNumber: msg.sequence_number,\n op: data.op,\n p: data.p,\n });\n } catch (error) {\n this.logger.debug('Failed to decode/parse message', {\n sequenceNumber: msg.sequence_number,\n error,\n });\n continue;\n }\n } else {\n continue;\n }\n\n if (data.p !== 'hcs-12') {\n this.logger.debug('Skipping non-HCS-12 message', {\n sequenceNumber: msg.sequence_number,\n protocol: data.p,\n });\n continue;\n }\n\n const entry: AssemblyRegistryEntry = {\n id: msg.sequence_number.toString(),\n sequenceNumber: msg.sequence_number,\n timestamp: msg.consensus_timestamp || new Date().toISOString(),\n submitter: (msg as any).payer_account_id || 'unknown',\n data,\n };\n\n this.processAssemblyMessage(targetTopicId, entry);\n\n this.logger.debug('Processed message for assembly', {\n topicId: targetTopicId,\n sequenceNumber: entry.sequenceNumber,\n op: entry.data.op,\n });\n } catch (error) {\n this.logger.warn('Failed to parse assembly message', {\n sequenceNumber: msg.sequence_number,\n error,\n });\n }\n }\n\n const finalState = this.assemblyStates.get(targetTopicId) || null;\n this.logger.info('Assembly state after sync', {\n topicId: targetTopicId,\n hasState: !!finalState,\n name: finalState?.name,\n version: finalState?.version,\n actionsCount: finalState?.actions?.length || 0,\n blocksCount: finalState?.blocks?.length || 0,\n });\n return finalState;\n } catch (error) {\n this.logger.error('Failed to sync assembly state', {\n topicId: targetTopicId,\n error,\n });\n return null;\n }\n }\n\n /**\n * Process a message for a specific assembly topic\n */\n private processAssemblyMessage(\n topicId: string,\n entry: AssemblyRegistryEntry,\n ): void {\n const message = entry.data as AssemblyMessage;\n let state = this.assemblyStates.get(topicId);\n\n this.logger.debug('Processing assembly message', {\n topicId,\n op: message.op,\n hasState: !!state,\n });\n\n switch (message.op) {\n case 'register':\n const reg = message as AssemblyRegistration;\n state = {\n topicId: topicId,\n name: reg.name,\n version: reg.version,\n description: reg.description,\n tags: reg.tags,\n author: reg.author,\n actions: [],\n blocks: [],\n created: entry.timestamp,\n updated: entry.timestamp,\n };\n this.assemblyStates.set(topicId, state);\n this.logger.debug('Assembly registered', {\n topicId,\n name: reg.name,\n version: reg.version,\n });\n break;\n\n case 'add-action':\n if (!state) {\n this.logger.warn('Cannot add action without assembly registration');\n return;\n }\n const addAction = message as AssemblyAddAction;\n const action: AssemblyAction = {\n t_id: addAction.t_id,\n alias: addAction.alias,\n config: addAction.config,\n data: addAction.data,\n };\n state.actions.push(action);\n state.updated = entry.timestamp;\n break;\n\n case 'add-block':\n if (!state) {\n this.logger.warn('Cannot add block without assembly registration');\n return;\n }\n const addBlock = message as AssemblyAddBlock;\n const block: AssemblyBlock = {\n block_t_id: addBlock.block_t_id,\n actions: addBlock.actions,\n attributes: addBlock.attributes,\n children: addBlock.children,\n data: addBlock.data,\n };\n state.blocks.push(block);\n state.updated = entry.timestamp;\n break;\n\n case 'update':\n if (!state) {\n this.logger.warn('Cannot update without assembly registration');\n return;\n }\n const update = message as AssemblyUpdate;\n if (update.description !== undefined) {\n state.description = update.description;\n }\n if (update.tags !== undefined) {\n state.tags = update.tags;\n }\n state.updated = entry.timestamp;\n break;\n }\n }\n\n /**\n * Override sync to rebuild state from all messages\n */\n async sync(): Promise<void> {\n if (!this.topicId || !this.client) {\n this.logger.warn('Cannot sync without topic ID and client');\n return;\n }\n\n this.entries.clear();\n this.assemblyStates.delete(this.topicId);\n\n this.logger.info('Syncing assembly messages', {\n topicId: this.topicId,\n });\n\n try {\n const messages = await this.client.mirrorNode.getTopicMessagesByFilter(\n this.topicId,\n {\n order: 'asc',\n limit: 1000,\n },\n );\n\n const messageArray = Array.isArray(messages) ? messages : [];\n\n this.logger.info('Processing assembly messages', {\n topicId: this.topicId,\n messageCount: messageArray.length,\n });\n\n for (const msg of messageArray) {\n try {\n let data: any;\n\n if ((msg as any).message) {\n try {\n let messageContent: string;\n const isServerEnvironment = typeof window === 'undefined';\n\n if (isServerEnvironment) {\n messageContent = Buffer.from(\n (msg as any).message,\n 'base64',\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob((msg as any).message), c =>\n c.charCodeAt(0),\n ),\n );\n }\n\n data = JSON.parse(messageContent);\n } catch (error) {\n this.logger.debug('Failed to decode/parse message in sync', {\n sequenceNumber: msg.sequence_number,\n error,\n });\n continue;\n }\n } else if ((msg as any).raw_content) {\n try {\n data = JSON.parse((msg as any).raw_content);\n } catch {\n continue;\n }\n } else {\n const msgAny = msg as any;\n if (msgAny.p && msgAny.op) {\n data = { ...msgAny };\n delete data.consensus_timestamp;\n delete data.sequence_number;\n delete data.payer_account_id;\n delete data.topic_id;\n delete data.running_hash;\n delete data.running_hash_version;\n delete data.chunk_info;\n delete data.created;\n delete data.payer;\n } else {\n continue;\n }\n }\n\n if (data.p !== 'hcs-12') {\n continue;\n }\n\n const entry: AssemblyRegistryEntry = {\n id: msg.sequence_number.toString(),\n sequenceNumber: msg.sequence_number,\n timestamp: msg.consensus_timestamp || new Date().toISOString(),\n submitter: (msg as any).payer_account_id || 'unknown',\n data,\n };\n\n this.entries.set(entry.id, entry);\n\n await this.processMessage(entry);\n\n this.logger.debug('Processed sync message', {\n sequenceNumber: entry.sequenceNumber,\n op: entry.data.op,\n });\n } catch (error) {\n this.logger.warn('Failed to parse assembly message', {\n sequenceNumber: msg.sequence_number,\n error,\n });\n }\n }\n\n this.logger.info('Assembly sync completed', {\n topicId: this.topicId,\n messageCount: messageArray.length,\n });\n } catch (error) {\n this.logger.error('Failed to sync assembly', { error });\n throw error;\n }\n }\n\n /**\n * Validate an assembly message\n */\n private validateMessage(message: AssemblyMessage): void {\n try {\n validateAssemblyMessage(message);\n } catch (error) {\n if (error instanceof ZodError) {\n const issues = error.errors.map(\n e => `${e.path.join('.')}: ${e.message}`,\n );\n throw new Error(`Assembly validation failed: ${issues.join('; ')}`);\n }\n throw error;\n }\n }\n}\n"],"names":[],"mappings":"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"}
|