Some checks failed
CI/CD Pipeline / Solidity Contracts (push) Failing after 1m3s
CI/CD Pipeline / Security Scanning (push) Successful in 2m18s
CI/CD Pipeline / Lint and Format (push) Failing after 34s
CI/CD Pipeline / Terraform Validation (push) Failing after 20s
CI/CD Pipeline / Kubernetes Validation (push) Successful in 22s
Deploy ChainID 138 / Deploy ChainID 138 (push) Failing after 40s
HYBX OMNL TypeScript & anchor / token-aggregation build + reconcile artifact (push) Failing after 49s
OMNL reconcile anchor / Run omnl:reconcile and upload artifacts (push) Failing after 21s
Validation / validate-genesis (push) Successful in 25s
Validation / validate-terraform (push) Failing after 21s
Validation / validate-kubernetes (push) Failing after 8s
Validation / validate-smart-contracts (push) Failing after 8s
Validation / validate-security (push) Failing after 1m11s
Validation / validate-documentation (push) Failing after 14s
Verify Deployment / Verify Deployment (push) Failing after 45s
Ship AddressActivityRegistry V1/V2, ISO20022IntakeGateway, Chain138ParticipantSurface, checkpoint hub contracts, checkpoint-core package, aggregator/indexer/sdk services, relay profile guards, M00 diamond bridge facet, and OMNL compliance contracts. Co-authored-by: Cursor <cursoragent@cursor.com>
48 lines
1.7 KiB
JavaScript
48 lines
1.7 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.buildMerkleRoot = buildMerkleRoot;
|
|
exports.merkleProofs = merkleProofs;
|
|
const ethers_1 = require("ethers");
|
|
/** Matches CheckpointLeaf.buildMerkleRoot (pair sort, odd duplicate). */
|
|
function buildMerkleRoot(hashes) {
|
|
if (hashes.length === 0)
|
|
return ethers_1.ethers.ZeroHash;
|
|
let layer = [...hashes];
|
|
while (layer.length > 1) {
|
|
const next = [];
|
|
for (let i = 0; i < layer.length; i += 2) {
|
|
const a = layer[i];
|
|
const b = i + 1 < layer.length ? layer[i + 1] : a;
|
|
const [left, right] = a.toLowerCase() < b.toLowerCase() ? [a, b] : [b, a];
|
|
next.push(ethers_1.ethers.keccak256(ethers_1.ethers.concat([left, right])));
|
|
}
|
|
layer = next;
|
|
}
|
|
return layer[0];
|
|
}
|
|
function merkleProofs(hashes) {
|
|
const root = buildMerkleRoot(hashes);
|
|
const proofs = hashes.map((_, index) => buildProof(hashes, index));
|
|
return { root, proofs };
|
|
}
|
|
function buildProof(leaves, index) {
|
|
const proof = [];
|
|
let idx = index;
|
|
let layer = [...leaves];
|
|
while (layer.length > 1) {
|
|
const next = [];
|
|
for (let i = 0; i < layer.length; i += 2) {
|
|
const a = layer[i];
|
|
const b = i + 1 < layer.length ? layer[i + 1] : a;
|
|
const [left, right] = a.toLowerCase() < b.toLowerCase() ? [a, b] : [b, a];
|
|
next.push(ethers_1.ethers.keccak256(ethers_1.ethers.concat([left, right])));
|
|
}
|
|
const siblingIdx = idx % 2 === 0 ? idx + 1 : idx - 1;
|
|
if (siblingIdx < layer.length)
|
|
proof.push(layer[siblingIdx]);
|
|
idx = Math.floor(idx / 2);
|
|
layer = next;
|
|
}
|
|
return proof;
|
|
}
|