@hashgraphonline/standards-sdk 0.1.168 → 0.1.170
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 +1 -0
- package/dist/browser/hcs-11/client.d.ts.map +1 -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/index.d.ts +1 -0
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/standards-sdk.browser.js +29 -5
- 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-11/client.d.ts.map +1 -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/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-11/client.d.ts.map +1 -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/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.es103.js +2 -2
- package/dist/es/standards-sdk.es104.js +1 -1
- package/dist/es/standards-sdk.es106.js +1 -1
- package/dist/es/standards-sdk.es108.js +2 -2
- package/dist/es/standards-sdk.es11.js +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 -56
- package/dist/es/standards-sdk.es155.js.map +1 -1
- package/dist/es/standards-sdk.es156.js +34 -84
- package/dist/es/standards-sdk.es156.js.map +1 -1
- package/dist/es/standards-sdk.es157.js +48 -81
- package/dist/es/standards-sdk.es157.js.map +1 -1
- package/dist/es/standards-sdk.es158.js +124 -186
- package/dist/es/standards-sdk.es158.js.map +1 -1
- package/dist/es/standards-sdk.es159.js +34 -12474
- 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 +51 -68
- package/dist/es/standards-sdk.es161.js.map +1 -1
- package/dist/es/standards-sdk.es162.js +67 -533
- package/dist/es/standards-sdk.es162.js.map +1 -1
- package/dist/es/standards-sdk.es163.js +70 -161
- package/dist/es/standards-sdk.es163.js.map +1 -1
- package/dist/es/standards-sdk.es164.js +187 -309
- package/dist/es/standards-sdk.es164.js.map +1 -1
- package/dist/es/standards-sdk.es165.js +13 -342
- package/dist/es/standards-sdk.es165.js.map +1 -1
- package/dist/es/standards-sdk.es166.js +538 -441
- package/dist/es/standards-sdk.es166.js.map +1 -1
- package/dist/es/standards-sdk.es167.js +142 -301
- package/dist/es/standards-sdk.es167.js.map +1 -1
- package/dist/es/standards-sdk.es168.js +310 -64
- package/dist/es/standards-sdk.es168.js.map +1 -1
- package/dist/es/standards-sdk.es169.js +332 -158
- package/dist/es/standards-sdk.es169.js.map +1 -1
- package/dist/es/standards-sdk.es170.js +441 -210
- package/dist/es/standards-sdk.es170.js.map +1 -1
- package/dist/es/standards-sdk.es171.js +314 -222
- package/dist/es/standards-sdk.es171.js.map +1 -1
- package/dist/es/standards-sdk.es172.js +65 -108
- package/dist/es/standards-sdk.es172.js.map +1 -1
- package/dist/es/standards-sdk.es173.js +61 -114
- 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 +12 -12
- 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 +12 -12
- package/dist/es/standards-sdk.es27.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 +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.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.es71.js +2 -2
- package/dist/es/standards-sdk.es72.js +3 -3
- package/dist/es/standards-sdk.es75.js +5 -5
- 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.es81.js +2 -2
- package/dist/es/standards-sdk.es83.js +2 -2
- 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 +4 -4
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +3 -3
- 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 +3 -3
- package/dist/es/utils/key-type-detector.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,185 +1,481 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
import { Logger } from "./standards-sdk.es123.js";
|
|
2
|
+
import { HederaMirrorNode } from "./standards-sdk.es144.js";
|
|
3
|
+
import { HRLResolver } from "./standards-sdk.es127.js";
|
|
4
|
+
import { hash } from "./standards-sdk.es137.js";
|
|
5
|
+
import { hcs26DiscoveryMetadataSchema, hcs26DiscoveryMetadataPatchSchema, hcs26DiscoveryRegisterSchema, hcs26DiscoveryRegisterLegacySchema, hcs26DiscoveryDeleteSchema, hcs26DiscoveryUpdateSchema, hcs26DiscoveryUpdateLegacySchema, hcs26VersionRegisterSchema, hcs26VersionRegisterLegacySchema, hcs26VersionUpdateSchema, hcs26VersionDeleteSchema, hcs26SkillManifestSchema } from "./standards-sdk.es117.js";
|
|
6
|
+
function parseSemver(versionRaw) {
|
|
7
|
+
const trimmed = versionRaw.trim().replace(/^v/i, "");
|
|
8
|
+
const match = trimmed.match(
|
|
9
|
+
/^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+[0-9A-Za-z.-]+)?$/
|
|
10
|
+
);
|
|
11
|
+
if (!match) {
|
|
12
|
+
return null;
|
|
9
13
|
}
|
|
10
|
-
|
|
11
|
-
|
|
14
|
+
const major = Number(match[1]);
|
|
15
|
+
const minor = Number(match[2]);
|
|
16
|
+
const patch = Number(match[3]);
|
|
17
|
+
if (![major, minor, patch].every(Number.isFinite)) {
|
|
18
|
+
return null;
|
|
12
19
|
}
|
|
13
|
-
|
|
20
|
+
const prereleaseRaw = match[4];
|
|
21
|
+
const prerelease = prereleaseRaw ? prereleaseRaw.split(".").map((part) => {
|
|
22
|
+
if (/^(0|[1-9]\d*)$/.test(part)) {
|
|
23
|
+
return Number(part);
|
|
24
|
+
}
|
|
25
|
+
return part;
|
|
26
|
+
}) : [];
|
|
27
|
+
return { major, minor, patch, prerelease };
|
|
14
28
|
}
|
|
15
|
-
function
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
29
|
+
function compareSemver(a, b) {
|
|
30
|
+
if (a.major !== b.major) return a.major - b.major;
|
|
31
|
+
if (a.minor !== b.minor) return a.minor - b.minor;
|
|
32
|
+
if (a.patch !== b.patch) return a.patch - b.patch;
|
|
33
|
+
const aHasPre = a.prerelease.length > 0;
|
|
34
|
+
const bHasPre = b.prerelease.length > 0;
|
|
35
|
+
if (!aHasPre && bHasPre) return 1;
|
|
36
|
+
if (aHasPre && !bHasPre) return -1;
|
|
37
|
+
if (!aHasPre && !bHasPre) return 0;
|
|
38
|
+
const len = Math.max(a.prerelease.length, b.prerelease.length);
|
|
39
|
+
for (let index = 0; index < len; index += 1) {
|
|
40
|
+
const aId = a.prerelease[index];
|
|
41
|
+
const bId = b.prerelease[index];
|
|
42
|
+
if (aId === void 0 && bId !== void 0) return -1;
|
|
43
|
+
if (aId !== void 0 && bId === void 0) return 1;
|
|
44
|
+
if (aId === bId) continue;
|
|
45
|
+
if (typeof aId === "number" && typeof bId === "number") {
|
|
46
|
+
return aId - bId;
|
|
47
|
+
}
|
|
48
|
+
if (typeof aId === "number" && typeof bId === "string") {
|
|
49
|
+
return -1;
|
|
50
|
+
}
|
|
51
|
+
if (typeof aId === "string" && typeof bId === "number") {
|
|
52
|
+
return 1;
|
|
53
|
+
}
|
|
54
|
+
if (typeof aId === "string" && typeof bId === "string") {
|
|
55
|
+
return aId < bId ? -1 : 1;
|
|
56
|
+
}
|
|
41
57
|
}
|
|
58
|
+
return 0;
|
|
42
59
|
}
|
|
43
|
-
function
|
|
44
|
-
|
|
45
|
-
Logger.clearInstances();
|
|
60
|
+
function isActiveStatus(status) {
|
|
61
|
+
return !status || status === "active";
|
|
46
62
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
return loggerFactory(options);
|
|
51
|
-
}
|
|
52
|
-
const globalDisable = typeof process !== "undefined" && process.env?.DISABLE_LOGS === "true";
|
|
53
|
-
this.silent = options.silent || globalDisable;
|
|
54
|
-
this.level = this.silent ? "silent" : options.level || "info";
|
|
55
|
-
this.moduleContext = options.module || "app";
|
|
56
|
-
this.prettyPrint = !this.silent && options.prettyPrint !== false;
|
|
63
|
+
function normalizeUidString(value) {
|
|
64
|
+
if (typeof value !== "string") {
|
|
65
|
+
return null;
|
|
57
66
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
_Logger.instances.delete(moduleKey);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
if (!_Logger.instances.has(moduleKey)) {
|
|
68
|
-
const logger = loggerFactory ? loggerFactory(options) : new _Logger(options);
|
|
69
|
-
_Logger.instances.set(moduleKey, logger);
|
|
70
|
-
}
|
|
71
|
-
return _Logger.instances.get(moduleKey);
|
|
67
|
+
const trimmed = value.trim();
|
|
68
|
+
return trimmed.length > 0 ? trimmed : null;
|
|
69
|
+
}
|
|
70
|
+
function resolveSequenceNumber(primary, fallback) {
|
|
71
|
+
if (typeof primary === "number") {
|
|
72
|
+
return primary;
|
|
72
73
|
}
|
|
73
|
-
|
|
74
|
-
|
|
74
|
+
if (typeof fallback === "number") {
|
|
75
|
+
return fallback;
|
|
75
76
|
}
|
|
76
|
-
|
|
77
|
-
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
function parseSequenceFromUid(uid) {
|
|
80
|
+
if (!/^\d+$/.test(uid)) {
|
|
81
|
+
return null;
|
|
78
82
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
83
|
+
const parsed = Number(uid);
|
|
84
|
+
return Number.isSafeInteger(parsed) ? parsed : null;
|
|
85
|
+
}
|
|
86
|
+
function ensureNonEmptyString(value, field) {
|
|
87
|
+
if (typeof value !== "string") {
|
|
88
|
+
throw new Error(`Expected ${field} to be a string`);
|
|
84
89
|
}
|
|
85
|
-
|
|
86
|
-
|
|
90
|
+
const trimmed = value.trim();
|
|
91
|
+
if (!trimmed) {
|
|
92
|
+
throw new Error(`Expected ${field} to be a non-empty string`);
|
|
93
|
+
}
|
|
94
|
+
return trimmed;
|
|
95
|
+
}
|
|
96
|
+
function mergeDiscoveryMetadata(base, update) {
|
|
97
|
+
if (!update) {
|
|
98
|
+
return base;
|
|
87
99
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
100
|
+
return { ...base, ...update };
|
|
101
|
+
}
|
|
102
|
+
function normalizeDiscoveryRegister(input, messageSequenceNumber) {
|
|
103
|
+
const seq = typeof input.sequence_number === "number" ? input.sequence_number : typeof messageSequenceNumber === "number" ? messageSequenceNumber : void 0;
|
|
104
|
+
if ("t_id" in input) {
|
|
105
|
+
return {
|
|
106
|
+
p: "hcs-26",
|
|
107
|
+
op: "register",
|
|
108
|
+
t_id: ensureNonEmptyString(input.t_id, "t_id"),
|
|
109
|
+
account_id: ensureNonEmptyString(input.account_id, "account_id"),
|
|
110
|
+
metadata: input.metadata,
|
|
111
|
+
...input.m ? { m: input.m } : {},
|
|
112
|
+
...typeof seq === "number" ? { sequence_number: seq } : {}
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
return {
|
|
116
|
+
p: "hcs-26",
|
|
117
|
+
op: "register",
|
|
118
|
+
t_id: ensureNonEmptyString(input.version_registry, "version_registry"),
|
|
119
|
+
account_id: ensureNonEmptyString(input.publisher, "publisher"),
|
|
120
|
+
metadata: input.metadata,
|
|
121
|
+
...input.m ? { m: input.m } : {},
|
|
122
|
+
...typeof seq === "number" ? { sequence_number: seq } : {}
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
class Hcs26SkillRegistryResolver {
|
|
126
|
+
constructor(deps) {
|
|
127
|
+
this.network = deps.network;
|
|
128
|
+
this.logger = deps.logger ?? Logger.getInstance({
|
|
129
|
+
module: "HCS26Resolver",
|
|
130
|
+
level: "info"
|
|
131
|
+
});
|
|
132
|
+
this.mirrorNode = new HederaMirrorNode(
|
|
133
|
+
deps.network,
|
|
134
|
+
this.logger,
|
|
135
|
+
deps.mirrorNode
|
|
136
|
+
);
|
|
137
|
+
this.hrlResolver = new HRLResolver("warn");
|
|
138
|
+
}
|
|
139
|
+
async resolveDiscoveryMetadataHrl(metadataHrl, mode) {
|
|
140
|
+
const resolved = await this.hrlResolver.resolve(metadataHrl, {
|
|
141
|
+
network: this.network,
|
|
142
|
+
returnRaw: true
|
|
143
|
+
});
|
|
144
|
+
const bytes = resolved.content instanceof ArrayBuffer ? Buffer.from(resolved.content) : Buffer.from(String(resolved.content), "utf8");
|
|
145
|
+
let raw;
|
|
146
|
+
try {
|
|
147
|
+
raw = JSON.parse(bytes.toString("utf8"));
|
|
148
|
+
} catch {
|
|
149
|
+
throw new Error("Discovery metadata HRL content is not valid JSON");
|
|
91
150
|
}
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
}
|
|
96
|
-
return { msg: "", data: args[0] };
|
|
151
|
+
const schema = mode === "full" ? hcs26DiscoveryMetadataSchema : hcs26DiscoveryMetadataPatchSchema;
|
|
152
|
+
const parsed = schema.safeParse(raw);
|
|
153
|
+
if (!parsed.success) {
|
|
154
|
+
throw new Error(`Invalid discovery metadata: ${parsed.error.message}`);
|
|
97
155
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
156
|
+
return this.normalizeDiscoveryMetadataObject(
|
|
157
|
+
parsed.data
|
|
158
|
+
);
|
|
159
|
+
}
|
|
160
|
+
normalizeDiscoveryMetadataObject(metadata) {
|
|
161
|
+
if (typeof metadata.icon !== "string" || metadata.icon.trim().length === 0) {
|
|
162
|
+
const iconLegacy = metadata.icon_hcs1;
|
|
163
|
+
if (typeof iconLegacy === "string" && iconLegacy.trim().length > 0) {
|
|
164
|
+
return { ...metadata, icon: iconLegacy };
|
|
105
165
|
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
return objectArgs.length > 0 ? { msg, data: objectArgs } : { msg };
|
|
166
|
+
}
|
|
167
|
+
return metadata;
|
|
109
168
|
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
169
|
+
async resolveDiscoveryMetadataUri(metadataUri, mode) {
|
|
170
|
+
const trimmed = metadataUri.trim();
|
|
171
|
+
if (trimmed.startsWith("hcs://1/")) {
|
|
172
|
+
return this.resolveDiscoveryMetadataHrl(trimmed, mode);
|
|
113
173
|
}
|
|
114
|
-
|
|
115
|
-
const currentLevelIndex = levels.indexOf(this.level);
|
|
116
|
-
const targetLevelIndex = levels.indexOf(level);
|
|
117
|
-
return targetLevelIndex >= currentLevelIndex;
|
|
174
|
+
throw new Error(`Unsupported discovery metadata URI: ${trimmed}`);
|
|
118
175
|
}
|
|
119
|
-
|
|
120
|
-
if (
|
|
121
|
-
return
|
|
176
|
+
resolveDiscoveryMetadataObject(params) {
|
|
177
|
+
if (typeof params.metadata === "string") {
|
|
178
|
+
return this.resolveDiscoveryMetadataUri(params.metadata, params.mode);
|
|
122
179
|
}
|
|
123
|
-
|
|
124
|
-
|
|
180
|
+
const schema = params.mode === "full" ? hcs26DiscoveryMetadataSchema : hcs26DiscoveryMetadataPatchSchema;
|
|
181
|
+
const parsed = schema.safeParse(params.metadata);
|
|
182
|
+
if (!parsed.success) {
|
|
183
|
+
throw new Error(`Invalid discovery metadata: ${parsed.error.message}`);
|
|
125
184
|
}
|
|
126
|
-
|
|
127
|
-
|
|
185
|
+
return Promise.resolve(
|
|
186
|
+
this.normalizeDiscoveryMetadataObject(
|
|
187
|
+
parsed.data
|
|
188
|
+
)
|
|
189
|
+
);
|
|
190
|
+
}
|
|
191
|
+
async getDiscoveryRegister(params) {
|
|
192
|
+
const messages = await this.mirrorNode.getTopicMessages(
|
|
193
|
+
params.directoryTopicId,
|
|
194
|
+
{
|
|
195
|
+
sequenceNumber: `eq:${params.skillUid}`,
|
|
196
|
+
limit: 5,
|
|
197
|
+
order: "asc"
|
|
198
|
+
}
|
|
199
|
+
);
|
|
200
|
+
for (const message of messages) {
|
|
201
|
+
const parsedNew = hcs26DiscoveryRegisterSchema.safeParse(message);
|
|
202
|
+
const parsedLegacy = parsedNew.success ? null : hcs26DiscoveryRegisterLegacySchema.safeParse(message);
|
|
203
|
+
const parsed = parsedNew.success ? parsedNew : parsedLegacy && parsedLegacy.success ? parsedLegacy : null;
|
|
204
|
+
if (!parsed) {
|
|
205
|
+
continue;
|
|
206
|
+
}
|
|
207
|
+
const normalized = normalizeDiscoveryRegister(
|
|
208
|
+
parsed.data,
|
|
209
|
+
message.sequence_number
|
|
210
|
+
);
|
|
211
|
+
const seq = normalized.sequence_number;
|
|
212
|
+
if (typeof seq === "number" && seq === params.skillUid) {
|
|
213
|
+
const metadata = await this.resolveDiscoveryMetadataObject({
|
|
214
|
+
metadata: normalized.metadata,
|
|
215
|
+
mode: "full"
|
|
216
|
+
});
|
|
217
|
+
return { ...normalized, metadata };
|
|
218
|
+
}
|
|
128
219
|
}
|
|
129
|
-
return
|
|
220
|
+
return null;
|
|
130
221
|
}
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
222
|
+
async resolveDiscoveryRecord(params) {
|
|
223
|
+
const register = await this.getDiscoveryRegister({
|
|
224
|
+
directoryTopicId: params.directoryTopicId,
|
|
225
|
+
skillUid: params.skillUid
|
|
226
|
+
});
|
|
227
|
+
if (!register) {
|
|
228
|
+
return null;
|
|
134
229
|
}
|
|
135
|
-
const
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
230
|
+
const scanLimit = typeof params.scanLimit === "number" && params.scanLimit > 0 ? Math.min(5e3, Math.floor(params.scanLimit)) : 1e3;
|
|
231
|
+
const messages = await this.mirrorNode.getTopicMessages(
|
|
232
|
+
params.directoryTopicId,
|
|
233
|
+
{
|
|
234
|
+
limit: scanLimit,
|
|
235
|
+
order: "asc"
|
|
236
|
+
}
|
|
237
|
+
);
|
|
238
|
+
const uid = String(params.skillUid);
|
|
239
|
+
const registerSequence = resolveSequenceNumber(
|
|
240
|
+
register.sequence_number,
|
|
241
|
+
params.skillUid
|
|
242
|
+
);
|
|
243
|
+
let current = register;
|
|
244
|
+
for (const message of messages) {
|
|
245
|
+
const messageSequence = resolveSequenceNumber(
|
|
246
|
+
void 0,
|
|
247
|
+
message.sequence_number
|
|
248
|
+
);
|
|
249
|
+
const deleteParsed = hcs26DiscoveryDeleteSchema.safeParse(message);
|
|
250
|
+
if (deleteParsed.success && deleteParsed.data.uid === uid) {
|
|
251
|
+
const deleteSequence = resolveSequenceNumber(
|
|
252
|
+
deleteParsed.data.sequence_number,
|
|
253
|
+
messageSequence
|
|
254
|
+
);
|
|
255
|
+
if (registerSequence !== null && deleteSequence !== null && deleteSequence <= registerSequence) {
|
|
256
|
+
continue;
|
|
257
|
+
}
|
|
258
|
+
return null;
|
|
259
|
+
}
|
|
260
|
+
const updateParsedNew = hcs26DiscoveryUpdateSchema.safeParse(message);
|
|
261
|
+
const updateParsedLegacy = updateParsedNew.success ? null : hcs26DiscoveryUpdateLegacySchema.safeParse(message);
|
|
262
|
+
const updateParsed = updateParsedNew.success ? updateParsedNew : updateParsedLegacy && updateParsedLegacy.success ? updateParsedLegacy : null;
|
|
263
|
+
if (!updateParsed || updateParsed.data.uid !== uid) {
|
|
264
|
+
continue;
|
|
265
|
+
}
|
|
266
|
+
const updateSequence = resolveSequenceNumber(
|
|
267
|
+
updateParsed.data.sequence_number,
|
|
268
|
+
messageSequence
|
|
269
|
+
);
|
|
270
|
+
if (registerSequence !== null && updateSequence !== null && updateSequence <= registerSequence) {
|
|
271
|
+
continue;
|
|
272
|
+
}
|
|
273
|
+
const nextAccountId = "account_id" in updateParsed.data ? normalizeUidString(updateParsed.data.account_id) : normalizeUidString(updateParsed.data.publisher);
|
|
274
|
+
const nextMetadataRaw = updateParsed.data.metadata;
|
|
275
|
+
const nextMetadata = nextMetadataRaw !== void 0 ? await this.resolveDiscoveryMetadataObject({
|
|
276
|
+
metadata: nextMetadataRaw,
|
|
277
|
+
mode: "patch"
|
|
278
|
+
}) : void 0;
|
|
279
|
+
current = {
|
|
280
|
+
...current,
|
|
281
|
+
...nextAccountId ? { account_id: nextAccountId } : {},
|
|
282
|
+
metadata: mergeDiscoveryMetadata(current.metadata, nextMetadata)
|
|
152
283
|
};
|
|
153
|
-
consoleMethod(JSON.stringify(logObj));
|
|
154
284
|
}
|
|
285
|
+
return current;
|
|
155
286
|
}
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
287
|
+
async listVersionRegisters(params) {
|
|
288
|
+
const limit = typeof params.limit === "number" && params.limit > 0 ? Math.min(1e3, params.limit) : 500;
|
|
289
|
+
const messages = await this.mirrorNode.getTopicMessages(
|
|
290
|
+
params.versionRegistryTopicId,
|
|
291
|
+
{
|
|
292
|
+
limit,
|
|
293
|
+
order: "desc"
|
|
294
|
+
}
|
|
295
|
+
);
|
|
296
|
+
const registersByUid = /* @__PURE__ */ new Map();
|
|
297
|
+
const updatesByUid = /* @__PURE__ */ new Map();
|
|
298
|
+
const deletedByUid = /* @__PURE__ */ new Map();
|
|
299
|
+
for (const message of messages) {
|
|
300
|
+
const parsedNew = hcs26VersionRegisterSchema.safeParse(message);
|
|
301
|
+
const parsedLegacy = parsedNew.success ? null : hcs26VersionRegisterLegacySchema.safeParse(message);
|
|
302
|
+
const registerParsed = parsedNew.success ? parsedNew : parsedLegacy && parsedLegacy.success ? parsedLegacy : null;
|
|
303
|
+
if (registerParsed) {
|
|
304
|
+
if (registerParsed.data.skill_uid !== params.skillUid) {
|
|
305
|
+
continue;
|
|
306
|
+
}
|
|
307
|
+
const uid = typeof registerParsed.data.sequence_number === "number" ? String(registerParsed.data.sequence_number) : typeof message.sequence_number === "number" ? String(message.sequence_number) : null;
|
|
308
|
+
if (uid) {
|
|
309
|
+
const registerSequence = resolveSequenceNumber(
|
|
310
|
+
registerParsed.data.sequence_number,
|
|
311
|
+
message.sequence_number
|
|
312
|
+
);
|
|
313
|
+
registersByUid.set(uid, {
|
|
314
|
+
register: registerParsed.data,
|
|
315
|
+
sequenceNumber: registerSequence
|
|
316
|
+
});
|
|
317
|
+
}
|
|
318
|
+
continue;
|
|
319
|
+
}
|
|
320
|
+
const updateParsed = hcs26VersionUpdateSchema.safeParse(message);
|
|
321
|
+
if (updateParsed.success) {
|
|
322
|
+
const uid = updateParsed.data.uid.trim();
|
|
323
|
+
const list = updatesByUid.get(uid) ?? [];
|
|
324
|
+
list.push({
|
|
325
|
+
update: updateParsed.data,
|
|
326
|
+
sequenceNumber: resolveSequenceNumber(
|
|
327
|
+
updateParsed.data.sequence_number,
|
|
328
|
+
message.sequence_number
|
|
329
|
+
)
|
|
330
|
+
});
|
|
331
|
+
updatesByUid.set(uid, list);
|
|
332
|
+
continue;
|
|
333
|
+
}
|
|
334
|
+
const deleteParsed = hcs26VersionDeleteSchema.safeParse(message);
|
|
335
|
+
if (deleteParsed.success) {
|
|
336
|
+
const uid = deleteParsed.data.uid.trim();
|
|
337
|
+
const list = deletedByUid.get(uid) ?? [];
|
|
338
|
+
const sequenceNumber = resolveSequenceNumber(
|
|
339
|
+
deleteParsed.data.sequence_number,
|
|
340
|
+
message.sequence_number
|
|
341
|
+
);
|
|
342
|
+
if (sequenceNumber !== null) {
|
|
343
|
+
list.push(sequenceNumber);
|
|
344
|
+
deletedByUid.set(uid, list);
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
const entries = [];
|
|
349
|
+
for (const [uid, registerState] of registersByUid.entries()) {
|
|
350
|
+
const registerSequence = registerState.sequenceNumber ?? parseSequenceFromUid(uid);
|
|
351
|
+
const deleteSequences = deletedByUid.get(uid) ?? [];
|
|
352
|
+
const hasDeleteAfterRegister = deleteSequences.some(
|
|
353
|
+
(sequence) => registerSequence === null ? true : sequence > registerSequence
|
|
354
|
+
);
|
|
355
|
+
if (hasDeleteAfterRegister) {
|
|
356
|
+
continue;
|
|
357
|
+
}
|
|
358
|
+
const updates = updatesByUid.get(uid);
|
|
359
|
+
if (!updates || updates.length === 0) {
|
|
360
|
+
entries.push(registerState.register);
|
|
361
|
+
continue;
|
|
362
|
+
}
|
|
363
|
+
const sorted = [...updates].filter(
|
|
364
|
+
(update) => registerSequence === null ? true : update.sequenceNumber !== null && update.sequenceNumber > registerSequence
|
|
365
|
+
).sort((a, b) => {
|
|
366
|
+
const aSeq = a.sequenceNumber ?? 0;
|
|
367
|
+
const bSeq = b.sequenceNumber ?? 0;
|
|
368
|
+
return aSeq - bSeq;
|
|
369
|
+
});
|
|
370
|
+
if (sorted.length === 0) {
|
|
371
|
+
entries.push(registerState.register);
|
|
372
|
+
continue;
|
|
373
|
+
}
|
|
374
|
+
const final = sorted.reduce((acc, updateState) => {
|
|
375
|
+
if (updateState.update.status) {
|
|
376
|
+
return { ...acc, status: updateState.update.status };
|
|
377
|
+
}
|
|
378
|
+
return acc;
|
|
379
|
+
}, registerState.register);
|
|
380
|
+
entries.push(final);
|
|
381
|
+
}
|
|
382
|
+
return entries;
|
|
164
383
|
}
|
|
165
|
-
|
|
166
|
-
this.
|
|
384
|
+
async getLatestVersionRegister(params) {
|
|
385
|
+
const entries = await this.listVersionRegisters({
|
|
386
|
+
versionRegistryTopicId: params.versionRegistryTopicId,
|
|
387
|
+
skillUid: params.skillUid,
|
|
388
|
+
limit: 100
|
|
389
|
+
});
|
|
390
|
+
const active = entries.filter((entry) => isActiveStatus(entry.status));
|
|
391
|
+
if (active.length === 0) {
|
|
392
|
+
return null;
|
|
393
|
+
}
|
|
394
|
+
let best = active[0];
|
|
395
|
+
let bestParsed = parseSemver(best.version);
|
|
396
|
+
for (let index = 1; index < active.length; index += 1) {
|
|
397
|
+
const candidate = active[index];
|
|
398
|
+
const candidateParsed = parseSemver(candidate.version);
|
|
399
|
+
if (!bestParsed && candidateParsed) {
|
|
400
|
+
best = candidate;
|
|
401
|
+
bestParsed = candidateParsed;
|
|
402
|
+
continue;
|
|
403
|
+
}
|
|
404
|
+
if (bestParsed && candidateParsed) {
|
|
405
|
+
const cmp = compareSemver(candidateParsed, bestParsed);
|
|
406
|
+
if (cmp > 0) {
|
|
407
|
+
best = candidate;
|
|
408
|
+
bestParsed = candidateParsed;
|
|
409
|
+
continue;
|
|
410
|
+
}
|
|
411
|
+
if (cmp === 0) {
|
|
412
|
+
const bestSeq = typeof best.sequence_number === "number" ? best.sequence_number : 0;
|
|
413
|
+
const candSeq = typeof candidate.sequence_number === "number" ? candidate.sequence_number : 0;
|
|
414
|
+
if (candSeq > bestSeq) {
|
|
415
|
+
best = candidate;
|
|
416
|
+
bestParsed = candidateParsed;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
return best;
|
|
167
422
|
}
|
|
168
|
-
|
|
169
|
-
|
|
423
|
+
async resolveManifest(params) {
|
|
424
|
+
const manifestHrl = typeof params.manifestHrl === "string" && params.manifestHrl.trim().length > 0 ? params.manifestHrl.trim() : typeof params.manifestTopicId === "string" && params.manifestTopicId.trim().length > 0 ? `hcs://1/${params.manifestTopicId.trim()}` : null;
|
|
425
|
+
if (!manifestHrl) {
|
|
426
|
+
throw new Error("Manifest HRL or topic id is required");
|
|
427
|
+
}
|
|
428
|
+
const resolved = await this.hrlResolver.resolve(manifestHrl, {
|
|
429
|
+
network: this.network,
|
|
430
|
+
returnRaw: true
|
|
431
|
+
});
|
|
432
|
+
const contentType = resolved.contentType ?? "";
|
|
433
|
+
if (!contentType.toLowerCase().startsWith("application/json")) {
|
|
434
|
+
throw new Error(
|
|
435
|
+
`Expected application/json for manifest, got ${resolved.contentType ?? "unknown"}`
|
|
436
|
+
);
|
|
437
|
+
}
|
|
438
|
+
const bytes = resolved.content instanceof ArrayBuffer ? Buffer.from(resolved.content) : Buffer.from(String(resolved.content), "utf8");
|
|
439
|
+
const sha256Hex = await hash(bytes, "sha256");
|
|
440
|
+
let raw;
|
|
441
|
+
try {
|
|
442
|
+
raw = JSON.parse(bytes.toString("utf8"));
|
|
443
|
+
} catch {
|
|
444
|
+
throw new Error("Manifest content is not valid JSON");
|
|
445
|
+
}
|
|
446
|
+
const parsed = hcs26SkillManifestSchema.safeParse(raw);
|
|
447
|
+
if (!parsed.success) {
|
|
448
|
+
throw new Error(`Invalid HCS-26 manifest: ${parsed.error.message}`);
|
|
449
|
+
}
|
|
450
|
+
const hasSkillMd = parsed.data.files.some((file) => file.path === "SKILL.md");
|
|
451
|
+
if (!hasSkillMd) {
|
|
452
|
+
throw new Error(
|
|
453
|
+
'HCS-26 manifest must include SKILL.md at path "SKILL.md"'
|
|
454
|
+
);
|
|
455
|
+
}
|
|
456
|
+
return { manifest: parsed.data, raw, sha256Hex };
|
|
170
457
|
}
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
458
|
+
async verifyVersionRegisterMatchesManifest(params) {
|
|
459
|
+
const checksumRaw = params.versionRegister.checksum;
|
|
460
|
+
if (!checksumRaw) {
|
|
461
|
+
this.logger.warn(
|
|
462
|
+
"HCS-26 version register is missing checksum; skipping manifest verification."
|
|
463
|
+
);
|
|
464
|
+
return;
|
|
465
|
+
}
|
|
466
|
+
const checksum = checksumRaw.trim();
|
|
467
|
+
if (!checksum.startsWith("sha256:")) {
|
|
468
|
+
throw new Error(`Unsupported checksum: ${checksum}`);
|
|
469
|
+
}
|
|
470
|
+
const expectedHex = checksum.slice("sha256:".length);
|
|
471
|
+
if (params.manifestSha256Hex !== expectedHex) {
|
|
472
|
+
throw new Error(
|
|
473
|
+
`Manifest checksum mismatch (expected ${expectedHex}, got ${params.manifestSha256Hex})`
|
|
474
|
+
);
|
|
475
|
+
}
|
|
177
476
|
}
|
|
178
|
-
}
|
|
179
|
-
_Logger.instances = /* @__PURE__ */ new Map();
|
|
180
|
-
let Logger = _Logger;
|
|
477
|
+
}
|
|
181
478
|
export {
|
|
182
|
-
|
|
183
|
-
setLoggerFactory
|
|
479
|
+
Hcs26SkillRegistryResolver
|
|
184
480
|
};
|
|
185
481
|
//# sourceMappingURL=standards-sdk.es118.js.map
|