Files
smom-dbis-138/contracts/mainnet-checkpoint/libraries/CheckpointLeaf.sol
defiQUG c336809676
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
Add mainnet checkpoint stack: ISO attestation, participant Etherscan surface, and services.
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>
2026-05-25 00:30:45 -07:00

106 lines
3.1 KiB
Solidity

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
/**
* @title CheckpointLeaf
* @notice Canonical payment leaves for Merkle proofs (versioned).
*/
library CheckpointLeaf {
bytes1 internal constant PAYMENT_LEAF_V1 = 0x01;
bytes1 internal constant PAYMENT_LEAF_V2 = 0x02;
struct PaymentLeafV1 {
bytes32 txHash;
address from;
address to;
uint256 value;
uint256 blockNumber;
uint64 blockTimestamp;
uint256 gasUsed;
bool success;
}
/// @notice V2 adds optional ERC-20 token + log index for transfer-only batches
struct PaymentLeafV2 {
bytes32 txHash;
address from;
address to;
address token;
uint256 value;
uint256 blockNumber;
uint64 blockTimestamp;
uint256 gasUsed;
bool success;
uint32 logIndex;
}
function paymentLeafV1(
uint64 chainId,
PaymentLeafV1 memory leaf
) internal pure returns (bytes32) {
return keccak256(
abi.encode(
PAYMENT_LEAF_V1,
chainId,
leaf.txHash,
leaf.from,
leaf.to,
leaf.value,
leaf.blockNumber,
leaf.blockTimestamp,
leaf.gasUsed,
leaf.success
)
);
}
function paymentLeafV2(uint64 chainId, PaymentLeafV2 memory leaf) internal pure returns (bytes32) {
return keccak256(
abi.encode(
PAYMENT_LEAF_V2,
chainId,
leaf.txHash,
leaf.from,
leaf.to,
leaf.token,
leaf.value,
leaf.blockNumber,
leaf.blockTimestamp,
leaf.gasUsed,
leaf.success,
leaf.logIndex
)
);
}
function buildMerkleRoot(bytes32[] memory leaves) internal pure returns (bytes32) {
require(leaves.length > 0, "empty");
if (leaves.length == 1) return leaves[0];
bytes32[] memory layer = leaves;
while (layer.length > 1) {
uint256 nextLen = (layer.length + 1) / 2;
bytes32[] memory next = new bytes32[](nextLen);
for (uint256 i = 0; i < layer.length; i += 2) {
bytes32 a = layer[i];
bytes32 b = i + 1 < layer.length ? layer[i + 1] : a;
next[i / 2] = _hashPair(a, b);
}
layer = next;
}
return layer[0];
}
function _hashPair(bytes32 a, bytes32 b) private pure returns (bytes32) {
return a < b ? keccak256(abi.encodePacked(a, b)) : keccak256(abi.encodePacked(b, a));
}
function verifyMerkle(bytes32 root, bytes32 leaf, bytes32[] memory proof) internal pure returns (bool) {
bytes32 computed = leaf;
for (uint256 i = 0; i < proof.length; i++) {
bytes32 p = proof[i];
computed = computed < p ? keccak256(abi.encodePacked(computed, p)) : keccak256(abi.encodePacked(p, computed));
}
return computed == root;
}
}