Files
smom-dbis-138/script/deploy/vault/MigrateGRUVaultIndex138.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

83 lines
2.6 KiB
Solidity

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
import {Script, console2} from "forge-std/Script.sol";
import {GRUVaultIndex} from "../../../contracts/vault/GRUVaultIndex.sol";
import {VaultFactory} from "../../../contracts/vault/VaultFactory.sol";
interface IGRUVaultIndexLegacy {
function allVaults(uint256 index) external view returns (address);
function vaults(address vault)
external
view
returns (
address entity,
address baseToken,
address depositToken,
address debtToken,
uint8 gruTier,
bytes32 ibanHash,
bytes32 policyProfileKey,
uint256 recordedAt,
bool active
);
}
/// @notice Deploy GRUVaultIndex v2 and migrate records from legacy index with policy profile backfill.
contract MigrateGRUVaultIndex138 is Script {
function run() external {
uint256 pk = vm.envUint("PRIVATE_KEY");
address admin = vm.addr(pk);
address oldIndex = vm.envAddress("OLD_GRU_VAULT_INDEX");
address factory = vm.envAddress("VAULT_FACTORY_ADDRESS");
bytes32 policyKey = vm.envBytes32("GRU_POLICY_PROFILE_KEY");
vm.startBroadcast(pk);
GRUVaultIndex newIndex = new GRUVaultIndex(admin);
console2.log("New GRUVaultIndex:", address(newIndex));
IGRUVaultIndexLegacy legacy = IGRUVaultIndexLegacy(oldIndex);
uint256 imported;
for (uint256 i = 0; i < 32; i++) {
address vault;
try legacy.allVaults(i) returns (address v) {
vault = v;
} catch {
break;
}
if (vault == address(0)) break;
(
address entity,
address baseToken,
address depositToken,
address debtToken,
uint8 gruTier,
bytes32 ibanHash,
bytes32 existingKey,
uint256 recordedAt,
bool active
) = legacy.vaults(vault);
if (!active) continue;
bytes32 key = existingKey == bytes32(0) ? policyKey : existingKey;
newIndex.importVault(
vault, entity, baseToken, depositToken, debtToken, gruTier, ibanHash, key, recordedAt
);
imported++;
console2.log("Imported vault", vault);
}
newIndex.grantFactoryRole(factory);
VaultFactory(factory).setGruVaultIndex(address(newIndex));
vm.stopBroadcast();
console2.log("Migrated vault count:", imported);
console2.log("Update GRU_VAULT_INDEX to", address(newIndex));
}
}