More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 2,923 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Transfer | 22302916 | 8 hrs ago | IN | 0.01218116 ETH | 0.00000894 | ||||
Transfer | 22302635 | 9 hrs ago | IN | 0.0062659 ETH | 0.00000982 | ||||
Transfer | 22301850 | 12 hrs ago | IN | 0.01098434 ETH | 0.00000894 | ||||
Transfer | 22301716 | 12 hrs ago | IN | 0.00526129 ETH | 0.00000831 | ||||
Transfer | 22300256 | 17 hrs ago | IN | 0.01200944 ETH | 0.00001004 | ||||
Transfer | 22299141 | 21 hrs ago | IN | 0.00790392 ETH | 0.00000932 | ||||
Transfer | 22298695 | 22 hrs ago | IN | 0.00556034 ETH | 0.00001002 | ||||
Transfer | 22297993 | 25 hrs ago | IN | 0.02047079 ETH | 0.00001157 | ||||
Transfer | 22297943 | 25 hrs ago | IN | 0.01095979 ETH | 0.0000094 | ||||
Transfer | 22297036 | 28 hrs ago | IN | 0.03006308 ETH | 0.00001189 | ||||
Transfer | 22295811 | 32 hrs ago | IN | 0.01094261 ETH | 0.00001114 | ||||
Transfer | 22295593 | 33 hrs ago | IN | 0.02546298 ETH | 0.00000981 | ||||
Transfer | 22295021 | 35 hrs ago | IN | 0.01284913 ETH | 0.00000965 | ||||
Transfer | 22294685 | 36 hrs ago | IN | 0.05603334 ETH | 0.00001172 | ||||
Transfer | 22293995 | 38 hrs ago | IN | 0.01947275 ETH | 0.0000097 | ||||
Transfer | 22293188 | 41 hrs ago | IN | 0.03306324 ETH | 0.00000865 | ||||
Transfer | 22292523 | 43 hrs ago | IN | 0.01361968 ETH | 0.00001014 | ||||
Transfer | 22292398 | 43 hrs ago | IN | 0.01661318 ETH | 0.00000906 | ||||
Transfer | 22291916 | 45 hrs ago | IN | 0.01905574 ETH | 0.00000919 | ||||
Transfer | 22291563 | 46 hrs ago | IN | 0.0950915 ETH | 0.00000987 | ||||
Transfer | 22291452 | 47 hrs ago | IN | 0.01028313 ETH | 0.00000905 | ||||
Send Multi Sig | 22291033 | 2 days ago | IN | 0 ETH | 0.00022167 | ||||
Transfer | 22289328 | 2 days ago | IN | 0.07223046 ETH | 0.00003089 | ||||
Transfer | 22288544 | 2 days ago | IN | 0.01819248 ETH | 0.00000777 | ||||
Transfer | 22287506 | 2 days ago | IN | 0.01944006 ETH | 0.00001277 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Method | Block |
From
|
To
|
|||
---|---|---|---|---|---|---|---|
Deposit | 22291033 | 2 days ago | 96 ETH | ||||
Transfer | 22290849 | 2 days ago | 96 ETH | ||||
Deposit | 22284198 | 2 days ago | 96 ETH | ||||
Transfer | 22283856 | 3 days ago | 1,920 ETH | ||||
Transfer | 22283856 | 3 days ago | 96 ETH | ||||
Transfer | 22283856 | 3 days ago | 90.70435428 ETH | ||||
Transfer | 22276746 | 4 days ago | 160 ETH | ||||
Deposit | 22276746 | 4 days ago | 160 ETH | ||||
Deposit | 22269806 | 4 days ago | 384 ETH | ||||
Transfer | 22269360 | 5 days ago | 384 ETH | ||||
Deposit | 22253164 | 7 days ago | 128 ETH | ||||
Transfer | 22247887 | 8 days ago | 128 ETH | ||||
Deposit | 22242899 | 8 days ago | 192 ETH | ||||
Transfer | 22241009 | 9 days ago | 192 ETH | ||||
Deposit | 22235075 | 9 days ago | 256 ETH | ||||
Transfer | 22234199 | 9 days ago | 256 ETH | ||||
Deposit | 22232002 | 10 days ago | 160 ETH | ||||
Deposit | 22226699 | 10 days ago | 416 ETH | ||||
Transfer | 22226699 | 10 days ago | 160 ETH | ||||
Deposit | 22219466 | 12 days ago | 96 ETH | ||||
Transfer | 22219466 | 12 days ago | 416 ETH | ||||
Transfer | 22198017 | 15 days ago | 96 ETH | ||||
Deposit | 22191046 | 15 days ago | 96 ETH | ||||
Transfer | 22190810 | 16 days ago | 96 ETH | ||||
Deposit | 22183645 | 17 days ago | 64 ETH |
Loading...
Loading
Minimal Proxy Contract for 0xe8e847cf573fc8ed75621660a36affd18c543d7e
Contract Name:
WalletSimple
Compiler Version
v0.7.5+commit.eb77ed08
Contract Source Code (Solidity Multiple files format)
// SPDX-License-Identifier: Apache-2.0 pragma solidity 0.7.5; import './TransferHelper.sol'; import './Forwarder.sol'; import './ERC20Interface.sol'; /** * * WalletSimple * ============ * * Basic multi-signer wallet designed for use in a co-signing environment where 2 signatures are required to move funds. * Typically used in a 2-of-3 signing configuration. Uses ecrecover to allow for 2 signatures in a single transaction. * * The first signature is created on the operation hash (see Data Formats) and passed to sendMultiSig/sendMultiSigToken * The signer is determined by verifyMultiSig(). * * The second signature is created by the submitter of the transaction and determined by msg.signer. * * Data Formats * ============ * * The signature is created with ethereumjs-util.ecsign(operationHash). * Like the eth_sign RPC call, it packs the values as a 65-byte array of [r, s, v]. * Unlike eth_sign, the message is not prefixed. * * The operationHash the result of keccak256(prefix, toAddress, value, data, expireTime). * For ether transactions, `prefix` is "ETHER". * For token transaction, `prefix` is "ERC20" and `data` is the tokenContractAddress. * * */ contract WalletSimple { // Events event Deposited(address from, uint256 value, bytes data); event SafeModeActivated(address msgSender); event Transacted( address msgSender, // Address of the sender of the message initiating the transaction address otherSigner, // Address of the signer (second signature) used to initiate the transaction bytes32 operation, // Operation hash (see Data Formats) address toAddress, // The address the transaction was sent to uint256 value, // Amount of Wei sent to the address bytes data // Data sent when invoking the transaction ); event BatchTransfer(address sender, address recipient, uint256 value); // this event shows the other signer and the operation hash that they signed // specific batch transfer events are emitted in Batcher event BatchTransacted( address msgSender, // Address of the sender of the message initiating the transaction address otherSigner, // Address of the signer (second signature) used to initiate the transaction bytes32 operation // Operation hash (see Data Formats) ); // Public fields mapping(address => bool) public signers; // The addresses that can co-sign transactions on the wallet bool public safeMode = false; // When active, wallet may only send to signer addresses bool public initialized = false; // True if the contract has been initialized // Internal fields uint256 private constant MAX_SEQUENCE_ID_INCREASE = 10000; uint256 constant SEQUENCE_ID_WINDOW_SIZE = 10; uint256[SEQUENCE_ID_WINDOW_SIZE] recentSequenceIds; /** * Set up a simple multi-sig wallet by specifying the signers allowed to be used on this wallet. * 2 signers will be required to send a transaction from this wallet. * Note: The sender is NOT automatically added to the list of signers. * Signers CANNOT be changed once they are set * * @param allowedSigners An array of signers on the wallet */ function init(address[] calldata allowedSigners) external onlyUninitialized { require(allowedSigners.length == 3, 'Invalid number of signers'); for (uint8 i = 0; i < allowedSigners.length; i++) { require(allowedSigners[i] != address(0), 'Invalid signer'); signers[allowedSigners[i]] = true; } initialized = true; } /** * Get the network identifier that signers must sign over * This provides protection signatures being replayed on other chains * This must be a virtual function because chain-specific contracts will need * to override with their own network ids. It also can't be a field * to allow this contract to be used by proxy with delegatecall, which will * not pick up on state variables */ function getNetworkId() internal virtual pure returns (string memory) { return 'ETHER'; } /** * Get the network identifier that signers must sign over for token transfers * This provides protection signatures being replayed on other chains * This must be a virtual function because chain-specific contracts will need * to override with their own network ids. It also can't be a field * to allow this contract to be used by proxy with delegatecall, which will * not pick up on state variables */ function getTokenNetworkId() internal virtual pure returns (string memory) { return 'ERC20'; } /** * Get the network identifier that signers must sign over for batch transfers * This provides protection signatures being replayed on other chains * This must be a virtual function because chain-specific contracts will need * to override with their own network ids. It also can't be a field * to allow this contract to be used by proxy with delegatecall, which will * not pick up on state variables */ function getBatchNetworkId() internal virtual pure returns (string memory) { return 'ETHER-Batch'; } /** * Determine if an address is a signer on this wallet * @param signer address to check * returns boolean indicating whether address is signer or not */ function isSigner(address signer) public view returns (bool) { return signers[signer]; } /** * Modifier that will execute internal code block only if the sender is an authorized signer on this wallet */ modifier onlySigner { require(isSigner(msg.sender), 'Non-signer in onlySigner method'); _; } /** * Modifier that will execute internal code block only if the contract has not been initialized yet */ modifier onlyUninitialized { require(!initialized, 'Contract already initialized'); _; } /** * Gets called when a transaction is received with data that does not match any other method */ fallback() external payable { if (msg.value > 0) { // Fire deposited event if we are receiving funds Deposited(msg.sender, msg.value, msg.data); } } /** * Gets called when a transaction is received with ether and no data */ receive() external payable { if (msg.value > 0) { // Fire deposited event if we are receiving funds Deposited(msg.sender, msg.value, msg.data); } } /** * Execute a multi-signature transaction from this wallet using 2 signers: one from msg.sender and the other from ecrecover. * Sequence IDs are numbers starting from 1. They are used to prevent replay attacks and may not be repeated. * * @param toAddress the destination address to send an outgoing transaction * @param value the amount in Wei to be sent * @param data the data to send to the toAddress when invoking the transaction * @param expireTime the number of seconds since 1970 for which this transaction is valid * @param sequenceId the unique sequence id obtainable from getNextSequenceId * @param signature see Data Formats */ function sendMultiSig( address toAddress, uint256 value, bytes calldata data, uint256 expireTime, uint256 sequenceId, bytes calldata signature ) external onlySigner { // Verify the other signer bytes32 operationHash = keccak256( abi.encodePacked( getNetworkId(), toAddress, value, data, expireTime, sequenceId ) ); address otherSigner = verifyMultiSig( toAddress, operationHash, signature, expireTime, sequenceId ); // Success, send the transaction (bool success, ) = toAddress.call{ value: value }(data); require(success, 'Call execution failed'); emit Transacted( msg.sender, otherSigner, operationHash, toAddress, value, data ); } /** * Execute a batched multi-signature transaction from this wallet using 2 signers: one from msg.sender and the other from ecrecover. * Sequence IDs are numbers starting from 1. They are used to prevent replay attacks and may not be repeated. * The recipients and values to send are encoded in two arrays, where for index i, recipients[i] will be sent values[i]. * * @param recipients The list of recipients to send to * @param values The list of values to send to * @param expireTime the number of seconds since 1970 for which this transaction is valid * @param sequenceId the unique sequence id obtainable from getNextSequenceId * @param signature see Data Formats */ function sendMultiSigBatch( address[] calldata recipients, uint256[] calldata values, uint256 expireTime, uint256 sequenceId, bytes calldata signature ) external onlySigner { require(recipients.length != 0, 'Not enough recipients'); require( recipients.length == values.length, 'Unequal recipients and values' ); require(recipients.length < 256, 'Too many recipients, max 255'); // Verify the other signer bytes32 operationHash = keccak256( abi.encodePacked( getBatchNetworkId(), recipients, values, expireTime, sequenceId ) ); // the first parameter (toAddress) is used to ensure transactions in safe mode only go to a signer // if in safe mode, we should use normal sendMultiSig to recover, so this check will always fail if in safe mode require(!safeMode, 'Batch in safe mode'); address otherSigner = verifyMultiSig( address(0x0), operationHash, signature, expireTime, sequenceId ); batchTransfer(recipients, values); emit BatchTransacted(msg.sender, otherSigner, operationHash); } /** * Transfer funds in a batch to each of recipients * @param recipients The list of recipients to send to * @param values The list of values to send to recipients. * The recipient with index i in recipients array will be sent values[i]. * Thus, recipients and values must be the same length */ function batchTransfer( address[] calldata recipients, uint256[] calldata values ) internal { for (uint256 i = 0; i < recipients.length; i++) { require(address(this).balance >= values[i], 'Insufficient funds'); (bool success, ) = recipients[i].call{ value: values[i] }(''); require(success, 'Call failed'); emit BatchTransfer(msg.sender, recipients[i], values[i]); } } /** * Execute a multi-signature token transfer from this wallet using 2 signers: one from msg.sender and the other from ecrecover. * Sequence IDs are numbers starting from 1. They are used to prevent replay attacks and may not be repeated. * * @param toAddress the destination address to send an outgoing transaction * @param value the amount in tokens to be sent * @param tokenContractAddress the address of the erc20 token contract * @param expireTime the number of seconds since 1970 for which this transaction is valid * @param sequenceId the unique sequence id obtainable from getNextSequenceId * @param signature see Data Formats */ function sendMultiSigToken( address toAddress, uint256 value, address tokenContractAddress, uint256 expireTime, uint256 sequenceId, bytes calldata signature ) external onlySigner { // Verify the other signer bytes32 operationHash = keccak256( abi.encodePacked( getTokenNetworkId(), toAddress, value, tokenContractAddress, expireTime, sequenceId ) ); verifyMultiSig(toAddress, operationHash, signature, expireTime, sequenceId); TransferHelper.safeTransfer(tokenContractAddress, toAddress, value); } /** * Execute a token flush from one of the forwarder addresses. This transfer needs only a single signature and can be done by any signer * * @param forwarderAddress the address of the forwarder address to flush the tokens from * @param tokenContractAddress the address of the erc20 token contract */ function flushForwarderTokens( address payable forwarderAddress, address tokenContractAddress ) external onlySigner { Forwarder forwarder = Forwarder(forwarderAddress); forwarder.flushTokens(tokenContractAddress); } /** * Do common multisig verification for both eth sends and erc20token transfers * * @param toAddress the destination address to send an outgoing transaction * @param operationHash see Data Formats * @param signature see Data Formats * @param expireTime the number of seconds since 1970 for which this transaction is valid * @param sequenceId the unique sequence id obtainable from getNextSequenceId * returns address that has created the signature */ function verifyMultiSig( address toAddress, bytes32 operationHash, bytes calldata signature, uint256 expireTime, uint256 sequenceId ) private returns (address) { address otherSigner = recoverAddressFromSignature(operationHash, signature); // Verify if we are in safe mode. In safe mode, the wallet can only send to signers require(!safeMode || isSigner(toAddress), 'External transfer in safe mode'); // Verify that the transaction has not expired require(expireTime >= block.timestamp, 'Transaction expired'); // Try to insert the sequence ID. Will revert if the sequence id was invalid tryInsertSequenceId(sequenceId); require(isSigner(otherSigner), 'Invalid signer'); require(otherSigner != msg.sender, 'Signers cannot be equal'); return otherSigner; } /** * Irrevocably puts contract into safe mode. When in this mode, transactions may only be sent to signing addresses. */ function activateSafeMode() external onlySigner { safeMode = true; SafeModeActivated(msg.sender); } /** * Gets signer's address using ecrecover * @param operationHash see Data Formats * @param signature see Data Formats * returns address recovered from the signature */ function recoverAddressFromSignature( bytes32 operationHash, bytes memory signature ) private pure returns (address) { require(signature.length == 65, 'Invalid signature - wrong length'); // We need to unpack the signature, which is given as an array of 65 bytes (like eth.sign) bytes32 r; bytes32 s; uint8 v; // solhint-disable-next-line assembly { r := mload(add(signature, 32)) s := mload(add(signature, 64)) v := and(mload(add(signature, 65)), 255) } if (v < 27) { v += 27; // Ethereum versions are 27 or 28 as opposed to 0 or 1 which is submitted by some signing libs } // protect against signature malleability // S value must be in the lower half orader // reference: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/051d340171a93a3d401aaaea46b4b62fa81e5d7c/contracts/cryptography/ECDSA.sol#L53 require( uint256(s) <= 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0, "ECDSA: invalid signature 's' value" ); // note that this returns 0 if the signature is invalid // Since 0x0 can never be a signer, when the recovered signer address // is checked against our signer list, that 0x0 will cause an invalid signer failure return ecrecover(operationHash, v, r, s); } /** * Verify that the sequence id has not been used before and inserts it. Throws if the sequence ID was not accepted. * We collect a window of up to 10 recent sequence ids, and allow any sequence id that is not in the window and * greater than the minimum element in the window. * @param sequenceId to insert into array of stored ids */ function tryInsertSequenceId(uint256 sequenceId) private onlySigner { // Keep a pointer to the lowest value element in the window uint256 lowestValueIndex = 0; // fetch recentSequenceIds into memory for function context to avoid unnecessary sloads uint256[SEQUENCE_ID_WINDOW_SIZE] memory _recentSequenceIds = recentSequenceIds; for (uint256 i = 0; i < SEQUENCE_ID_WINDOW_SIZE; i++) { require(_recentSequenceIds[i] != sequenceId, 'Sequence ID already used'); if (_recentSequenceIds[i] < _recentSequenceIds[lowestValueIndex]) { lowestValueIndex = i; } } // The sequence ID being used is lower than the lowest value in the window // so we cannot accept it as it may have been used before require( sequenceId > _recentSequenceIds[lowestValueIndex], 'Sequence ID below window' ); // Block sequence IDs which are much higher than the lowest value // This prevents people blocking the contract by using very large sequence IDs quickly require( sequenceId <= (_recentSequenceIds[lowestValueIndex] + MAX_SEQUENCE_ID_INCREASE), 'Sequence ID above maximum' ); recentSequenceIds[lowestValueIndex] = sequenceId; } /** * Gets the next available sequence ID for signing when using executeAndConfirm * returns the sequenceId one higher than the highest currently stored */ function getNextSequenceId() public view returns (uint256) { uint256 highestSequenceId = 0; for (uint256 i = 0; i < SEQUENCE_ID_WINDOW_SIZE; i++) { if (recentSequenceIds[i] > highestSequenceId) { highestSequenceId = recentSequenceIds[i]; } } return highestSequenceId + 1; } }
File 2 of 4: ERC20Interface.sol
// SPDX-License-Identifier: UNLICENSED pragma solidity 0.7.5; /** * Contract that exposes the needed erc20 token functions */ abstract contract ERC20Interface { // Send _value amount of tokens to address _to function transfer(address _to, uint256 _value) public virtual returns (bool success); // Get the account balance of another account with address _owner function balanceOf(address _owner) public virtual view returns (uint256 balance); }
File 3 of 4: Forwarder.sol
// SPDX-License-Identifier: Apache-2.0 pragma solidity 0.7.5; import './TransferHelper.sol'; import './ERC20Interface.sol'; /** * Contract that will forward any incoming Ether to the creator of the contract * */ contract Forwarder { // Address to which any funds sent to this contract will be forwarded address public parentAddress; event ForwarderDeposited(address from, uint256 value, bytes data); /** * Initialize the contract, and sets the destination address to that of the creator */ function init(address _parentAddress) external onlyUninitialized { parentAddress = _parentAddress; uint256 value = address(this).balance; if (value == 0) { return; } (bool success, ) = parentAddress.call{ value: value }(''); require(success, 'Flush failed'); // NOTE: since we are forwarding on initialization, // we don't have the context of the original sender. // We still emit an event about the forwarding but set // the sender to the forwarder itself emit ForwarderDeposited(address(this), value, msg.data); } /** * Modifier that will execute internal code block only if the sender is the parent address */ modifier onlyParent { require(msg.sender == parentAddress, 'Only Parent'); _; } /** * Modifier that will execute internal code block only if the contract has not been initialized yet */ modifier onlyUninitialized { require(parentAddress == address(0x0), 'Already initialized'); _; } /** * Default function; Gets called when data is sent but does not match any other function */ fallback() external payable { flush(); } /** * Default function; Gets called when Ether is deposited with no data, and forwards it to the parent address */ receive() external payable { flush(); } /** * Execute a token transfer of the full balance from the forwarder token to the parent address * @param tokenContractAddress the address of the erc20 token contract */ function flushTokens(address tokenContractAddress) external onlyParent { ERC20Interface instance = ERC20Interface(tokenContractAddress); address forwarderAddress = address(this); uint256 forwarderBalance = instance.balanceOf(forwarderAddress); if (forwarderBalance == 0) { return; } TransferHelper.safeTransfer( tokenContractAddress, parentAddress, forwarderBalance ); } /** * Flush the entire balance of the contract to the parent address. */ function flush() public { uint256 value = address(this).balance; if (value == 0) { return; } (bool success, ) = parentAddress.call{ value: value }(''); require(success, 'Flush failed'); emit ForwarderDeposited(msg.sender, value, msg.data); } }
File 4 of 4: TransferHelper.sol
// SPDX-License-Identifier: Apache-2.0 pragma solidity >=0.7.5; // helper methods for interacting with ERC20 tokens and sending ETH that do not consistently return true/false library TransferHelper { function safeApprove( address token, address to, uint256 value ) internal { // bytes4(keccak256(bytes('approve(address,uint256)'))); (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0x095ea7b3, to, value)); require( success && (data.length == 0 || abi.decode(data, (bool))), 'TransferHelper::safeApprove: approve failed' ); } function safeTransfer( address token, address to, uint256 value ) internal { // bytes4(keccak256(bytes('transfer(address,uint256)'))); (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0xa9059cbb, to, value)); require( success && (data.length == 0 || abi.decode(data, (bool))), 'TransferHelper::safeTransfer: transfer failed' ); } function safeTransferFrom( address token, address from, address to, uint256 value ) internal { // bytes4(keccak256(bytes('transferFrom(address,address,uint256)'))); (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0x23b872dd, from, to, value)); require( success && (data.length == 0 || abi.decode(data, (bool))), 'TransferHelper::transferFrom: transferFrom failed' ); } function safeTransferETH(address to, uint256 value) internal { (bool success, ) = to.call{value: value}(new bytes(0)); require(success, 'TransferHelper::safeTransferETH: ETH transfer failed'); } }
Contract ABI
API[{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"msgSender","type":"address"},{"indexed":false,"internalType":"address","name":"otherSigner","type":"address"},{"indexed":false,"internalType":"bytes32","name":"operation","type":"bytes32"}],"name":"BatchTransacted","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"address","name":"recipient","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"BatchTransfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"},{"indexed":false,"internalType":"bytes","name":"data","type":"bytes"}],"name":"Deposited","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"msgSender","type":"address"}],"name":"SafeModeActivated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"msgSender","type":"address"},{"indexed":false,"internalType":"address","name":"otherSigner","type":"address"},{"indexed":false,"internalType":"bytes32","name":"operation","type":"bytes32"},{"indexed":false,"internalType":"address","name":"toAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"},{"indexed":false,"internalType":"bytes","name":"data","type":"bytes"}],"name":"Transacted","type":"event"},{"stateMutability":"payable","type":"fallback"},{"inputs":[],"name":"activateSafeMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"forwarderAddress","type":"address"},{"internalType":"address","name":"tokenContractAddress","type":"address"}],"name":"flushForwarderTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getNextSequenceId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"allowedSigners","type":"address[]"}],"name":"init","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"initialized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"signer","type":"address"}],"name":"isSigner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"safeMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"toAddress","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"uint256","name":"expireTime","type":"uint256"},{"internalType":"uint256","name":"sequenceId","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"sendMultiSig","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"recipients","type":"address[]"},{"internalType":"uint256[]","name":"values","type":"uint256[]"},{"internalType":"uint256","name":"expireTime","type":"uint256"},{"internalType":"uint256","name":"sequenceId","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"sendMultiSigBatch","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"toAddress","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"address","name":"tokenContractAddress","type":"address"},{"internalType":"uint256","name":"expireTime","type":"uint256"},{"internalType":"uint256","name":"sequenceId","type":"uint256"},{"internalType":"bytes","name":"signature","type":"bytes"}],"name":"sendMultiSigToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"signers","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Latest 25 blocks (From a total of 60 blocks with 2.39 Ether produced)
Block | Transaction | Difficulty | Gas Used | Reward | |
---|---|---|---|---|---|
22302917 | 8 hrs ago | 29 | 0.00 TH | 987,260 (2.75%) | 0.001934187977700483 ETH |
22265209 | 5 days ago | 35 | 0.00 TH | 1,430,007 (3.98%) | 0.002669778560776842 ETH |
22265189 | 5 days ago | 24 | 0.00 TH | 1,651,342 (4.59%) | 0.002754730279747946 ETH |
22257388 | 6 days ago | 55 | 0.00 TH | 3,725,445 (10.38%) | 0.008461474156392815 ETH |
22255107 | 7 days ago | 57 | 0.00 TH | 3,657,207 (10.17%) | 0.005239137579557427 ETH |
22249898 | 7 days ago | 54 | 0.00 TH | 2,952,816 (8.25%) | 0.0040367905113 ETH |
21817580 | 68 days ago | 46 | 0.00 TH | 3,712,167 (10.33%) | 0.007690487736536877 ETH |
21810500 | 69 days ago | 32 | 0.00 TH | 1,377,674 (3.85%) | 0.006218197770157143 ETH |
21793731 | 71 days ago | 43 | 0.00 TH | 2,412,287 (6.73%) | 0.005622225958173726 ETH |
21779378 | 73 days ago | 31 | 0.00 TH | 2,860,887 (7.99%) | 0.005731196163086937 ETH |
21725280 | 81 days ago | 52 | 0.00 TH | 4,073,088 (13.56%) | 0.008082480467217487 ETH |
21553546 | 105 days ago | 54 | 0.00 TH | 3,952,789 (13.18%) | 0.003069858254578485 ETH |
21360291 | 131 days ago | 64 | 0.00 TH | 3,625,869 (12.09%) | 0.007613410075848052 ETH |
21337267 | 135 days ago | 62 | 0.00 TH | 4,236,819 (14.12%) | 0.015455995970172407 ETH |
20986530 | 184 days ago | 54 | 0.00 TH | 2,374,828 (7.92%) | 0.016285421941999296 ETH |
20982251 | 184 days ago | 38 | 0.00 TH | 1,742,538 (5.81%) | 0.0042787405980666 ETH |
20970946 | 186 days ago | 201 | 0.00 TH | 10,194,739 (33.98%) | 0.017142775560941923 ETH |
20941803 | 190 days ago | 59 | 0.00 TH | 3,439,265 (11.46%) | 0.005102057326561341 ETH |
20935913 | 191 days ago | 118 | 0.00 TH | 5,309,500 (17.70%) | 0.011895205243577976 ETH |
20929647 | 192 days ago | 104 | 0.00 TH | 8,884,570 (29.62%) | 0.037115493811229095 ETH |
20922506 | 193 days ago | 123 | 0.00 TH | 8,152,327 (27.17%) | 0.02805416693048328 ETH |
20917888 | 193 days ago | 73 | 0.00 TH | 3,629,184 (12.10%) | 0.009085325948110828 ETH |
20900485 | 196 days ago | 41 | 0.00 TH | 2,960,166 (9.87%) | 0.004630470721762691 ETH |
20887972 | 197 days ago | 97 | 0.00 TH | 4,643,338 (15.48%) | 0.00360733050486903 ETH |
20575042 | 241 days ago | 58 | 0.00 TH | 6,193,743 (20.65%) | 0.002039084708021174 ETH |
Loading...
Loading
Loading...
Loading
Latest 25 from a total of 42333 withdrawals (15,506.274603248 ETH withdrawn)
Validator Index | Block | Amount | |
---|---|---|---|
1787231 | 22305425 | 21 mins ago | 0.019213466 ETH |
1787230 | 22305425 | 21 mins ago | 0.01925313 ETH |
1785448 | 22305327 | 40 mins ago | 0.019240815 ETH |
1785447 | 22305327 | 40 mins ago | 0.019236809 ETH |
1785445 | 22305327 | 40 mins ago | 0.019252099 ETH |
1783818 | 22305230 | 1 hr ago | 0.019223595 ETH |
1783817 | 22305229 | 1 hr ago | 0.019224904 ETH |
1783816 | 22305229 | 1 hr ago | 0.019230391 ETH |
1783815 | 22305229 | 1 hr ago | 0.019218754 ETH |
1782717 | 22305167 | 1 hr ago | 0.019211929 ETH |
1782716 | 22305166 | 1 hr ago | 0.019237201 ETH |
1782715 | 22305166 | 1 hr ago | 0.019227874 ETH |
1782714 | 22305166 | 1 hr ago | 0.019214022 ETH |
1782712 | 22305166 | 1 hr ago | 0.019202865 ETH |
1780518 | 22305072 | 1 hr ago | 0.063990393 ETH |
1780517 | 22305072 | 1 hr ago | 0.019271235 ETH |
1780516 | 22305072 | 1 hr ago | 0.019249574 ETH |
1780515 | 22305072 | 1 hr ago | 0.019264501 ETH |
1780514 | 22305071 | 1 hr ago | 0.019228714 ETH |
1780513 | 22305071 | 1 hr ago | 0.019251705 ETH |
1780512 | 22305071 | 1 hr ago | 0.019267655 ETH |
1777001 | 22304865 | 2 hrs ago | 0.019251082 ETH |
1777000 | 22304865 | 2 hrs ago | 0.019242054 ETH |
1776445 | 22304834 | 2 hrs ago | 0.01925825 ETH |
1776444 | 22304834 | 2 hrs ago | 0.019248446 ETH |
Multichain Portfolio | 34 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|---|---|---|---|---|
ETH | 100.00% | $1,615.71 | 900.9464 | $1,455,664.42 |
Loading...
Loading
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.