@canton-network/core-tx-visualizer 0.9.0 → 0.11.0

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/index.cjs ADDED
@@ -0,0 +1,563 @@
1
+ 'use strict';
2
+
3
+ var coreLedgerProto = require('@canton-network/core-ledger-proto');
4
+
5
+ // src/index.ts
6
+
7
+ // src/utils.ts
8
+ function fromBase64(b64) {
9
+ const binaryString = atob(b64);
10
+ const len = binaryString.length;
11
+ const bytes = new Uint8Array(len);
12
+ for (let i = 0; i < len; i++) {
13
+ bytes[i] = binaryString.charCodeAt(i);
14
+ }
15
+ return bytes;
16
+ }
17
+ function toBase64(data) {
18
+ let binaryString = "";
19
+ const len = data.byteLength;
20
+ for (let i = 0; i < len; i++) {
21
+ binaryString += String.fromCharCode(data[i]);
22
+ }
23
+ return btoa(binaryString);
24
+ }
25
+ function toHex(bytes) {
26
+ return Array.from(bytes).map((byte) => byte.toString(16).padStart(2, "0")).join("");
27
+ }
28
+ async function sha256(message) {
29
+ const msg = typeof message === "string" ? new TextEncoder().encode(message) : message;
30
+ return crypto.subtle.digest("SHA-256", new Uint8Array(msg)).then((hash) => new Uint8Array(hash));
31
+ }
32
+ async function mkByteArray(...args) {
33
+ const normalizedArgs = args.map((arg) => {
34
+ if (typeof arg === "number") {
35
+ return new Uint8Array([arg]);
36
+ } else {
37
+ return arg;
38
+ }
39
+ });
40
+ let totalLength = 0;
41
+ normalizedArgs.forEach((arg) => {
42
+ totalLength += arg.length;
43
+ });
44
+ const mergedArray = new Uint8Array(totalLength);
45
+ let offset = 0;
46
+ normalizedArgs.forEach((arg) => {
47
+ mergedArray.set(arg, offset);
48
+ offset += arg.length;
49
+ });
50
+ return mergedArray;
51
+ }
52
+
53
+ // src/hashing_scheme_v2.ts
54
+ var PREPARED_TRANSACTION_HASH_PURPOSE = Uint8Array.from([
55
+ 0,
56
+ 0,
57
+ 0,
58
+ 48
59
+ ]);
60
+ var NODE_ENCODING_VERSION = Uint8Array.from([1]);
61
+ var HASHING_SCHEME_VERSION = Uint8Array.from([coreLedgerProto.HashingSchemeVersion.V2]);
62
+ async function encodeBool(value) {
63
+ return new Uint8Array([value ? 1 : 0]);
64
+ }
65
+ async function encodeInt32(value) {
66
+ const buffer = new ArrayBuffer(4);
67
+ const view = new DataView(buffer);
68
+ view.setInt32(0, value, false);
69
+ return new Uint8Array(buffer);
70
+ }
71
+ async function encodeInt64(value) {
72
+ const num = typeof value === "bigint" ? value : BigInt(value || 0);
73
+ const buffer = new ArrayBuffer(8);
74
+ const view = new DataView(buffer);
75
+ view.setBigInt64(0, num, false);
76
+ return new Uint8Array(buffer);
77
+ }
78
+ async function encodeString(value = "") {
79
+ const utf8Bytes = new TextEncoder().encode(value);
80
+ return encodeBytes(utf8Bytes);
81
+ }
82
+ async function encodeBytes(value) {
83
+ const length = await encodeInt32(value.length);
84
+ return mkByteArray(length, value);
85
+ }
86
+ async function encodeHash(value) {
87
+ return value;
88
+ }
89
+ function encodeHexString(value = "") {
90
+ const bytes = new Uint8Array(value.length / 2);
91
+ for (let i = 0; i < value.length; i += 2) {
92
+ bytes[i / 2] = parseInt(value.slice(i, i + 2), 16);
93
+ }
94
+ return encodeBytes(bytes);
95
+ }
96
+ async function encodeOptional(value, encodeFn) {
97
+ if (value === void 0 || value === null) {
98
+ return new Uint8Array([0]);
99
+ } else {
100
+ return mkByteArray(1, await encodeFn(value));
101
+ }
102
+ }
103
+ async function encodeProtoOptional(parentValue, fieldName, value, encodeFn) {
104
+ if (parentValue && parentValue[fieldName] !== void 0) {
105
+ return mkByteArray(1, await encodeFn(value));
106
+ } else {
107
+ return new Uint8Array([0]);
108
+ }
109
+ }
110
+ async function encodeRepeated(values = [], encodeFn) {
111
+ const length = await encodeInt32(values.length);
112
+ const encodedValues = await Promise.all(values.map(encodeFn));
113
+ return mkByteArray(length, ...encodedValues);
114
+ }
115
+ function findSeed(nodeId, nodeSeeds) {
116
+ const seed = nodeSeeds.find(
117
+ (seed2) => seed2.nodeId.toString() === nodeId
118
+ )?.seed;
119
+ return seed;
120
+ }
121
+ async function encodeIdentifier(identifier) {
122
+ return mkByteArray(
123
+ await encodeString(identifier.packageId),
124
+ await encodeRepeated(identifier.moduleName.split("."), encodeString),
125
+ await encodeRepeated(identifier.entityName.split("."), encodeString)
126
+ );
127
+ }
128
+ async function encodeMetadata(metadata) {
129
+ return mkByteArray(
130
+ Uint8Array.from([1]),
131
+ await encodeRepeated(metadata.submitterInfo?.actAs, encodeString),
132
+ await encodeString(metadata.submitterInfo?.commandId),
133
+ await encodeString(metadata.transactionUuid),
134
+ await encodeInt32(metadata.mediatorGroup),
135
+ await encodeString(metadata.synchronizerId),
136
+ await encodeProtoOptional(
137
+ metadata,
138
+ "minLedgerEffectiveTime",
139
+ metadata.minLedgerEffectiveTime,
140
+ encodeInt64
141
+ ),
142
+ await encodeProtoOptional(
143
+ metadata,
144
+ "maxLedgerEffectiveTime",
145
+ metadata.maxLedgerEffectiveTime,
146
+ encodeInt64
147
+ ),
148
+ await encodeInt64(metadata.preparationTime),
149
+ await encodeRepeated(metadata.inputContracts, encodeInputContract)
150
+ );
151
+ }
152
+ async function encodeCreateNode(create, nodeId, nodeSeeds) {
153
+ return create ? mkByteArray(
154
+ NODE_ENCODING_VERSION,
155
+ await encodeString(create.lfVersion),
156
+ 0,
157
+ await encodeOptional(findSeed(nodeId, nodeSeeds), encodeHash),
158
+ await encodeHexString(create.contractId),
159
+ await encodeString(create.packageName),
160
+ await encodeIdentifier(create.templateId),
161
+ await encodeValue(create.argument),
162
+ await encodeRepeated(create.signatories, encodeString),
163
+ await encodeRepeated(create.stakeholders, encodeString)
164
+ ) : mkByteArray();
165
+ }
166
+ async function encodeExerciseNode(exercise, nodeId, nodesDict, nodeSeeds) {
167
+ return mkByteArray(
168
+ NODE_ENCODING_VERSION,
169
+ await encodeString(exercise.lfVersion),
170
+ 1,
171
+ await encodeHash(findSeed(nodeId, nodeSeeds)),
172
+ await encodeHexString(exercise.contractId),
173
+ await encodeString(exercise.packageName),
174
+ await encodeIdentifier(exercise.templateId),
175
+ await encodeRepeated(exercise.signatories, encodeString),
176
+ await encodeRepeated(exercise.stakeholders, encodeString),
177
+ await encodeRepeated(exercise.actingParties, encodeString),
178
+ await encodeProtoOptional(
179
+ exercise,
180
+ "interfaceId",
181
+ exercise.interfaceId,
182
+ encodeIdentifier
183
+ ),
184
+ await encodeString(exercise.choiceId),
185
+ await encodeValue(exercise.chosenValue),
186
+ await encodeBool(exercise.consuming),
187
+ await encodeProtoOptional(
188
+ exercise,
189
+ "exerciseResult",
190
+ exercise.exerciseResult,
191
+ encodeValue
192
+ ),
193
+ await encodeRepeated(exercise.choiceObservers, encodeString),
194
+ await encodeRepeated(
195
+ exercise.children,
196
+ encodeNodeId(nodesDict, nodeSeeds)
197
+ )
198
+ );
199
+ }
200
+ async function encodeFetchNode(fetch) {
201
+ return mkByteArray(
202
+ NODE_ENCODING_VERSION,
203
+ await encodeString(fetch.lfVersion),
204
+ 2,
205
+ await encodeHexString(fetch.contractId),
206
+ await encodeString(fetch.packageName),
207
+ await encodeIdentifier(fetch.templateId),
208
+ await encodeRepeated(fetch.signatories, encodeString),
209
+ await encodeRepeated(fetch.stakeholders, encodeString),
210
+ await encodeProtoOptional(
211
+ fetch,
212
+ "interfaceId",
213
+ fetch.interfaceId,
214
+ encodeIdentifier
215
+ ),
216
+ await encodeRepeated(fetch.actingParties, encodeString)
217
+ );
218
+ }
219
+ async function encodeRollbackNode(rollback, nodesDict, nodeSeeds) {
220
+ return mkByteArray(
221
+ NODE_ENCODING_VERSION,
222
+ 3,
223
+ await encodeRepeated(
224
+ rollback.children,
225
+ encodeNodeId(nodesDict, nodeSeeds)
226
+ )
227
+ );
228
+ }
229
+ async function encodeInputContract(contract) {
230
+ if (contract.contract.oneofKind === "v1")
231
+ return mkByteArray(
232
+ await encodeInt64(contract.createdAt),
233
+ await sha256(
234
+ await encodeCreateNode(
235
+ contract.contract.v1,
236
+ "unused_node_id",
237
+ []
238
+ )
239
+ )
240
+ );
241
+ else throw new Error("Unsupported contract version");
242
+ }
243
+ async function encodeValue(value) {
244
+ if (value.sum.oneofKind === "unit") {
245
+ return Uint8Array.from([0]);
246
+ } else if (value.sum.oneofKind === "bool") {
247
+ return mkByteArray(
248
+ Uint8Array.from([1]),
249
+ await encodeBool(value.sum.bool)
250
+ );
251
+ } else if (value.sum.oneofKind === "int64") {
252
+ return mkByteArray(
253
+ Uint8Array.from([2]),
254
+ await encodeInt64(parseInt(value.sum.int64))
255
+ );
256
+ } else if (value.sum.oneofKind === "numeric") {
257
+ return mkByteArray(
258
+ Uint8Array.from([3]),
259
+ await encodeString(value.sum.numeric)
260
+ );
261
+ } else if (value.sum.oneofKind === "timestamp") {
262
+ return mkByteArray(
263
+ Uint8Array.from([4]),
264
+ await encodeInt64(BigInt(value.sum.timestamp))
265
+ );
266
+ } else if (value.sum.oneofKind === "date") {
267
+ return mkByteArray(
268
+ Uint8Array.from([5]),
269
+ await encodeInt32(value.sum.date)
270
+ );
271
+ } else if (value.sum.oneofKind === "party") {
272
+ return mkByteArray(
273
+ Uint8Array.from([6]),
274
+ await encodeString(value.sum.party)
275
+ );
276
+ } else if (value.sum.oneofKind === "text") {
277
+ return mkByteArray(
278
+ Uint8Array.from([7]),
279
+ await encodeString(value.sum.text)
280
+ );
281
+ } else if (value.sum.oneofKind === "contractId") {
282
+ return mkByteArray(
283
+ Uint8Array.from([8]),
284
+ await encodeHexString(value.sum.contractId)
285
+ );
286
+ } else if (value.sum.oneofKind === "optional") {
287
+ return mkByteArray(
288
+ Uint8Array.from([9]),
289
+ await encodeProtoOptional(
290
+ value.sum.optional,
291
+ "value",
292
+ value.sum.optional.value,
293
+ encodeValue
294
+ )
295
+ );
296
+ } else if (value.sum.oneofKind === "list") {
297
+ return mkByteArray(
298
+ Uint8Array.from([10]),
299
+ await encodeRepeated(value.sum.list.elements, encodeValue)
300
+ );
301
+ } else if (value.sum.oneofKind === "textMap") {
302
+ return mkByteArray(
303
+ Uint8Array.from([11]),
304
+ await encodeRepeated(value.sum.textMap?.entries, encodeTextMapEntry)
305
+ );
306
+ } else if (value.sum.oneofKind === "record") {
307
+ return mkByteArray(
308
+ Uint8Array.from([12]),
309
+ await encodeProtoOptional(
310
+ value.sum.record,
311
+ "recordId",
312
+ value.sum.record.recordId,
313
+ encodeIdentifier
314
+ ),
315
+ await encodeRepeated(value.sum.record.fields, encodeRecordField)
316
+ );
317
+ } else if (value.sum.oneofKind === "variant") {
318
+ return mkByteArray(
319
+ Uint8Array.from([13]),
320
+ await encodeProtoOptional(
321
+ value.sum.variant,
322
+ "variantId",
323
+ value.sum.variant.variantId,
324
+ encodeIdentifier
325
+ ),
326
+ await encodeString(value.sum.variant.constructor),
327
+ await encodeValue(value.sum.variant.value)
328
+ );
329
+ } else if (value.sum.oneofKind === "enum") {
330
+ return mkByteArray(
331
+ Uint8Array.from([14]),
332
+ await encodeProtoOptional(
333
+ value.sum.enum,
334
+ "enumId",
335
+ value.sum.enum.enumId,
336
+ encodeIdentifier
337
+ ),
338
+ await encodeString(value.sum.enum.constructor)
339
+ );
340
+ } else if (value.sum.oneofKind === "genMap") {
341
+ return mkByteArray(
342
+ Uint8Array.from([15]),
343
+ await encodeRepeated(value.sum.genMap?.entries, encodeGenMapEntry)
344
+ );
345
+ }
346
+ throw new Error("Unsupported value type: " + JSON.stringify(value));
347
+ }
348
+ async function encodeTextMapEntry(entry) {
349
+ return mkByteArray(
350
+ await encodeString(entry.key),
351
+ await encodeValue(entry.value)
352
+ );
353
+ }
354
+ async function encodeRecordField(field) {
355
+ return mkByteArray(
356
+ await encodeOptional(field.label, encodeString),
357
+ await encodeValue(field.value)
358
+ );
359
+ }
360
+ async function encodeGenMapEntry(entry) {
361
+ return mkByteArray(
362
+ await encodeValue(entry.key),
363
+ await encodeValue(entry.value)
364
+ );
365
+ }
366
+ function encodeNodeId(nodesDict, nodeSeeds) {
367
+ return async (nodeId) => {
368
+ const node = nodesDict[nodeId];
369
+ if (!node) {
370
+ throw new Error(`Node with ID ${nodeId} not found in transaction`);
371
+ }
372
+ const encodedNode = await encodeNode(node, nodesDict, nodeSeeds);
373
+ return sha256(encodedNode);
374
+ };
375
+ }
376
+ async function encodeNode(node, nodesDict, nodeSeeds) {
377
+ if (node.versionedNode.oneofKind === "v1") {
378
+ if (node.versionedNode.v1.nodeType.oneofKind === "create") {
379
+ return encodeCreateNode(
380
+ node.versionedNode.v1.nodeType.create,
381
+ node.nodeId,
382
+ nodeSeeds
383
+ );
384
+ } else if (node.versionedNode.v1.nodeType.oneofKind === "exercise") {
385
+ return encodeExerciseNode(
386
+ node.versionedNode.v1.nodeType.exercise,
387
+ node.nodeId,
388
+ nodesDict,
389
+ nodeSeeds
390
+ );
391
+ } else if (node.versionedNode.v1.nodeType.oneofKind === "fetch") {
392
+ return encodeFetchNode(node.versionedNode.v1.nodeType.fetch);
393
+ } else if (node.versionedNode.v1.nodeType.oneofKind === "rollback") {
394
+ return encodeRollbackNode(
395
+ node.versionedNode.v1.nodeType.rollback,
396
+ nodesDict,
397
+ nodeSeeds
398
+ );
399
+ }
400
+ throw new Error("Unsupported node type");
401
+ } else {
402
+ throw new Error(`Unsupported node version`);
403
+ }
404
+ }
405
+ function createNodesDict(preparedTransaction) {
406
+ const nodesDict = {};
407
+ const nodes = preparedTransaction.transaction?.nodes || [];
408
+ for (const node of nodes) {
409
+ nodesDict[node.nodeId] = node;
410
+ }
411
+ return nodesDict;
412
+ }
413
+ async function encodeTransaction(transaction, nodesDict, nodeSeeds) {
414
+ return mkByteArray(
415
+ await encodeString(transaction.version),
416
+ await encodeRepeated(
417
+ transaction.roots,
418
+ encodeNodeId(nodesDict, nodeSeeds)
419
+ )
420
+ );
421
+ }
422
+ async function hashTransaction(transaction, nodesDict) {
423
+ const encodedTransaction = await encodeTransaction(
424
+ transaction,
425
+ nodesDict,
426
+ transaction.nodeSeeds
427
+ );
428
+ const hash = await sha256(
429
+ await mkByteArray(PREPARED_TRANSACTION_HASH_PURPOSE, encodedTransaction)
430
+ );
431
+ return hash;
432
+ }
433
+ async function hashMetadata(metadata) {
434
+ const hash = await sha256(
435
+ await mkByteArray(
436
+ PREPARED_TRANSACTION_HASH_PURPOSE,
437
+ await encodeMetadata(metadata)
438
+ )
439
+ );
440
+ return hash;
441
+ }
442
+ async function encodePreparedTransaction(preparedTransaction) {
443
+ const nodesDict = createNodesDict(preparedTransaction);
444
+ const transactionHash = await hashTransaction(
445
+ preparedTransaction.transaction,
446
+ nodesDict
447
+ );
448
+ const metadataHash = await hashMetadata(preparedTransaction.metadata);
449
+ return mkByteArray(
450
+ PREPARED_TRANSACTION_HASH_PURPOSE,
451
+ HASHING_SCHEME_VERSION,
452
+ transactionHash,
453
+ metadataHash
454
+ );
455
+ }
456
+ async function computePreparedTransaction(preparedTransaction) {
457
+ return sha256(await encodePreparedTransaction(preparedTransaction));
458
+ }
459
+ async function computeSha256CantonHash(purpose, bytes) {
460
+ const encodedPurpose = await encodeInt32(purpose);
461
+ const hashInput = await mkByteArray(encodedPurpose, bytes);
462
+ const hashBytes = await sha256(hashInput);
463
+ const multiprefix = new Uint8Array([18, 32]);
464
+ return mkByteArray(multiprefix, hashBytes);
465
+ }
466
+ async function computeMultiHashForTopology(hashes) {
467
+ const sortedHashes = hashes.slice().sort((a, b) => toHex(a).localeCompare(toHex(b)));
468
+ const numHashesBytes = await encodeInt32(sortedHashes.length);
469
+ const concatenatedHashes = [numHashesBytes];
470
+ for (const h of sortedHashes) {
471
+ const lengthBytes = await encodeInt32(h.length);
472
+ concatenatedHashes.push(lengthBytes, h);
473
+ }
474
+ return mkByteArray(...concatenatedHashes);
475
+ }
476
+
477
+ // src/index.ts
478
+ var decodePreparedTransaction = (preparedTransaction) => {
479
+ const bytes = fromBase64(preparedTransaction);
480
+ return coreLedgerProto.PreparedTransaction.fromBinary(bytes);
481
+ };
482
+ var decodeTopologyTransaction = (topologyTx) => {
483
+ const bytes = fromBase64(topologyTx);
484
+ return coreLedgerProto.TopologyTransaction.fromBinary(bytes);
485
+ };
486
+ var hashPreparedTransaction = async (preparedTransaction, format = "base64") => {
487
+ let preparedTx;
488
+ if (typeof preparedTransaction === "string") {
489
+ preparedTx = decodePreparedTransaction(preparedTransaction);
490
+ } else {
491
+ preparedTx = preparedTransaction;
492
+ }
493
+ const hash = await computePreparedTransaction(preparedTx);
494
+ switch (format) {
495
+ case "base64":
496
+ return toBase64(hash);
497
+ case "hex":
498
+ return toHex(hash);
499
+ }
500
+ };
501
+ var validateAuthorizedPartyIds = (preparedTransaction, authorizedPartyIds) => {
502
+ let preparedTx;
503
+ if (typeof preparedTransaction === "string") {
504
+ preparedTx = decodePreparedTransaction(preparedTransaction);
505
+ } else {
506
+ preparedTx = preparedTransaction;
507
+ }
508
+ const results = {};
509
+ preparedTx.metadata?.submitterInfo?.actAs.forEach((party) => {
510
+ results[party] = {
511
+ isAuthorized: authorizedPartyIds.includes(party),
512
+ locations: [
513
+ ...results[party].locations,
514
+ "metadata.submitterInfo.actAs"
515
+ ]
516
+ };
517
+ });
518
+ preparedTx.transaction?.nodes.forEach((node) => {
519
+ if (node.versionedNode.oneofKind === "v1") {
520
+ if (node.versionedNode.v1.nodeType.oneofKind === "create") {
521
+ node.versionedNode.v1.nodeType.create.signatories.forEach(
522
+ (party) => {
523
+ results[party] = {
524
+ isAuthorized: authorizedPartyIds.includes(party),
525
+ locations: [
526
+ ...results[party].locations,
527
+ `transaction.nodes.${node.nodeId}.create.signatories`
528
+ ]
529
+ };
530
+ }
531
+ );
532
+ node.versionedNode.v1.nodeType.create.stakeholders.forEach(
533
+ (party) => {
534
+ results[party] = {
535
+ isAuthorized: authorizedPartyIds.includes(party),
536
+ locations: [
537
+ ...results[party].locations,
538
+ `transaction.nodes.${node.nodeId}.create.stakeholders`
539
+ ]
540
+ };
541
+ }
542
+ );
543
+ }
544
+ if (node.versionedNode.v1.nodeType.oneofKind === "exercise") {
545
+ throw new Error("Unsupported");
546
+ }
547
+ if (node.versionedNode.v1.nodeType.oneofKind === "fetch") {
548
+ throw new Error("Unsupported");
549
+ }
550
+ if (node.versionedNode.v1.nodeType.oneofKind === "rollback") ;
551
+ }
552
+ });
553
+ return results;
554
+ };
555
+
556
+ exports.computeMultiHashForTopology = computeMultiHashForTopology;
557
+ exports.computeSha256CantonHash = computeSha256CantonHash;
558
+ exports.decodePreparedTransaction = decodePreparedTransaction;
559
+ exports.decodeTopologyTransaction = decodeTopologyTransaction;
560
+ exports.hashPreparedTransaction = hashPreparedTransaction;
561
+ exports.validateAuthorizedPartyIds = validateAuthorizedPartyIds;
562
+ //# sourceMappingURL=index.cjs.map
563
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils.ts","../src/hashing_scheme_v2.ts","../src/index.ts"],"names":["HashingSchemeVersion","seed","PreparedTransaction","TopologyTransaction"],"mappings":"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","file":"index.cjs","sourcesContent":["// Copyright (c) 2025 Digital Asset (Switzerland) GmbH and/or its affiliates. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\n/** Take a base64 encoded string and return a Uint8Array of the decoded bytes */\nexport function fromBase64(b64: string): Uint8Array {\n const binaryString = atob(b64)\n const len = binaryString.length\n const bytes = new Uint8Array(len)\n for (let i = 0; i < len; i++) {\n bytes[i] = binaryString.charCodeAt(i)\n }\n return bytes\n}\n\n/** Take a byte buffer (Uint8Array) and encode it into a base64 string */\nexport function toBase64(data: Uint8Array): string {\n let binaryString = ''\n const len = data.byteLength\n for (let i = 0; i < len; i++) {\n binaryString += String.fromCharCode(data[i])\n }\n return btoa(binaryString)\n}\n\n/** Take a byte buffer (Uint8Array) and encode it into a hex string */\nexport function toHex(bytes: Uint8Array): string {\n return Array.from(bytes)\n .map((byte) => byte.toString(16).padStart(2, '0'))\n .join('')\n}\n\nexport function fromHex(hex: string): Uint8Array {\n if (hex.length % 2 !== 0) {\n throw new Error('Invalid hex string length')\n }\n\n const bytes = new Uint8Array(hex.length / 2)\n for (let i = 0; i < hex.length; i += 2) {\n bytes[i / 2] = parseInt(hex.slice(i, i + 2), 16)\n }\n return bytes\n}\n\nexport async function sha256(\n message: string | Uint8Array\n): Promise<Uint8Array> {\n const msg =\n typeof message === 'string'\n ? new TextEncoder().encode(message)\n : message\n\n return crypto.subtle\n .digest('SHA-256', new Uint8Array(msg))\n .then((hash) => new Uint8Array(hash))\n}\n\n/** Utility to concatenate byte arrays or single bytes */\nexport async function mkByteArray(\n ...args: (number | Uint8Array)[]\n): Promise<Uint8Array> {\n const normalizedArgs: Uint8Array[] = args.map((arg) => {\n if (typeof arg === 'number') {\n return new Uint8Array([arg])\n } else {\n return arg\n }\n })\n\n let totalLength = 0\n normalizedArgs.forEach((arg) => {\n totalLength += arg.length\n })\n\n const mergedArray = new Uint8Array(totalLength)\n let offset = 0\n\n normalizedArgs.forEach((arg) => {\n mergedArray.set(arg, offset)\n offset += arg.length\n })\n\n return mergedArray\n}\n","// Copyright (c) 2025 Digital Asset (Switzerland) GmbH and/or its affiliates. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport {\n DamlTransaction,\n DamlTransaction_Node,\n DamlTransaction_NodeSeed,\n HashingSchemeVersion,\n Metadata,\n Metadata_InputContract,\n PreparedTransaction,\n} from '@canton-network/core-ledger-proto'\nimport {\n Create,\n Exercise,\n Fetch,\n Rollback,\n} from '@canton-network/core-ledger-proto'\nimport {\n GenMap_Entry,\n Identifier,\n RecordField,\n TextMap_Entry,\n Value,\n} from '@canton-network/core-ledger-proto'\nimport { mkByteArray, sha256, toHex } from './utils.js'\n\n// Hash purpose reserved for prepared transaction\nconst PREPARED_TRANSACTION_HASH_PURPOSE = Uint8Array.from([\n 0x00, 0x00, 0x00, 0x30,\n])\n\nconst NODE_ENCODING_VERSION = Uint8Array.from([0x01])\n\nconst HASHING_SCHEME_VERSION = Uint8Array.from([HashingSchemeVersion.V2])\n\nasync function encodeBool(value: boolean): Promise<Uint8Array> {\n return new Uint8Array([value ? 1 : 0])\n}\n\nasync function encodeInt32(value: number): Promise<Uint8Array> {\n const buffer = new ArrayBuffer(4)\n const view = new DataView(buffer)\n view.setInt32(0, value, false) // true for little-endian\n return new Uint8Array(buffer)\n}\n\nasync function encodeInt64(\n value: bigint | number | undefined\n): Promise<Uint8Array> {\n const num = typeof value === 'bigint' ? value : BigInt(value || 0)\n const buffer = new ArrayBuffer(8)\n const view = new DataView(buffer)\n view.setBigInt64(0, num, false) // true for little-endian\n return new Uint8Array(buffer)\n}\n\nexport async function encodeString(value: string = ''): Promise<Uint8Array> {\n const utf8Bytes = new TextEncoder().encode(value)\n return encodeBytes(utf8Bytes)\n}\n\nasync function encodeBytes(value: Uint8Array): Promise<Uint8Array> {\n const length = await encodeInt32(value.length)\n return mkByteArray(length, value)\n}\n\nasync function encodeHash(value: Uint8Array): Promise<Uint8Array> {\n return value\n}\n\nfunction encodeHexString(value: string = ''): Promise<Uint8Array> {\n // Convert hex string to Uint8Array\n const bytes = new Uint8Array(value.length / 2)\n for (let i = 0; i < value.length; i += 2) {\n bytes[i / 2] = parseInt(value.slice(i, i + 2), 16)\n }\n return encodeBytes(bytes)\n}\n\n// Maybe suspicious?\nasync function encodeOptional<T>(\n value: T | undefined | null,\n encodeFn: (arg: T) => Promise<Uint8Array>\n): Promise<Uint8Array> {\n if (value === undefined || value === null) {\n return new Uint8Array([0]) // Return empty array for undefined fields\n } else {\n return mkByteArray(1, await encodeFn(value))\n }\n}\n\n// Maybe suspicious?\nasync function encodeProtoOptional<T, P extends object>(\n parentValue: P,\n fieldName: keyof P,\n value: T,\n encodeFn: (value: T) => Promise<Uint8Array>\n): Promise<Uint8Array> {\n if (parentValue && parentValue[fieldName] !== undefined) {\n return mkByteArray(1, await encodeFn(value))\n } else {\n return new Uint8Array([0]) // Return empty array for undefined fields\n }\n}\n\nasync function encodeRepeated<T>(\n values: T[] = [],\n encodeFn: (value: T) => Promise<Uint8Array>\n): Promise<Uint8Array> {\n const length = await encodeInt32(values.length)\n const encodedValues = await Promise.all(values.map(encodeFn))\n return mkByteArray(length, ...encodedValues)\n}\n\nfunction findSeed(\n nodeId: string,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Uint8Array | undefined {\n const seed = nodeSeeds.find(\n (seed) => seed.nodeId.toString() === nodeId\n )?.seed\n\n return seed\n}\n\nasync function encodeIdentifier(identifier: Identifier): Promise<Uint8Array> {\n return mkByteArray(\n await encodeString(identifier.packageId),\n await encodeRepeated(identifier.moduleName.split('.'), encodeString),\n await encodeRepeated(identifier.entityName.split('.'), encodeString)\n )\n}\n\nasync function encodeMetadata(metadata: Metadata): Promise<Uint8Array> {\n return mkByteArray(\n Uint8Array.from([0x01]),\n await encodeRepeated(metadata.submitterInfo?.actAs, encodeString),\n await encodeString(metadata.submitterInfo?.commandId),\n await encodeString(metadata.transactionUuid),\n await encodeInt32(metadata.mediatorGroup),\n await encodeString(metadata.synchronizerId),\n await encodeProtoOptional(\n metadata,\n 'minLedgerEffectiveTime',\n metadata.minLedgerEffectiveTime,\n encodeInt64\n ),\n await encodeProtoOptional(\n metadata,\n 'maxLedgerEffectiveTime',\n metadata.maxLedgerEffectiveTime,\n encodeInt64\n ),\n await encodeInt64(metadata.preparationTime),\n await encodeRepeated(metadata.inputContracts, encodeInputContract)\n )\n}\n\nasync function encodeCreateNode(\n create: Create | undefined,\n nodeId: string,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Promise<Uint8Array> {\n return create\n ? mkByteArray(\n NODE_ENCODING_VERSION,\n await encodeString(create.lfVersion),\n 0 /** Create node tag */,\n await encodeOptional(findSeed(nodeId, nodeSeeds), encodeHash),\n await encodeHexString(create.contractId),\n await encodeString(create.packageName),\n await encodeIdentifier(create.templateId!),\n await encodeValue(create.argument!),\n await encodeRepeated(create.signatories, encodeString),\n await encodeRepeated(create.stakeholders, encodeString)\n )\n : mkByteArray()\n}\n\nasync function encodeExerciseNode(\n exercise: Exercise,\n nodeId: string,\n nodesDict: Record<string, DamlTransaction_Node>,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Promise<Uint8Array> {\n return mkByteArray(\n NODE_ENCODING_VERSION,\n await encodeString(exercise.lfVersion),\n 1 /** Exercise node tag */,\n await encodeHash(findSeed(nodeId, nodeSeeds)!),\n await encodeHexString(exercise.contractId),\n await encodeString(exercise.packageName),\n await encodeIdentifier(exercise.templateId!),\n await encodeRepeated(exercise.signatories, encodeString),\n await encodeRepeated(exercise.stakeholders, encodeString),\n await encodeRepeated(exercise.actingParties, encodeString),\n await encodeProtoOptional(\n exercise,\n 'interfaceId',\n exercise.interfaceId!,\n encodeIdentifier\n ),\n await encodeString(exercise.choiceId),\n await encodeValue(exercise.chosenValue!),\n await encodeBool(exercise.consuming),\n await encodeProtoOptional(\n exercise,\n 'exerciseResult',\n exercise.exerciseResult!,\n encodeValue\n ),\n await encodeRepeated(exercise.choiceObservers, encodeString),\n await encodeRepeated(\n exercise.children,\n encodeNodeId(nodesDict, nodeSeeds)\n )\n )\n}\n\nasync function encodeFetchNode(fetch: Fetch): Promise<Uint8Array> {\n return mkByteArray(\n NODE_ENCODING_VERSION,\n await encodeString(fetch.lfVersion),\n 2 /** Fetch node tag */,\n await encodeHexString(fetch.contractId),\n await encodeString(fetch.packageName),\n await encodeIdentifier(fetch.templateId!),\n await encodeRepeated(fetch.signatories, encodeString),\n await encodeRepeated(fetch.stakeholders, encodeString),\n await encodeProtoOptional(\n fetch,\n 'interfaceId',\n fetch.interfaceId!,\n encodeIdentifier\n ),\n await encodeRepeated(fetch.actingParties, encodeString)\n )\n}\n\nasync function encodeRollbackNode(\n rollback: Rollback,\n nodesDict: Record<string, DamlTransaction_Node>,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Promise<Uint8Array> {\n return mkByteArray(\n NODE_ENCODING_VERSION,\n 3 /** Rollback node tag */,\n await encodeRepeated(\n rollback.children,\n encodeNodeId(nodesDict, nodeSeeds)\n )\n )\n}\n\nasync function encodeInputContract(contract: Metadata_InputContract) {\n if (contract.contract.oneofKind === 'v1')\n return mkByteArray(\n await encodeInt64(contract.createdAt),\n await sha256(\n await encodeCreateNode(\n contract.contract.v1,\n 'unused_node_id',\n []\n )\n )\n )\n else throw new Error('Unsupported contract version')\n}\n\nasync function encodeValue(value: Value): Promise<Uint8Array> {\n if (value.sum.oneofKind === 'unit') {\n return Uint8Array.from([0]) // Unit value\n } else if (value.sum.oneofKind === 'bool') {\n return mkByteArray(\n Uint8Array.from([0x01]),\n await encodeBool(value.sum.bool)\n )\n } else if (value.sum.oneofKind === 'int64') {\n return mkByteArray(\n Uint8Array.from([0x02]),\n await encodeInt64(parseInt(value.sum.int64))\n )\n } else if (value.sum.oneofKind === 'numeric') {\n return mkByteArray(\n Uint8Array.from([0x03]),\n await encodeString(value.sum.numeric)\n )\n } else if (value.sum.oneofKind === 'timestamp') {\n return mkByteArray(\n Uint8Array.from([0x04]),\n await encodeInt64(BigInt(value.sum.timestamp))\n )\n } else if (value.sum.oneofKind === 'date') {\n return mkByteArray(\n Uint8Array.from([0x05]),\n await encodeInt32(value.sum.date)\n )\n } else if (value.sum.oneofKind === 'party') {\n return mkByteArray(\n Uint8Array.from([0x06]),\n await encodeString(value.sum.party)\n )\n } else if (value.sum.oneofKind === 'text') {\n return mkByteArray(\n Uint8Array.from([0x07]),\n await encodeString(value.sum.text)\n )\n } else if (value.sum.oneofKind === 'contractId') {\n return mkByteArray(\n Uint8Array.from([0x08]),\n await encodeHexString(value.sum.contractId)\n )\n } else if (value.sum.oneofKind === 'optional') {\n return mkByteArray(\n Uint8Array.from([0x09]),\n await encodeProtoOptional(\n value.sum.optional,\n 'value',\n value.sum.optional.value as Value,\n encodeValue\n )\n )\n } else if (value.sum.oneofKind === 'list') {\n return mkByteArray(\n Uint8Array.from([0x0a]),\n await encodeRepeated(value.sum.list.elements, encodeValue)\n )\n } else if (value.sum.oneofKind === 'textMap') {\n return mkByteArray(\n Uint8Array.from([0x0b]),\n await encodeRepeated(value.sum.textMap?.entries, encodeTextMapEntry)\n )\n } else if (value.sum.oneofKind === 'record') {\n return mkByteArray(\n Uint8Array.from([0x0c]),\n await encodeProtoOptional(\n value.sum.record,\n 'recordId',\n value.sum.record.recordId!,\n encodeIdentifier\n ),\n await encodeRepeated(value.sum.record.fields, encodeRecordField)\n )\n } else if (value.sum.oneofKind === 'variant') {\n return mkByteArray(\n Uint8Array.from([0x0d]),\n await encodeProtoOptional(\n value.sum.variant,\n 'variantId',\n value.sum.variant.variantId!,\n encodeIdentifier\n ),\n await encodeString(value.sum.variant.constructor),\n await encodeValue(value.sum.variant.value!)\n )\n } else if (value.sum.oneofKind === 'enum') {\n return mkByteArray(\n Uint8Array.from([0x0e]),\n await encodeProtoOptional(\n value.sum.enum,\n 'enumId',\n value.sum.enum.enumId!,\n encodeIdentifier\n ),\n await encodeString(value.sum.enum.constructor)\n )\n } else if (value.sum.oneofKind === 'genMap') {\n return mkByteArray(\n Uint8Array.from([0x0f]),\n await encodeRepeated(value.sum.genMap?.entries, encodeGenMapEntry)\n )\n }\n\n throw new Error('Unsupported value type: ' + JSON.stringify(value))\n}\n\nasync function encodeTextMapEntry(entry: TextMap_Entry): Promise<Uint8Array> {\n return mkByteArray(\n await encodeString(entry.key),\n await encodeValue(entry.value!)\n )\n}\n\nasync function encodeRecordField(field: RecordField): Promise<Uint8Array> {\n return mkByteArray(\n await encodeOptional(field.label, encodeString),\n await encodeValue(field.value!)\n )\n}\n\nasync function encodeGenMapEntry(entry: GenMap_Entry): Promise<Uint8Array> {\n return mkByteArray(\n await encodeValue(entry.key!),\n await encodeValue(entry.value!)\n )\n}\n\nfunction encodeNodeId(\n nodesDict: Record<string, DamlTransaction_Node>,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): (nodeId: string) => Promise<Uint8Array> {\n return async (nodeId: string): Promise<Uint8Array> => {\n const node = nodesDict[nodeId]\n if (!node) {\n throw new Error(`Node with ID ${nodeId} not found in transaction`)\n }\n\n const encodedNode = await encodeNode(node, nodesDict, nodeSeeds)\n return sha256(encodedNode)\n }\n}\n\nasync function encodeNode(\n node: DamlTransaction_Node,\n nodesDict: Record<string, DamlTransaction_Node>,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Promise<Uint8Array> {\n if (node.versionedNode.oneofKind === 'v1') {\n if (node.versionedNode.v1.nodeType.oneofKind === 'create') {\n return encodeCreateNode(\n node.versionedNode.v1.nodeType.create,\n node.nodeId,\n nodeSeeds\n )\n } else if (node.versionedNode.v1.nodeType.oneofKind === 'exercise') {\n return encodeExerciseNode(\n node.versionedNode.v1.nodeType.exercise,\n node.nodeId,\n nodesDict,\n nodeSeeds\n )\n } else if (node.versionedNode.v1.nodeType.oneofKind === 'fetch') {\n return encodeFetchNode(node.versionedNode.v1.nodeType.fetch)\n } else if (node.versionedNode.v1.nodeType.oneofKind === 'rollback') {\n return encodeRollbackNode(\n node.versionedNode.v1.nodeType.rollback,\n nodesDict,\n nodeSeeds\n )\n }\n\n throw new Error('Unsupported node type')\n } else {\n throw new Error(`Unsupported node version`)\n }\n}\n\nfunction createNodesDict(\n preparedTransaction: PreparedTransaction\n): Record<string, DamlTransaction_Node> {\n const nodesDict: Record<string, DamlTransaction_Node> = {}\n const nodes = preparedTransaction.transaction?.nodes || []\n for (const node of nodes) {\n nodesDict[node.nodeId] = node\n }\n return nodesDict\n}\n\nasync function encodeTransaction(\n transaction: DamlTransaction,\n nodesDict: Record<string, DamlTransaction_Node>,\n nodeSeeds: DamlTransaction_NodeSeed[]\n): Promise<Uint8Array> {\n return mkByteArray(\n await encodeString(transaction.version),\n await encodeRepeated(\n transaction.roots,\n encodeNodeId(nodesDict, nodeSeeds)\n )\n )\n}\n\nasync function hashTransaction(\n transaction: DamlTransaction,\n nodesDict: Record<string, DamlTransaction_Node>\n): Promise<Uint8Array> {\n const encodedTransaction = await encodeTransaction(\n transaction,\n nodesDict,\n transaction.nodeSeeds\n )\n\n const hash = await sha256(\n await mkByteArray(PREPARED_TRANSACTION_HASH_PURPOSE, encodedTransaction)\n )\n\n return hash\n}\n\nasync function hashMetadata(metadata: Metadata): Promise<Uint8Array> {\n const hash = await sha256(\n await mkByteArray(\n PREPARED_TRANSACTION_HASH_PURPOSE,\n await encodeMetadata(metadata)\n )\n )\n\n return hash\n}\n\nasync function encodePreparedTransaction(\n preparedTransaction: PreparedTransaction\n): Promise<Uint8Array> {\n const nodesDict = createNodesDict(preparedTransaction)\n\n const transactionHash = await hashTransaction(\n preparedTransaction.transaction!,\n nodesDict\n )\n const metadataHash = await hashMetadata(preparedTransaction.metadata!)\n\n return mkByteArray(\n PREPARED_TRANSACTION_HASH_PURPOSE,\n HASHING_SCHEME_VERSION,\n transactionHash,\n metadataHash\n )\n}\n\nexport async function computePreparedTransaction(\n preparedTransaction: PreparedTransaction\n): Promise<Uint8Array> {\n return sha256(await encodePreparedTransaction(preparedTransaction))\n}\n\nexport async function computeSha256CantonHash(\n purpose: number,\n bytes: Uint8Array\n) {\n const encodedPurpose = await encodeInt32(purpose)\n\n const hashInput = await mkByteArray(encodedPurpose, bytes)\n const hashBytes = await sha256(hashInput)\n const multiprefix = new Uint8Array([0x12, 0x20])\n return mkByteArray(multiprefix, hashBytes)\n}\n\nexport async function computeMultiHashForTopology(hashes: Uint8Array[]) {\n const sortedHashes = hashes\n .slice()\n .sort((a, b) => toHex(a).localeCompare(toHex(b)))\n\n const numHashesBytes = await encodeInt32(sortedHashes.length)\n\n const concatenatedHashes = [numHashesBytes]\n\n for (const h of sortedHashes) {\n const lengthBytes = await encodeInt32(h.length)\n concatenatedHashes.push(lengthBytes, h)\n }\n\n return mkByteArray(...concatenatedHashes)\n}\n","// Copyright (c) 2025 Digital Asset (Switzerland) GmbH and/or its affiliates. All rights reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nimport {\n PreparedTransaction,\n TopologyTransaction,\n} from '@canton-network/core-ledger-proto'\nimport { computePreparedTransaction } from './hashing_scheme_v2.js'\nimport { fromBase64, toBase64, toHex } from './utils.js'\nexport {\n computeSha256CantonHash,\n computeMultiHashForTopology,\n} from './hashing_scheme_v2.js'\n\n/**\n * Decodes a base64 encoded prepared transaction into a well-typed data model, generated directly from Protobuf definitions.\n *\n * @param preparedTransaction - The prepared transaction in base64 format\n * @returns The decoded prepared transaction\n */\nexport const decodePreparedTransaction = (\n preparedTransaction: string\n): PreparedTransaction => {\n const bytes = fromBase64(preparedTransaction)\n return PreparedTransaction.fromBinary(bytes)\n}\n\nexport const decodeTopologyTransaction = (\n topologyTx: string\n): TopologyTransaction => {\n const bytes = fromBase64(topologyTx)\n return TopologyTransaction.fromBinary(bytes)\n}\n\n/**\n * Computes the hash of a prepared transaction.\n *\n * @param preparedTransaction - The prepared transaction to hash\n * @param format - The format of the output hash (base64 or hex)\n * @returns The computed hash in the specified format\n */\nexport const hashPreparedTransaction = async (\n preparedTransaction: string | PreparedTransaction,\n format: 'base64' | 'hex' = 'base64'\n): Promise<string> => {\n let preparedTx: PreparedTransaction\n\n if (typeof preparedTransaction === 'string') {\n preparedTx = decodePreparedTransaction(preparedTransaction)\n } else {\n preparedTx = preparedTransaction\n }\n\n const hash = await computePreparedTransaction(preparedTx)\n\n switch (format) {\n case 'base64':\n return toBase64(hash)\n case 'hex':\n return toHex(hash)\n }\n}\n\ntype ValidationResult = Record<\n string,\n {\n isAuthorized: boolean\n locations: string[]\n }\n>\n\nexport const validateAuthorizedPartyIds = (\n preparedTransaction: string | PreparedTransaction,\n authorizedPartyIds: string[]\n): ValidationResult => {\n let preparedTx: PreparedTransaction\n\n if (typeof preparedTransaction === 'string') {\n preparedTx = decodePreparedTransaction(preparedTransaction)\n } else {\n preparedTx = preparedTransaction\n }\n\n const results: ValidationResult = {}\n preparedTx.metadata?.submitterInfo?.actAs.forEach((party) => {\n results[party] = {\n isAuthorized: authorizedPartyIds.includes(party),\n locations: [\n ...results[party].locations,\n 'metadata.submitterInfo.actAs',\n ],\n }\n })\n\n // then check transaction nodes\n preparedTx.transaction?.nodes.forEach((node) => {\n if (node.versionedNode.oneofKind === 'v1') {\n if (node.versionedNode.v1.nodeType.oneofKind === 'create') {\n node.versionedNode.v1.nodeType.create.signatories.forEach(\n (party) => {\n results[party] = {\n isAuthorized: authorizedPartyIds.includes(party),\n locations: [\n ...results[party].locations,\n `transaction.nodes.${node.nodeId}.create.signatories`,\n ],\n }\n }\n )\n\n node.versionedNode.v1.nodeType.create.stakeholders.forEach(\n (party) => {\n results[party] = {\n isAuthorized: authorizedPartyIds.includes(party),\n locations: [\n ...results[party].locations,\n `transaction.nodes.${node.nodeId}.create.stakeholders`,\n ],\n }\n }\n )\n }\n\n if (node.versionedNode.v1.nodeType.oneofKind === 'exercise') {\n throw new Error('Unsupported')\n }\n\n if (node.versionedNode.v1.nodeType.oneofKind === 'fetch') {\n throw new Error('Unsupported')\n }\n\n if (node.versionedNode.v1.nodeType.oneofKind === 'rollback') {\n // do we need to check these nodes?\n }\n }\n })\n\n return results\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { PreparedTransaction } from '@canton-network/core-ledger-proto';
1
+ import { PreparedTransaction, TopologyTransaction } from '@canton-network/core-ledger-proto';
2
2
  export { computeSha256CantonHash, computeMultiHashForTopology, } from './hashing_scheme_v2.js';
3
3
  /**
4
4
  * Decodes a base64 encoded prepared transaction into a well-typed data model, generated directly from Protobuf definitions.
@@ -7,6 +7,7 @@ export { computeSha256CantonHash, computeMultiHashForTopology, } from './hashing
7
7
  * @returns The decoded prepared transaction
8
8
  */
9
9
  export declare const decodePreparedTransaction: (preparedTransaction: string) => PreparedTransaction;
10
+ export declare const decodeTopologyTransaction: (topologyTx: string) => TopologyTransaction;
10
11
  /**
11
12
  * Computes the hash of a prepared transaction.
12
13
  *
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAA;AAGvE,OAAO,EACH,uBAAuB,EACvB,2BAA2B,GAC9B,MAAM,wBAAwB,CAAA;AAE/B;;;;;GAKG;AACH,eAAO,MAAM,yBAAyB,GAClC,qBAAqB,MAAM,KAC5B,mBAGF,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,uBAAuB,GAChC,qBAAqB,MAAM,GAAG,mBAAmB,EACjD,SAAQ,QAAQ,GAAG,KAAgB,KACpC,OAAO,CAAC,MAAM,CAiBhB,CAAA;AAED,KAAK,gBAAgB,GAAG,MAAM,CAC1B,MAAM,EACN;IACI,YAAY,EAAE,OAAO,CAAA;IACrB,SAAS,EAAE,MAAM,EAAE,CAAA;CACtB,CACJ,CAAA;AAED,eAAO,MAAM,0BAA0B,GACnC,qBAAqB,MAAM,GAAG,mBAAmB,EACjD,oBAAoB,MAAM,EAAE,KAC7B,gBAgEF,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EACH,mBAAmB,EACnB,mBAAmB,EACtB,MAAM,mCAAmC,CAAA;AAG1C,OAAO,EACH,uBAAuB,EACvB,2BAA2B,GAC9B,MAAM,wBAAwB,CAAA;AAE/B;;;;;GAKG;AACH,eAAO,MAAM,yBAAyB,GAClC,qBAAqB,MAAM,KAC5B,mBAGF,CAAA;AAED,eAAO,MAAM,yBAAyB,GAClC,YAAY,MAAM,KACnB,mBAGF,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,uBAAuB,GAChC,qBAAqB,MAAM,GAAG,mBAAmB,EACjD,SAAQ,QAAQ,GAAG,KAAgB,KACpC,OAAO,CAAC,MAAM,CAiBhB,CAAA;AAED,KAAK,gBAAgB,GAAG,MAAM,CAC1B,MAAM,EACN;IACI,YAAY,EAAE,OAAO,CAAA;IACrB,SAAS,EAAE,MAAM,EAAE,CAAA;CACtB,CACJ,CAAA;AAED,eAAO,MAAM,0BAA0B,GACnC,qBAAqB,MAAM,GAAG,mBAAmB,EACjD,oBAAoB,MAAM,EAAE,KAC7B,gBAgEF,CAAA"}