@hashgraphonline/standards-sdk 0.1.161 → 0.1.162
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-14/index.d.ts +1 -0
- package/dist/cjs/hcs-14/index.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/aid-dns-web-profile.d.ts +1 -0
- package/dist/cjs/hcs-14/resolvers/aid-dns-web-profile.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/ans-dns-web-profile-utils.d.ts +23 -0
- package/dist/cjs/hcs-14/resolvers/ans-dns-web-profile-utils.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/ans-dns-web-profile.d.ts +32 -0
- package/dist/cjs/hcs-14/resolvers/ans-dns-web-profile.d.ts.map +1 -0
- package/dist/cjs/hcs-14/resolvers/hcs-11-profile.d.ts +1 -0
- package/dist/cjs/hcs-14/resolvers/hcs-11-profile.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/hiero.d.ts +1 -0
- package/dist/cjs/hcs-14/resolvers/hiero.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/registry.d.ts +21 -0
- package/dist/cjs/hcs-14/resolvers/registry.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/types.d.ts +40 -5
- package/dist/cjs/hcs-14/resolvers/types.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/uaid-did-resolution-profile.d.ts +1 -0
- package/dist/cjs/hcs-14/resolvers/uaid-did-resolution-profile.d.ts.map +1 -1
- package/dist/cjs/hcs-14/resolvers/uaid-dns-web-profile.d.ts +1 -0
- package/dist/cjs/hcs-14/resolvers/uaid-dns-web-profile.d.ts.map +1 -1
- package/dist/cjs/hcs-14/sdk.d.ts +23 -1
- package/dist/cjs/hcs-14/sdk.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +2 -2
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/es/hcs-14/index.d.ts +1 -0
- package/dist/es/hcs-14/index.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/aid-dns-web-profile.d.ts +1 -0
- package/dist/es/hcs-14/resolvers/aid-dns-web-profile.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/ans-dns-web-profile-utils.d.ts +23 -0
- package/dist/es/hcs-14/resolvers/ans-dns-web-profile-utils.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/ans-dns-web-profile.d.ts +32 -0
- package/dist/es/hcs-14/resolvers/ans-dns-web-profile.d.ts.map +1 -0
- package/dist/es/hcs-14/resolvers/hcs-11-profile.d.ts +1 -0
- package/dist/es/hcs-14/resolvers/hcs-11-profile.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/hiero.d.ts +1 -0
- package/dist/es/hcs-14/resolvers/hiero.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/registry.d.ts +21 -0
- package/dist/es/hcs-14/resolvers/registry.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/types.d.ts +40 -5
- package/dist/es/hcs-14/resolvers/types.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/uaid-did-resolution-profile.d.ts +1 -0
- package/dist/es/hcs-14/resolvers/uaid-did-resolution-profile.d.ts.map +1 -1
- package/dist/es/hcs-14/resolvers/uaid-dns-web-profile.d.ts +1 -0
- package/dist/es/hcs-14/resolvers/uaid-dns-web-profile.d.ts.map +1 -1
- package/dist/es/hcs-14/sdk.d.ts +23 -1
- package/dist/es/hcs-14/sdk.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +89 -86
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es100.js +136 -124
- package/dist/es/standards-sdk.es100.js.map +1 -1
- package/dist/es/standards-sdk.es101.js +138 -42
- package/dist/es/standards-sdk.es101.js.map +1 -1
- package/dist/es/standards-sdk.es102.js +43 -259
- package/dist/es/standards-sdk.es102.js.map +1 -1
- package/dist/es/standards-sdk.es103.js +245 -82
- package/dist/es/standards-sdk.es103.js.map +1 -1
- package/dist/es/standards-sdk.es104.js +50 -49
- package/dist/es/standards-sdk.es104.js.map +1 -1
- package/dist/es/standards-sdk.es105.js +100 -29
- package/dist/es/standards-sdk.es105.js.map +1 -1
- package/dist/es/standards-sdk.es106.js +27 -229
- package/dist/es/standards-sdk.es106.js.map +1 -1
- package/dist/es/standards-sdk.es107.js +228 -109
- package/dist/es/standards-sdk.es107.js.map +1 -1
- package/dist/es/standards-sdk.es108.js +94 -15
- package/dist/es/standards-sdk.es108.js.map +1 -1
- package/dist/es/standards-sdk.es109.js +30 -80
- package/dist/es/standards-sdk.es109.js.map +1 -1
- package/dist/es/standards-sdk.es11.js +1 -1
- package/dist/es/standards-sdk.es110.js +80 -27
- package/dist/es/standards-sdk.es110.js.map +1 -1
- package/dist/es/standards-sdk.es111.js +27 -248
- package/dist/es/standards-sdk.es111.js.map +1 -1
- package/dist/es/standards-sdk.es112.js +246 -472
- package/dist/es/standards-sdk.es112.js.map +1 -1
- package/dist/es/standards-sdk.es113.js +458 -85
- package/dist/es/standards-sdk.es113.js.map +1 -1
- package/dist/es/standards-sdk.es114.js +96 -151
- package/dist/es/standards-sdk.es114.js.map +1 -1
- package/dist/es/standards-sdk.es115.js +155 -29
- package/dist/es/standards-sdk.es115.js.map +1 -1
- package/dist/es/standards-sdk.es116.js +26 -4
- package/dist/es/standards-sdk.es116.js.map +1 -1
- package/dist/es/standards-sdk.es117.js +10 -140
- package/dist/es/standards-sdk.es117.js.map +1 -1
- package/dist/es/standards-sdk.es118.js +140 -27
- package/dist/es/standards-sdk.es118.js.map +1 -1
- package/dist/es/standards-sdk.es119.js +27 -20
- package/dist/es/standards-sdk.es119.js.map +1 -1
- package/dist/es/standards-sdk.es12.js +1 -1
- package/dist/es/standards-sdk.es120.js +18 -156
- package/dist/es/standards-sdk.es120.js.map +1 -1
- package/dist/es/standards-sdk.es121.js +148 -191
- package/dist/es/standards-sdk.es121.js.map +1 -1
- package/dist/es/standards-sdk.es122.js +160 -747
- package/dist/es/standards-sdk.es122.js.map +1 -1
- package/dist/es/standards-sdk.es123.js +786 -9
- package/dist/es/standards-sdk.es123.js.map +1 -1
- package/dist/es/standards-sdk.es124.js +13 -567
- package/dist/es/standards-sdk.es124.js.map +1 -1
- package/dist/es/standards-sdk.es125.js +541 -576
- package/dist/es/standards-sdk.es125.js.map +1 -1
- package/dist/es/standards-sdk.es126.js +601 -12
- package/dist/es/standards-sdk.es126.js.map +1 -1
- package/dist/es/standards-sdk.es127.js +13 -2
- package/dist/es/standards-sdk.es127.js.map +1 -1
- package/dist/es/standards-sdk.es128.js +2 -87
- package/dist/es/standards-sdk.es128.js.map +1 -1
- package/dist/es/standards-sdk.es129.js +84 -37
- package/dist/es/standards-sdk.es129.js.map +1 -1
- package/dist/es/standards-sdk.es13.js +1 -1
- package/dist/es/standards-sdk.es130.js +40 -2
- package/dist/es/standards-sdk.es130.js.map +1 -1
- package/dist/es/standards-sdk.es131.js +2 -235
- package/dist/es/standards-sdk.es131.js.map +1 -1
- package/dist/es/standards-sdk.es132.js +204 -1109
- package/dist/es/standards-sdk.es132.js.map +1 -1
- package/dist/es/standards-sdk.es133.js +1059 -225
- package/dist/es/standards-sdk.es133.js.map +1 -1
- package/dist/es/standards-sdk.es134.js +303 -419
- package/dist/es/standards-sdk.es134.js.map +1 -1
- package/dist/es/standards-sdk.es135.js +418 -351
- package/dist/es/standards-sdk.es135.js.map +1 -1
- package/dist/es/standards-sdk.es136.js +347 -1108
- package/dist/es/standards-sdk.es136.js.map +1 -1
- package/dist/es/standards-sdk.es137.js +1088 -180
- package/dist/es/standards-sdk.es137.js.map +1 -1
- package/dist/es/standards-sdk.es138.js +153 -1512
- package/dist/es/standards-sdk.es138.js.map +1 -1
- package/dist/es/standards-sdk.es139.js +1567 -1255
- package/dist/es/standards-sdk.es139.js.map +1 -1
- package/dist/es/standards-sdk.es14.js +1 -1
- package/dist/es/standards-sdk.es140.js +1255 -17
- package/dist/es/standards-sdk.es140.js.map +1 -1
- package/dist/es/standards-sdk.es141.js +15 -85
- package/dist/es/standards-sdk.es141.js.map +1 -1
- package/dist/es/standards-sdk.es142.js +77 -71
- package/dist/es/standards-sdk.es142.js.map +1 -1
- package/dist/es/standards-sdk.es143.js +79 -891
- package/dist/es/standards-sdk.es143.js.map +1 -1
- package/dist/es/standards-sdk.es144.js +886 -53
- package/dist/es/standards-sdk.es144.js.map +1 -1
- package/dist/es/standards-sdk.es145.js +53 -152
- package/dist/es/standards-sdk.es145.js.map +1 -1
- package/dist/es/standards-sdk.es146.js +159 -7
- package/dist/es/standards-sdk.es146.js.map +1 -1
- package/dist/es/standards-sdk.es147.js +7 -86
- package/dist/es/standards-sdk.es147.js.map +1 -1
- package/dist/es/standards-sdk.es148.js +65 -44
- package/dist/es/standards-sdk.es148.js.map +1 -1
- package/dist/es/standards-sdk.es149.js +65 -30
- package/dist/es/standards-sdk.es149.js.map +1 -1
- package/dist/es/standards-sdk.es15.js +1 -1
- package/dist/es/standards-sdk.es150.js +30 -34
- package/dist/es/standards-sdk.es150.js.map +1 -1
- package/dist/es/standards-sdk.es151.js +34 -45
- package/dist/es/standards-sdk.es151.js.map +1 -1
- package/dist/es/standards-sdk.es152.js +48 -138
- package/dist/es/standards-sdk.es152.js.map +1 -1
- package/dist/es/standards-sdk.es153.js +133 -37
- package/dist/es/standards-sdk.es153.js.map +1 -1
- package/dist/es/standards-sdk.es154.js +34 -12474
- package/dist/es/standards-sdk.es154.js.map +1 -1
- package/dist/es/standards-sdk.es155.js +12477 -12
- package/dist/es/standards-sdk.es155.js.map +1 -1
- package/dist/es/standards-sdk.es156.js +15 -54
- package/dist/es/standards-sdk.es156.js.map +1 -1
- package/dist/es/standards-sdk.es157.js +48 -76
- package/dist/es/standards-sdk.es157.js.map +1 -1
- package/dist/es/standards-sdk.es158.js +69 -66
- package/dist/es/standards-sdk.es158.js.map +1 -1
- package/dist/es/standards-sdk.es159.js +71 -63
- package/dist/es/standards-sdk.es159.js.map +1 -1
- package/dist/es/standards-sdk.es16.js +5 -5
- package/dist/es/standards-sdk.es160.js +188 -160
- package/dist/es/standards-sdk.es160.js.map +1 -1
- package/dist/es/standards-sdk.es161.js +65 -314
- package/dist/es/standards-sdk.es161.js.map +1 -1
- package/dist/es/standards-sdk.es162.js +232 -336
- package/dist/es/standards-sdk.es162.js.map +1 -1
- package/dist/es/standards-sdk.es163.js +129 -410
- package/dist/es/standards-sdk.es163.js.map +1 -1
- package/dist/es/standards-sdk.es164.js +200 -209
- package/dist/es/standards-sdk.es164.js.map +1 -1
- package/dist/es/standards-sdk.es165.js +334 -64
- package/dist/es/standards-sdk.es165.js.map +1 -1
- package/dist/es/standards-sdk.es166.js +442 -231
- package/dist/es/standards-sdk.es166.js.map +1 -1
- package/dist/es/standards-sdk.es167.js +317 -158
- package/dist/es/standards-sdk.es167.js.map +1 -1
- package/dist/es/standards-sdk.es168.js +61 -207
- package/dist/es/standards-sdk.es168.js.map +1 -1
- package/dist/es/standards-sdk.es169.js +155 -222
- package/dist/es/standards-sdk.es169.js.map +1 -1
- package/dist/es/standards-sdk.es170.js +178 -75
- package/dist/es/standards-sdk.es170.js.map +1 -1
- package/dist/es/standards-sdk.es171.js +226 -113
- package/dist/es/standards-sdk.es171.js.map +1 -1
- package/dist/es/standards-sdk.es172.js +77 -119
- package/dist/es/standards-sdk.es172.js.map +1 -1
- package/dist/es/standards-sdk.es173.js +103 -162
- package/dist/es/standards-sdk.es173.js.map +1 -1
- package/dist/es/standards-sdk.es174.js +141 -119
- package/dist/es/standards-sdk.es174.js.map +1 -1
- package/dist/es/standards-sdk.es175.js +152 -298
- package/dist/es/standards-sdk.es175.js.map +1 -1
- package/dist/es/standards-sdk.es176.js +120 -240
- package/dist/es/standards-sdk.es176.js.map +1 -1
- package/dist/es/standards-sdk.es177.js +298 -83
- package/dist/es/standards-sdk.es177.js.map +1 -1
- package/dist/es/standards-sdk.es178.js +262 -0
- package/dist/es/standards-sdk.es178.js.map +1 -0
- package/dist/es/standards-sdk.es179.js +119 -0
- package/dist/es/standards-sdk.es179.js.map +1 -0
- package/dist/es/standards-sdk.es18.js +12 -12
- package/dist/es/standards-sdk.es19.js +9 -9
- package/dist/es/standards-sdk.es2.js +2 -2
- package/dist/es/standards-sdk.es20.js +1 -1
- package/dist/es/standards-sdk.es21.js +1 -1
- package/dist/es/standards-sdk.es22.js +1 -1
- package/dist/es/standards-sdk.es23.js +1 -1
- package/dist/es/standards-sdk.es24.js +1 -1
- package/dist/es/standards-sdk.es25.js +1 -1
- package/dist/es/standards-sdk.es26.js +1 -1
- package/dist/es/standards-sdk.es27.js +12 -12
- package/dist/es/standards-sdk.es30.js +2 -2
- package/dist/es/standards-sdk.es31.js +4 -4
- package/dist/es/standards-sdk.es32.js +1 -1
- package/dist/es/standards-sdk.es35.js +6 -6
- package/dist/es/standards-sdk.es36.js +4 -4
- package/dist/es/standards-sdk.es37.js +2 -2
- package/dist/es/standards-sdk.es38.js +2 -2
- package/dist/es/standards-sdk.es39.js +1 -1
- package/dist/es/standards-sdk.es4.js +2 -2
- package/dist/es/standards-sdk.es40.js +1 -1
- package/dist/es/standards-sdk.es41.js +2 -2
- package/dist/es/standards-sdk.es46.js +1 -1
- package/dist/es/standards-sdk.es5.js +2 -2
- package/dist/es/standards-sdk.es51.js +1 -1
- package/dist/es/standards-sdk.es53.js +1 -1
- package/dist/es/standards-sdk.es56.js +2 -2
- package/dist/es/standards-sdk.es58.js +37 -4
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +17 -10
- package/dist/es/standards-sdk.es59.js.map +1 -1
- package/dist/es/standards-sdk.es6.js +2 -2
- package/dist/es/standards-sdk.es60.js +2 -1
- package/dist/es/standards-sdk.es60.js.map +1 -1
- package/dist/es/standards-sdk.es61.js +1 -0
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es62.js +19 -5
- package/dist/es/standards-sdk.es62.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +214 -153
- package/dist/es/standards-sdk.es63.js.map +1 -1
- package/dist/es/standards-sdk.es64.js +205 -84
- package/dist/es/standards-sdk.es64.js.map +1 -1
- package/dist/es/standards-sdk.es65.js +125 -40
- package/dist/es/standards-sdk.es65.js.map +1 -1
- package/dist/es/standards-sdk.es66.js +41 -261
- package/dist/es/standards-sdk.es66.js.map +1 -1
- package/dist/es/standards-sdk.es67.js +262 -24
- package/dist/es/standards-sdk.es67.js.map +1 -1
- package/dist/es/standards-sdk.es68.js +25 -87
- package/dist/es/standards-sdk.es68.js.map +1 -1
- package/dist/es/standards-sdk.es69.js +95 -3
- package/dist/es/standards-sdk.es69.js.map +1 -1
- package/dist/es/standards-sdk.es7.js +1 -1
- package/dist/es/standards-sdk.es70.js +3 -100
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +62 -61
- package/dist/es/standards-sdk.es71.js.map +1 -1
- package/dist/es/standards-sdk.es72.js +98 -17
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es73.js +19 -77
- package/dist/es/standards-sdk.es73.js.map +1 -1
- package/dist/es/standards-sdk.es74.js +77 -458
- package/dist/es/standards-sdk.es74.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +240 -106
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +286 -170
- package/dist/es/standards-sdk.es76.js.map +1 -1
- package/dist/es/standards-sdk.es77.js +207 -71
- package/dist/es/standards-sdk.es77.js.map +1 -1
- package/dist/es/standards-sdk.es78.js +72 -71
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es79.js +71 -143
- package/dist/es/standards-sdk.es79.js.map +1 -1
- package/dist/es/standards-sdk.es80.js +136 -62
- package/dist/es/standards-sdk.es80.js.map +1 -1
- package/dist/es/standards-sdk.es81.js +45 -380
- package/dist/es/standards-sdk.es81.js.map +1 -1
- package/dist/es/standards-sdk.es82.js +130 -222
- package/dist/es/standards-sdk.es82.js.map +1 -1
- package/dist/es/standards-sdk.es83.js +444 -313
- package/dist/es/standards-sdk.es83.js.map +1 -1
- package/dist/es/standards-sdk.es84.js +364 -88
- package/dist/es/standards-sdk.es84.js.map +1 -1
- package/dist/es/standards-sdk.es85.js +89 -125
- package/dist/es/standards-sdk.es85.js.map +1 -1
- package/dist/es/standards-sdk.es86.js +125 -8
- package/dist/es/standards-sdk.es86.js.map +1 -1
- package/dist/es/standards-sdk.es87.js +6 -45
- package/dist/es/standards-sdk.es87.js.map +1 -1
- package/dist/es/standards-sdk.es88.js +44 -98
- package/dist/es/standards-sdk.es88.js.map +1 -1
- package/dist/es/standards-sdk.es89.js +84 -331
- package/dist/es/standards-sdk.es89.js.map +1 -1
- package/dist/es/standards-sdk.es9.js +2 -2
- package/dist/es/standards-sdk.es90.js +160 -93
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es91.js +275 -55
- package/dist/es/standards-sdk.es91.js.map +1 -1
- package/dist/es/standards-sdk.es92.js +55 -43
- package/dist/es/standards-sdk.es92.js.map +1 -1
- package/dist/es/standards-sdk.es93.js +44 -145
- package/dist/es/standards-sdk.es93.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +113 -30
- package/dist/es/standards-sdk.es94.js.map +1 -1
- package/dist/es/standards-sdk.es95.js +59 -22
- package/dist/es/standards-sdk.es95.js.map +1 -1
- package/dist/es/standards-sdk.es96.js +28 -23
- package/dist/es/standards-sdk.es96.js.map +1 -1
- package/dist/es/standards-sdk.es97.js +23 -238
- package/dist/es/standards-sdk.es97.js.map +1 -1
- package/dist/es/standards-sdk.es98.js +225 -267
- package/dist/es/standards-sdk.es98.js.map +1 -1
- package/dist/es/standards-sdk.es99.js +220 -95
- package/dist/es/standards-sdk.es99.js.map +1 -1
- package/package.json +5 -1
|
@@ -1,64 +1,284 @@
|
|
|
1
|
-
import { PublicKey } from "@hashgraph/sdk";
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { Status, PublicKey, TransactionId, AccountId } from "@hashgraph/sdk";
|
|
2
|
+
import { HCS21BaseClient } from "./standards-sdk.es89.js";
|
|
3
|
+
import { HCS21TopicType } from "./standards-sdk.es86.js";
|
|
4
|
+
import { HCS21ValidationError } from "./standards-sdk.es87.js";
|
|
5
|
+
import { buildHcs21CreateRegistryTx, buildHcs21MessageTx } from "./standards-sdk.es88.js";
|
|
6
|
+
import { buildHcs2CreateRegistryTx, buildHcs2RegisterTx } from "./standards-sdk.es78.js";
|
|
7
|
+
import { HCS2RegistryType } from "./standards-sdk.es74.js";
|
|
8
|
+
class HCS21BrowserClient extends HCS21BaseClient {
|
|
9
|
+
constructor(config) {
|
|
10
|
+
super({ network: config.network, logger: config.logger });
|
|
11
|
+
this.hwc = config.hwc;
|
|
6
12
|
}
|
|
7
|
-
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
async createRegistryTopic(params) {
|
|
14
|
+
const { publicKey } = await this.getSignerContext();
|
|
15
|
+
const tx = buildHcs21CreateRegistryTx({
|
|
16
|
+
ttl: params.ttl,
|
|
17
|
+
indexed: params.indexed,
|
|
18
|
+
type: params.type,
|
|
19
|
+
metaTopicId: params.metaTopicId,
|
|
20
|
+
adminKey: params.adminKey,
|
|
21
|
+
submitKey: params.submitKey,
|
|
22
|
+
operatorPublicKey: publicKey
|
|
23
|
+
});
|
|
24
|
+
if (params.transactionMemo) {
|
|
25
|
+
tx.setTransactionMemo(params.transactionMemo);
|
|
26
|
+
}
|
|
27
|
+
const { receipt } = await this.executeWithWallet(tx);
|
|
28
|
+
if (receipt.status !== Status.Success || !receipt.topicId) {
|
|
29
|
+
throw new HCS21ValidationError(
|
|
30
|
+
"Failed to create HCS-21 registry topic",
|
|
31
|
+
"invalid_payload"
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
return receipt.topicId.toString();
|
|
16
35
|
}
|
|
17
|
-
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
36
|
+
async createAdapterVersionPointerTopic(params) {
|
|
37
|
+
const { publicKey } = await this.getSignerContext();
|
|
38
|
+
const tx = buildHcs2CreateRegistryTx({
|
|
39
|
+
registryType: HCS2RegistryType.NON_INDEXED,
|
|
40
|
+
ttl: params.ttl,
|
|
41
|
+
adminKey: params.adminKey,
|
|
42
|
+
submitKey: params.submitKey,
|
|
43
|
+
memoOverride: params.memoOverride,
|
|
44
|
+
operatorPublicKey: publicKey
|
|
45
|
+
});
|
|
46
|
+
if (params.transactionMemo) {
|
|
47
|
+
tx.setTransactionMemo(params.transactionMemo);
|
|
48
|
+
}
|
|
49
|
+
const { receipt } = await this.executeWithWallet(tx);
|
|
50
|
+
if (receipt.status !== Status.Success || !receipt.topicId) {
|
|
51
|
+
throw new HCS21ValidationError(
|
|
52
|
+
"Failed to create HCS-2 registry version topic",
|
|
53
|
+
"invalid_payload"
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
return receipt.topicId.toString();
|
|
26
57
|
}
|
|
27
|
-
|
|
28
|
-
const {
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
58
|
+
async createRegistryDiscoveryTopic(params) {
|
|
59
|
+
const { publicKey } = await this.getSignerContext();
|
|
60
|
+
const tx = buildHcs2CreateRegistryTx({
|
|
61
|
+
registryType: HCS2RegistryType.INDEXED,
|
|
62
|
+
ttl: params.ttl,
|
|
63
|
+
adminKey: params.adminKey,
|
|
64
|
+
submitKey: params.submitKey,
|
|
65
|
+
memoOverride: params.memoOverride,
|
|
66
|
+
operatorPublicKey: publicKey
|
|
67
|
+
});
|
|
68
|
+
if (params.transactionMemo) {
|
|
69
|
+
tx.setTransactionMemo(params.transactionMemo);
|
|
70
|
+
}
|
|
71
|
+
const { receipt } = await this.executeWithWallet(tx);
|
|
72
|
+
if (receipt.status !== Status.Success || !receipt.topicId) {
|
|
73
|
+
throw new HCS21ValidationError(
|
|
74
|
+
"Failed to create registry-of-registries topic",
|
|
75
|
+
"invalid_payload"
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
return receipt.topicId.toString();
|
|
35
79
|
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
80
|
+
async createAdapterCategoryTopic(params) {
|
|
81
|
+
const { publicKey } = await this.getSignerContext();
|
|
82
|
+
const tx = buildHcs21CreateRegistryTx({
|
|
83
|
+
ttl: params.ttl,
|
|
84
|
+
indexed: params.indexed ?? 0,
|
|
85
|
+
type: HCS21TopicType.ADAPTER_CATEGORY,
|
|
86
|
+
metaTopicId: params.metaTopicId,
|
|
87
|
+
adminKey: params.adminKey,
|
|
88
|
+
submitKey: params.submitKey,
|
|
89
|
+
operatorPublicKey: publicKey
|
|
90
|
+
});
|
|
91
|
+
if (params.transactionMemo) {
|
|
92
|
+
tx.setTransactionMemo(params.transactionMemo);
|
|
93
|
+
}
|
|
94
|
+
const { receipt } = await this.executeWithWallet(tx);
|
|
95
|
+
if (receipt.status !== Status.Success || !receipt.topicId) {
|
|
96
|
+
throw new HCS21ValidationError(
|
|
97
|
+
"Failed to create adapter category topic",
|
|
98
|
+
"invalid_payload"
|
|
99
|
+
);
|
|
100
|
+
}
|
|
101
|
+
return receipt.topicId.toString();
|
|
102
|
+
}
|
|
103
|
+
async publishVersionPointer(params) {
|
|
104
|
+
const tx = buildHcs2RegisterTx({
|
|
105
|
+
registryTopicId: params.versionTopicId,
|
|
106
|
+
targetTopicId: params.declarationTopicId,
|
|
107
|
+
memo: params.memo,
|
|
108
|
+
analyticsMemo: params.transactionMemo
|
|
109
|
+
});
|
|
110
|
+
const { receipt, transactionId } = await this.executeWithWallet(tx);
|
|
111
|
+
if (receipt.status !== Status.Success) {
|
|
112
|
+
throw new HCS21ValidationError(
|
|
113
|
+
"Failed to publish registry version pointer",
|
|
114
|
+
"invalid_payload"
|
|
115
|
+
);
|
|
116
|
+
}
|
|
117
|
+
return {
|
|
118
|
+
sequenceNumber: this.toNumber(receipt.topicSequenceNumber),
|
|
119
|
+
transactionId
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
async resolveVersionPointer(versionTopicId) {
|
|
123
|
+
const [latest] = await this.mirrorNode.getTopicMessages(versionTopicId, {
|
|
124
|
+
limit: 1,
|
|
125
|
+
order: "desc"
|
|
126
|
+
});
|
|
127
|
+
if (!latest) {
|
|
128
|
+
throw new HCS21ValidationError(
|
|
129
|
+
"Version pointer topic has no messages",
|
|
130
|
+
"invalid_payload"
|
|
131
|
+
);
|
|
132
|
+
}
|
|
133
|
+
const declarationTopicId = latest.t_id;
|
|
134
|
+
if (typeof declarationTopicId !== "string" || declarationTopicId.length === 0) {
|
|
135
|
+
throw new HCS21ValidationError(
|
|
136
|
+
"Version pointer topic does not include a declaration topic ID (`t_id`)",
|
|
137
|
+
"invalid_payload"
|
|
138
|
+
);
|
|
139
|
+
}
|
|
140
|
+
const rawSequence = typeof latest.sequence_number === "number" ? latest.sequence_number : Number(latest.sequence_number);
|
|
141
|
+
const sequenceNumber = Number.isFinite(rawSequence) ? rawSequence : 0;
|
|
142
|
+
return {
|
|
143
|
+
versionTopicId,
|
|
144
|
+
declarationTopicId,
|
|
145
|
+
sequenceNumber,
|
|
146
|
+
payer: latest.payer,
|
|
147
|
+
memo: latest.m,
|
|
148
|
+
op: latest.op
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
async registerCategoryTopic(params) {
|
|
152
|
+
const tx = buildHcs2RegisterTx({
|
|
153
|
+
registryTopicId: params.discoveryTopicId,
|
|
154
|
+
targetTopicId: params.categoryTopicId,
|
|
155
|
+
metadata: params.metadata,
|
|
156
|
+
memo: params.memo,
|
|
157
|
+
analyticsMemo: params.transactionMemo
|
|
158
|
+
});
|
|
159
|
+
const { receipt, transactionId } = await this.executeWithWallet(tx);
|
|
160
|
+
if (receipt.status !== Status.Success) {
|
|
161
|
+
throw new HCS21ValidationError(
|
|
162
|
+
"Failed to register adapter category topic",
|
|
163
|
+
"invalid_payload"
|
|
164
|
+
);
|
|
165
|
+
}
|
|
166
|
+
return {
|
|
167
|
+
sequenceNumber: this.toNumber(receipt.topicSequenceNumber),
|
|
168
|
+
transactionId
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
async publishCategoryEntry(params) {
|
|
172
|
+
const memo = params.memo ?? `adapter:${params.adapterId}`;
|
|
173
|
+
const tx = buildHcs2RegisterTx({
|
|
174
|
+
registryTopicId: params.categoryTopicId,
|
|
175
|
+
targetTopicId: params.versionTopicId,
|
|
176
|
+
metadata: params.metadata,
|
|
177
|
+
memo,
|
|
178
|
+
analyticsMemo: params.transactionMemo
|
|
179
|
+
});
|
|
180
|
+
const { receipt, transactionId } = await this.executeWithWallet(tx);
|
|
181
|
+
if (receipt.status !== Status.Success) {
|
|
182
|
+
throw new HCS21ValidationError(
|
|
183
|
+
"Failed to publish adapter category entry",
|
|
184
|
+
"invalid_payload"
|
|
185
|
+
);
|
|
186
|
+
}
|
|
187
|
+
return {
|
|
188
|
+
sequenceNumber: this.toNumber(receipt.topicSequenceNumber),
|
|
189
|
+
transactionId
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
async publishDeclaration(params) {
|
|
193
|
+
const declaration = "p" in params.declaration ? this.validateDeclaration(params.declaration) : this.buildDeclaration(params.declaration);
|
|
194
|
+
const tx = buildHcs21MessageTx({
|
|
195
|
+
topicId: params.topicId,
|
|
196
|
+
declaration,
|
|
197
|
+
transactionMemo: params.transactionMemo
|
|
198
|
+
});
|
|
199
|
+
const { receipt, transactionId } = await this.executeWithWallet(tx);
|
|
200
|
+
if (receipt.status !== Status.Success) {
|
|
201
|
+
throw new HCS21ValidationError(
|
|
202
|
+
"Failed to submit HCS-21 declaration",
|
|
203
|
+
"invalid_payload"
|
|
204
|
+
);
|
|
205
|
+
}
|
|
206
|
+
return {
|
|
207
|
+
sequenceNumber: this.toNumber(receipt.topicSequenceNumber),
|
|
208
|
+
transactionId
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
async fetchDeclarations(topicId, options) {
|
|
212
|
+
const { messages = [] } = await this.hwc.getMessages(topicId);
|
|
213
|
+
const envelopes = [];
|
|
214
|
+
for (const message of messages) {
|
|
215
|
+
if (!message || message.p !== "hcs-21") {
|
|
216
|
+
continue;
|
|
217
|
+
}
|
|
218
|
+
try {
|
|
219
|
+
const declaration = this.validateDeclaration(message);
|
|
220
|
+
envelopes.push({
|
|
221
|
+
declaration,
|
|
222
|
+
consensusTimestamp: message.consensus_timestamp,
|
|
223
|
+
sequenceNumber: Number(message.sequence_number ?? 0),
|
|
224
|
+
payer: message.payer
|
|
225
|
+
});
|
|
226
|
+
} catch (error) {
|
|
227
|
+
const detail = error instanceof Error ? error.message : "unknown error";
|
|
228
|
+
this.logger.warn(`Skipping invalid HCS-21 browser message: ${detail}`);
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
const ordered = options?.order === "desc" ? [...envelopes].sort((a, b) => b.sequenceNumber - a.sequenceNumber) : envelopes;
|
|
232
|
+
if (options?.limit && options.limit > 0) {
|
|
233
|
+
return ordered.slice(0, options.limit);
|
|
234
|
+
}
|
|
235
|
+
return ordered;
|
|
236
|
+
}
|
|
237
|
+
async getSignerContext() {
|
|
238
|
+
if (this.signerCache) {
|
|
239
|
+
return this.signerCache;
|
|
240
|
+
}
|
|
241
|
+
const accountInfo = this.hwc.getAccountInfo?.();
|
|
242
|
+
const accountId = typeof accountInfo === "string" ? accountInfo : accountInfo?.accountId;
|
|
243
|
+
if (!accountId) {
|
|
244
|
+
throw new HCS21ValidationError(
|
|
245
|
+
"Wallet is not connected",
|
|
246
|
+
"invalid_payload"
|
|
247
|
+
);
|
|
248
|
+
}
|
|
249
|
+
const accountResponse = await this.hwc.requestAccount(accountId);
|
|
250
|
+
const key = accountResponse?.key?.key;
|
|
251
|
+
if (!key) {
|
|
252
|
+
throw new HCS21ValidationError(
|
|
253
|
+
"Unable to resolve wallet public key",
|
|
254
|
+
"invalid_payload"
|
|
255
|
+
);
|
|
256
|
+
}
|
|
257
|
+
const publicKey = PublicKey.fromString(key);
|
|
258
|
+
this.signerCache = { accountId, publicKey };
|
|
259
|
+
return this.signerCache;
|
|
260
|
+
}
|
|
261
|
+
async executeWithWallet(tx) {
|
|
262
|
+
const { accountId } = await this.getSignerContext();
|
|
263
|
+
const txId = TransactionId.generate(AccountId.fromString(accountId));
|
|
264
|
+
tx.setTransactionId(txId);
|
|
265
|
+
const receipt = await this.hwc.executeTransaction(tx, false);
|
|
266
|
+
return {
|
|
267
|
+
receipt,
|
|
268
|
+
transactionId: txId.toString()
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
toNumber(value) {
|
|
272
|
+
if (typeof value === "number") {
|
|
273
|
+
return value;
|
|
274
|
+
}
|
|
275
|
+
if (value && typeof value.toNumber === "function") {
|
|
276
|
+
return value.toNumber();
|
|
277
|
+
}
|
|
278
|
+
return void 0;
|
|
45
279
|
}
|
|
46
|
-
}
|
|
47
|
-
function normalizeDigest(value) {
|
|
48
|
-
return value.replace(/^sha384[-:]?/i, "").trim().toLowerCase();
|
|
49
|
-
}
|
|
50
|
-
function verifyArtifactDigest(artifact, expectedDigest) {
|
|
51
|
-
const hash = createHash("sha384");
|
|
52
|
-
hash.update(artifact);
|
|
53
|
-
const hex = hash.digest("hex").toLowerCase();
|
|
54
|
-
const base64 = Buffer.from(hex, "hex").toString("base64").toLowerCase();
|
|
55
|
-
const expected = normalizeDigest(expectedDigest);
|
|
56
|
-
return expected === hex || expected === base64;
|
|
57
280
|
}
|
|
58
281
|
export {
|
|
59
|
-
|
|
60
|
-
verifyArtifactDigest,
|
|
61
|
-
verifyDeclarationSignature,
|
|
62
|
-
verifyManifestSignature
|
|
282
|
+
HCS21BrowserClient
|
|
63
283
|
};
|
|
64
284
|
//# sourceMappingURL=standards-sdk.es91.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es91.js","sources":["../../src/hcs-21/verify.ts"],"sourcesContent":["import { PublicKey } from '@hashgraph/sdk';\nimport { createHash } from 'crypto';\nimport { AdapterDeclaration } from './types';\n\ntype JsonValue =\n | string\n | number\n | boolean\n | null\n | JsonValue[]\n | { [key: string]: JsonValue };\n\nfunction sortObject(value: JsonValue): JsonValue {\n if (Array.isArray(value)) {\n return value.map(sortObject) as JsonValue;\n }\n if (value && typeof value === 'object') {\n const entries = Object.entries(value as Record<string, JsonValue>).sort(\n ([a], [b]) => (a < b ? -1 : a > b ? 1 : 0),\n );\n const sorted: Record<string, JsonValue> = {};\n for (const [key, val] of entries) {\n sorted[key] = sortObject(val);\n }\n return sorted;\n }\n return value;\n}\n\nexport function canonicalize(value: unknown): string {\n const sorted = sortObject(value as JsonValue);\n return JSON.stringify(sorted);\n}\n\nexport function verifyDeclarationSignature(\n declaration: AdapterDeclaration,\n publisherPublicKey: string,\n): boolean {\n if (!declaration.signature) {\n return false;\n }\n try {\n const { signature, ...unsigned } = declaration;\n const payload = canonicalize(unsigned);\n const signatureBytes = Buffer.from(signature, 'base64');\n const publicKey = PublicKey.fromString(publisherPublicKey);\n return publicKey.verify(Buffer.from(payload, 'utf8'), signatureBytes);\n } catch {\n return false;\n }\n}\n\nexport function verifyManifestSignature(\n manifest: unknown,\n signatureBase64: string,\n publisherPublicKey: string,\n): boolean {\n try {\n const payload = canonicalize(manifest as JsonValue);\n const signatureBytes = Buffer.from(signatureBase64, 'base64');\n const publicKey = PublicKey.fromString(publisherPublicKey);\n return publicKey.verify(Buffer.from(payload, 'utf8'), signatureBytes);\n } catch {\n return false;\n }\n}\n\nfunction normalizeDigest(value: string): string {\n return value\n .replace(/^sha384[-:]?/i, '')\n .trim()\n .toLowerCase();\n}\n\nexport function verifyArtifactDigest(\n artifact: Buffer | Uint8Array,\n expectedDigest: string,\n): boolean {\n const hash = createHash('sha384');\n hash.update(artifact);\n const hex = hash.digest('hex').toLowerCase();\n const base64 = Buffer.from(hex, 'hex').toString('base64').toLowerCase();\n const expected = normalizeDigest(expectedDigest);\n return expected === hex || expected === base64;\n}\n"],"names":[],"mappings":";;AAYA,SAAS,WAAW,OAA6B;AAC/C,MAAI,MAAM,QAAQ,KAAK,GAAG;AACxB,WAAO,MAAM,IAAI,UAAU;AAAA,EAC7B;AACA,MAAI,SAAS,OAAO,UAAU,UAAU;AACtC,UAAM,UAAU,OAAO,QAAQ,KAAkC,EAAE;AAAA,MACjE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAO,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI;AAAA,IAAA;AAE1C,UAAM,SAAoC,CAAA;AAC1C,eAAW,CAAC,KAAK,GAAG,KAAK,SAAS;AAChC,aAAO,GAAG,IAAI,WAAW,GAAG;AAAA,IAC9B;AACA,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,SAAS,aAAa,OAAwB;AACnD,QAAM,SAAS,WAAW,KAAkB;AAC5C,SAAO,KAAK,UAAU,MAAM;AAC9B;AAEO,SAAS,2BACd,aACA,oBACS;AACT,MAAI,CAAC,YAAY,WAAW;AAC1B,WAAO;AAAA,EACT;AACA,MAAI;AACF,UAAM,EAAE,WAAW,GAAG,SAAA,IAAa;AACnC,UAAM,UAAU,aAAa,QAAQ;AACrC,UAAM,iBAAiB,OAAO,KAAK,WAAW,QAAQ;AACtD,UAAM,YAAY,UAAU,WAAW,kBAAkB;AACzD,WAAO,UAAU,OAAO,OAAO,KAAK,SAAS,MAAM,GAAG,cAAc;AAAA,EACtE,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEO,SAAS,wBACd,UACA,iBACA,oBACS;AACT,MAAI;AACF,UAAM,UAAU,aAAa,QAAqB;AAClD,UAAM,iBAAiB,OAAO,KAAK,iBAAiB,QAAQ;AAC5D,UAAM,YAAY,UAAU,WAAW,kBAAkB;AACzD,WAAO,UAAU,OAAO,OAAO,KAAK,SAAS,MAAM,GAAG,cAAc;AAAA,EACtE,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,gBAAgB,OAAuB;AAC9C,SAAO,MACJ,QAAQ,iBAAiB,EAAE,EAC3B,KAAA,EACA,YAAA;AACL;AAEO,SAAS,qBACd,UACA,gBACS;AACT,QAAM,OAAO,WAAW,QAAQ;AAChC,OAAK,OAAO,QAAQ;AACpB,QAAM,MAAM,KAAK,OAAO,KAAK,EAAE,YAAA;AAC/B,QAAM,SAAS,OAAO,KAAK,KAAK,KAAK,EAAE,SAAS,QAAQ,EAAE,YAAA;AAC1D,QAAM,WAAW,gBAAgB,cAAc;AAC/C,SAAO,aAAa,OAAO,aAAa;AAC1C;"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es91.js","sources":["../../src/hcs-21/browser.ts"],"sourcesContent":["import type { HashinalsWalletConnectSDK } from '@hashgraphonline/hashinal-wc';\nimport {\n AccountId,\n PublicKey,\n Status,\n Transaction,\n TransactionId,\n TransactionReceipt,\n} from '@hashgraph/sdk';\nimport Long from 'long';\nimport type { ILogger } from '../utils/logger';\nimport { NetworkType } from '../utils/types';\nimport {\n HCS21BaseClient,\n BuildDeclarationParams,\n FetchDeclarationsOptions,\n} from './base-client';\nimport type {\n CreateRegistryTopicParams,\n CreateAdapterVersionPointerTopicParams,\n CreateRegistryDiscoveryTopicParams,\n CreateAdapterCategoryTopicParams,\n PublishVersionPointerParams,\n RegisterCategoryTopicParams,\n PublishCategoryEntryParams,\n PublishDeclarationParams,\n PublishDeclarationResult,\n VersionPointerResolution,\n} from './sdk';\nimport {\n AdapterDeclaration,\n AdapterDeclarationEnvelope,\n HCS21TopicType,\n} from './types';\nimport { HCS21ValidationError } from './errors';\nimport { buildHcs21CreateRegistryTx, buildHcs21MessageTx } from './tx';\nimport { buildHcs2CreateRegistryTx, buildHcs2RegisterTx } from '../hcs-2/tx';\nimport { HCS2RegistryType } from '../hcs-2/types';\n\nexport interface BrowserHCS21ClientConfig {\n network: NetworkType;\n hwc: HashinalsWalletConnectSDK;\n logger?: ILogger;\n}\n\nexport class HCS21BrowserClient extends HCS21BaseClient {\n private readonly hwc: HashinalsWalletConnectSDK;\n private signerCache?: { accountId: string; publicKey: PublicKey };\n\n constructor(config: BrowserHCS21ClientConfig) {\n super({ network: config.network, logger: config.logger });\n this.hwc = config.hwc;\n }\n\n async createRegistryTopic(\n params: CreateRegistryTopicParams,\n ): Promise<string> {\n const { publicKey } = await this.getSignerContext();\n const tx = buildHcs21CreateRegistryTx({\n ttl: params.ttl,\n indexed: params.indexed,\n type: params.type,\n metaTopicId: params.metaTopicId,\n adminKey: params.adminKey,\n submitKey: params.submitKey,\n operatorPublicKey: publicKey,\n });\n\n if (params.transactionMemo) {\n tx.setTransactionMemo(params.transactionMemo);\n }\n\n const { receipt } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success || !receipt.topicId) {\n throw new HCS21ValidationError(\n 'Failed to create HCS-21 registry topic',\n 'invalid_payload',\n );\n }\n\n return receipt.topicId.toString();\n }\n\n async createAdapterVersionPointerTopic(\n params: CreateAdapterVersionPointerTopicParams,\n ): Promise<string> {\n const { publicKey } = await this.getSignerContext();\n const tx = buildHcs2CreateRegistryTx({\n registryType: HCS2RegistryType.NON_INDEXED,\n ttl: params.ttl,\n adminKey: params.adminKey,\n submitKey: params.submitKey,\n memoOverride: params.memoOverride,\n operatorPublicKey: publicKey,\n });\n\n if (params.transactionMemo) {\n tx.setTransactionMemo(params.transactionMemo);\n }\n\n const { receipt } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success || !receipt.topicId) {\n throw new HCS21ValidationError(\n 'Failed to create HCS-2 registry version topic',\n 'invalid_payload',\n );\n }\n\n return receipt.topicId.toString();\n }\n\n async createRegistryDiscoveryTopic(\n params: CreateRegistryDiscoveryTopicParams,\n ): Promise<string> {\n const { publicKey } = await this.getSignerContext();\n const tx = buildHcs2CreateRegistryTx({\n registryType: HCS2RegistryType.INDEXED,\n ttl: params.ttl,\n adminKey: params.adminKey,\n submitKey: params.submitKey,\n memoOverride: params.memoOverride,\n operatorPublicKey: publicKey,\n });\n\n if (params.transactionMemo) {\n tx.setTransactionMemo(params.transactionMemo);\n }\n\n const { receipt } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success || !receipt.topicId) {\n throw new HCS21ValidationError(\n 'Failed to create registry-of-registries topic',\n 'invalid_payload',\n );\n }\n\n return receipt.topicId.toString();\n }\n\n async createAdapterCategoryTopic(\n params: CreateAdapterCategoryTopicParams,\n ): Promise<string> {\n const { publicKey } = await this.getSignerContext();\n const tx = buildHcs21CreateRegistryTx({\n ttl: params.ttl,\n indexed: params.indexed ?? 0,\n type: HCS21TopicType.ADAPTER_CATEGORY,\n metaTopicId: params.metaTopicId,\n adminKey: params.adminKey,\n submitKey: params.submitKey,\n operatorPublicKey: publicKey,\n });\n\n if (params.transactionMemo) {\n tx.setTransactionMemo(params.transactionMemo);\n }\n\n const { receipt } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success || !receipt.topicId) {\n throw new HCS21ValidationError(\n 'Failed to create adapter category topic',\n 'invalid_payload',\n );\n }\n\n return receipt.topicId.toString();\n }\n\n async publishVersionPointer(\n params: PublishVersionPointerParams,\n ): Promise<PublishDeclarationResult> {\n const tx = buildHcs2RegisterTx({\n registryTopicId: params.versionTopicId,\n targetTopicId: params.declarationTopicId,\n memo: params.memo,\n analyticsMemo: params.transactionMemo,\n });\n\n const { receipt, transactionId } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success) {\n throw new HCS21ValidationError(\n 'Failed to publish registry version pointer',\n 'invalid_payload',\n );\n }\n\n return {\n sequenceNumber: this.toNumber(receipt.topicSequenceNumber),\n transactionId,\n };\n }\n\n async resolveVersionPointer(\n versionTopicId: string,\n ): Promise<VersionPointerResolution> {\n const [latest] = await this.mirrorNode.getTopicMessages(versionTopicId, {\n limit: 1,\n order: 'desc',\n });\n\n if (!latest) {\n throw new HCS21ValidationError(\n 'Version pointer topic has no messages',\n 'invalid_payload',\n );\n }\n\n const declarationTopicId = (latest as { t_id?: unknown }).t_id;\n\n if (\n typeof declarationTopicId !== 'string' ||\n declarationTopicId.length === 0\n ) {\n throw new HCS21ValidationError(\n 'Version pointer topic does not include a declaration topic ID (`t_id`)',\n 'invalid_payload',\n );\n }\n\n const rawSequence =\n typeof latest.sequence_number === 'number'\n ? latest.sequence_number\n : Number(latest.sequence_number);\n const sequenceNumber = Number.isFinite(rawSequence) ? rawSequence : 0;\n\n return {\n versionTopicId,\n declarationTopicId,\n sequenceNumber,\n payer: (latest as { payer?: string }).payer,\n memo: (latest as { m?: string }).m,\n op: (latest as { op?: string }).op,\n };\n }\n\n async registerCategoryTopic(\n params: RegisterCategoryTopicParams,\n ): Promise<PublishDeclarationResult> {\n const tx = buildHcs2RegisterTx({\n registryTopicId: params.discoveryTopicId,\n targetTopicId: params.categoryTopicId,\n metadata: params.metadata,\n memo: params.memo,\n analyticsMemo: params.transactionMemo,\n });\n\n const { receipt, transactionId } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success) {\n throw new HCS21ValidationError(\n 'Failed to register adapter category topic',\n 'invalid_payload',\n );\n }\n\n return {\n sequenceNumber: this.toNumber(receipt.topicSequenceNumber),\n transactionId,\n };\n }\n\n async publishCategoryEntry(\n params: PublishCategoryEntryParams,\n ): Promise<PublishDeclarationResult> {\n const memo = params.memo ?? `adapter:${params.adapterId}`;\n const tx = buildHcs2RegisterTx({\n registryTopicId: params.categoryTopicId,\n targetTopicId: params.versionTopicId,\n metadata: params.metadata,\n memo,\n analyticsMemo: params.transactionMemo,\n });\n\n const { receipt, transactionId } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success) {\n throw new HCS21ValidationError(\n 'Failed to publish adapter category entry',\n 'invalid_payload',\n );\n }\n\n return {\n sequenceNumber: this.toNumber(receipt.topicSequenceNumber),\n transactionId,\n };\n }\n\n async publishDeclaration(\n params: PublishDeclarationParams,\n ): Promise<PublishDeclarationResult> {\n const declaration =\n 'p' in params.declaration\n ? this.validateDeclaration(params.declaration)\n : this.buildDeclaration(params.declaration);\n\n const tx = buildHcs21MessageTx({\n topicId: params.topicId,\n declaration,\n transactionMemo: params.transactionMemo,\n });\n\n const { receipt, transactionId } = await this.executeWithWallet(tx);\n\n if (receipt.status !== Status.Success) {\n throw new HCS21ValidationError(\n 'Failed to submit HCS-21 declaration',\n 'invalid_payload',\n );\n }\n\n return {\n sequenceNumber: this.toNumber(receipt.topicSequenceNumber),\n transactionId,\n };\n }\n\n async fetchDeclarations(\n topicId: string,\n options?: FetchDeclarationsOptions,\n ): Promise<AdapterDeclarationEnvelope[]> {\n const { messages = [] } = await this.hwc.getMessages(topicId);\n const envelopes: AdapterDeclarationEnvelope[] = [];\n\n for (const message of messages) {\n if (!message || message.p !== 'hcs-21') {\n continue;\n }\n\n try {\n const declaration = this.validateDeclaration(message);\n envelopes.push({\n declaration,\n consensusTimestamp: message.consensus_timestamp,\n sequenceNumber: Number(message.sequence_number ?? 0),\n payer: message.payer,\n });\n } catch (error) {\n const detail = error instanceof Error ? error.message : 'unknown error';\n this.logger.warn(`Skipping invalid HCS-21 browser message: ${detail}`);\n }\n }\n\n const ordered =\n options?.order === 'desc'\n ? [...envelopes].sort((a, b) => b.sequenceNumber - a.sequenceNumber)\n : envelopes;\n\n if (options?.limit && options.limit > 0) {\n return ordered.slice(0, options.limit);\n }\n\n return ordered;\n }\n\n private async getSignerContext(): Promise<{\n accountId: string;\n publicKey: PublicKey;\n }> {\n if (this.signerCache) {\n return this.signerCache;\n }\n\n const accountInfo = this.hwc.getAccountInfo?.();\n const accountId =\n typeof accountInfo === 'string' ? accountInfo : accountInfo?.accountId;\n\n if (!accountId) {\n throw new HCS21ValidationError(\n 'Wallet is not connected',\n 'invalid_payload',\n );\n }\n\n const accountResponse = await this.hwc.requestAccount(accountId);\n const key = accountResponse?.key?.key;\n\n if (!key) {\n throw new HCS21ValidationError(\n 'Unable to resolve wallet public key',\n 'invalid_payload',\n );\n }\n\n const publicKey = PublicKey.fromString(key);\n this.signerCache = { accountId, publicKey };\n return this.signerCache;\n }\n\n private async executeWithWallet<T extends Transaction>(\n tx: T,\n ): Promise<{ receipt: TransactionReceipt; transactionId: string }> {\n const { accountId } = await this.getSignerContext();\n const txId = TransactionId.generate(AccountId.fromString(accountId));\n tx.setTransactionId(txId);\n const receipt = await this.hwc.executeTransaction(tx, false);\n return {\n receipt,\n transactionId: txId.toString(),\n };\n }\n\n private toNumber(value?: number | Long | null): number | undefined {\n if (typeof value === 'number') {\n return value;\n }\n if (value && typeof (value as Long).toNumber === 'function') {\n return (value as Long).toNumber();\n }\n return undefined;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,52 +1,64 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const trimmed = value.trim();
|
|
7
|
-
if (!trimmed) return fallback;
|
|
8
|
-
return trimmed;
|
|
9
|
-
}
|
|
10
|
-
function buildHcs15BaseAccountCreateTx(params) {
|
|
11
|
-
const tx = new AccountCreateTransaction().setECDSAKeyWithAlias(params.publicKey).setInitialBalance(
|
|
12
|
-
params.initialBalance instanceof Hbar ? params.initialBalance : new Hbar(params.initialBalance ?? 1)
|
|
13
|
-
);
|
|
14
|
-
if (typeof params.maxAutomaticTokenAssociations === "number") {
|
|
15
|
-
tx.setMaxAutomaticTokenAssociations(params.maxAutomaticTokenAssociations);
|
|
1
|
+
import { PublicKey } from "@hashgraph/sdk";
|
|
2
|
+
import { createHash } from "crypto";
|
|
3
|
+
function sortObject(value) {
|
|
4
|
+
if (Array.isArray(value)) {
|
|
5
|
+
return value.map(sortObject);
|
|
16
6
|
}
|
|
17
|
-
if (
|
|
18
|
-
|
|
7
|
+
if (value && typeof value === "object") {
|
|
8
|
+
const entries = Object.entries(value).sort(
|
|
9
|
+
([a], [b]) => a < b ? -1 : a > b ? 1 : 0
|
|
10
|
+
);
|
|
11
|
+
const sorted = {};
|
|
12
|
+
for (const [key, val] of entries) {
|
|
13
|
+
sorted[key] = sortObject(val);
|
|
14
|
+
}
|
|
15
|
+
return sorted;
|
|
19
16
|
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
);
|
|
26
|
-
return tx;
|
|
17
|
+
return value;
|
|
18
|
+
}
|
|
19
|
+
function canonicalize(value) {
|
|
20
|
+
const sorted = sortObject(value);
|
|
21
|
+
return JSON.stringify(sorted);
|
|
27
22
|
}
|
|
28
|
-
function
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
23
|
+
function verifyDeclarationSignature(declaration, publisherPublicKey) {
|
|
24
|
+
if (!declaration.signature) {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
try {
|
|
28
|
+
const { signature, ...unsigned } = declaration;
|
|
29
|
+
const payload = canonicalize(unsigned);
|
|
30
|
+
const signatureBytes = Buffer.from(signature, "base64");
|
|
31
|
+
const publicKey = PublicKey.fromString(publisherPublicKey);
|
|
32
|
+
return publicKey.verify(Buffer.from(payload, "utf8"), signatureBytes);
|
|
33
|
+
} catch {
|
|
34
|
+
return false;
|
|
34
35
|
}
|
|
35
|
-
|
|
36
|
-
|
|
36
|
+
}
|
|
37
|
+
function verifyManifestSignature(manifest, signatureBase64, publisherPublicKey) {
|
|
38
|
+
try {
|
|
39
|
+
const payload = canonicalize(manifest);
|
|
40
|
+
const signatureBytes = Buffer.from(signatureBase64, "base64");
|
|
41
|
+
const publicKey = PublicKey.fromString(publisherPublicKey);
|
|
42
|
+
return publicKey.verify(Buffer.from(payload, "utf8"), signatureBytes);
|
|
43
|
+
} catch {
|
|
44
|
+
return false;
|
|
37
45
|
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
);
|
|
44
|
-
|
|
46
|
+
}
|
|
47
|
+
function normalizeDigest(value) {
|
|
48
|
+
return value.replace(/^sha384[-:]?/i, "").trim().toLowerCase();
|
|
49
|
+
}
|
|
50
|
+
function verifyArtifactDigest(artifact, expectedDigest) {
|
|
51
|
+
const hash = createHash("sha384");
|
|
52
|
+
hash.update(artifact);
|
|
53
|
+
const hex = hash.digest("hex").toLowerCase();
|
|
54
|
+
const base64 = Buffer.from(hex, "hex").toString("base64").toLowerCase();
|
|
55
|
+
const expected = normalizeDigest(expectedDigest);
|
|
56
|
+
return expected === hex || expected === base64;
|
|
45
57
|
}
|
|
46
58
|
export {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
59
|
+
canonicalize,
|
|
60
|
+
verifyArtifactDigest,
|
|
61
|
+
verifyDeclarationSignature,
|
|
62
|
+
verifyManifestSignature
|
|
51
63
|
};
|
|
52
64
|
//# sourceMappingURL=standards-sdk.es92.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es92.js","sources":["../../src/hcs-
|
|
1
|
+
{"version":3,"file":"standards-sdk.es92.js","sources":["../../src/hcs-21/verify.ts"],"sourcesContent":["import { PublicKey } from '@hashgraph/sdk';\nimport { createHash } from 'crypto';\nimport { AdapterDeclaration } from './types';\n\ntype JsonValue =\n | string\n | number\n | boolean\n | null\n | JsonValue[]\n | { [key: string]: JsonValue };\n\nfunction sortObject(value: JsonValue): JsonValue {\n if (Array.isArray(value)) {\n return value.map(sortObject) as JsonValue;\n }\n if (value && typeof value === 'object') {\n const entries = Object.entries(value as Record<string, JsonValue>).sort(\n ([a], [b]) => (a < b ? -1 : a > b ? 1 : 0),\n );\n const sorted: Record<string, JsonValue> = {};\n for (const [key, val] of entries) {\n sorted[key] = sortObject(val);\n }\n return sorted;\n }\n return value;\n}\n\nexport function canonicalize(value: unknown): string {\n const sorted = sortObject(value as JsonValue);\n return JSON.stringify(sorted);\n}\n\nexport function verifyDeclarationSignature(\n declaration: AdapterDeclaration,\n publisherPublicKey: string,\n): boolean {\n if (!declaration.signature) {\n return false;\n }\n try {\n const { signature, ...unsigned } = declaration;\n const payload = canonicalize(unsigned);\n const signatureBytes = Buffer.from(signature, 'base64');\n const publicKey = PublicKey.fromString(publisherPublicKey);\n return publicKey.verify(Buffer.from(payload, 'utf8'), signatureBytes);\n } catch {\n return false;\n }\n}\n\nexport function verifyManifestSignature(\n manifest: unknown,\n signatureBase64: string,\n publisherPublicKey: string,\n): boolean {\n try {\n const payload = canonicalize(manifest as JsonValue);\n const signatureBytes = Buffer.from(signatureBase64, 'base64');\n const publicKey = PublicKey.fromString(publisherPublicKey);\n return publicKey.verify(Buffer.from(payload, 'utf8'), signatureBytes);\n } catch {\n return false;\n }\n}\n\nfunction normalizeDigest(value: string): string {\n return value\n .replace(/^sha384[-:]?/i, '')\n .trim()\n .toLowerCase();\n}\n\nexport function verifyArtifactDigest(\n artifact: Buffer | Uint8Array,\n expectedDigest: string,\n): boolean {\n const hash = createHash('sha384');\n hash.update(artifact);\n const hex = hash.digest('hex').toLowerCase();\n const base64 = Buffer.from(hex, 'hex').toString('base64').toLowerCase();\n const expected = normalizeDigest(expectedDigest);\n return expected === hex || expected === base64;\n}\n"],"names":[],"mappings":";;AAYA,SAAS,WAAW,OAA6B;AAC/C,MAAI,MAAM,QAAQ,KAAK,GAAG;AACxB,WAAO,MAAM,IAAI,UAAU;AAAA,EAC7B;AACA,MAAI,SAAS,OAAO,UAAU,UAAU;AACtC,UAAM,UAAU,OAAO,QAAQ,KAAkC,EAAE;AAAA,MACjE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAO,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI;AAAA,IAAA;AAE1C,UAAM,SAAoC,CAAA;AAC1C,eAAW,CAAC,KAAK,GAAG,KAAK,SAAS;AAChC,aAAO,GAAG,IAAI,WAAW,GAAG;AAAA,IAC9B;AACA,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,SAAS,aAAa,OAAwB;AACnD,QAAM,SAAS,WAAW,KAAkB;AAC5C,SAAO,KAAK,UAAU,MAAM;AAC9B;AAEO,SAAS,2BACd,aACA,oBACS;AACT,MAAI,CAAC,YAAY,WAAW;AAC1B,WAAO;AAAA,EACT;AACA,MAAI;AACF,UAAM,EAAE,WAAW,GAAG,SAAA,IAAa;AACnC,UAAM,UAAU,aAAa,QAAQ;AACrC,UAAM,iBAAiB,OAAO,KAAK,WAAW,QAAQ;AACtD,UAAM,YAAY,UAAU,WAAW,kBAAkB;AACzD,WAAO,UAAU,OAAO,OAAO,KAAK,SAAS,MAAM,GAAG,cAAc;AAAA,EACtE,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEO,SAAS,wBACd,UACA,iBACA,oBACS;AACT,MAAI;AACF,UAAM,UAAU,aAAa,QAAqB;AAClD,UAAM,iBAAiB,OAAO,KAAK,iBAAiB,QAAQ;AAC5D,UAAM,YAAY,UAAU,WAAW,kBAAkB;AACzD,WAAO,UAAU,OAAO,OAAO,KAAK,SAAS,MAAM,GAAG,cAAc;AAAA,EACtE,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEA,SAAS,gBAAgB,OAAuB;AAC9C,SAAO,MACJ,QAAQ,iBAAiB,EAAE,EAC3B,KAAA,EACA,YAAA;AACL;AAEO,SAAS,qBACd,UACA,gBACS;AACT,QAAM,OAAO,WAAW,QAAQ;AAChC,OAAK,OAAO,QAAQ;AACpB,QAAM,MAAM,KAAK,OAAO,KAAK,EAAE,YAAA;AAC/B,QAAM,SAAS,OAAO,KAAK,KAAK,KAAK,EAAE,SAAS,QAAQ,EAAE,YAAA;AAC1D,QAAM,WAAW,gBAAgB,cAAc;AAC/C,SAAO,aAAa,OAAO,aAAa;AAC1C;"}
|