@hashgraphonline/standards-sdk 0.0.157-canary.2 → 0.0.157-canary.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/hcs-10/base-client.d.ts +1 -1
- package/dist/cjs/hcs-10/base-client.d.ts.map +1 -1
- package/dist/cjs/hcs-10/sdk.d.ts +1 -1
- package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-11/agent-builder.d.ts +2 -0
- package/dist/cjs/hcs-11/agent-builder.d.ts.map +1 -1
- package/dist/cjs/hcs-11/client.d.ts +2 -0
- package/dist/cjs/hcs-11/client.d.ts.map +1 -1
- package/dist/cjs/hcs-11/types.d.ts +4 -2
- package/dist/cjs/hcs-11/types.d.ts.map +1 -1
- package/dist/cjs/hcs-15/index.d.ts +3 -0
- package/dist/cjs/hcs-15/index.d.ts.map +1 -0
- package/dist/cjs/hcs-15/petal-manager.d.ts +27 -0
- package/dist/cjs/hcs-15/petal-manager.d.ts.map +1 -0
- package/dist/cjs/hcs-15/types.d.ts +41 -0
- package/dist/cjs/hcs-15/types.d.ts.map +1 -0
- package/dist/cjs/hcs-16/flora-account-manager.d.ts.map +1 -1
- package/dist/cjs/hcs-16/types.d.ts +3 -5
- package/dist/cjs/hcs-16/types.d.ts.map +1 -1
- package/dist/cjs/hcs-18/discovery.d.ts +1 -0
- package/dist/cjs/hcs-18/discovery.d.ts.map +1 -1
- package/dist/cjs/hcs-18/types.d.ts +1 -0
- package/dist/cjs/hcs-18/types.d.ts.map +1 -1
- package/dist/cjs/hcs-20/sdk.d.ts.map +1 -1
- package/dist/cjs/hcs-7/evm-bridge.d.ts.map +1 -1
- package/dist/cjs/hcs-7/redis-cache.d.ts.map +1 -1
- package/dist/cjs/hcs-7/wasm-bridge.d.ts.map +1 -1
- package/dist/cjs/{index-xZmk-HBD.cjs → index-CJsmyij2.cjs} +12 -12
- package/dist/cjs/index-CJsmyij2.cjs.map +1 -0
- package/dist/cjs/{index-CyAbgH2f-Cv8mxAhS.cjs → index-CyAbgH2f-Dn5WQtPx.cjs} +2 -2
- package/dist/cjs/{index-CyAbgH2f-Cv8mxAhS.cjs.map → index-CyAbgH2f-Dn5WQtPx.cjs.map} +1 -1
- package/dist/cjs/index.d.ts +1 -1
- package/dist/cjs/services/types.d.ts +1 -1
- package/dist/cjs/services/types.d.ts.map +1 -1
- package/dist/cjs/standards-sdk.cjs +1 -1
- package/dist/cjs/{standards-sdk.es45-BxAtDqsy-ELd4REyl.cjs → standards-sdk.es45-BxAtDqsy-CiMtsDbD.cjs} +2 -2
- package/dist/cjs/{standards-sdk.es45-BxAtDqsy-ELd4REyl.cjs.map → standards-sdk.es45-BxAtDqsy-CiMtsDbD.cjs.map} +1 -1
- package/dist/cjs/{standards-sdk.es46-BI8ACeLM-DRmcgoN0.cjs → standards-sdk.es46-BI8ACeLM-DFYgO-fP.cjs} +2 -2
- package/dist/cjs/{standards-sdk.es46-BI8ACeLM-DRmcgoN0.cjs.map → standards-sdk.es46-BI8ACeLM-DFYgO-fP.cjs.map} +1 -1
- package/dist/cjs/{standards-sdk.es47-DbkY3FlD-DfMpZygD.cjs → standards-sdk.es47-DbkY3FlD-2qTWs2BD.cjs} +2 -2
- package/dist/cjs/{standards-sdk.es47-DbkY3FlD-DfMpZygD.cjs.map → standards-sdk.es47-DbkY3FlD-2qTWs2BD.cjs.map} +1 -1
- package/dist/cjs/{standards-sdk.es48-DzT9Qc3F-CmCkJl3x.cjs → standards-sdk.es48-DzT9Qc3F-Byz0fQnW.cjs} +2 -2
- package/dist/cjs/{standards-sdk.es48-DzT9Qc3F-CmCkJl3x.cjs.map → standards-sdk.es48-DzT9Qc3F-Byz0fQnW.cjs.map} +1 -1
- package/dist/cjs/utils/logger.d.ts.map +1 -1
- package/dist/es/hcs-10/base-client.d.ts +1 -1
- package/dist/es/hcs-10/base-client.d.ts.map +1 -1
- package/dist/es/hcs-10/sdk.d.ts +1 -1
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/hcs-11/agent-builder.d.ts +2 -0
- package/dist/es/hcs-11/agent-builder.d.ts.map +1 -1
- package/dist/es/hcs-11/client.d.ts +2 -0
- package/dist/es/hcs-11/client.d.ts.map +1 -1
- package/dist/es/hcs-11/types.d.ts +4 -2
- package/dist/es/hcs-11/types.d.ts.map +1 -1
- package/dist/es/hcs-15/index.d.ts +3 -0
- package/dist/es/hcs-15/index.d.ts.map +1 -0
- package/dist/es/hcs-15/petal-manager.d.ts +27 -0
- package/dist/es/hcs-15/petal-manager.d.ts.map +1 -0
- package/dist/es/hcs-15/types.d.ts +41 -0
- package/dist/es/hcs-15/types.d.ts.map +1 -0
- package/dist/es/hcs-16/flora-account-manager.d.ts.map +1 -1
- package/dist/es/hcs-16/types.d.ts +3 -5
- package/dist/es/hcs-16/types.d.ts.map +1 -1
- package/dist/es/hcs-18/discovery.d.ts +1 -0
- package/dist/es/hcs-18/discovery.d.ts.map +1 -1
- package/dist/es/hcs-18/types.d.ts +1 -0
- package/dist/es/hcs-18/types.d.ts.map +1 -1
- package/dist/es/hcs-20/sdk.d.ts.map +1 -1
- package/dist/es/hcs-7/evm-bridge.d.ts.map +1 -1
- package/dist/es/hcs-7/redis-cache.d.ts.map +1 -1
- package/dist/es/hcs-7/wasm-bridge.d.ts.map +1 -1
- package/dist/es/index.d.ts +1 -1
- package/dist/es/services/types.d.ts +1 -1
- package/dist/es/services/types.d.ts.map +1 -1
- package/dist/es/standards-sdk.es.js +19 -22
- package/dist/es/standards-sdk.es.js.map +1 -1
- package/dist/es/standards-sdk.es10.js +1 -1
- package/dist/es/standards-sdk.es11.js +10 -2
- package/dist/es/standards-sdk.es11.js.map +1 -1
- package/dist/es/standards-sdk.es12.js +1 -1
- package/dist/es/standards-sdk.es13.js +1 -1
- package/dist/es/standards-sdk.es13.js.map +1 -1
- package/dist/es/standards-sdk.es14.js +1 -1
- package/dist/es/standards-sdk.es15.js +39 -9
- package/dist/es/standards-sdk.es15.js.map +1 -1
- package/dist/es/standards-sdk.es16.js +1 -0
- package/dist/es/standards-sdk.es16.js.map +1 -1
- package/dist/es/standards-sdk.es18.js +1 -1
- package/dist/es/standards-sdk.es19.js +1 -1
- package/dist/es/standards-sdk.es2.js +1 -1
- package/dist/es/standards-sdk.es20.js +2 -2
- package/dist/es/standards-sdk.es23.js +2 -2
- package/dist/es/standards-sdk.es25.js +4 -2
- package/dist/es/standards-sdk.es25.js.map +1 -1
- package/dist/es/standards-sdk.es26.js +2 -2
- package/dist/es/standards-sdk.es27.js +152 -6
- package/dist/es/standards-sdk.es27.js.map +1 -1
- package/dist/es/standards-sdk.es28.js +26 -189
- package/dist/es/standards-sdk.es28.js.map +1 -1
- package/dist/es/standards-sdk.es29.js +446 -26
- package/dist/es/standards-sdk.es29.js.map +1 -1
- package/dist/es/standards-sdk.es3.js +1 -1
- package/dist/es/standards-sdk.es3.js.map +1 -1
- package/dist/es/standards-sdk.es30.js +6 -342
- package/dist/es/standards-sdk.es30.js.map +1 -1
- package/dist/es/standards-sdk.es31.js +202 -6
- package/dist/es/standards-sdk.es31.js.map +1 -1
- package/dist/es/standards-sdk.es32.js +34 -202
- package/dist/es/standards-sdk.es32.js.map +1 -1
- package/dist/es/standards-sdk.es33.js +529 -34
- package/dist/es/standards-sdk.es33.js.map +1 -1
- package/dist/es/standards-sdk.es34.js +87 -501
- package/dist/es/standards-sdk.es34.js.map +1 -1
- package/dist/es/standards-sdk.es35.js +19 -98
- package/dist/es/standards-sdk.es35.js.map +1 -1
- package/dist/es/standards-sdk.es36.js +156 -18
- package/dist/es/standards-sdk.es36.js.map +1 -1
- package/dist/es/standards-sdk.es37.js +146 -150
- package/dist/es/standards-sdk.es37.js.map +1 -1
- package/dist/es/standards-sdk.es38.js +561 -134
- package/dist/es/standards-sdk.es38.js.map +1 -1
- package/dist/es/standards-sdk.es39.js +562 -543
- package/dist/es/standards-sdk.es39.js.map +1 -1
- package/dist/es/standards-sdk.es4.js +6 -4
- package/dist/es/standards-sdk.es4.js.map +1 -1
- package/dist/es/standards-sdk.es40.js +4 -601
- package/dist/es/standards-sdk.es40.js.map +1 -1
- package/dist/es/standards-sdk.es41.js +415 -4
- package/dist/es/standards-sdk.es41.js.map +1 -1
- package/dist/es/standards-sdk.es42.js +1536 -389
- package/dist/es/standards-sdk.es42.js.map +1 -1
- package/dist/es/standards-sdk.es43.js +133 -1541
- package/dist/es/standards-sdk.es43.js.map +1 -1
- package/dist/es/standards-sdk.es44.js +7 -155
- package/dist/es/standards-sdk.es44.js.map +1 -1
- package/dist/es/standards-sdk.es45.js +2 -7
- package/dist/es/standards-sdk.es45.js.map +1 -1
- package/dist/es/standards-sdk.es46.js +5 -5
- package/dist/es/standards-sdk.es48.js +1 -1
- package/dist/es/standards-sdk.es49.js +1 -1
- package/dist/es/standards-sdk.es5.js +4 -6
- package/dist/es/standards-sdk.es5.js.map +1 -1
- package/dist/es/standards-sdk.es50.js +1 -1
- package/dist/es/standards-sdk.es51.js +1 -1
- package/dist/es/standards-sdk.es52.js +1 -1
- package/dist/es/standards-sdk.es54.js +7135 -2
- package/dist/es/standards-sdk.es54.js.map +1 -1
- package/dist/es/standards-sdk.es55.js +7134 -41
- package/dist/es/standards-sdk.es55.js.map +1 -1
- package/dist/es/standards-sdk.es56.js +37 -37
- package/dist/es/standards-sdk.es56.js.map +1 -1
- package/dist/es/standards-sdk.es57.js +37 -37
- package/dist/es/standards-sdk.es57.js.map +1 -1
- package/dist/es/standards-sdk.es58.js +78 -72
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +41 -7134
- package/dist/es/standards-sdk.es59.js.map +1 -1
- package/dist/es/standards-sdk.es6.js.map +1 -1
- package/dist/es/standards-sdk.es7.js +28 -22
- package/dist/es/standards-sdk.es7.js.map +1 -1
- package/dist/es/standards-sdk.es8.js +5 -5
- package/dist/es/utils/logger.d.ts.map +1 -1
- package/package.json +37 -35
- package/dist/cjs/hcs-21/index.d.ts +0 -4
- package/dist/cjs/hcs-21/index.d.ts.map +0 -1
- package/dist/cjs/hcs-21/petal-account-manager.d.ts +0 -52
- package/dist/cjs/hcs-21/petal-account-manager.d.ts.map +0 -1
- package/dist/cjs/hcs-21/types.d.ts +0 -44
- package/dist/cjs/hcs-21/types.d.ts.map +0 -1
- package/dist/cjs/index-xZmk-HBD.cjs.map +0 -1
- package/dist/es/hcs-21/index.d.ts +0 -4
- package/dist/es/hcs-21/index.d.ts.map +0 -1
- package/dist/es/hcs-21/petal-account-manager.d.ts +0 -52
- package/dist/es/hcs-21/petal-account-manager.d.ts.map +0 -1
- package/dist/es/hcs-21/types.d.ts +0 -44
- package/dist/es/hcs-21/types.d.ts.map +0 -1
- package/dist/es/standards-sdk.es60.js +0 -7144
- package/dist/es/standards-sdk.es60.js.map +0 -1
|
@@ -1,8 +1,419 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { I as InscriptionSDK } from "./standards-sdk.es46.js";
|
|
2
|
+
import { Logger } from "./standards-sdk.es34.js";
|
|
3
|
+
import { ProgressReporter } from "./standards-sdk.es36.js";
|
|
4
|
+
async function inscribe(input, clientConfig, options, existingSDK) {
|
|
5
|
+
const logger = Logger.getInstance({
|
|
6
|
+
module: "Inscriber",
|
|
7
|
+
...options.logging
|
|
8
|
+
});
|
|
9
|
+
logger.info("Starting inscription process", {
|
|
10
|
+
type: input.type,
|
|
11
|
+
mode: options.mode || "file",
|
|
12
|
+
...input.type === "url" ? { url: input.url } : {},
|
|
13
|
+
...input.type === "file" ? { path: input.path } : {},
|
|
14
|
+
...input.type === "buffer" ? { fileName: input.fileName, bufferSize: input.buffer.byteLength } : {}
|
|
15
|
+
});
|
|
16
|
+
try {
|
|
17
|
+
if (options.mode === "hashinal" && options.metadata) {
|
|
18
|
+
validateHashinalMetadata(options.metadata, logger);
|
|
19
|
+
}
|
|
20
|
+
let sdk;
|
|
21
|
+
if (existingSDK) {
|
|
22
|
+
logger.debug("Using existing InscriptionSDK instance");
|
|
23
|
+
sdk = existingSDK;
|
|
24
|
+
} else if (options.apiKey) {
|
|
25
|
+
logger.debug("Initializing InscriptionSDK with API key");
|
|
26
|
+
sdk = new InscriptionSDK({
|
|
27
|
+
apiKey: options.apiKey,
|
|
28
|
+
network: clientConfig.network || "mainnet"
|
|
29
|
+
});
|
|
30
|
+
} else {
|
|
31
|
+
logger.debug("Initializing InscriptionSDK with server auth");
|
|
32
|
+
sdk = await InscriptionSDK.createWithAuth({
|
|
33
|
+
type: "server",
|
|
34
|
+
accountId: clientConfig.accountId,
|
|
35
|
+
privateKey: clientConfig.privateKey,
|
|
36
|
+
network: clientConfig.network || "mainnet"
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
const baseRequest = {
|
|
40
|
+
holderId: clientConfig.accountId,
|
|
41
|
+
metadata: options.metadata || {},
|
|
42
|
+
tags: options.tags || [],
|
|
43
|
+
mode: options.mode || "file",
|
|
44
|
+
chunkSize: options.chunkSize
|
|
45
|
+
};
|
|
46
|
+
let request;
|
|
47
|
+
switch (input.type) {
|
|
48
|
+
case "url":
|
|
49
|
+
request = {
|
|
50
|
+
...baseRequest,
|
|
51
|
+
file: {
|
|
52
|
+
type: "url",
|
|
53
|
+
url: input.url
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
break;
|
|
57
|
+
case "file":
|
|
58
|
+
request = {
|
|
59
|
+
...baseRequest,
|
|
60
|
+
file: {
|
|
61
|
+
type: "path",
|
|
62
|
+
path: input.path
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
break;
|
|
66
|
+
case "buffer":
|
|
67
|
+
request = {
|
|
68
|
+
...baseRequest,
|
|
69
|
+
file: {
|
|
70
|
+
type: "base64",
|
|
71
|
+
base64: Buffer.from(input.buffer).toString("base64"),
|
|
72
|
+
fileName: input.fileName,
|
|
73
|
+
mimeType: input.mimeType
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
break;
|
|
77
|
+
}
|
|
78
|
+
if (options.mode === "hashinal") {
|
|
79
|
+
request.metadataObject = options.metadata;
|
|
80
|
+
request.creator = options.metadata?.creator || clientConfig.accountId;
|
|
81
|
+
request.description = options.metadata?.description;
|
|
82
|
+
if (options.jsonFileURL) {
|
|
83
|
+
request.jsonFileURL = options.jsonFileURL;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
logger.debug("Preparing to inscribe content", {
|
|
87
|
+
type: input.type,
|
|
88
|
+
mode: options.mode || "file",
|
|
89
|
+
holderId: clientConfig.accountId
|
|
90
|
+
});
|
|
91
|
+
const result = await sdk.inscribeAndExecute(request, clientConfig);
|
|
92
|
+
logger.info("Starting to inscribe.", {
|
|
93
|
+
type: input.type,
|
|
94
|
+
mode: options.mode || "file",
|
|
95
|
+
transactionId: result.jobId
|
|
96
|
+
});
|
|
97
|
+
if (result.completed && options.waitForConfirmation) {
|
|
98
|
+
const inscription = result;
|
|
99
|
+
return {
|
|
100
|
+
confirmed: true,
|
|
101
|
+
result,
|
|
102
|
+
inscription,
|
|
103
|
+
sdk
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
if (options.waitForConfirmation) {
|
|
107
|
+
console.log("Waiting for inscription confirmation", {
|
|
108
|
+
transactionId: result.jobId,
|
|
109
|
+
maxAttempts: options.waitMaxAttempts,
|
|
110
|
+
intervalMs: options.waitIntervalMs
|
|
111
|
+
});
|
|
112
|
+
const inscription = await waitForInscriptionConfirmation(
|
|
113
|
+
sdk,
|
|
114
|
+
result.jobId,
|
|
115
|
+
options.waitMaxAttempts,
|
|
116
|
+
options.waitIntervalMs,
|
|
117
|
+
options.progressCallback
|
|
118
|
+
);
|
|
119
|
+
logger.info("Inscription confirmation received", {
|
|
120
|
+
transactionId: result.jobId
|
|
121
|
+
});
|
|
122
|
+
return {
|
|
123
|
+
confirmed: true,
|
|
124
|
+
result,
|
|
125
|
+
inscription,
|
|
126
|
+
sdk
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
return {
|
|
130
|
+
confirmed: false,
|
|
131
|
+
result,
|
|
132
|
+
sdk
|
|
133
|
+
};
|
|
134
|
+
} catch (error) {
|
|
135
|
+
logger.error("Error during inscription process", error);
|
|
136
|
+
throw error;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
async function inscribeWithSigner(input, signer, options, existingSDK) {
|
|
140
|
+
const logger = Logger.getInstance({
|
|
141
|
+
module: "Inscriber",
|
|
142
|
+
...options.logging
|
|
143
|
+
});
|
|
144
|
+
logger.info("Starting inscription process with signer", {
|
|
145
|
+
type: input.type,
|
|
146
|
+
mode: options.mode || "file",
|
|
147
|
+
...input.type === "url" ? { url: input.url } : {},
|
|
148
|
+
...input.type === "file" ? { path: input.path } : {},
|
|
149
|
+
...input.type === "buffer" ? { fileName: input.fileName, bufferSize: input.buffer.byteLength } : {}
|
|
150
|
+
});
|
|
151
|
+
try {
|
|
152
|
+
if (options.mode === "hashinal" && options.metadata) {
|
|
153
|
+
validateHashinalMetadata(options.metadata, logger);
|
|
154
|
+
}
|
|
155
|
+
const accountId = signer.getAccountId().toString();
|
|
156
|
+
logger.debug("Using account ID from signer", { accountId });
|
|
157
|
+
let sdk;
|
|
158
|
+
if (existingSDK) {
|
|
159
|
+
logger.debug("Using existing InscriptionSDK instance");
|
|
160
|
+
sdk = existingSDK;
|
|
161
|
+
} else if (options.apiKey) {
|
|
162
|
+
logger.debug("Initializing InscriptionSDK with API key");
|
|
163
|
+
sdk = new InscriptionSDK({
|
|
164
|
+
apiKey: options.apiKey,
|
|
165
|
+
network: options.network || "mainnet"
|
|
166
|
+
});
|
|
167
|
+
} else {
|
|
168
|
+
logger.debug("Initializing InscriptionSDK with client auth");
|
|
169
|
+
sdk = await InscriptionSDK.createWithAuth({
|
|
170
|
+
type: "client",
|
|
171
|
+
accountId,
|
|
172
|
+
signer,
|
|
173
|
+
network: options.network || "mainnet"
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
const baseRequest = {
|
|
177
|
+
holderId: accountId,
|
|
178
|
+
metadata: options.metadata || {},
|
|
179
|
+
tags: options.tags || [],
|
|
180
|
+
mode: options.mode || "file",
|
|
181
|
+
chunkSize: options.chunkSize
|
|
182
|
+
};
|
|
183
|
+
let request;
|
|
184
|
+
switch (input.type) {
|
|
185
|
+
case "url":
|
|
186
|
+
request = {
|
|
187
|
+
...baseRequest,
|
|
188
|
+
file: {
|
|
189
|
+
type: "url",
|
|
190
|
+
url: input.url
|
|
191
|
+
}
|
|
192
|
+
};
|
|
193
|
+
break;
|
|
194
|
+
case "file":
|
|
195
|
+
request = {
|
|
196
|
+
...baseRequest,
|
|
197
|
+
file: {
|
|
198
|
+
type: "path",
|
|
199
|
+
path: input.path
|
|
200
|
+
}
|
|
201
|
+
};
|
|
202
|
+
break;
|
|
203
|
+
case "buffer":
|
|
204
|
+
request = {
|
|
205
|
+
...baseRequest,
|
|
206
|
+
file: {
|
|
207
|
+
type: "base64",
|
|
208
|
+
base64: Buffer.from(input.buffer).toString("base64"),
|
|
209
|
+
fileName: input.fileName,
|
|
210
|
+
mimeType: input.mimeType
|
|
211
|
+
}
|
|
212
|
+
};
|
|
213
|
+
break;
|
|
214
|
+
}
|
|
215
|
+
if (options.mode === "hashinal") {
|
|
216
|
+
request.metadataObject = options.metadata;
|
|
217
|
+
request.creator = options.metadata?.creator || accountId;
|
|
218
|
+
request.description = options.metadata?.description;
|
|
219
|
+
if (options.jsonFileURL) {
|
|
220
|
+
request.jsonFileURL = options.jsonFileURL;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
logger.debug("Preparing to inscribe content with signer", {
|
|
224
|
+
type: input.type,
|
|
225
|
+
mode: options.mode || "file",
|
|
226
|
+
holderId: accountId
|
|
227
|
+
});
|
|
228
|
+
const result = await sdk.inscribe(
|
|
229
|
+
{
|
|
230
|
+
...request,
|
|
231
|
+
holderId: accountId
|
|
232
|
+
},
|
|
233
|
+
signer
|
|
234
|
+
);
|
|
235
|
+
logger.info("Inscription started", {
|
|
236
|
+
type: input.type,
|
|
237
|
+
mode: options.mode || "file",
|
|
238
|
+
transactionId: result.jobId
|
|
239
|
+
});
|
|
240
|
+
if (options.waitForConfirmation) {
|
|
241
|
+
logger.debug("Waiting for inscription confirmation", {
|
|
242
|
+
transactionId: result.jobId,
|
|
243
|
+
maxAttempts: options.waitMaxAttempts,
|
|
244
|
+
intervalMs: options.waitIntervalMs
|
|
245
|
+
});
|
|
246
|
+
const inscription = await waitForInscriptionConfirmation(
|
|
247
|
+
sdk,
|
|
248
|
+
result.jobId,
|
|
249
|
+
options.waitMaxAttempts,
|
|
250
|
+
options.waitIntervalMs,
|
|
251
|
+
options.progressCallback
|
|
252
|
+
);
|
|
253
|
+
logger.info("Inscription confirmation received", {
|
|
254
|
+
transactionId: result.jobId
|
|
255
|
+
});
|
|
256
|
+
return {
|
|
257
|
+
confirmed: true,
|
|
258
|
+
result,
|
|
259
|
+
inscription,
|
|
260
|
+
sdk
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
return {
|
|
264
|
+
confirmed: false,
|
|
265
|
+
result,
|
|
266
|
+
sdk
|
|
267
|
+
};
|
|
268
|
+
} catch (error) {
|
|
269
|
+
logger.error("Error during inscription process", error);
|
|
270
|
+
throw error;
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
async function retrieveInscription(transactionId, options) {
|
|
274
|
+
const logger = Logger.getInstance({
|
|
275
|
+
module: "Inscriber",
|
|
276
|
+
...options?.logging || {}
|
|
277
|
+
});
|
|
278
|
+
const formattedTransactionId = transactionId.includes("@") ? `${transactionId.split("@")[0]}-${transactionId.split("@")[1].replace(/\./g, "-")}` : transactionId;
|
|
279
|
+
logger.info("Retrieving inscription", {
|
|
280
|
+
originalTransactionId: transactionId,
|
|
281
|
+
formattedTransactionId
|
|
282
|
+
});
|
|
283
|
+
try {
|
|
284
|
+
let sdk;
|
|
285
|
+
if (options?.apiKey) {
|
|
286
|
+
logger.debug("Initializing InscriptionSDK with API key");
|
|
287
|
+
sdk = new InscriptionSDK({
|
|
288
|
+
apiKey: options.apiKey,
|
|
289
|
+
network: options.network || "mainnet"
|
|
290
|
+
});
|
|
291
|
+
} else if (options?.accountId && options?.privateKey) {
|
|
292
|
+
logger.debug("Initializing InscriptionSDK with server auth");
|
|
293
|
+
sdk = await InscriptionSDK.createWithAuth({
|
|
294
|
+
type: "server",
|
|
295
|
+
accountId: options.accountId,
|
|
296
|
+
privateKey: options.privateKey,
|
|
297
|
+
network: options.network || "mainnet"
|
|
298
|
+
});
|
|
299
|
+
} else {
|
|
300
|
+
const error = new Error(
|
|
301
|
+
"Either API key or account ID and private key are required for retrieving inscriptions"
|
|
302
|
+
);
|
|
303
|
+
logger.error("Missing authentication credentials", {
|
|
304
|
+
hasApiKey: Boolean(options?.apiKey),
|
|
305
|
+
hasAccountId: Boolean(options?.accountId),
|
|
306
|
+
hasPrivateKey: Boolean(options?.privateKey)
|
|
307
|
+
});
|
|
308
|
+
throw error;
|
|
309
|
+
}
|
|
310
|
+
logger.debug("Initialized SDK for inscription retrieval", {
|
|
311
|
+
formattedTransactionId,
|
|
312
|
+
network: options.network || "mainnet"
|
|
313
|
+
});
|
|
314
|
+
const result = await sdk.retrieveInscription(formattedTransactionId);
|
|
315
|
+
logger.info("Successfully retrieved inscription", {
|
|
316
|
+
formattedTransactionId
|
|
317
|
+
});
|
|
318
|
+
return result;
|
|
319
|
+
} catch (error) {
|
|
320
|
+
logger.error("Error retrieving inscription", {
|
|
321
|
+
formattedTransactionId,
|
|
322
|
+
error
|
|
323
|
+
});
|
|
324
|
+
throw error;
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
function validateHashinalMetadata(metadata, logger) {
|
|
328
|
+
const requiredFields = ["name", "creator", "description", "type"];
|
|
329
|
+
const missingFields = requiredFields.filter((field) => !metadata[field]);
|
|
330
|
+
if (missingFields.length > 0) {
|
|
331
|
+
const error = new Error(
|
|
332
|
+
`Missing required Hashinal metadata fields: ${missingFields.join(", ")}`
|
|
333
|
+
);
|
|
334
|
+
logger.error("Hashinal metadata validation failed", { missingFields });
|
|
335
|
+
throw error;
|
|
336
|
+
}
|
|
337
|
+
logger.debug("Hashinal metadata validation passed", {
|
|
338
|
+
name: metadata.name,
|
|
339
|
+
creator: metadata.creator,
|
|
340
|
+
description: metadata.description,
|
|
341
|
+
type: metadata.type,
|
|
342
|
+
hasAttributes: !!metadata.attributes,
|
|
343
|
+
hasProperties: !!metadata.properties
|
|
344
|
+
});
|
|
345
|
+
}
|
|
346
|
+
async function waitForInscriptionConfirmation(sdk, transactionId, maxAttempts = 30, intervalMs = 4e3, progressCallback) {
|
|
347
|
+
const logger = Logger.getInstance({ module: "Inscriber" });
|
|
348
|
+
const progressReporter = new ProgressReporter({
|
|
349
|
+
module: "Inscriber",
|
|
350
|
+
logger,
|
|
351
|
+
callback: progressCallback
|
|
352
|
+
});
|
|
353
|
+
try {
|
|
354
|
+
logger.debug("Waiting for inscription confirmation", {
|
|
355
|
+
transactionId,
|
|
356
|
+
maxAttempts,
|
|
357
|
+
intervalMs
|
|
358
|
+
});
|
|
359
|
+
progressReporter.preparing("Preparing for inscription confirmation", 5, {
|
|
360
|
+
transactionId,
|
|
361
|
+
maxAttempts,
|
|
362
|
+
intervalMs
|
|
363
|
+
});
|
|
364
|
+
try {
|
|
365
|
+
const waitMethod = sdk.waitForInscription.bind(sdk);
|
|
366
|
+
const wrappedCallback = (data) => {
|
|
367
|
+
const stage = data.stage || "confirming";
|
|
368
|
+
const message = data.message || "Processing inscription";
|
|
369
|
+
const percent = data.progressPercent || 50;
|
|
370
|
+
progressReporter.report({
|
|
371
|
+
stage,
|
|
372
|
+
message,
|
|
373
|
+
progressPercent: percent,
|
|
374
|
+
details: {}
|
|
375
|
+
});
|
|
376
|
+
};
|
|
377
|
+
return await waitMethod(
|
|
378
|
+
transactionId,
|
|
379
|
+
maxAttempts,
|
|
380
|
+
intervalMs,
|
|
381
|
+
true,
|
|
382
|
+
wrappedCallback
|
|
383
|
+
);
|
|
384
|
+
} catch (e) {
|
|
385
|
+
console.log(e);
|
|
386
|
+
logger.debug("Falling back to standard waitForInscription method", {
|
|
387
|
+
error: e
|
|
388
|
+
});
|
|
389
|
+
progressReporter.verifying("Verifying inscription status", 50, {
|
|
390
|
+
error: e
|
|
391
|
+
});
|
|
392
|
+
return await sdk.waitForInscription(
|
|
393
|
+
transactionId,
|
|
394
|
+
maxAttempts,
|
|
395
|
+
intervalMs,
|
|
396
|
+
true
|
|
397
|
+
);
|
|
398
|
+
}
|
|
399
|
+
} catch (error) {
|
|
400
|
+
logger.error("Error waiting for inscription confirmation", {
|
|
401
|
+
transactionId,
|
|
402
|
+
maxAttempts,
|
|
403
|
+
intervalMs,
|
|
404
|
+
error
|
|
405
|
+
});
|
|
406
|
+
progressReporter.failed("Inscription confirmation failed", {
|
|
407
|
+
transactionId,
|
|
408
|
+
error
|
|
409
|
+
});
|
|
410
|
+
throw error;
|
|
411
|
+
}
|
|
4
412
|
}
|
|
5
413
|
export {
|
|
6
|
-
|
|
414
|
+
inscribe,
|
|
415
|
+
inscribeWithSigner,
|
|
416
|
+
retrieveInscription,
|
|
417
|
+
waitForInscriptionConfirmation
|
|
7
418
|
};
|
|
8
419
|
//# sourceMappingURL=standards-sdk.es41.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es41.js","sources":["../../src/utils/topic-id-utils.ts"],"sourcesContent":["/**\n * Utility functions for safely handling topic ID properties that may use different naming conventions\n */\n\n/**\n * Safely extracts topic ID from an inscription result object that may have either `topicId` or `topic_id`\n * @param inscription - The inscription result object\n * @returns The topic ID string or undefined if not found\n */\nexport function getTopicId(inscription: any): string | undefined {\n if (!inscription) return undefined;\n\n return inscription.topicId ?? inscription.topic_id;\n}\n"],"names":[],"mappings":"AASO,SAAS,WAAW,aAAsC;AAC/D,MAAI,CAAC,YAAa,QAAO;AAEzB,SAAO,YAAY,WAAW,YAAY;AAC5C;"}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es41.js","sources":["../../src/inscribe/inscriber.ts"],"sourcesContent":["import { InscriptionSDK } from '@kiloscribe/inscription-sdk';\nimport {\n InscriptionOptions,\n InscriptionResult,\n RetrievedInscriptionResult,\n HederaClientConfig,\n} from './types';\nimport type { DAppSigner } from '@hashgraph/hedera-wallet-connect';\nimport { Logger } from '../utils/logger';\nimport { ProgressCallback, ProgressReporter } from '../utils/progress-reporter';\n\nexport type InscriptionInput =\n | { type: 'url'; url: string }\n | { type: 'file'; path: string }\n | {\n type: 'buffer';\n buffer: ArrayBuffer | Buffer;\n fileName: string;\n mimeType?: string;\n };\n\nexport type InscriptionResponse =\n | { confirmed: false; result: InscriptionResult; sdk: InscriptionSDK }\n | {\n confirmed: true;\n result: InscriptionResult;\n inscription: RetrievedInscriptionResult;\n sdk: InscriptionSDK;\n };\n\nexport async function inscribe(\n input: InscriptionInput,\n clientConfig: HederaClientConfig,\n options: InscriptionOptions,\n existingSDK?: InscriptionSDK,\n): Promise<InscriptionResponse> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...options.logging,\n });\n\n logger.info('Starting inscription process', {\n type: input.type,\n mode: options.mode || 'file',\n ...(input.type === 'url' ? { url: input.url } : {}),\n ...(input.type === 'file' ? { path: input.path } : {}),\n ...(input.type === 'buffer'\n ? { fileName: input.fileName, bufferSize: input.buffer.byteLength }\n : {}),\n });\n\n try {\n if (options.mode === 'hashinal' && options.metadata) {\n validateHashinalMetadata(options.metadata, logger);\n }\n\n let sdk: InscriptionSDK;\n\n if (existingSDK) {\n logger.debug('Using existing InscriptionSDK instance');\n sdk = existingSDK;\n } else if (options.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: clientConfig.network || 'mainnet',\n });\n } else {\n logger.debug('Initializing InscriptionSDK with server auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'server',\n accountId: clientConfig.accountId,\n privateKey: clientConfig.privateKey,\n network: clientConfig.network || 'mainnet',\n });\n }\n\n const baseRequest = {\n holderId: clientConfig.accountId,\n metadata: options.metadata || {},\n tags: options.tags || [],\n mode: options.mode || 'file',\n chunkSize: options.chunkSize,\n };\n\n let request: any;\n switch (input.type) {\n case 'url':\n request = {\n ...baseRequest,\n file: {\n type: 'url',\n url: input.url,\n },\n };\n break;\n\n case 'file':\n request = {\n ...baseRequest,\n file: {\n type: 'path',\n path: input.path,\n },\n };\n break;\n\n case 'buffer':\n request = {\n ...baseRequest,\n file: {\n type: 'base64',\n base64: Buffer.from(input.buffer).toString('base64'),\n fileName: input.fileName,\n mimeType: input.mimeType,\n },\n };\n break;\n }\n\n if (options.mode === 'hashinal') {\n request.metadataObject = options.metadata;\n request.creator = options.metadata?.creator || clientConfig.accountId;\n request.description = options.metadata?.description;\n\n if (options.jsonFileURL) {\n request.jsonFileURL = options.jsonFileURL;\n }\n }\n\n logger.debug('Preparing to inscribe content', {\n type: input.type,\n mode: options.mode || 'file',\n holderId: clientConfig.accountId,\n });\n\n const result = await sdk.inscribeAndExecute(request, clientConfig);\n logger.info('Starting to inscribe.', {\n type: input.type,\n mode: options.mode || 'file',\n transactionId: result.jobId,\n });\n\n if (result.completed && options.waitForConfirmation) {\n const inscription = result as RetrievedInscriptionResult;\n\n return {\n confirmed: true,\n result,\n inscription,\n sdk,\n };\n }\n\n if (options.waitForConfirmation) {\n console.log('Waiting for inscription confirmation', {\n transactionId: result.jobId,\n maxAttempts: options.waitMaxAttempts,\n intervalMs: options.waitIntervalMs,\n });\n\n const inscription = await waitForInscriptionConfirmation(\n sdk,\n result.jobId,\n options.waitMaxAttempts,\n options.waitIntervalMs,\n options.progressCallback,\n );\n\n logger.info('Inscription confirmation received', {\n transactionId: result.jobId,\n });\n\n return {\n confirmed: true,\n result,\n inscription,\n sdk,\n };\n }\n\n return {\n confirmed: false,\n result,\n sdk,\n };\n } catch (error) {\n logger.error('Error during inscription process', error);\n throw error;\n }\n}\n\nexport async function inscribeWithSigner(\n input: InscriptionInput,\n signer: DAppSigner,\n options: InscriptionOptions,\n existingSDK?: InscriptionSDK,\n): Promise<InscriptionResponse> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...options.logging,\n });\n\n logger.info('Starting inscription process with signer', {\n type: input.type,\n mode: options.mode || 'file',\n ...(input.type === 'url' ? { url: input.url } : {}),\n ...(input.type === 'file' ? { path: input.path } : {}),\n ...(input.type === 'buffer'\n ? { fileName: input.fileName, bufferSize: input.buffer.byteLength }\n : {}),\n });\n\n try {\n if (options.mode === 'hashinal' && options.metadata) {\n validateHashinalMetadata(options.metadata, logger);\n }\n\n const accountId = signer.getAccountId().toString();\n logger.debug('Using account ID from signer', { accountId });\n\n let sdk: InscriptionSDK;\n\n if (existingSDK) {\n logger.debug('Using existing InscriptionSDK instance');\n sdk = existingSDK;\n } else if (options.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: options.network || 'mainnet',\n });\n } else {\n logger.debug('Initializing InscriptionSDK with client auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'client',\n accountId,\n signer: signer,\n network: options.network || 'mainnet',\n });\n }\n\n const baseRequest = {\n holderId: accountId,\n metadata: options.metadata || {},\n tags: options.tags || [],\n mode: options.mode || 'file',\n chunkSize: options.chunkSize,\n };\n\n let request: any;\n switch (input.type) {\n case 'url':\n request = {\n ...baseRequest,\n file: {\n type: 'url',\n url: input.url,\n },\n };\n break;\n\n case 'file':\n request = {\n ...baseRequest,\n file: {\n type: 'path',\n path: input.path,\n },\n };\n break;\n\n case 'buffer':\n request = {\n ...baseRequest,\n file: {\n type: 'base64',\n base64: Buffer.from(input.buffer).toString('base64'),\n fileName: input.fileName,\n mimeType: input.mimeType,\n },\n };\n break;\n }\n\n if (options.mode === 'hashinal') {\n request.metadataObject = options.metadata;\n request.creator = options.metadata?.creator || accountId;\n request.description = options.metadata?.description;\n\n if (options.jsonFileURL) {\n request.jsonFileURL = options.jsonFileURL;\n }\n }\n\n logger.debug('Preparing to inscribe content with signer', {\n type: input.type,\n mode: options.mode || 'file',\n holderId: accountId,\n });\n\n const result = await sdk.inscribe(\n {\n ...request,\n holderId: accountId,\n },\n signer,\n );\n logger.info('Inscription started', {\n type: input.type,\n mode: options.mode || 'file',\n transactionId: result.jobId,\n });\n\n if (options.waitForConfirmation) {\n logger.debug('Waiting for inscription confirmation', {\n transactionId: result.jobId,\n maxAttempts: options.waitMaxAttempts,\n intervalMs: options.waitIntervalMs,\n });\n\n const inscription = await waitForInscriptionConfirmation(\n sdk,\n result.jobId,\n options.waitMaxAttempts,\n options.waitIntervalMs,\n options.progressCallback,\n );\n\n logger.info('Inscription confirmation received', {\n transactionId: result.jobId,\n });\n\n return {\n confirmed: true,\n result,\n inscription,\n sdk,\n };\n }\n\n return {\n confirmed: false,\n result,\n sdk,\n };\n } catch (error) {\n logger.error('Error during inscription process', error);\n throw error;\n }\n}\n\nexport async function retrieveInscription(\n transactionId: string,\n options: InscriptionOptions & { accountId?: string; privateKey?: string },\n): Promise<RetrievedInscriptionResult> {\n const logger = Logger.getInstance({\n module: 'Inscriber',\n ...(options?.logging || {}),\n });\n\n const formattedTransactionId = transactionId.includes('@')\n ? `${transactionId.split('@')[0]}-${transactionId\n .split('@')[1]\n .replace(/\\./g, '-')}`\n : transactionId;\n\n logger.info('Retrieving inscription', {\n originalTransactionId: transactionId,\n formattedTransactionId,\n });\n\n try {\n let sdk: InscriptionSDK;\n\n if (options?.apiKey) {\n logger.debug('Initializing InscriptionSDK with API key');\n sdk = new InscriptionSDK({\n apiKey: options.apiKey,\n network: options.network || 'mainnet',\n });\n } else if (options?.accountId && options?.privateKey) {\n logger.debug('Initializing InscriptionSDK with server auth');\n sdk = await InscriptionSDK.createWithAuth({\n type: 'server',\n accountId: options.accountId,\n privateKey: options.privateKey,\n network: options.network || 'mainnet',\n });\n } else {\n const error = new Error(\n 'Either API key or account ID and private key are required for retrieving inscriptions',\n );\n logger.error('Missing authentication credentials', {\n hasApiKey: Boolean(options?.apiKey),\n hasAccountId: Boolean(options?.accountId),\n hasPrivateKey: Boolean(options?.privateKey),\n });\n throw error;\n }\n\n logger.debug('Initialized SDK for inscription retrieval', {\n formattedTransactionId,\n network: options.network || 'mainnet',\n });\n\n const result = await sdk.retrieveInscription(formattedTransactionId);\n logger.info('Successfully retrieved inscription', {\n formattedTransactionId,\n });\n\n return result;\n } catch (error) {\n logger.error('Error retrieving inscription', {\n formattedTransactionId,\n error,\n });\n throw error;\n }\n}\n\nfunction validateHashinalMetadata(metadata: any, logger: any): void {\n const requiredFields = ['name', 'creator', 'description', 'type'];\n const missingFields = requiredFields.filter(field => !metadata[field]);\n\n if (missingFields.length > 0) {\n const error = new Error(\n `Missing required Hashinal metadata fields: ${missingFields.join(', ')}`,\n );\n logger.error('Hashinal metadata validation failed', { missingFields });\n throw error;\n }\n\n logger.debug('Hashinal metadata validation passed', {\n name: metadata.name,\n creator: metadata.creator,\n description: metadata.description,\n type: metadata.type,\n hasAttributes: !!metadata.attributes,\n hasProperties: !!metadata.properties,\n });\n}\n\nexport async function waitForInscriptionConfirmation(\n sdk: InscriptionSDK,\n transactionId: string,\n maxAttempts: number = 30,\n intervalMs: number = 4000,\n progressCallback?: ProgressCallback,\n): Promise<RetrievedInscriptionResult> {\n const logger = Logger.getInstance({ module: 'Inscriber' });\n const progressReporter = new ProgressReporter({\n module: 'Inscriber',\n logger,\n callback: progressCallback,\n });\n\n try {\n logger.debug('Waiting for inscription confirmation', {\n transactionId,\n maxAttempts,\n intervalMs,\n });\n\n progressReporter.preparing('Preparing for inscription confirmation', 5, {\n transactionId,\n maxAttempts,\n intervalMs,\n });\n\n try {\n const waitMethod = sdk.waitForInscription.bind(sdk) as (\n txId: string,\n maxAttempts: number,\n intervalMs: number,\n checkCompletion: boolean,\n progressCallback?: Function,\n ) => Promise<RetrievedInscriptionResult>;\n\n const wrappedCallback = (data: any) => {\n const stage = data.stage || 'confirming';\n const message = data.message || 'Processing inscription';\n const percent = data.progressPercent || 50;\n\n progressReporter.report({\n stage: stage,\n message: message,\n progressPercent: percent,\n details: {},\n });\n };\n\n return await waitMethod(\n transactionId,\n maxAttempts,\n intervalMs,\n true,\n wrappedCallback,\n );\n } catch (e) {\n console.log(e);\n\n logger.debug('Falling back to standard waitForInscription method', {\n error: e,\n });\n progressReporter.verifying('Verifying inscription status', 50, {\n error: e,\n });\n\n return await sdk.waitForInscription(\n transactionId,\n maxAttempts,\n intervalMs,\n true,\n );\n }\n } catch (error) {\n logger.error('Error waiting for inscription confirmation', {\n transactionId,\n maxAttempts,\n intervalMs,\n error,\n });\n\n progressReporter.failed('Inscription confirmation failed', {\n transactionId,\n error,\n });\n\n throw error;\n }\n}\n"],"names":[],"mappings":";;;AA8BA,eAAsB,SACpB,OACA,cACA,SACA,aAC8B;AAC9B,QAAM,SAAS,OAAO,YAAY;AAAA,IAChC,QAAQ;AAAA,IACR,GAAG,QAAQ;AAAA,EAAA,CACZ;AAED,SAAO,KAAK,gCAAgC;AAAA,IAC1C,MAAM,MAAM;AAAA,IACZ,MAAM,QAAQ,QAAQ;AAAA,IACtB,GAAI,MAAM,SAAS,QAAQ,EAAE,KAAK,MAAM,IAAA,IAAQ,CAAA;AAAA,IAChD,GAAI,MAAM,SAAS,SAAS,EAAE,MAAM,MAAM,KAAA,IAAS,CAAA;AAAA,IACnD,GAAI,MAAM,SAAS,WACf,EAAE,UAAU,MAAM,UAAU,YAAY,MAAM,OAAO,WAAA,IACrD,CAAA;AAAA,EAAC,CACN;AAED,MAAI;AACF,QAAI,QAAQ,SAAS,cAAc,QAAQ,UAAU;AACnD,+BAAyB,QAAQ,UAAU,MAAM;AAAA,IACnD;AAEA,QAAI;AAEJ,QAAI,aAAa;AACf,aAAO,MAAM,wCAAwC;AACrD,YAAM;AAAA,IACR,WAAW,QAAQ,QAAQ;AACzB,aAAO,MAAM,0CAA0C;AACvD,YAAM,IAAI,eAAe;AAAA,QACvB,QAAQ,QAAQ;AAAA,QAChB,SAAS,aAAa,WAAW;AAAA,MAAA,CAClC;AAAA,IACH,OAAO;AACL,aAAO,MAAM,8CAA8C;AAC3D,YAAM,MAAM,eAAe,eAAe;AAAA,QACxC,MAAM;AAAA,QACN,WAAW,aAAa;AAAA,QACxB,YAAY,aAAa;AAAA,QACzB,SAAS,aAAa,WAAW;AAAA,MAAA,CAClC;AAAA,IACH;AAEA,UAAM,cAAc;AAAA,MAClB,UAAU,aAAa;AAAA,MACvB,UAAU,QAAQ,YAAY,CAAA;AAAA,MAC9B,MAAM,QAAQ,QAAQ,CAAA;AAAA,MACtB,MAAM,QAAQ,QAAQ;AAAA,MACtB,WAAW,QAAQ;AAAA,IAAA;AAGrB,QAAI;AACJ,YAAQ,MAAM,MAAA;AAAA,MACZ,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,KAAK,MAAM;AAAA,UAAA;AAAA,QACb;AAEF;AAAA,MAEF,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,MAAM,MAAM;AAAA,UAAA;AAAA,QACd;AAEF;AAAA,MAEF,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,QAAQ,OAAO,KAAK,MAAM,MAAM,EAAE,SAAS,QAAQ;AAAA,YACnD,UAAU,MAAM;AAAA,YAChB,UAAU,MAAM;AAAA,UAAA;AAAA,QAClB;AAEF;AAAA,IAAA;AAGJ,QAAI,QAAQ,SAAS,YAAY;AAC/B,cAAQ,iBAAiB,QAAQ;AACjC,cAAQ,UAAU,QAAQ,UAAU,WAAW,aAAa;AAC5D,cAAQ,cAAc,QAAQ,UAAU;AAExC,UAAI,QAAQ,aAAa;AACvB,gBAAQ,cAAc,QAAQ;AAAA,MAChC;AAAA,IACF;AAEA,WAAO,MAAM,iCAAiC;AAAA,MAC5C,MAAM,MAAM;AAAA,MACZ,MAAM,QAAQ,QAAQ;AAAA,MACtB,UAAU,aAAa;AAAA,IAAA,CACxB;AAED,UAAM,SAAS,MAAM,IAAI,mBAAmB,SAAS,YAAY;AACjE,WAAO,KAAK,yBAAyB;AAAA,MACnC,MAAM,MAAM;AAAA,MACZ,MAAM,QAAQ,QAAQ;AAAA,MACtB,eAAe,OAAO;AAAA,IAAA,CACvB;AAED,QAAI,OAAO,aAAa,QAAQ,qBAAqB;AACnD,YAAM,cAAc;AAEpB,aAAO;AAAA,QACL,WAAW;AAAA,QACX;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ;AAEA,QAAI,QAAQ,qBAAqB;AAC/B,cAAQ,IAAI,wCAAwC;AAAA,QAClD,eAAe,OAAO;AAAA,QACtB,aAAa,QAAQ;AAAA,QACrB,YAAY,QAAQ;AAAA,MAAA,CACrB;AAED,YAAM,cAAc,MAAM;AAAA,QACxB;AAAA,QACA,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,QAAQ;AAAA,MAAA;AAGV,aAAO,KAAK,qCAAqC;AAAA,QAC/C,eAAe,OAAO;AAAA,MAAA,CACvB;AAED,aAAO;AAAA,QACL,WAAW;AAAA,QACX;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ;AAEA,WAAO;AAAA,MACL,WAAW;AAAA,MACX;AAAA,MACA;AAAA,IAAA;AAAA,EAEJ,SAAS,OAAO;AACd,WAAO,MAAM,oCAAoC,KAAK;AACtD,UAAM;AAAA,EACR;AACF;AAEA,eAAsB,mBACpB,OACA,QACA,SACA,aAC8B;AAC9B,QAAM,SAAS,OAAO,YAAY;AAAA,IAChC,QAAQ;AAAA,IACR,GAAG,QAAQ;AAAA,EAAA,CACZ;AAED,SAAO,KAAK,4CAA4C;AAAA,IACtD,MAAM,MAAM;AAAA,IACZ,MAAM,QAAQ,QAAQ;AAAA,IACtB,GAAI,MAAM,SAAS,QAAQ,EAAE,KAAK,MAAM,IAAA,IAAQ,CAAA;AAAA,IAChD,GAAI,MAAM,SAAS,SAAS,EAAE,MAAM,MAAM,KAAA,IAAS,CAAA;AAAA,IACnD,GAAI,MAAM,SAAS,WACf,EAAE,UAAU,MAAM,UAAU,YAAY,MAAM,OAAO,WAAA,IACrD,CAAA;AAAA,EAAC,CACN;AAED,MAAI;AACF,QAAI,QAAQ,SAAS,cAAc,QAAQ,UAAU;AACnD,+BAAyB,QAAQ,UAAU,MAAM;AAAA,IACnD;AAEA,UAAM,YAAY,OAAO,aAAA,EAAe,SAAA;AACxC,WAAO,MAAM,gCAAgC,EAAE,UAAA,CAAW;AAE1D,QAAI;AAEJ,QAAI,aAAa;AACf,aAAO,MAAM,wCAAwC;AACrD,YAAM;AAAA,IACR,WAAW,QAAQ,QAAQ;AACzB,aAAO,MAAM,0CAA0C;AACvD,YAAM,IAAI,eAAe;AAAA,QACvB,QAAQ,QAAQ;AAAA,QAChB,SAAS,QAAQ,WAAW;AAAA,MAAA,CAC7B;AAAA,IACH,OAAO;AACL,aAAO,MAAM,8CAA8C;AAC3D,YAAM,MAAM,eAAe,eAAe;AAAA,QACxC,MAAM;AAAA,QACN;AAAA,QACA;AAAA,QACA,SAAS,QAAQ,WAAW;AAAA,MAAA,CAC7B;AAAA,IACH;AAEA,UAAM,cAAc;AAAA,MAClB,UAAU;AAAA,MACV,UAAU,QAAQ,YAAY,CAAA;AAAA,MAC9B,MAAM,QAAQ,QAAQ,CAAA;AAAA,MACtB,MAAM,QAAQ,QAAQ;AAAA,MACtB,WAAW,QAAQ;AAAA,IAAA;AAGrB,QAAI;AACJ,YAAQ,MAAM,MAAA;AAAA,MACZ,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,KAAK,MAAM;AAAA,UAAA;AAAA,QACb;AAEF;AAAA,MAEF,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,MAAM,MAAM;AAAA,UAAA;AAAA,QACd;AAEF;AAAA,MAEF,KAAK;AACH,kBAAU;AAAA,UACR,GAAG;AAAA,UACH,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,QAAQ,OAAO,KAAK,MAAM,MAAM,EAAE,SAAS,QAAQ;AAAA,YACnD,UAAU,MAAM;AAAA,YAChB,UAAU,MAAM;AAAA,UAAA;AAAA,QAClB;AAEF;AAAA,IAAA;AAGJ,QAAI,QAAQ,SAAS,YAAY;AAC/B,cAAQ,iBAAiB,QAAQ;AACjC,cAAQ,UAAU,QAAQ,UAAU,WAAW;AAC/C,cAAQ,cAAc,QAAQ,UAAU;AAExC,UAAI,QAAQ,aAAa;AACvB,gBAAQ,cAAc,QAAQ;AAAA,MAChC;AAAA,IACF;AAEA,WAAO,MAAM,6CAA6C;AAAA,MACxD,MAAM,MAAM;AAAA,MACZ,MAAM,QAAQ,QAAQ;AAAA,MACtB,UAAU;AAAA,IAAA,CACX;AAED,UAAM,SAAS,MAAM,IAAI;AAAA,MACvB;AAAA,QACE,GAAG;AAAA,QACH,UAAU;AAAA,MAAA;AAAA,MAEZ;AAAA,IAAA;AAEF,WAAO,KAAK,uBAAuB;AAAA,MACjC,MAAM,MAAM;AAAA,MACZ,MAAM,QAAQ,QAAQ;AAAA,MACtB,eAAe,OAAO;AAAA,IAAA,CACvB;AAED,QAAI,QAAQ,qBAAqB;AAC/B,aAAO,MAAM,wCAAwC;AAAA,QACnD,eAAe,OAAO;AAAA,QACtB,aAAa,QAAQ;AAAA,QACrB,YAAY,QAAQ;AAAA,MAAA,CACrB;AAED,YAAM,cAAc,MAAM;AAAA,QACxB;AAAA,QACA,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,QAAQ;AAAA,MAAA;AAGV,aAAO,KAAK,qCAAqC;AAAA,QAC/C,eAAe,OAAO;AAAA,MAAA,CACvB;AAED,aAAO;AAAA,QACL,WAAW;AAAA,QACX;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ;AAEA,WAAO;AAAA,MACL,WAAW;AAAA,MACX;AAAA,MACA;AAAA,IAAA;AAAA,EAEJ,SAAS,OAAO;AACd,WAAO,MAAM,oCAAoC,KAAK;AACtD,UAAM;AAAA,EACR;AACF;AAEA,eAAsB,oBACpB,eACA,SACqC;AACrC,QAAM,SAAS,OAAO,YAAY;AAAA,IAChC,QAAQ;AAAA,IACR,GAAI,SAAS,WAAW,CAAA;AAAA,EAAC,CAC1B;AAED,QAAM,yBAAyB,cAAc,SAAS,GAAG,IACrD,GAAG,cAAc,MAAM,GAAG,EAAE,CAAC,CAAC,IAAI,cAC/B,MAAM,GAAG,EAAE,CAAC,EACZ,QAAQ,OAAO,GAAG,CAAC,KACtB;AAEJ,SAAO,KAAK,0BAA0B;AAAA,IACpC,uBAAuB;AAAA,IACvB;AAAA,EAAA,CACD;AAED,MAAI;AACF,QAAI;AAEJ,QAAI,SAAS,QAAQ;AACnB,aAAO,MAAM,0CAA0C;AACvD,YAAM,IAAI,eAAe;AAAA,QACvB,QAAQ,QAAQ;AAAA,QAChB,SAAS,QAAQ,WAAW;AAAA,MAAA,CAC7B;AAAA,IACH,WAAW,SAAS,aAAa,SAAS,YAAY;AACpD,aAAO,MAAM,8CAA8C;AAC3D,YAAM,MAAM,eAAe,eAAe;AAAA,QACxC,MAAM;AAAA,QACN,WAAW,QAAQ;AAAA,QACnB,YAAY,QAAQ;AAAA,QACpB,SAAS,QAAQ,WAAW;AAAA,MAAA,CAC7B;AAAA,IACH,OAAO;AACL,YAAM,QAAQ,IAAI;AAAA,QAChB;AAAA,MAAA;AAEF,aAAO,MAAM,sCAAsC;AAAA,QACjD,WAAW,QAAQ,SAAS,MAAM;AAAA,QAClC,cAAc,QAAQ,SAAS,SAAS;AAAA,QACxC,eAAe,QAAQ,SAAS,UAAU;AAAA,MAAA,CAC3C;AACD,YAAM;AAAA,IACR;AAEA,WAAO,MAAM,6CAA6C;AAAA,MACxD;AAAA,MACA,SAAS,QAAQ,WAAW;AAAA,IAAA,CAC7B;AAED,UAAM,SAAS,MAAM,IAAI,oBAAoB,sBAAsB;AACnE,WAAO,KAAK,sCAAsC;AAAA,MAChD;AAAA,IAAA,CACD;AAED,WAAO;AAAA,EACT,SAAS,OAAO;AACd,WAAO,MAAM,gCAAgC;AAAA,MAC3C;AAAA,MACA;AAAA,IAAA,CACD;AACD,UAAM;AAAA,EACR;AACF;AAEA,SAAS,yBAAyB,UAAe,QAAmB;AAClE,QAAM,iBAAiB,CAAC,QAAQ,WAAW,eAAe,MAAM;AAChE,QAAM,gBAAgB,eAAe,OAAO,WAAS,CAAC,SAAS,KAAK,CAAC;AAErE,MAAI,cAAc,SAAS,GAAG;AAC5B,UAAM,QAAQ,IAAI;AAAA,MAChB,8CAA8C,cAAc,KAAK,IAAI,CAAC;AAAA,IAAA;AAExE,WAAO,MAAM,uCAAuC,EAAE,cAAA,CAAe;AACrE,UAAM;AAAA,EACR;AAEA,SAAO,MAAM,uCAAuC;AAAA,IAClD,MAAM,SAAS;AAAA,IACf,SAAS,SAAS;AAAA,IAClB,aAAa,SAAS;AAAA,IACtB,MAAM,SAAS;AAAA,IACf,eAAe,CAAC,CAAC,SAAS;AAAA,IAC1B,eAAe,CAAC,CAAC,SAAS;AAAA,EAAA,CAC3B;AACH;AAEA,eAAsB,+BACpB,KACA,eACA,cAAsB,IACtB,aAAqB,KACrB,kBACqC;AACrC,QAAM,SAAS,OAAO,YAAY,EAAE,QAAQ,aAAa;AACzD,QAAM,mBAAmB,IAAI,iBAAiB;AAAA,IAC5C,QAAQ;AAAA,IACR;AAAA,IACA,UAAU;AAAA,EAAA,CACX;AAED,MAAI;AACF,WAAO,MAAM,wCAAwC;AAAA,MACnD;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAED,qBAAiB,UAAU,0CAA0C,GAAG;AAAA,MACtE;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAED,QAAI;AACF,YAAM,aAAa,IAAI,mBAAmB,KAAK,GAAG;AAQlD,YAAM,kBAAkB,CAAC,SAAc;AACrC,cAAM,QAAQ,KAAK,SAAS;AAC5B,cAAM,UAAU,KAAK,WAAW;AAChC,cAAM,UAAU,KAAK,mBAAmB;AAExC,yBAAiB,OAAO;AAAA,UACtB;AAAA,UACA;AAAA,UACA,iBAAiB;AAAA,UACjB,SAAS,CAAA;AAAA,QAAC,CACX;AAAA,MACH;AAEA,aAAO,MAAM;AAAA,QACX;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ,SAAS,GAAG;AACV,cAAQ,IAAI,CAAC;AAEb,aAAO,MAAM,sDAAsD;AAAA,QACjE,OAAO;AAAA,MAAA,CACR;AACD,uBAAiB,UAAU,gCAAgC,IAAI;AAAA,QAC7D,OAAO;AAAA,MAAA,CACR;AAED,aAAO,MAAM,IAAI;AAAA,QACf;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ;AAAA,EACF,SAAS,OAAO;AACd,WAAO,MAAM,8CAA8C;AAAA,MACzD;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,CACD;AAED,qBAAiB,OAAO,mCAAmC;AAAA,MACzD;AAAA,MACA;AAAA,IAAA,CACD;AAED,UAAM;AAAA,EACR;AACF;"}
|