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>
49 lines
1.8 KiB
JavaScript
49 lines
1.8 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.recordActivityBatch = recordActivityBatch;
|
|
const ethers_1 = require("ethers");
|
|
const checkpoint_core_1 = require("@dbis/checkpoint-core");
|
|
const leafCodec_1 = require("./leafCodec");
|
|
const REGISTRY_ABI = [
|
|
'function recordBatch(uint64 batchId, tuple(bytes32 txHash,address from,address to,uint256 valueWei,uint256 blockNumber138,uint64 blockTimestamp138,uint64 valueUsdE8,uint32 logCount,bytes32 receiptHash)[] records) external',
|
|
'function recorded(bytes32) view returns (bool)',
|
|
];
|
|
function activityRecord(leaf) {
|
|
const usd = leaf.totalTransfersUsd ?? leaf.valueUsd ?? leaf.nativeValueUsd ?? '0';
|
|
return {
|
|
txHash: leaf.txHash,
|
|
from: leaf.from,
|
|
to: leaf.to,
|
|
valueWei: (0, leafCodec_1.effectiveValue)(leaf),
|
|
blockNumber138: BigInt(leaf.blockNumber),
|
|
blockTimestamp138: BigInt(leaf.blockTimestamp),
|
|
valueUsdE8: (0, checkpoint_core_1.usdStringToE8)(usd),
|
|
logCount: leaf.logCount ?? 0,
|
|
receiptHash: leaf.receiptHash ?? ethers_1.ethers.ZeroHash,
|
|
};
|
|
}
|
|
async function recordActivityBatch(wallet, registryAddress, batchId, leaves) {
|
|
if (!registryAddress || leaves.length === 0)
|
|
return null;
|
|
const registry = new ethers_1.ethers.Contract(registryAddress, REGISTRY_ABI, wallet);
|
|
const pending = [];
|
|
for (const leaf of leaves) {
|
|
if (!leaf.txHash)
|
|
continue;
|
|
try {
|
|
if (await registry.recorded(leaf.txHash))
|
|
continue;
|
|
}
|
|
catch {
|
|
/* continue */
|
|
}
|
|
pending.push(leaf);
|
|
}
|
|
if (pending.length === 0)
|
|
return null;
|
|
const records = pending.map(activityRecord);
|
|
const tx = await registry.recordBatch(batchId, records, { gasLimit: 2500000n });
|
|
await tx.wait();
|
|
return tx.hash;
|
|
}
|