@hashgraphonline/standards-sdk 0.1.167 → 0.1.169
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/README.md +21 -7
- package/dist/browser/hcs-10/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-10/types.d.ts +3 -1
- package/dist/browser/hcs-10/types.d.ts.map +1 -1
- package/dist/browser/hcs-11/client.d.ts.map +1 -1
- package/dist/browser/hcs-11/types.d.ts +2 -1
- package/dist/browser/hcs-11/types.d.ts.map +1 -1
- package/dist/browser/hcs-12/sdk.d.ts +2 -0
- package/dist/browser/hcs-12/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-15/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-15/types.d.ts +2 -1
- package/dist/browser/hcs-15/types.d.ts.map +1 -1
- package/dist/browser/hcs-16/sdk.d.ts +2 -1
- package/dist/browser/hcs-16/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-17/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-17/types.d.ts +2 -1
- package/dist/browser/hcs-17/types.d.ts.map +1 -1
- package/dist/browser/hcs-18/sdk.d.ts +2 -1
- package/dist/browser/hcs-18/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-2/client.d.ts +2 -1
- package/dist/browser/hcs-2/client.d.ts.map +1 -1
- package/dist/browser/hcs-20/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-20/types.d.ts +2 -1
- package/dist/browser/hcs-20/types.d.ts.map +1 -1
- package/dist/browser/hcs-21/sdk.d.ts +2 -1
- package/dist/browser/hcs-21/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-27/base-client.d.ts +41 -0
- package/dist/browser/hcs-27/base-client.d.ts.map +1 -0
- package/dist/browser/hcs-27/index.d.ts +6 -0
- package/dist/browser/hcs-27/index.d.ts.map +1 -0
- package/dist/browser/hcs-27/memos.d.ts +5 -0
- package/dist/browser/hcs-27/memos.d.ts.map +1 -0
- package/dist/browser/hcs-27/merkle.d.ts +23 -0
- package/dist/browser/hcs-27/merkle.d.ts.map +1 -0
- package/dist/browser/hcs-27/sdk.d.ts +23 -0
- package/dist/browser/hcs-27/sdk.d.ts.map +1 -0
- package/dist/browser/hcs-27/types.d.ts +1611 -0
- package/dist/browser/hcs-27/types.d.ts.map +1 -0
- package/dist/browser/hcs-5/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-5/types.d.ts +2 -1
- package/dist/browser/hcs-5/types.d.ts.map +1 -1
- package/dist/browser/hcs-6/sdk.d.ts +2 -1
- package/dist/browser/hcs-6/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-7/sdk.d.ts.map +1 -1
- package/dist/browser/hcs-7/types.d.ts +2 -1
- package/dist/browser/hcs-7/types.d.ts.map +1 -1
- package/dist/browser/index.d.ts +1 -0
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/standards-sdk.browser.js +33 -8
- package/dist/browser/standards-sdk.browser.js.map +1 -1
- package/dist/browser/utils/key-type-detector.d.ts.map +1 -1
- package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-10/types.d.ts +3 -1
- package/dist/cjs/hcs-10/types.d.ts.map +1 -1
- package/dist/cjs/hcs-11/client.d.ts.map +1 -1
- package/dist/cjs/hcs-11/types.d.ts +2 -1
- package/dist/cjs/hcs-11/types.d.ts.map +1 -1
- package/dist/cjs/hcs-12/sdk.d.ts +2 -0
- package/dist/cjs/hcs-12/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-15/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-15/types.d.ts +2 -1
- package/dist/cjs/hcs-15/types.d.ts.map +1 -1
- package/dist/cjs/hcs-16/sdk.d.ts +2 -1
- package/dist/cjs/hcs-16/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-17/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-17/types.d.ts +2 -1
- package/dist/cjs/hcs-17/types.d.ts.map +1 -1
- package/dist/cjs/hcs-18/sdk.d.ts +2 -1
- package/dist/cjs/hcs-18/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-2/client.d.ts +2 -1
- package/dist/cjs/hcs-2/client.d.ts.map +1 -1
- package/dist/cjs/hcs-20/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-20/types.d.ts +2 -1
- package/dist/cjs/hcs-20/types.d.ts.map +1 -1
- package/dist/cjs/hcs-21/sdk.d.ts +2 -1
- package/dist/cjs/hcs-21/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-27/base-client.d.ts +41 -0
- package/dist/cjs/hcs-27/base-client.d.ts.map +1 -0
- package/dist/cjs/hcs-27/index.d.ts +6 -0
- package/dist/cjs/hcs-27/index.d.ts.map +1 -0
- package/dist/cjs/hcs-27/memos.d.ts +5 -0
- package/dist/cjs/hcs-27/memos.d.ts.map +1 -0
- package/dist/cjs/hcs-27/merkle.d.ts +23 -0
- package/dist/cjs/hcs-27/merkle.d.ts.map +1 -0
- package/dist/cjs/hcs-27/sdk.d.ts +23 -0
- package/dist/cjs/hcs-27/sdk.d.ts.map +1 -0
- package/dist/cjs/hcs-27/types.d.ts +1611 -0
- package/dist/cjs/hcs-27/types.d.ts.map +1 -0
- package/dist/cjs/hcs-5/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-5/types.d.ts +2 -1
- package/dist/cjs/hcs-5/types.d.ts.map +1 -1
- package/dist/cjs/hcs-6/sdk.d.ts +2 -1
- package/dist/cjs/hcs-6/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-7/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-7/types.d.ts +2 -1
- package/dist/cjs/hcs-7/types.d.ts.map +1 -1
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +2 -2
- package/dist/cjs/standards-sdk.cjs.map +1 -1
- package/dist/cjs/utils/key-type-detector.d.ts.map +1 -1
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/hcs-10/types.d.ts +3 -1
- package/dist/es/hcs-10/types.d.ts.map +1 -1
- package/dist/es/hcs-11/client.d.ts.map +1 -1
- package/dist/es/hcs-11/types.d.ts +2 -1
- package/dist/es/hcs-11/types.d.ts.map +1 -1
- package/dist/es/hcs-12/sdk.d.ts +2 -0
- package/dist/es/hcs-12/sdk.d.ts.map +1 -1
- package/dist/es/hcs-15/sdk.d.ts.map +1 -1
- package/dist/es/hcs-15/types.d.ts +2 -1
- package/dist/es/hcs-15/types.d.ts.map +1 -1
- package/dist/es/hcs-16/sdk.d.ts +2 -1
- package/dist/es/hcs-16/sdk.d.ts.map +1 -1
- package/dist/es/hcs-17/sdk.d.ts.map +1 -1
- package/dist/es/hcs-17/types.d.ts +2 -1
- package/dist/es/hcs-17/types.d.ts.map +1 -1
- package/dist/es/hcs-18/sdk.d.ts +2 -1
- package/dist/es/hcs-18/sdk.d.ts.map +1 -1
- package/dist/es/hcs-2/client.d.ts +2 -1
- package/dist/es/hcs-2/client.d.ts.map +1 -1
- package/dist/es/hcs-20/sdk.d.ts.map +1 -1
- package/dist/es/hcs-20/types.d.ts +2 -1
- package/dist/es/hcs-20/types.d.ts.map +1 -1
- package/dist/es/hcs-21/sdk.d.ts +2 -1
- package/dist/es/hcs-21/sdk.d.ts.map +1 -1
- package/dist/es/hcs-27/base-client.d.ts +41 -0
- package/dist/es/hcs-27/base-client.d.ts.map +1 -0
- package/dist/es/hcs-27/index.d.ts +6 -0
- package/dist/es/hcs-27/index.d.ts.map +1 -0
- package/dist/es/hcs-27/memos.d.ts +5 -0
- package/dist/es/hcs-27/memos.d.ts.map +1 -0
- package/dist/es/hcs-27/merkle.d.ts +23 -0
- package/dist/es/hcs-27/merkle.d.ts.map +1 -0
- package/dist/es/hcs-27/sdk.d.ts +23 -0
- package/dist/es/hcs-27/sdk.d.ts.map +1 -0
- package/dist/es/hcs-27/types.d.ts +1611 -0
- package/dist/es/hcs-27/types.d.ts.map +1 -0
- package/dist/es/hcs-5/sdk.d.ts.map +1 -1
- package/dist/es/hcs-5/types.d.ts +2 -1
- package/dist/es/hcs-5/types.d.ts.map +1 -1
- package/dist/es/hcs-6/sdk.d.ts +2 -1
- package/dist/es/hcs-6/sdk.d.ts.map +1 -1
- package/dist/es/hcs-7/sdk.d.ts.map +1 -1
- package/dist/es/hcs-7/types.d.ts +2 -1
- package/dist/es/hcs-7/types.d.ts.map +1 -1
- package/dist/es/index.d.ts +1 -0
- package/dist/es/index.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +67 -38
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es101.js +2 -2
- package/dist/es/standards-sdk.es102.js.map +1 -1
- package/dist/es/standards-sdk.es103.js +2 -2
- package/dist/es/standards-sdk.es104.js +2 -2
- package/dist/es/standards-sdk.es104.js.map +1 -1
- package/dist/es/standards-sdk.es106.js +1 -1
- package/dist/es/standards-sdk.es108.js +3 -3
- package/dist/es/standards-sdk.es108.js.map +1 -1
- package/dist/es/standards-sdk.es11.js +3 -2
- package/dist/es/standards-sdk.es11.js.map +1 -1
- package/dist/es/standards-sdk.es110.js +1 -1
- package/dist/es/standards-sdk.es111.js +2 -2
- package/dist/es/standards-sdk.es112.js +151 -234
- package/dist/es/standards-sdk.es112.js.map +1 -1
- package/dist/es/standards-sdk.es113.js +20 -471
- package/dist/es/standards-sdk.es113.js.map +1 -1
- package/dist/es/standards-sdk.es114.js +263 -104
- package/dist/es/standards-sdk.es114.js.map +1 -1
- package/dist/es/standards-sdk.es115.js +167 -138
- package/dist/es/standards-sdk.es115.js.map +1 -1
- package/dist/es/standards-sdk.es116.js +315 -29
- package/dist/es/standards-sdk.es116.js.map +1 -1
- package/dist/es/standards-sdk.es117.js +250 -10
- package/dist/es/standards-sdk.es117.js.map +1 -1
- package/dist/es/standards-sdk.es118.js +448 -152
- package/dist/es/standards-sdk.es118.js.map +1 -1
- package/dist/es/standards-sdk.es119.js +101 -25
- 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 +155 -17
- package/dist/es/standards-sdk.es120.js.map +1 -1
- package/dist/es/standards-sdk.es121.js +29 -155
- package/dist/es/standards-sdk.es121.js.map +1 -1
- package/dist/es/standards-sdk.es122.js +9 -200
- package/dist/es/standards-sdk.es122.js.map +1 -1
- package/dist/es/standards-sdk.es123.js +146 -754
- package/dist/es/standards-sdk.es123.js.map +1 -1
- package/dist/es/standards-sdk.es124.js +27 -11
- package/dist/es/standards-sdk.es124.js.map +1 -1
- package/dist/es/standards-sdk.es125.js +19 -564
- package/dist/es/standards-sdk.es125.js.map +1 -1
- package/dist/es/standards-sdk.es126.js +140 -582
- package/dist/es/standards-sdk.es126.js.map +1 -1
- package/dist/es/standards-sdk.es127.js +202 -12
- package/dist/es/standards-sdk.es127.js.map +1 -1
- package/dist/es/standards-sdk.es128.js +790 -2
- package/dist/es/standards-sdk.es128.js.map +1 -1
- package/dist/es/standards-sdk.es129.js +10 -84
- 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 +567 -40
- package/dist/es/standards-sdk.es130.js.map +1 -1
- package/dist/es/standards-sdk.es131.js +626 -2
- package/dist/es/standards-sdk.es131.js.map +1 -1
- package/dist/es/standards-sdk.es132.js +12 -234
- package/dist/es/standards-sdk.es132.js.map +1 -1
- package/dist/es/standards-sdk.es133.js +2 -1140
- package/dist/es/standards-sdk.es133.js.map +1 -1
- package/dist/es/standards-sdk.es134.js +73 -292
- package/dist/es/standards-sdk.es134.js.map +1 -1
- package/dist/es/standards-sdk.es135.js +36 -418
- package/dist/es/standards-sdk.es135.js.map +1 -1
- package/dist/es/standards-sdk.es136.js +2 -355
- package/dist/es/standards-sdk.es136.js.map +1 -1
- package/dist/es/standards-sdk.es137.js +198 -1079
- package/dist/es/standards-sdk.es137.js.map +1 -1
- package/dist/es/standards-sdk.es138.js +1107 -175
- package/dist/es/standards-sdk.es138.js.map +1 -1
- package/dist/es/standards-sdk.es139.js +218 -1479
- 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 +422 -1500
- package/dist/es/standards-sdk.es140.js.map +1 -1
- package/dist/es/standards-sdk.es141.js +351 -13
- package/dist/es/standards-sdk.es141.js.map +1 -1
- package/dist/es/standards-sdk.es142.js +1102 -73
- package/dist/es/standards-sdk.es142.js.map +1 -1
- package/dist/es/standards-sdk.es143.js +203 -76
- package/dist/es/standards-sdk.es143.js.map +1 -1
- package/dist/es/standards-sdk.es144.js +1459 -830
- package/dist/es/standards-sdk.es144.js.map +1 -1
- package/dist/es/standards-sdk.es145.js +1499 -59
- package/dist/es/standards-sdk.es145.js.map +1 -1
- package/dist/es/standards-sdk.es146.js +14 -156
- package/dist/es/standards-sdk.es146.js.map +1 -1
- package/dist/es/standards-sdk.es147.js +87 -7
- package/dist/es/standards-sdk.es147.js.map +1 -1
- package/dist/es/standards-sdk.es148.js +74 -79
- package/dist/es/standards-sdk.es148.js.map +1 -1
- package/dist/es/standards-sdk.es149.js +934 -61
- 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 +60 -30
- package/dist/es/standards-sdk.es150.js.map +1 -1
- package/dist/es/standards-sdk.es151.js +159 -34
- package/dist/es/standards-sdk.es151.js.map +1 -1
- package/dist/es/standards-sdk.es152.js +7 -48
- package/dist/es/standards-sdk.es152.js.map +1 -1
- package/dist/es/standards-sdk.es153.js +70 -122
- package/dist/es/standards-sdk.es153.js.map +1 -1
- package/dist/es/standards-sdk.es154.js +58 -35
- package/dist/es/standards-sdk.es154.js.map +1 -1
- package/dist/es/standards-sdk.es155.js +30 -12482
- package/dist/es/standards-sdk.es155.js.map +1 -1
- package/dist/es/standards-sdk.es156.js +34 -56
- package/dist/es/standards-sdk.es156.js.map +1 -1
- package/dist/es/standards-sdk.es157.js +48 -84
- package/dist/es/standards-sdk.es157.js.map +1 -1
- package/dist/es/standards-sdk.es158.js +128 -71
- package/dist/es/standards-sdk.es158.js.map +1 -1
- package/dist/es/standards-sdk.es159.js +33 -191
- 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 +12477 -12
- package/dist/es/standards-sdk.es160.js.map +1 -1
- package/dist/es/standards-sdk.es161.js +15 -548
- package/dist/es/standards-sdk.es161.js.map +1 -1
- package/dist/es/standards-sdk.es162.js +51 -167
- package/dist/es/standards-sdk.es162.js.map +1 -1
- package/dist/es/standards-sdk.es163.js +70 -308
- package/dist/es/standards-sdk.es163.js.map +1 -1
- package/dist/es/standards-sdk.es164.js +71 -336
- package/dist/es/standards-sdk.es164.js.map +1 -1
- package/dist/es/standards-sdk.es165.js +186 -439
- package/dist/es/standards-sdk.es165.js.map +1 -1
- package/dist/es/standards-sdk.es166.js +537 -318
- package/dist/es/standards-sdk.es166.js.map +1 -1
- package/dist/es/standards-sdk.es167.js +63 -66
- package/dist/es/standards-sdk.es167.js.map +1 -1
- package/dist/es/standards-sdk.es168.js +165 -66
- package/dist/es/standards-sdk.es168.js.map +1 -1
- package/dist/es/standards-sdk.es169.js +310 -160
- package/dist/es/standards-sdk.es169.js.map +1 -1
- package/dist/es/standards-sdk.es170.js +336 -212
- package/dist/es/standards-sdk.es170.js.map +1 -1
- package/dist/es/standards-sdk.es171.js +437 -223
- package/dist/es/standards-sdk.es171.js.map +1 -1
- package/dist/es/standards-sdk.es172.js +324 -112
- package/dist/es/standards-sdk.es172.js.map +1 -1
- package/dist/es/standards-sdk.es173.js +65 -115
- package/dist/es/standards-sdk.es173.js.map +1 -1
- package/dist/es/standards-sdk.es174.js +151 -140
- package/dist/es/standards-sdk.es174.js.map +1 -1
- package/dist/es/standards-sdk.es175.js +193 -156
- package/dist/es/standards-sdk.es175.js.map +1 -1
- package/dist/es/standards-sdk.es176.js +221 -121
- package/dist/es/standards-sdk.es176.js.map +1 -1
- package/dist/es/standards-sdk.es177.js +81 -293
- package/dist/es/standards-sdk.es177.js.map +1 -1
- package/dist/es/standards-sdk.es178.js +114 -247
- package/dist/es/standards-sdk.es178.js.map +1 -1
- package/dist/es/standards-sdk.es179.js +119 -110
- package/dist/es/standards-sdk.es179.js.map +1 -1
- package/dist/es/standards-sdk.es18.js +15 -14
- package/dist/es/standards-sdk.es18.js.map +1 -1
- package/dist/es/standards-sdk.es180.js +188 -0
- package/dist/es/standards-sdk.es180.js.map +1 -0
- package/dist/es/standards-sdk.es181.js +142 -0
- package/dist/es/standards-sdk.es181.js.map +1 -0
- package/dist/es/standards-sdk.es182.js +334 -0
- package/dist/es/standards-sdk.es182.js.map +1 -0
- package/dist/es/standards-sdk.es183.js +262 -0
- package/dist/es/standards-sdk.es183.js.map +1 -0
- package/dist/es/standards-sdk.es184.js +155 -0
- package/dist/es/standards-sdk.es184.js.map +1 -0
- 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 +13 -13
- package/dist/es/standards-sdk.es27.js.map +1 -1
- package/dist/es/standards-sdk.es28.js.map +1 -1
- 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 +5 -5
- package/dist/es/standards-sdk.es36.js.map +1 -1
- 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 +3 -3
- package/dist/es/standards-sdk.es4.js.map +1 -1
- 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.es59.js +1 -1
- package/dist/es/standards-sdk.es6.js +2 -2
- package/dist/es/standards-sdk.es60.js +1 -1
- package/dist/es/standards-sdk.es62.js +1 -1
- package/dist/es/standards-sdk.es63.js +2 -2
- package/dist/es/standards-sdk.es64.js +1 -1
- package/dist/es/standards-sdk.es65.js +1 -1
- package/dist/es/standards-sdk.es66.js +1 -1
- package/dist/es/standards-sdk.es67.js +7 -7
- package/dist/es/standards-sdk.es69.js +1 -1
- package/dist/es/standards-sdk.es7.js +1 -1
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +2 -2
- package/dist/es/standards-sdk.es72.js +5 -4
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +6 -6
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +3 -3
- package/dist/es/standards-sdk.es77.js +2 -2
- package/dist/es/standards-sdk.es78.js +1 -1
- package/dist/es/standards-sdk.es79.js.map +1 -1
- package/dist/es/standards-sdk.es8.js.map +1 -1
- package/dist/es/standards-sdk.es81.js +2 -2
- package/dist/es/standards-sdk.es83.js +7 -5
- package/dist/es/standards-sdk.es83.js.map +1 -1
- package/dist/es/standards-sdk.es84.js +4 -4
- package/dist/es/standards-sdk.es85.js +1 -1
- package/dist/es/standards-sdk.es88.js +1 -1
- package/dist/es/standards-sdk.es89.js +2 -2
- package/dist/es/standards-sdk.es9.js +2 -2
- package/dist/es/standards-sdk.es90.js +5 -5
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +4 -4
- package/dist/es/standards-sdk.es94.js.map +1 -1
- package/dist/es/standards-sdk.es96.js +2 -2
- package/dist/es/standards-sdk.es98.js +1 -1
- package/dist/es/standards-sdk.es99.js +4 -4
- package/dist/es/standards-sdk.es99.js.map +1 -1
- package/dist/es/utils/key-type-detector.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,163 +1,37 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
static getInstance(options = {}) {
|
|
18
|
-
if (!ProgressReporter.instance) {
|
|
19
|
-
ProgressReporter.instance = new ProgressReporter(options);
|
|
20
|
-
} else {
|
|
21
|
-
if (options.callback) {
|
|
22
|
-
ProgressReporter.instance.setCallback(options.callback);
|
|
23
|
-
}
|
|
24
|
-
if (options.module) {
|
|
25
|
-
ProgressReporter.instance.setModule(options.module);
|
|
26
|
-
}
|
|
27
|
-
if (options.logger) {
|
|
28
|
-
ProgressReporter.instance.setLogger(options.logger);
|
|
29
|
-
}
|
|
30
|
-
if (options.minPercent !== void 0) {
|
|
31
|
-
ProgressReporter.instance.setMinPercent(options.minPercent);
|
|
32
|
-
}
|
|
33
|
-
if (options.maxPercent !== void 0) {
|
|
34
|
-
ProgressReporter.instance.setMaxPercent(options.maxPercent);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return ProgressReporter.instance;
|
|
38
|
-
}
|
|
39
|
-
setCallback(callback) {
|
|
40
|
-
this.callback = callback;
|
|
41
|
-
}
|
|
42
|
-
setModule(module) {
|
|
43
|
-
this.module = module;
|
|
44
|
-
}
|
|
45
|
-
setLogger(logger) {
|
|
46
|
-
this.logger = logger;
|
|
47
|
-
}
|
|
48
|
-
setMinPercent(minPercent) {
|
|
49
|
-
this.minPercent = minPercent;
|
|
50
|
-
}
|
|
51
|
-
setMaxPercent(maxPercent) {
|
|
52
|
-
this.maxPercent = maxPercent;
|
|
53
|
-
}
|
|
54
|
-
createSubProgress(options) {
|
|
55
|
-
const subReporter = new ProgressReporter({
|
|
56
|
-
module: this.module,
|
|
57
|
-
logger: this.logger,
|
|
58
|
-
logProgress: this.logProgress,
|
|
59
|
-
minPercent: options.minPercent,
|
|
60
|
-
maxPercent: options.maxPercent
|
|
61
|
-
});
|
|
62
|
-
const logPrefix = options.logPrefix || "";
|
|
63
|
-
subReporter.setCallback((data) => {
|
|
64
|
-
const scaledPercent = this.scalePercent(
|
|
65
|
-
data.progressPercent,
|
|
66
|
-
options.minPercent,
|
|
67
|
-
options.maxPercent
|
|
68
|
-
);
|
|
69
|
-
let formattedMessage = data.message;
|
|
70
|
-
if (logPrefix && !formattedMessage.startsWith(logPrefix)) {
|
|
71
|
-
formattedMessage = `${logPrefix}: ${formattedMessage}`;
|
|
72
|
-
}
|
|
73
|
-
this.report({
|
|
74
|
-
stage: data.stage,
|
|
75
|
-
message: formattedMessage,
|
|
76
|
-
progressPercent: scaledPercent,
|
|
77
|
-
details: data.details
|
|
1
|
+
import { getSkillVerificationStatus } from "./standards-sdk.es166.js";
|
|
2
|
+
import { HCS26BaseClient } from "./standards-sdk.es120.js";
|
|
3
|
+
function mapVerification(status) {
|
|
4
|
+
const pendingRequest = status.pendingRequest ?? void 0;
|
|
5
|
+
return {
|
|
6
|
+
name: status.name,
|
|
7
|
+
verified: status.verified,
|
|
8
|
+
previouslyVerified: status.previouslyVerified,
|
|
9
|
+
...pendingRequest ? { pendingRequest } : {}
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
function createRegistryBrokerVerificationProvider(client) {
|
|
13
|
+
return {
|
|
14
|
+
async getSkillVerificationStatus(params) {
|
|
15
|
+
const status = await getSkillVerificationStatus(client, {
|
|
16
|
+
name: params.name
|
|
78
17
|
});
|
|
79
|
-
|
|
80
|
-
return subReporter;
|
|
81
|
-
}
|
|
82
|
-
report(data) {
|
|
83
|
-
const rawPercent = data.progressPercent;
|
|
84
|
-
const percent = Math.max(0, Math.min(100, rawPercent));
|
|
85
|
-
const scaledPercent = this.scalePercent(percent, 0, 100);
|
|
86
|
-
const now = Date.now();
|
|
87
|
-
if (scaledPercent === this.lastReportedPercent && now - this.lastReportedTime < this.throttleMs && data.stage !== "completed" && data.stage !== "failed") {
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
this.lastReportedPercent = scaledPercent;
|
|
91
|
-
this.lastReportedTime = now;
|
|
92
|
-
const progressData = {
|
|
93
|
-
...data,
|
|
94
|
-
progressPercent: scaledPercent
|
|
95
|
-
};
|
|
96
|
-
if (this.logProgress) {
|
|
97
|
-
this.logger.debug(
|
|
98
|
-
`[${this.module}] [${data.stage.toUpperCase()}] ${data.message} (${scaledPercent.toFixed(1)}%)`,
|
|
99
|
-
data.details
|
|
100
|
-
);
|
|
18
|
+
return mapVerification(status);
|
|
101
19
|
}
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
const sourceRange = sourceMax - sourceMin;
|
|
113
|
-
const scaleFactor = range / sourceRange;
|
|
114
|
-
return this.minPercent + (percent - sourceMin) * scaleFactor;
|
|
115
|
-
}
|
|
116
|
-
preparing(message, percent, details) {
|
|
117
|
-
this.report({
|
|
118
|
-
stage: "preparing",
|
|
119
|
-
message,
|
|
120
|
-
progressPercent: percent,
|
|
121
|
-
details
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
submitting(message, percent, details) {
|
|
125
|
-
this.report({
|
|
126
|
-
stage: "submitting",
|
|
127
|
-
message,
|
|
128
|
-
progressPercent: percent,
|
|
129
|
-
details
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
confirming(message, percent, details) {
|
|
133
|
-
this.report({
|
|
134
|
-
stage: "confirming",
|
|
135
|
-
message,
|
|
136
|
-
progressPercent: percent,
|
|
137
|
-
details
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
verifying(message, percent, details) {
|
|
141
|
-
this.report({
|
|
142
|
-
stage: "verifying",
|
|
143
|
-
message,
|
|
144
|
-
progressPercent: percent,
|
|
145
|
-
details
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
completed(message, details) {
|
|
149
|
-
this.report({ stage: "completed", message, progressPercent: 100, details });
|
|
150
|
-
}
|
|
151
|
-
failed(message, details) {
|
|
152
|
-
this.report({
|
|
153
|
-
stage: "failed",
|
|
154
|
-
message,
|
|
155
|
-
progressPercent: this.lastReportedPercent,
|
|
156
|
-
details
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
class HCS26Client extends HCS26BaseClient {
|
|
23
|
+
constructor(config) {
|
|
24
|
+
const provider = config.verificationProvider ?? (config.registryBrokerClient ? createRegistryBrokerVerificationProvider(config.registryBrokerClient) : void 0);
|
|
25
|
+
super({
|
|
26
|
+
network: config.network,
|
|
27
|
+
logger: config.logger,
|
|
28
|
+
mirrorNode: config.mirrorNode,
|
|
29
|
+
verificationProvider: provider
|
|
157
30
|
});
|
|
158
31
|
}
|
|
159
32
|
}
|
|
160
33
|
export {
|
|
161
|
-
|
|
34
|
+
HCS26Client,
|
|
35
|
+
createRegistryBrokerVerificationProvider
|
|
162
36
|
};
|
|
163
37
|
//# sourceMappingURL=standards-sdk.es121.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es121.js","sources":["../../src/
|
|
1
|
+
{"version":3,"file":"standards-sdk.es121.js","sources":["../../src/hcs-26/sdk.ts"],"sourcesContent":["import type { RegistryBrokerClient } from '../services/registry-broker/client/base-client';\nimport { getSkillVerificationStatus } from '../services/registry-broker/client/skills';\nimport type { SkillVerificationStatusResponse } from '../services/registry-broker/types';\nimport {\n HCS26BaseClient,\n type HCS26ClientConfig,\n type HCS26SkillVerificationProvider,\n type HCS26SkillVerificationStatus,\n} from './base-client';\n\nexport interface SDKHCS26ClientConfig extends HCS26ClientConfig {\n registryBrokerClient?: RegistryBrokerClient;\n}\n\nfunction mapVerification(\n status: SkillVerificationStatusResponse,\n): HCS26SkillVerificationStatus {\n const pendingRequest = status.pendingRequest ?? undefined;\n return {\n name: status.name,\n verified: status.verified,\n previouslyVerified: status.previouslyVerified,\n ...(pendingRequest ? { pendingRequest } : {}),\n };\n}\n\nexport function createRegistryBrokerVerificationProvider(\n client: RegistryBrokerClient,\n): HCS26SkillVerificationProvider {\n return {\n async getSkillVerificationStatus(params: { name: string }) {\n const status = await getSkillVerificationStatus(client, {\n name: params.name,\n });\n return mapVerification(status);\n },\n };\n}\n\nexport class HCS26Client extends HCS26BaseClient {\n constructor(config: SDKHCS26ClientConfig) {\n const provider =\n config.verificationProvider ??\n (config.registryBrokerClient\n ? createRegistryBrokerVerificationProvider(config.registryBrokerClient)\n : undefined);\n\n super({\n network: config.network,\n logger: config.logger,\n mirrorNode: config.mirrorNode,\n verificationProvider: provider,\n });\n }\n}\n"],"names":[],"mappings":";;AAcA,SAAS,gBACP,QAC8B;AAC9B,QAAM,iBAAiB,OAAO,kBAAkB;AAChD,SAAO;AAAA,IACL,MAAM,OAAO;AAAA,IACb,UAAU,OAAO;AAAA,IACjB,oBAAoB,OAAO;AAAA,IAC3B,GAAI,iBAAiB,EAAE,mBAAmB,CAAA;AAAA,EAAC;AAE/C;AAEO,SAAS,yCACd,QACgC;AAChC,SAAO;AAAA,IACL,MAAM,2BAA2B,QAA0B;AACzD,YAAM,SAAS,MAAM,2BAA2B,QAAQ;AAAA,QACtD,MAAM,OAAO;AAAA,MAAA,CACd;AACD,aAAO,gBAAgB,MAAM;AAAA,IAC/B;AAAA,EAAA;AAEJ;AAEO,MAAM,oBAAoB,gBAAgB;AAAA,EAC/C,YAAY,QAA8B;AACxC,UAAM,WACJ,OAAO,yBACN,OAAO,uBACJ,yCAAyC,OAAO,oBAAoB,IACpE;AAEN,UAAM;AAAA,MACJ,SAAS,OAAO;AAAA,MAChB,QAAQ,OAAO;AAAA,MACf,YAAY,OAAO;AAAA,MACnB,sBAAsB;AAAA,IAAA,CACvB;AAAA,EACH;AACF;"}
|
|
@@ -1,206 +1,15 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
import "./standards-sdk.es142.js";
|
|
10
|
-
import "zod";
|
|
11
|
-
class HRLResolver {
|
|
12
|
-
constructor(logLevel = "info") {
|
|
13
|
-
this.defaultEndpoint = "https://kiloscribe.com/api/inscription-cdn";
|
|
14
|
-
this.logger = Logger.getInstance({
|
|
15
|
-
level: logLevel,
|
|
16
|
-
module: "HRLResolver"
|
|
1
|
+
import { HCS26BaseClient } from "./standards-sdk.es120.js";
|
|
2
|
+
class HCS26BrowserClient extends HCS26BaseClient {
|
|
3
|
+
constructor(config) {
|
|
4
|
+
super({
|
|
5
|
+
network: config.network,
|
|
6
|
+
logger: config.logger,
|
|
7
|
+
mirrorNode: config.mirrorNode,
|
|
8
|
+
verificationProvider: config.verificationProvider
|
|
17
9
|
});
|
|
18
10
|
}
|
|
19
|
-
/**
|
|
20
|
-
* Determines if a MIME type represents binary content
|
|
21
|
-
*/
|
|
22
|
-
isBinaryContentType(mimeType) {
|
|
23
|
-
const binaryTypes = [
|
|
24
|
-
"image/",
|
|
25
|
-
"audio/",
|
|
26
|
-
"video/",
|
|
27
|
-
"application/octet-stream",
|
|
28
|
-
"application/pdf",
|
|
29
|
-
"application/zip",
|
|
30
|
-
"application/gzip",
|
|
31
|
-
"application/x-binary",
|
|
32
|
-
"application/vnd.ms-",
|
|
33
|
-
"application/x-msdownload",
|
|
34
|
-
"application/x-shockwave-flash",
|
|
35
|
-
"font/",
|
|
36
|
-
"application/wasm"
|
|
37
|
-
];
|
|
38
|
-
return binaryTypes.some((prefix) => mimeType.startsWith(prefix));
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Parses an HRL string into its components
|
|
42
|
-
*/
|
|
43
|
-
parseHRL(hrl) {
|
|
44
|
-
if (!hrl) {
|
|
45
|
-
return null;
|
|
46
|
-
}
|
|
47
|
-
const hrlPattern = /^hcs:\/\/(\d+)\/([0-9]+\.[0-9]+\.[0-9]+)$/;
|
|
48
|
-
const match = hrl.match(hrlPattern);
|
|
49
|
-
if (!match) {
|
|
50
|
-
return null;
|
|
51
|
-
}
|
|
52
|
-
return {
|
|
53
|
-
standard: match[1],
|
|
54
|
-
topicId: match[2]
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
/**
|
|
58
|
-
* Validates if a string is a valid HRL
|
|
59
|
-
*/
|
|
60
|
-
isValidHRL(hrl) {
|
|
61
|
-
if (!hrl || typeof hrl !== "string") {
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
const parsed = this.parseHRL(hrl);
|
|
65
|
-
if (!parsed) {
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
const topicIdPattern = /^[0-9]+\.[0-9]+\.[0-9]+$/;
|
|
69
|
-
if (!topicIdPattern.test(parsed.topicId)) {
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
return true;
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* Validates if a string is a valid topic ID
|
|
76
|
-
*/
|
|
77
|
-
isValidTopicId(topicId) {
|
|
78
|
-
const topicIdPattern = /^[0-9]+\.[0-9]+\.[0-9]+$/;
|
|
79
|
-
return topicIdPattern.test(topicId);
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* Resolves content from either an HRL or a topic ID
|
|
83
|
-
* If a topic ID is provided, it queries the topic memo to determine the HCS standard
|
|
84
|
-
*/
|
|
85
|
-
async resolve(hrlOrTopicId, options) {
|
|
86
|
-
if (this.isValidHRL(hrlOrTopicId)) {
|
|
87
|
-
return this.resolveHRL(hrlOrTopicId, options);
|
|
88
|
-
}
|
|
89
|
-
if (!this.isValidTopicId(hrlOrTopicId)) {
|
|
90
|
-
throw new Error(`Invalid HRL or topic ID format: ${hrlOrTopicId}`);
|
|
91
|
-
}
|
|
92
|
-
try {
|
|
93
|
-
const mirrorNode = new HederaMirrorNode(options.network, this.logger);
|
|
94
|
-
const topicInfo = await mirrorNode.getTopicInfo(hrlOrTopicId);
|
|
95
|
-
const memo = topicInfo?.memo || "";
|
|
96
|
-
let standard = "1";
|
|
97
|
-
if (memo) {
|
|
98
|
-
const hcsMatch = memo.match(/^hcs-(\d+)/);
|
|
99
|
-
if (hcsMatch && hcsMatch[1]) {
|
|
100
|
-
standard = hcsMatch[1];
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
const hrl = `hcs://${standard}/${hrlOrTopicId}`;
|
|
104
|
-
return this.resolveHRL(hrl, options);
|
|
105
|
-
} catch (error) {
|
|
106
|
-
this.logger.error(
|
|
107
|
-
`Failed to get topic info for ${hrlOrTopicId}: ${error.message}`
|
|
108
|
-
);
|
|
109
|
-
const hrl = `hcs://1/${hrlOrTopicId}`;
|
|
110
|
-
return this.resolveHRL(hrl, options);
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
async getContentWithType(hrl, options) {
|
|
114
|
-
if (!this.isValidHRL(hrl)) {
|
|
115
|
-
return {
|
|
116
|
-
content: hrl,
|
|
117
|
-
contentType: "text/plain",
|
|
118
|
-
isBinary: false
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
try {
|
|
122
|
-
const result = await this.resolveHRL(hrl, options);
|
|
123
|
-
return {
|
|
124
|
-
content: result.content,
|
|
125
|
-
contentType: result.contentType,
|
|
126
|
-
isBinary: result.isBinary
|
|
127
|
-
};
|
|
128
|
-
} catch (e) {
|
|
129
|
-
const error = e;
|
|
130
|
-
const logMessage = `Error resolving HRL for content and type: ${error.message}`;
|
|
131
|
-
this.logger.error(logMessage);
|
|
132
|
-
throw new Error(logMessage);
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* Resolves HRL content with proper content type detection
|
|
137
|
-
*/
|
|
138
|
-
async resolveHRL(hrl, options) {
|
|
139
|
-
const parsed = this.parseHRL(hrl);
|
|
140
|
-
if (!parsed) {
|
|
141
|
-
throw new Error(`Invalid HRL format: ${hrl}`);
|
|
142
|
-
}
|
|
143
|
-
const { standard, topicId } = parsed;
|
|
144
|
-
this.logger.debug(
|
|
145
|
-
`Resolving HRL reference: standard=${standard}, topicId=${topicId}`
|
|
146
|
-
);
|
|
147
|
-
try {
|
|
148
|
-
const cdnEndpoint = options.cdnEndpoint || this.defaultEndpoint;
|
|
149
|
-
const cdnUrl = `${cdnEndpoint}/${topicId}?network=${options.network}`;
|
|
150
|
-
this.logger.debug(`Fetching content from CDN: ${cdnUrl}`);
|
|
151
|
-
const headResponse = await axios.head(cdnUrl);
|
|
152
|
-
const contentType = headResponse.headers["content-type"] || "";
|
|
153
|
-
const isBinary = this.isBinaryContentType(contentType);
|
|
154
|
-
if (isBinary || options.returnRaw) {
|
|
155
|
-
const response2 = await axios.get(cdnUrl, {
|
|
156
|
-
responseType: "arraybuffer"
|
|
157
|
-
});
|
|
158
|
-
return {
|
|
159
|
-
content: response2.data,
|
|
160
|
-
contentType,
|
|
161
|
-
topicId,
|
|
162
|
-
isBinary: true
|
|
163
|
-
};
|
|
164
|
-
}
|
|
165
|
-
if (contentType === "application/json") {
|
|
166
|
-
const response2 = await axios.get(cdnUrl, {
|
|
167
|
-
responseType: "json"
|
|
168
|
-
});
|
|
169
|
-
if (!response2.data) {
|
|
170
|
-
throw new Error(`Failed to fetch content from topic: ${topicId}`);
|
|
171
|
-
}
|
|
172
|
-
return {
|
|
173
|
-
content: response2.data,
|
|
174
|
-
contentType,
|
|
175
|
-
topicId,
|
|
176
|
-
isBinary: false
|
|
177
|
-
};
|
|
178
|
-
}
|
|
179
|
-
const response = await axios.get(cdnUrl);
|
|
180
|
-
if (!response.data) {
|
|
181
|
-
throw new Error(`Failed to fetch content from topic: ${topicId}`);
|
|
182
|
-
}
|
|
183
|
-
let content;
|
|
184
|
-
if (typeof response.data === "object") {
|
|
185
|
-
content = response.data.content || response.data.text || JSON.stringify(response.data);
|
|
186
|
-
} else {
|
|
187
|
-
content = response.data;
|
|
188
|
-
}
|
|
189
|
-
return {
|
|
190
|
-
content,
|
|
191
|
-
contentType,
|
|
192
|
-
topicId,
|
|
193
|
-
isBinary: false
|
|
194
|
-
};
|
|
195
|
-
} catch (e) {
|
|
196
|
-
const error = e;
|
|
197
|
-
const logMessage = `Error resolving HRL reference: ${error.message}`;
|
|
198
|
-
this.logger.error(logMessage);
|
|
199
|
-
throw new Error(logMessage);
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
11
|
}
|
|
203
12
|
export {
|
|
204
|
-
|
|
13
|
+
HCS26BrowserClient
|
|
205
14
|
};
|
|
206
15
|
//# sourceMappingURL=standards-sdk.es122.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es122.js","sources":["../../src/utils/hrl-resolver.ts"],"sourcesContent":["import axios from 'axios';\nimport { Logger, LogLevel, ILogger } from './logger';\nimport { NetworkType } from './types';\nimport { HederaMirrorNode } from '../services';\n\n/**\n * Options for HRL resolution\n */\nexport interface HRLResolutionOptions {\n network: NetworkType;\n returnRaw?: boolean;\n cdnEndpoint?: string;\n}\n\n/**\n * Result of an HRL resolution operation\n */\nexport interface HRLResolutionResult {\n content: string | ArrayBuffer;\n contentType: string;\n topicId: string;\n isBinary: boolean;\n}\n\nexport interface ContentWithType {\n content: string | ArrayBuffer;\n contentType: string;\n isBinary: boolean;\n}\n\n/**\n * Utility class for resolving Hedera Resource Locators across the SDK\n */\nexport class HRLResolver {\n private logger: ILogger;\n private defaultEndpoint = 'https://kiloscribe.com/api/inscription-cdn';\n\n constructor(logLevel: LogLevel = 'info') {\n this.logger = Logger.getInstance({\n level: logLevel,\n module: 'HRLResolver',\n });\n }\n\n /**\n * Determines if a MIME type represents binary content\n */\n private isBinaryContentType(mimeType: string): boolean {\n const binaryTypes = [\n 'image/',\n 'audio/',\n 'video/',\n 'application/octet-stream',\n 'application/pdf',\n 'application/zip',\n 'application/gzip',\n 'application/x-binary',\n 'application/vnd.ms-',\n 'application/x-msdownload',\n 'application/x-shockwave-flash',\n 'font/',\n 'application/wasm',\n ];\n\n return binaryTypes.some(prefix => mimeType.startsWith(prefix));\n }\n\n /**\n * Parses an HRL string into its components\n */\n public parseHRL(hrl: string): { standard: string; topicId: string } | null {\n if (!hrl) {\n return null;\n }\n\n const hrlPattern = /^hcs:\\/\\/(\\d+)\\/([0-9]+\\.[0-9]+\\.[0-9]+)$/;\n const match = hrl.match(hrlPattern);\n\n if (!match) {\n return null;\n }\n\n return {\n standard: match[1],\n topicId: match[2],\n };\n }\n\n /**\n * Validates if a string is a valid HRL\n */\n public isValidHRL(hrl: string): boolean {\n if (!hrl || typeof hrl !== 'string') {\n return false;\n }\n\n const parsed = this.parseHRL(hrl);\n if (!parsed) {\n return false;\n }\n\n const topicIdPattern = /^[0-9]+\\.[0-9]+\\.[0-9]+$/;\n if (!topicIdPattern.test(parsed.topicId)) {\n return false;\n }\n\n return true;\n }\n\n /**\n * Validates if a string is a valid topic ID\n */\n public isValidTopicId(topicId: string): boolean {\n const topicIdPattern = /^[0-9]+\\.[0-9]+\\.[0-9]+$/;\n return topicIdPattern.test(topicId);\n }\n\n /**\n * Resolves content from either an HRL or a topic ID\n * If a topic ID is provided, it queries the topic memo to determine the HCS standard\n */\n public async resolve(\n hrlOrTopicId: string,\n options: HRLResolutionOptions,\n ): Promise<HRLResolutionResult> {\n if (this.isValidHRL(hrlOrTopicId)) {\n return this.resolveHRL(hrlOrTopicId, options);\n }\n\n if (!this.isValidTopicId(hrlOrTopicId)) {\n throw new Error(`Invalid HRL or topic ID format: ${hrlOrTopicId}`);\n }\n\n try {\n const mirrorNode = new HederaMirrorNode(options.network, this.logger);\n const topicInfo = await mirrorNode.getTopicInfo(hrlOrTopicId);\n const memo = topicInfo?.memo || '';\n\n let standard = '1';\n if (memo) {\n const hcsMatch = memo.match(/^hcs-(\\d+)/);\n if (hcsMatch && hcsMatch[1]) {\n standard = hcsMatch[1];\n }\n }\n\n const hrl = `hcs://${standard}/${hrlOrTopicId}`;\n return this.resolveHRL(hrl, options);\n } catch (error: any) {\n this.logger.error(\n `Failed to get topic info for ${hrlOrTopicId}: ${error.message}`,\n );\n const hrl = `hcs://1/${hrlOrTopicId}`;\n return this.resolveHRL(hrl, options);\n }\n }\n\n public async getContentWithType(\n hrl: string,\n options: HRLResolutionOptions,\n ): Promise<ContentWithType> {\n if (!this.isValidHRL(hrl)) {\n return {\n content: hrl,\n contentType: 'text/plain',\n isBinary: false,\n };\n }\n\n try {\n const result = await this.resolveHRL(hrl, options);\n return {\n content: result.content,\n contentType: result.contentType,\n isBinary: result.isBinary,\n };\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error resolving HRL for content and type: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Resolves HRL content with proper content type detection\n */\n public async resolveHRL(\n hrl: string,\n options: HRLResolutionOptions,\n ): Promise<HRLResolutionResult> {\n const parsed = this.parseHRL(hrl);\n\n if (!parsed) {\n throw new Error(`Invalid HRL format: ${hrl}`);\n }\n\n const { standard, topicId } = parsed;\n\n this.logger.debug(\n `Resolving HRL reference: standard=${standard}, topicId=${topicId}`,\n );\n\n try {\n const cdnEndpoint = options.cdnEndpoint || this.defaultEndpoint;\n const cdnUrl = `${cdnEndpoint}/${topicId}?network=${options.network}`;\n\n this.logger.debug(`Fetching content from CDN: ${cdnUrl}`);\n const headResponse = await axios.head(cdnUrl);\n const contentType = headResponse.headers['content-type'] || '';\n const isBinary = this.isBinaryContentType(contentType);\n\n if (isBinary || options.returnRaw) {\n const response = await axios.get(cdnUrl, {\n responseType: 'arraybuffer',\n });\n\n return {\n content: response.data,\n contentType,\n topicId,\n isBinary: true,\n };\n }\n\n if (contentType === 'application/json') {\n const response = await axios.get(cdnUrl, {\n responseType: 'json',\n });\n\n if (!response.data) {\n throw new Error(`Failed to fetch content from topic: ${topicId}`);\n }\n\n return {\n content: response.data,\n contentType,\n topicId,\n isBinary: false,\n };\n }\n\n const response = await axios.get(cdnUrl);\n\n if (!response.data) {\n throw new Error(`Failed to fetch content from topic: ${topicId}`);\n }\n\n let content: string;\n\n if (typeof response.data === 'object') {\n content =\n response.data.content ||\n response.data.text ||\n JSON.stringify(response.data);\n } else {\n content = response.data;\n }\n\n return {\n content,\n contentType,\n topicId,\n isBinary: false,\n };\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error resolving HRL reference: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n}\n"],"names":["response"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es122.js","sources":["../../src/hcs-26/browser.ts"],"sourcesContent":["import type { ILogger } from '../utils/logger';\nimport type { NetworkType } from '../utils/types';\nimport { HCS26BaseClient, type HCS26ClientConfig } from './base-client';\n\nexport interface BrowserHCS26ClientConfig\n extends Omit<HCS26ClientConfig, 'network' | 'logger'> {\n network: NetworkType;\n logger?: ILogger;\n}\n\nexport class HCS26BrowserClient extends HCS26BaseClient {\n constructor(config: BrowserHCS26ClientConfig) {\n super({\n network: config.network,\n logger: config.logger,\n mirrorNode: config.mirrorNode,\n verificationProvider: config.verificationProvider,\n });\n }\n}\n"],"names":[],"mappings":";AAUO,MAAM,2BAA2B,gBAAgB;AAAA,EACtD,YAAY,QAAkC;AAC5C,UAAM;AAAA,MACJ,SAAS,OAAO;AAAA,MAChB,QAAQ,OAAO;AAAA,MACf,YAAY,OAAO;AAAA,MACnB,sBAAsB,OAAO;AAAA,IAAA,CAC9B;AAAA,EACH;AACF;"}
|