Files
smom-dbis-138/script/bridge/trustless/DeployChain138StabilizerFinish.s.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

50 lines
2.3 KiB
Solidity

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.19;
import {Script, console2} from "forge-std/Script.sol";
import {Stabilizer} from "../../../contracts/bridge/trustless/integration/Stabilizer.sol";
import {StablecoinPegManager} from "../../../contracts/bridge/trustless/integration/StablecoinPegManager.sol";
import {CommodityPegManager} from "../../../contracts/bridge/trustless/integration/CommodityPegManager.sol";
/// @notice Finish Chain 138 Stabilizer stack after peg managers are already deployed.
/// @dev Env: STABLECOIN_PEG_MANAGER, COMMODITY_PEG_MANAGER, PRIVATE_POOL_REGISTRY, PRIVATE_KEY
contract DeployChain138StabilizerFinish is Script {
function run() external {
require(block.chainid == 138, "chain138 only");
uint256 pk = vm.envUint("PRIVATE_KEY");
address admin = vm.envOr("STABILIZER_ADMIN", vm.addr(pk));
address privatePoolRegistry = vm.envAddress("PRIVATE_POOL_REGISTRY");
address stablecoinPeg = vm.envAddress("STABLECOIN_PEG_MANAGER");
address commodityPeg = vm.envAddress("COMMODITY_PEG_MANAGER");
address cUsdc = vm.envOr("COMPLIANT_USDC_ADDRESS", vm.envOr("CUSDC_ADDRESS_138", address(0)));
address cUsdt = vm.envOr("COMPLIANT_USDT_ADDRESS", vm.envOr("CUSDT_ADDRESS_138", address(0)));
address weth = vm.envOr("WETH9", address(0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2));
address xau = vm.envOr("XAU_ADDRESS_138", vm.envOr("cXAUC_ADDRESS_138", address(0x290E52a8819A4fbD0714E517225429aA2B70EC6b)));
StablecoinPegManager spm = StablecoinPegManager(stablecoinPeg);
CommodityPegManager cpm = CommodityPegManager(commodityPeg);
vm.startBroadcast(pk);
spm.registerWETH(weth);
if (xau != address(0)) {
cpm.setXAUAddress(xau);
cpm.registerCommodity(xau, "XAU", 1e18);
}
Stabilizer stabilizer = new Stabilizer(admin, privatePoolRegistry);
stabilizer.setStablecoinPegSource(stablecoinPeg, cUsdc != address(0) ? cUsdc : cUsdt);
if (xau != address(0)) {
stabilizer.setCommodityPegSource(commodityPeg, xau);
}
vm.stopBroadcast();
console2.log("Stabilizer", address(stabilizer));
console2.log("StablecoinPegManager", stablecoinPeg);
console2.log("CommodityPegManager", commodityPeg);
}
}