Source Code
Overview
S Balance
More Info
ContractCreator
Latest 1 from a total of 1 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Update | 20592921 | 8 days ago | IN | 0 S | 0.00004089 |
Loading...
Loading
Contract Source Code Verified (Exact Match)
Contract Name:
Staking
Compiler Version
v0.8.26+commit.8a97fa7a
Optimization Enabled:
Yes with 1000 runs
Other Settings:
paris EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.24; import "@openzeppelin/contracts/utils/ReentrancyGuard.sol"; import "./interfaces/IToken.sol"; import "./interfaces/IManager.sol"; contract Staking is ReentrancyGuard { IManager private Manager; IToken private Token; uint256 public totalStaked; uint256 private _initialRewardPerBlock = 2 * 1e18; // 2 tokens per block uint256 private _accumulatedRewardPerShare; uint256 private _halvingInterval = 54_000; // 54k blocks - 1 week uint256 private _startingBlock; uint256 private _lastRewardBlock; struct Stake { uint256 amount; uint256 rewardDebt; } mapping(address => Stake) public stakes; constructor(address _manager) { Manager = IManager(_manager); } /*------------------------------------* MODIFIERS *------------------------------------*/ modifier onlyOwner() { require(msg.sender == Manager.owner(), "Not authorized"); _; } /*------------------------------------* SETTERS *------------------------------------*/ function setManager(address _manager) external onlyOwner { Manager = IManager(_manager); } function update() external onlyOwner { Token = IToken(_getContract("Token")); } function start() external onlyOwner { _startingBlock = block.number; } /*------------------------------------* FUNCTIONS *------------------------------------*/ function stake(uint256 amount) external nonReentrant { require(amount > 0, "Amount must be greater than 0"); address sender = msg.sender; uint256 rewards = pendingReward(sender); if (rewards > 0) { _claim(sender, rewards); } _updatePool(); _stake(amount, sender); } function unstake(uint256 amount) external nonReentrant { address sender = msg.sender; require(amount > 0, "Amount must be greater than 0"); require(stakes[sender].amount >= amount, "Insufficient balance"); uint256 rewards = pendingReward(sender); if (rewards > 0) { _claim(sender, rewards); } _unstake(amount, sender); _updatePool(); } function claim() external nonReentrant { uint256 rewards = pendingReward(msg.sender); require(rewards > 0, "No rewards to claim"); _claim(msg.sender, rewards); _updatePool(); } /*------------------------------------* INTERNAL *------------------------------------*/ function _stake(uint256 amount, address user) private { Token.transferFrom(user, address(this), amount); totalStaked += amount; stakes[user].amount += amount; stakes[user].rewardDebt = (stakes[user].amount * _accumulatedRewardPerShare) / 1e18; } function _unstake(uint256 amount, address user) private { totalStaked -= amount; stakes[user].amount -= amount; stakes[user].rewardDebt = (stakes[user].amount * _accumulatedRewardPerShare) / 1e18; Token.transfer(user, amount); } function _claim(address user, uint256 _rewards) private { stakes[user].rewardDebt = (stakes[user].amount * _accumulatedRewardPerShare) / 1e18; Token.transfer(user, _rewards); } function _calculateReward( uint256 _from, uint256 _to ) internal view returns (uint256) { uint256 rewards; uint256 currentBlock = _from; uint256 __startingBlock = _startingBlock; uint256 __halvingInterval = _halvingInterval; uint256 __initialRewardPerBlock = _initialRewardPerBlock; for (uint256 i = 0; i < 4; i++) { uint256 nextHalvingBlock = __startingBlock + (i + 1) * __halvingInterval; if (_to <= nextHalvingBlock) { rewards += (_to - currentBlock) * (__initialRewardPerBlock >> i); break; } else if (currentBlock < nextHalvingBlock) { rewards += (nextHalvingBlock - currentBlock) * (__initialRewardPerBlock >> i); currentBlock = nextHalvingBlock; } } return rewards; } function _updatePool() internal { uint256 __lastRewardBlock = _lastRewardBlock; if (block.number <= __lastRewardBlock) { return; } uint256 reward = _calculateReward(__lastRewardBlock, block.number); if (totalStaked > 0) { _accumulatedRewardPerShare += (reward * 1e18) / totalStaked; } _lastRewardBlock = block.number; } function pendingReward(address _staker) public view returns (uint256) { uint256 accRewardPerShare = _accumulatedRewardPerShare; uint256 __lastRewardBlock = _lastRewardBlock; if (block.number > __lastRewardBlock && totalStaked > 0) { uint256 reward = _calculateReward(__lastRewardBlock, block.number); accRewardPerShare += (reward * 1e18) / totalStaked; } return (stakes[_staker].amount * accRewardPerShare) / 1e18 - stakes[_staker].rewardDebt; } /*------------------------------------* GETTERS *------------------------------------*/ /*------------------------------------* UTILS *------------------------------------*/ function _getContract( string memory contractName ) internal view returns (address) { return Manager.getContract(contractName); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v5.0.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.20; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the value of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the value of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves a `value` amount of tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 value) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets a `value` amount of tokens as the allowance of `spender` over the * caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 value) external returns (bool); /** * @dev Moves a `value` amount of tokens from `from` to `to` using the * allowance mechanism. `value` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 value) external returns (bool); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v5.0.0) (utils/ReentrancyGuard.sol) pragma solidity ^0.8.20; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant NOT_ENTERED = 1; uint256 private constant ENTERED = 2; uint256 private _status; /** * @dev Unauthorized reentrant call. */ error ReentrancyGuardReentrantCall(); constructor() { _status = NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be NOT_ENTERED if (_status == ENTERED) { revert ReentrancyGuardReentrantCall(); } // Any calls to nonReentrant after this point will fail _status = ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = NOT_ENTERED; } /** * @dev Returns true if the reentrancy guard is currently set to "entered", which indicates there is a * `nonReentrant` function in the call stack. */ function _reentrancyGuardEntered() internal view returns (bool) { return _status == ENTERED; } }
// SPDX-License-Identifier: UNLICENSED pragma solidity ^0.8.20; interface IManager { function getContract(string memory name) external view returns (address); function owner() external view returns (address); }
// SPDX-License-Identifier: MIT pragma solidity ^0.8.24; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; interface IToken is IERC20 { function mint(address to, uint256 value) external; function burnFrom(address account, uint256 value) external; }
{ "optimizer": { "enabled": true, "runs": 1000 }, "evmVersion": "paris", "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
[{"inputs":[{"internalType":"address","name":"_manager","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ReentrancyGuardReentrantCall","type":"error"},{"inputs":[],"name":"claim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_staker","type":"address"}],"name":"pendingReward","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_manager","type":"address"}],"name":"setManager","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"stake","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"stakes","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"uint256","name":"rewardDebt","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"start","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"totalStaked","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"unstake","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"update","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
6080604052671bc16d674ec8000060045561d2f0600655348015602157600080fd5b50604051610e01380380610e01833981016040819052603e916067565b6001600081905580546001600160a01b0319166001600160a01b03929092169190911790556095565b600060208284031215607857600080fd5b81516001600160a01b0381168114608e57600080fd5b9392505050565b610d5d806100a46000396000f3fe608060405234801561001057600080fd5b50600436106100a35760003560e01c8063a2e6204511610076578063be9a65551161005b578063be9a655514610138578063d0ebdbe714610140578063f40f0f521461015357600080fd5b8063a2e620451461011d578063a694fc3a1461012557600080fd5b806316934fc4146100a85780632e17de78146100e95780634e71d92d146100fe578063817b1cd214610106575b600080fd5b6100cf6100b6366004610be8565b6009602052600090815260409020805460019091015482565b604080519283526020830191909152015b60405180910390f35b6100fc6100f7366004610c0c565b610166565b005b6100fc610267565b61010f60035481565b6040519081526020016100e0565b6100fc6102eb565b6100fc610133366004610c0c565b610420565b6100fc6104a8565b6100fc61014e366004610be8565b610576565b61010f610161366004610be8565b61066d565b61016e610719565b33816101c15760405162461bcd60e51b815260206004820152601d60248201527f416d6f756e74206d7573742062652067726561746572207468616e203000000060448201526064015b60405180910390fd5b6001600160a01b0381166000908152600960205260409020548211156102295760405162461bcd60e51b815260206004820152601460248201527f496e73756666696369656e742062616c616e636500000000000000000000000060448201526064016101b8565b60006102348261066d565b9050801561024657610246828261075c565b610250838361082a565b6102586108f8565b50506102646001600055565b50565b61026f610719565b600061027a3361066d565b9050600081116102cc5760405162461bcd60e51b815260206004820152601360248201527f4e6f207265776172647320746f20636c61696d0000000000000000000000000060448201526064016101b8565b6102d6338261075c565b6102de6108f8565b506102e96001600055565b565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa15801561033e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103629190610c25565b6001600160a01b0316336001600160a01b0316146103b35760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b6103f16040518060400160405280600581526020017f546f6b656e00000000000000000000000000000000000000000000000000000081525061095a565b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b610428610719565b600081116104785760405162461bcd60e51b815260206004820152601d60248201527f416d6f756e74206d7573742062652067726561746572207468616e203000000060448201526064016101b8565b3360006104848261066d565b9050801561049657610496828261075c565b61049e6108f8565b61025883836109eb565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa1580156104fb573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061051f9190610c25565b6001600160a01b0316336001600160a01b0316146105705760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b43600755565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105c9573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105ed9190610c25565b6001600160a01b0316336001600160a01b03161461063e5760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b6001805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60055460085460009190438110801561068857506000600354115b156106c95760006106998243610b1f565b6003549091506106b182670de0b6b3a7640000610c58565b6106bb9190610c6f565b6106c59084610c91565b9250505b6001600160a01b038416600090815260096020526040902060018101549054670de0b6b3a7640000906106fd908590610c58565b6107079190610c6f565b6107119190610ca4565b949350505050565b600260005403610755576040517f3ee5aeb500000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6002600055565b6005546001600160a01b038316600090815260096020526040902054670de0b6b3a76400009161078b91610c58565b6107959190610c6f565b6001600160a01b038381166000818152600960205260409081902060010193909355600254925163a9059cbb60e01b815260048101919091526024810184905291169063a9059cbb906044015b6020604051808303816000875af1158015610801573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108259190610cb7565b505050565b816003600082825461083c9190610ca4565b90915550506001600160a01b03811660009081526009602052604081208054849290610869908490610ca4565b90915550506005546001600160a01b038216600090815260096020526040902054670de0b6b3a76400009161089d91610c58565b6108a79190610c6f565b6001600160a01b038281166000818152600960205260409081902060010193909355600254925163a9059cbb60e01b815260048101919091526024810185905291169063a9059cbb906044016107e2565b6008544381106109055750565b60006109118243610b1f565b600354909150156109525760035461093182670de0b6b3a7640000610c58565b61093b9190610c6f565b6005600082825461094c9190610c91565b90915550505b505043600855565b6001546040517f358177730000000000000000000000000000000000000000000000000000000081526000916001600160a01b0316906335817773906109a4908590600401610cd9565b602060405180830381865afa1580156109c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109e59190610c25565b92915050565b6002546040517f23b872dd0000000000000000000000000000000000000000000000000000000081526001600160a01b03838116600483015230602483015260448201859052909116906323b872dd906064016020604051808303816000875af1158015610a5d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a819190610cb7565b508160036000828254610a949190610c91565b90915550506001600160a01b03811660009081526009602052604081208054849290610ac1908490610c91565b90915550506005546001600160a01b038216600090815260096020526040902054670de0b6b3a764000091610af591610c58565b610aff9190610c6f565b6001600160a01b0390911660009081526009602052604090206001015550565b60075460065460045460009283928692845b6004811015610bc657600083610b48836001610c91565b610b529190610c58565b610b5c9086610c91565b9050808911610b8e5782821c610b72878b610ca4565b610b7c9190610c58565b610b869088610c91565b965050610bc6565b80861015610bbd5782821c610ba38783610ca4565b610bad9190610c58565b610bb79088610c91565b96508095505b50600101610b31565b5093979650505050505050565b6001600160a01b038116811461026457600080fd5b600060208284031215610bfa57600080fd5b8135610c0581610bd3565b9392505050565b600060208284031215610c1e57600080fd5b5035919050565b600060208284031215610c3757600080fd5b8151610c0581610bd3565b634e487b7160e01b600052601160045260246000fd5b80820281158282048414176109e5576109e5610c42565b600082610c8c57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156109e5576109e5610c42565b818103818111156109e5576109e5610c42565b600060208284031215610cc957600080fd5b81518015158114610c0557600080fd5b602081526000825180602084015260005b81811015610d075760208186018101516040868401015201610cea565b506000604082850101526040601f19601f8301168401019150509291505056fea264697066735822122052fc089eb144d6805c3846ffaecc3c783d86893fefcb822a4e3bc9868493da7964736f6c634300081a0033000000000000000000000000781a403332280b6e96b9968082b6c175b05d5ea1
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106100a35760003560e01c8063a2e6204511610076578063be9a65551161005b578063be9a655514610138578063d0ebdbe714610140578063f40f0f521461015357600080fd5b8063a2e620451461011d578063a694fc3a1461012557600080fd5b806316934fc4146100a85780632e17de78146100e95780634e71d92d146100fe578063817b1cd214610106575b600080fd5b6100cf6100b6366004610be8565b6009602052600090815260409020805460019091015482565b604080519283526020830191909152015b60405180910390f35b6100fc6100f7366004610c0c565b610166565b005b6100fc610267565b61010f60035481565b6040519081526020016100e0565b6100fc6102eb565b6100fc610133366004610c0c565b610420565b6100fc6104a8565b6100fc61014e366004610be8565b610576565b61010f610161366004610be8565b61066d565b61016e610719565b33816101c15760405162461bcd60e51b815260206004820152601d60248201527f416d6f756e74206d7573742062652067726561746572207468616e203000000060448201526064015b60405180910390fd5b6001600160a01b0381166000908152600960205260409020548211156102295760405162461bcd60e51b815260206004820152601460248201527f496e73756666696369656e742062616c616e636500000000000000000000000060448201526064016101b8565b60006102348261066d565b9050801561024657610246828261075c565b610250838361082a565b6102586108f8565b50506102646001600055565b50565b61026f610719565b600061027a3361066d565b9050600081116102cc5760405162461bcd60e51b815260206004820152601360248201527f4e6f207265776172647320746f20636c61696d0000000000000000000000000060448201526064016101b8565b6102d6338261075c565b6102de6108f8565b506102e96001600055565b565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa15801561033e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103629190610c25565b6001600160a01b0316336001600160a01b0316146103b35760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b6103f16040518060400160405280600581526020017f546f6b656e00000000000000000000000000000000000000000000000000000081525061095a565b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b610428610719565b600081116104785760405162461bcd60e51b815260206004820152601d60248201527f416d6f756e74206d7573742062652067726561746572207468616e203000000060448201526064016101b8565b3360006104848261066d565b9050801561049657610496828261075c565b61049e6108f8565b61025883836109eb565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa1580156104fb573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061051f9190610c25565b6001600160a01b0316336001600160a01b0316146105705760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b43600755565b600160009054906101000a90046001600160a01b03166001600160a01b0316638da5cb5b6040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105c9573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105ed9190610c25565b6001600160a01b0316336001600160a01b03161461063e5760405162461bcd60e51b815260206004820152600e60248201526d139bdd08185d5d1a1bdc9a5e995960921b60448201526064016101b8565b6001805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60055460085460009190438110801561068857506000600354115b156106c95760006106998243610b1f565b6003549091506106b182670de0b6b3a7640000610c58565b6106bb9190610c6f565b6106c59084610c91565b9250505b6001600160a01b038416600090815260096020526040902060018101549054670de0b6b3a7640000906106fd908590610c58565b6107079190610c6f565b6107119190610ca4565b949350505050565b600260005403610755576040517f3ee5aeb500000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6002600055565b6005546001600160a01b038316600090815260096020526040902054670de0b6b3a76400009161078b91610c58565b6107959190610c6f565b6001600160a01b038381166000818152600960205260409081902060010193909355600254925163a9059cbb60e01b815260048101919091526024810184905291169063a9059cbb906044015b6020604051808303816000875af1158015610801573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108259190610cb7565b505050565b816003600082825461083c9190610ca4565b90915550506001600160a01b03811660009081526009602052604081208054849290610869908490610ca4565b90915550506005546001600160a01b038216600090815260096020526040902054670de0b6b3a76400009161089d91610c58565b6108a79190610c6f565b6001600160a01b038281166000818152600960205260409081902060010193909355600254925163a9059cbb60e01b815260048101919091526024810185905291169063a9059cbb906044016107e2565b6008544381106109055750565b60006109118243610b1f565b600354909150156109525760035461093182670de0b6b3a7640000610c58565b61093b9190610c6f565b6005600082825461094c9190610c91565b90915550505b505043600855565b6001546040517f358177730000000000000000000000000000000000000000000000000000000081526000916001600160a01b0316906335817773906109a4908590600401610cd9565b602060405180830381865afa1580156109c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109e59190610c25565b92915050565b6002546040517f23b872dd0000000000000000000000000000000000000000000000000000000081526001600160a01b03838116600483015230602483015260448201859052909116906323b872dd906064016020604051808303816000875af1158015610a5d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a819190610cb7565b508160036000828254610a949190610c91565b90915550506001600160a01b03811660009081526009602052604081208054849290610ac1908490610c91565b90915550506005546001600160a01b038216600090815260096020526040902054670de0b6b3a764000091610af591610c58565b610aff9190610c6f565b6001600160a01b0390911660009081526009602052604090206001015550565b60075460065460045460009283928692845b6004811015610bc657600083610b48836001610c91565b610b529190610c58565b610b5c9086610c91565b9050808911610b8e5782821c610b72878b610ca4565b610b7c9190610c58565b610b869088610c91565b965050610bc6565b80861015610bbd5782821c610ba38783610ca4565b610bad9190610c58565b610bb79088610c91565b96508095505b50600101610b31565b5093979650505050505050565b6001600160a01b038116811461026457600080fd5b600060208284031215610bfa57600080fd5b8135610c0581610bd3565b9392505050565b600060208284031215610c1e57600080fd5b5035919050565b600060208284031215610c3757600080fd5b8151610c0581610bd3565b634e487b7160e01b600052601160045260246000fd5b80820281158282048414176109e5576109e5610c42565b600082610c8c57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156109e5576109e5610c42565b818103818111156109e5576109e5610c42565b600060208284031215610cc957600080fd5b81518015158114610c0557600080fd5b602081526000825180602084015260005b81811015610d075760208186018101516040868401015201610cea565b506000604082850101526040601f19601f8301168401019150509291505056fea264697066735822122052fc089eb144d6805c3846ffaecc3c783d86893fefcb822a4e3bc9868493da7964736f6c634300081a0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000781a403332280b6e96b9968082b6c175b05d5ea1
-----Decoded View---------------
Arg [0] : _manager (address): 0x781a403332280b6E96b9968082B6c175b05d5Ea1
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000781a403332280b6e96b9968082b6c175b05d5ea1
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 31 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
[ 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.