From 4ec91b0816b1cd88c0e9e629dce143713cb17ebe Mon Sep 17 00:00:00 2001 From: Igor Yalovoy Date: Wed, 11 Dec 2024 16:45:44 -0600 Subject: [PATCH 1/3] Refactor fund faucet script to support multiple addresses with balance checks and dynamic funding. --- script/actions/fund-faucet.s.sol | 39 ------------------------- script/actions/fund-faucets.s.sol | 47 +++++++++++++++++++++++++++++++ 2 files changed, 47 insertions(+), 39 deletions(-) delete mode 100644 script/actions/fund-faucet.s.sol create mode 100644 script/actions/fund-faucets.s.sol diff --git a/script/actions/fund-faucet.s.sol b/script/actions/fund-faucet.s.sol deleted file mode 100644 index dff04ee42..000000000 --- a/script/actions/fund-faucet.s.sol +++ /dev/null @@ -1,39 +0,0 @@ -// SPDX-License-Identifier: MIT -pragma solidity ^0.8.18; - -import "@kinto-core/wallet/KintoWalletFactory.sol"; -import "@kinto-core/wallet/KintoWallet.sol"; -import "@kinto-core/paymasters/SponsorPaymaster.sol"; - -import "@kinto-core-test/helpers/Create2Helper.sol"; -import "@kinto-core-test/helpers/ArtifactsReader.sol"; -import "@kinto-core-test/helpers/UUPSProxy.sol"; - -import "forge-std/Script.sol"; -import "forge-std/console.sol"; - -contract FundFaucetScript is Create2Helper, ArtifactsReader { - function setUp() public {} - - // NOTE: this migration must be run from the ledger admin - function run() public { - console.log("RUNNING ON CHAIN WITH ID", vm.toString(block.chainid)); - // Execute this script with the ledger admin but first we use the hot wallet - console.log("Executing with address", msg.sender, vm.envAddress("LEDGER_ADMIN")); - address factoryAddr = _getChainDeployment("KintoWalletFactory"); - if (factoryAddr == address(0)) { - console.log("Need to execute main deploy script first", factoryAddr); - return; - } - // Start admin - vm.startBroadcast(); - uint256 AMOUNT_TO_SEND = 0.1 ether; - KintoWalletFactory(address(factoryAddr)).sendMoneyToAccount{value: AMOUNT_TO_SEND}( - 0xb539019776eF803E89EC062Ad54cA24D1Fdb008a - ); - vm.stopBroadcast(); - require(address(0xb539019776eF803E89EC062Ad54cA24D1Fdb008a).balance >= AMOUNT_TO_SEND, "amount was not sent"); - // writes the addresses to a file - console.log("Faucet amount sent"); - } -} diff --git a/script/actions/fund-faucets.s.sol b/script/actions/fund-faucets.s.sol new file mode 100644 index 000000000..1805c0393 --- /dev/null +++ b/script/actions/fund-faucets.s.sol @@ -0,0 +1,47 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.18; + +import {KintoWalletFactory} from "@kinto-core/wallet/KintoWalletFactory.sol"; +import {MigrationHelper} from "@kinto-core-script/utils/MigrationHelper.sol"; +import {ArrayHelpers} from "@kinto-core-test/helpers/ArrayHelpers.sol"; +import "forge-std/console2.sol"; + +contract FundFaucetsScript is MigrationHelper { + using ArrayHelpers for *; + + address public constant FAUCET = 0x0719D47A213149E2Ef8d3f5afDaDA8a8E22dfc03; + address public constant WALLET_FUNDER = 0x4062E762EC9E2E70f40bd9586C18d1894966628F; + address public constant FAUCET_CLAIMER = 0x52F09693c9eEaA93A64BA697e3d3e43a1eB65477; + address public constant KYC_RELAYER = 0x6E31039abF8d248aBed57E307C9E1b7530c269E4; + + function run() public override { + super.run(); + + console2.log('Hot Wallet Balance: %e', deployer.balance); + if(deployer.balance < 0.25 ether) { + console2.log('Hot Wallet Balance too low. Refill.'); + return; + } + + address[4] memory faucets = [FAUCET, WALLET_FUNDER, FAUCET_CLAIMER, KYC_RELAYER]; + string[4] memory names = ["FAUCET", "WALLET_FUNDER", "FAUCET_CLAIMER", "KYC_RELAYER"]; + uint64[4] memory limits = [0.25 ether, 0.25 ether, 0.25 ether, 0.25 ether]; + uint64[4] memory amounts = [0.25 ether, 0.25 ether, 0.25 ether, 0.25 ether]; + + for (uint256 index = 0; index < faucets.length; index++) { + address faucet = faucets[index]; + uint256 balance = faucet.balance; + console2.log('Faucet:', names[index]); + console2.log('Address:', faucets[index]); + console2.log('Balance: %e', balance); + + if (balance < limits[index]) { + console2.log('Needs funding. Adding:', amounts[index]); + + KintoWalletFactory factory = KintoWalletFactory(_getChainDeployment("KintoWalletFactory")); + vm.broadcast(deployerPrivateKey); + factory.sendMoneyToAccount{value: amounts[index]}(faucet); + } + } + } +} From 89786bb7406ab203b4eb06b665a5b3da967c6be3 Mon Sep 17 00:00:00 2001 From: Igor Yalovoy Date: Wed, 11 Dec 2024 16:59:41 -0600 Subject: [PATCH 2/3] Refactor log statements in fund-faucets.s.sol to use consistent double quotes for better readability. --- script/actions/fund-faucets.s.sol | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/script/actions/fund-faucets.s.sol b/script/actions/fund-faucets.s.sol index 1805c0393..79270339d 100644 --- a/script/actions/fund-faucets.s.sol +++ b/script/actions/fund-faucets.s.sol @@ -17,9 +17,9 @@ contract FundFaucetsScript is MigrationHelper { function run() public override { super.run(); - console2.log('Hot Wallet Balance: %e', deployer.balance); - if(deployer.balance < 0.25 ether) { - console2.log('Hot Wallet Balance too low. Refill.'); + console2.log("Hot Wallet Balance: %e", deployer.balance); + if (deployer.balance < 0.25 ether) { + console2.log("Hot Wallet Balance too low. Refill."); return; } @@ -31,12 +31,12 @@ contract FundFaucetsScript is MigrationHelper { for (uint256 index = 0; index < faucets.length; index++) { address faucet = faucets[index]; uint256 balance = faucet.balance; - console2.log('Faucet:', names[index]); - console2.log('Address:', faucets[index]); - console2.log('Balance: %e', balance); + console2.log("Faucet:", names[index]); + console2.log("Address:", faucets[index]); + console2.log("Balance: %e", balance); if (balance < limits[index]) { - console2.log('Needs funding. Adding:', amounts[index]); + console2.log("Needs funding. Adding:", amounts[index]); KintoWalletFactory factory = KintoWalletFactory(_getChainDeployment("KintoWalletFactory")); vm.broadcast(deployerPrivateKey); From cfac64e47fbbaeeb59e378da2b8363460d936993 Mon Sep 17 00:00:00 2001 From: Igor Yalovoy Date: Thu, 12 Dec 2024 12:53:56 -0600 Subject: [PATCH 3/3] Add SponsorPaymaster integration and fund apps with balance checks and deposits. --- script/actions/fund-faucets.s.sol | 37 +++++++++++++++++++++++++++++-- 1 file changed, 35 insertions(+), 2 deletions(-) diff --git a/script/actions/fund-faucets.s.sol b/script/actions/fund-faucets.s.sol index 79270339d..74d81fa1d 100644 --- a/script/actions/fund-faucets.s.sol +++ b/script/actions/fund-faucets.s.sol @@ -2,6 +2,7 @@ pragma solidity ^0.8.18; import {KintoWalletFactory} from "@kinto-core/wallet/KintoWalletFactory.sol"; +import {SponsorPaymaster} from "@kinto-core/paymasters/SponsorPaymaster.sol"; import {MigrationHelper} from "@kinto-core-script/utils/MigrationHelper.sol"; import {ArrayHelpers} from "@kinto-core-test/helpers/ArrayHelpers.sol"; import "forge-std/console2.sol"; @@ -14,6 +15,10 @@ contract FundFaucetsScript is MigrationHelper { address public constant FAUCET_CLAIMER = 0x52F09693c9eEaA93A64BA697e3d3e43a1eB65477; address public constant KYC_RELAYER = 0x6E31039abF8d248aBed57E307C9E1b7530c269E4; + address public constant DINARI = 0xB2eEc63Cdc175d6d07B8f69804C0Ab5F66aCC3cb; + address public constant KINTO_CORE = 0xD157904639E89df05e89e0DabeEC99aE3d74F9AA; + address public constant SOCKET_DL = 0x3e9727470C66B1e77034590926CDe0242B5A3dCc; + function run() public override { super.run(); @@ -23,11 +28,15 @@ contract FundFaucetsScript is MigrationHelper { return; } + console2.log(""); + console2.log("Faucets"); + address[4] memory faucets = [FAUCET, WALLET_FUNDER, FAUCET_CLAIMER, KYC_RELAYER]; string[4] memory names = ["FAUCET", "WALLET_FUNDER", "FAUCET_CLAIMER", "KYC_RELAYER"]; uint64[4] memory limits = [0.25 ether, 0.25 ether, 0.25 ether, 0.25 ether]; uint64[4] memory amounts = [0.25 ether, 0.25 ether, 0.25 ether, 0.25 ether]; + KintoWalletFactory factory = KintoWalletFactory(_getChainDeployment("KintoWalletFactory")); for (uint256 index = 0; index < faucets.length; index++) { address faucet = faucets[index]; uint256 balance = faucet.balance; @@ -36,12 +45,36 @@ contract FundFaucetsScript is MigrationHelper { console2.log("Balance: %e", balance); if (balance < limits[index]) { - console2.log("Needs funding. Adding:", amounts[index]); + console2.log("Needs funding. Adding: %e", amounts[index]); - KintoWalletFactory factory = KintoWalletFactory(_getChainDeployment("KintoWalletFactory")); vm.broadcast(deployerPrivateKey); factory.sendMoneyToAccount{value: amounts[index]}(faucet); } } + + console2.log(""); + console2.log("Apps"); + + address[3] memory apps = [KINTO_CORE, DINARI, SOCKET_DL]; + string[3] memory appNames = ["KINTO_CORE", "DINARI", "SOCKET_DL"]; + uint56[3] memory appLimits = [0.02 ether, 0.02 ether, 0.02 ether]; + uint56[3] memory appAmounts = [0.01 ether, 0.01 ether, 0.01 ether]; + + SponsorPaymaster paymaster = SponsorPaymaster(_getChainDeployment("SponsorPaymaster")); + for (uint256 index = 0; index < apps.length; index++) { + address app = apps[index]; + uint256 balance = paymaster.balances(app); + + console2.log("App:", appNames[index]); + console2.log("Address:", app); + console2.log("Balance: %e", balance); + + if (balance < appLimits[index]) { + console2.log("Needs funding. Adding: %e", appAmounts[index]); + + vm.broadcast(deployerPrivateKey); + paymaster.addDepositFor{value: appAmounts[index]}(app); + } + } } }