Files
self/contracts/scripts/setRegistryId.ts
nicoshark 668732a57b Chore/refactor contracts (#582)
* add eu id support

* add ofac and disclosure euid support

* add contract support for euid cards

* update contracts

* add comment out to remember the interface what we need to implement

* prettier

* get combine verifyVcAndDisclose function and get bytes data

* unified library and clean constant V2

* fix verifyVcAndDisclose interface

* add prettier and run prettier except .sol files

* prettier

* circuit compilation for local environment

* add register id circuit in the contracts dir

* clean up ignition deploy scritps

* refactor deploy scripts

* prettier

* update serialized dsc tree

* fix ofac check

* fix passport attestation id

---------

Co-authored-by: turnoffthiscomputer <colin.remi07@gmail.com>
2025-06-03 14:58:41 +09:00

133 lines
4.8 KiB
TypeScript

import { ethers } from "ethers";
import * as dotenv from "dotenv";
import * as fs from "fs";
import * as path from "path";
// import { getCscaTreeRoot } from "../../common/src/utils/trees";
// import serialized_csca_tree from "../../common/pubkeys/serialized_csca_tree.json";
dotenv.config();
// Environment configuration
const NETWORK = process.env.NETWORK || "localhost"; // Default to localhost
const RPC_URL_KEY = NETWORK === "celo" ? "CELO_RPC_URL" : "CELO_ALFAJORES_RPC_URL";
const PRIVATE_KEY = process.env.CELO_KEY;
const SKIP_CSCA_UPDATE = process.env.SKIP_CSCA_UPDATE === "true";
const CSCA_ROOT = process.env.CSCA_ROOT; // Allow manual CSCA root setting
// Network to Chain ID mapping
const NETWORK_TO_CHAIN_ID: Record<string, string> = {
"localhost": "31337",
"celoAlfajores": "44787",
"celo": "42220",
};
// Get chain ID from network name
const getChainId = (network: string): string => {
return NETWORK_TO_CHAIN_ID[network] || NETWORK_TO_CHAIN_ID["localhost"];
};
const CHAIN_ID = getChainId(NETWORK);
// Dynamic paths based on chain ID
const deployedAddressesPath = path.join(__dirname, `../ignition/deployments/chain-${CHAIN_ID}/deployed_addresses.json`);
const contractAbiPath = path.join(__dirname, `../ignition/deployments/chain-${CHAIN_ID}/artifacts/DeployIdCardRegistryModule#IdentityRegistryIdCardImplV1.json`);
// Debug logs for paths and files
console.log("Network:", NETWORK);
console.log("Chain ID:", CHAIN_ID);
console.log("Current directory:", __dirname);
console.log("Deployed addresses path:", deployedAddressesPath);
console.log("Contract ABI path:", contractAbiPath);
// Debug logs for environment variables (redacted for security)
console.log(`${RPC_URL_KEY} configured:`, !!process.env[RPC_URL_KEY]);
console.log("CELO_KEY configured:", !!PRIVATE_KEY);
try {
const deployedAddresses = JSON.parse(fs.readFileSync(deployedAddressesPath, "utf-8"));
console.log("Deployed addresses loaded:", deployedAddresses);
const identityRegistryIdCardAbiFile = fs.readFileSync(contractAbiPath, "utf-8");
console.log("Registry ID Card ABI file loaded");
const identityRegistryIdCardAbi = JSON.parse(identityRegistryIdCardAbiFile).abi;
console.log("Registry ID Card ABI parsed");
function getContractAddressByExactName(exactName: string): string | unknown {
if (exactName in deployedAddresses) {
return deployedAddresses[exactName];
}
return undefined;
}
async function main() {
const provider = new ethers.JsonRpcProvider(process.env[RPC_URL_KEY] as string);
console.log("Provider created");
const wallet = new ethers.Wallet(PRIVATE_KEY as string, provider);
console.log("Wallet created");
// Get registry ID card address
const registryIdCardAddress = getContractAddressByExactName("DeployIdCardRegistryModule#IdentityRegistryIdCard");
console.log("Registry ID Card address:", registryIdCardAddress);
if (!registryIdCardAddress) {
throw new Error("Registry ID Card address not found in deployed_addresses.json");
}
// Get hub address
const hubAddress = getContractAddressByExactName("DeployHubV2#IdentityVerificationHubImplV2");
console.log("Hub address:", hubAddress);
if (!hubAddress) {
throw new Error("Hub address not found in deployed_addresses.json");
}
const identityRegistryIdCard = new ethers.Contract(registryIdCardAddress as string, identityRegistryIdCardAbi, wallet);
console.log("Registry ID Card contract instance created");
// Update hub address
console.log("Updating hub address...");
try {
const tx1 = await identityRegistryIdCard.updateHub(hubAddress);
const receipt1 = await tx1.wait();
console.log(`Hub address updated with tx: ${receipt1.hash}`);
} catch (error) {
console.error("Error updating hub address:", error);
}
// Update CSCA root (same value as passport registry)
console.log("Updating CSCA root...");
try {
if (SKIP_CSCA_UPDATE) {
console.log("Skipping CSCA root update as per configuration");
return;
}
if (!CSCA_ROOT) {
console.log("CSCA_ROOT environment variable not set, skipping CSCA root update");
console.log("To set CSCA root, use: CSCA_ROOT=<your_root_value> npm run set:registry:idcard");
return;
}
console.log("CSCA Merkle root:", CSCA_ROOT);
const tx2 = await identityRegistryIdCard.updateCscaRoot(CSCA_ROOT);
const receipt2 = await tx2.wait();
console.log(`CSCA root updated with tx: ${receipt2.hash}`);
} catch (error) {
console.error("Error updating CSCA root:", error);
}
console.log("Registry ID Card setup completed successfully!");
}
main().catch((error) => {
console.error("Execution error:", error);
process.exitCode = 1;
});
} catch (error) {
console.error("Initial setup error:", error);
process.exitCode = 1;
}