Overview
ETH Balance
0 ETH
ETH Value
$0.00More Info
Private Name Tags
ContractCreator
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
107558344 | 536 days ago | 0 ETH | ||||
107556916 | 536 days ago | 0 ETH | ||||
107556597 | 536 days ago | 0 ETH | ||||
107555489 | 536 days ago | 0 ETH | ||||
107554857 | 536 days ago | 0 ETH | ||||
107554198 | 536 days ago | 0 ETH | ||||
107553662 | 536 days ago | 0 ETH | ||||
107552809 | 536 days ago | 0 ETH | ||||
107549661 | 536 days ago | 0 ETH | ||||
107541388 | 536 days ago | 0 ETH | ||||
107541211 | 536 days ago | 0 ETH | ||||
107540411 | 536 days ago | 0 ETH | ||||
107540043 | 536 days ago | 0 ETH | ||||
107540018 | 536 days ago | 0 ETH | ||||
107539797 | 536 days ago | 0 ETH | ||||
107539619 | 536 days ago | 0 ETH | ||||
107539582 | 536 days ago | 0 ETH | ||||
107539287 | 536 days ago | 0 ETH | ||||
107539186 | 536 days ago | 0 ETH | ||||
107539097 | 536 days ago | 0 ETH | ||||
107538217 | 536 days ago | 0 ETH | ||||
107537602 | 536 days ago | 0 ETH | ||||
107536060 | 536 days ago | 0 ETH | ||||
107532292 | 536 days ago | 0 ETH | ||||
107531425 | 536 days ago | 0 ETH |
Loading...
Loading
Contract Name:
ThalesStakingRewardsPool
Compiler Version
v0.5.16+commit.9c3226ce
Optimization Enabled:
Yes with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
pragma solidity ^0.5.16; import "openzeppelin-solidity-2.3.0/contracts/token/ERC20/SafeERC20.sol"; import "openzeppelin-solidity-2.3.0/contracts/math/SafeMath.sol"; import "../utils/proxy/ProxyReentrancyGuard.sol"; import "../utils/proxy/ProxyOwned.sol"; import "../utils/proxy/ProxyPausable.sol"; import "@openzeppelin/upgrades-core/contracts/Initializable.sol"; import "../interfaces/IEscrowThales.sol"; import "../interfaces/IStakingThales.sol"; import "../interfaces/IThalesStakingRewardsPool.sol"; contract ThalesStakingRewardsPool is IThalesStakingRewardsPool, Initializable, ProxyOwned, ProxyReentrancyGuard, ProxyPausable { /* ========== LIBRARIES ========== */ using SafeMath for uint; using SafeERC20 for IERC20; IStakingThales public iStakingThales; IEscrowThales public iEscrowThales; IERC20 public rewardToken; uint public lifetimeClaimedRewards; function initialize( address _owner, address _stakingToken, address _rewardToken, address _escrowToken //THALES ) public initializer { setOwner(_owner); initNonReentrant(); iStakingThales = IStakingThales(_stakingToken); rewardToken = IERC20(_rewardToken); iEscrowThales = IEscrowThales(_escrowToken); rewardToken.approve(_escrowToken, 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff); } function setStakingThalesContract(address _stakingThalesContract) external onlyOwner { require(_stakingThalesContract != address(0), "Invalid address set"); iStakingThales = IStakingThales(_stakingThalesContract); emit StakingThalesChanged(_stakingThalesContract); } function setEscrow(address _escrowThalesContract) public onlyOwner { if (address(iEscrowThales) != address(0)) { rewardToken.approve(address(iEscrowThales), 0); } iEscrowThales = IEscrowThales(_escrowThalesContract); rewardToken.approve(_escrowThalesContract, 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff); emit EscrowThalesChanged(_escrowThalesContract); } function setRewardToken(address _rewardToken) external onlyOwner { require(_rewardToken != address(0), "Invalid address set"); if (address(iEscrowThales) != address(0)) { rewardToken.approve(address(iEscrowThales), 0); } rewardToken = IERC20(_rewardToken); rewardToken.approve(address(iEscrowThales), 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff); emit RewardTokenChanged(_rewardToken); } function addToEscrow(address account, uint amount) external { require(account != address(0), "Invalid address"); require(amount > 0, "Amount is 0"); require( msg.sender == address(iStakingThales), "Add to escrow can only be called from staking or ongoing airdrop contracts" ); iEscrowThales.addToEscrow(account, amount); lifetimeClaimedRewards = lifetimeClaimedRewards.add(amount); } event StakingThalesChanged(address stakingThales); event EscrowThalesChanged(address escrowThalesContract); event RewardTokenChanged(address rewardToken); }
pragma solidity ^0.5.0; import "./IERC20.sol"; import "../../math/SafeMath.sol"; import "../../utils/Address.sol"; /** * @title SafeERC20 * @dev Wrappers around ERC20 operations that throw on failure (when the token * contract returns false). Tokens that return no value (and instead revert or * throw on failure) are also supported, non-reverting calls are assumed to be * successful. * To use this library you can add a `using SafeERC20 for ERC20;` statement to your contract, * which allows you to call the safe operations as `token.safeTransfer(...)`, etc. */ library SafeERC20 { using SafeMath for uint256; using Address for address; function safeTransfer(IERC20 token, address to, uint256 value) internal { callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value)); } function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal { callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value)); } function safeApprove(IERC20 token, address spender, uint256 value) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' // solhint-disable-next-line max-line-length require((value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value)); } function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).add(value); callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal { uint256 newAllowance = token.allowance(address(this), spender).sub(value); callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance)); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. // A Solidity high level call has three parts: // 1. The target address is checked to verify it contains contract code // 2. The call itself is made, and success asserted // 3. The return value is decoded, which in turn checks the size of the returned data. // solhint-disable-next-line max-line-length require(address(token).isContract(), "SafeERC20: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = address(token).call(data); require(success, "SafeERC20: low-level call failed"); if (returndata.length > 0) { // Return data is optional // solhint-disable-next-line max-line-length require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed"); } } }
pragma solidity ^0.5.0; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { require(b <= a, "SafeMath: subtraction overflow"); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { // Solidity only automatically asserts when dividing by 0 require(b > 0, "SafeMath: division by zero"); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { require(b != 0, "SafeMath: modulo by zero"); return a % b; } }
pragma solidity ^0.5.0; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the `nonReentrant` modifier * available, which can be aplied 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. */ contract ProxyReentrancyGuard { /// @dev counter to allow mutex lock with only one SSTORE operation uint256 private _guardCounter; bool private _initialized; function initNonReentrant() public { require(!_initialized, "Already initialized"); _initialized = true; _guardCounter = 1; } /** * @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 make it call a * `private` function that does the actual work. */ modifier nonReentrant() { _guardCounter += 1; uint256 localCounter = _guardCounter; _; require(localCounter == _guardCounter, "ReentrancyGuard: reentrant call"); } }
// SPDX-License-Identifier: MIT pragma solidity >=0.5.0 <=0.7.6; // Clone of syntetix contract without constructor contract ProxyOwned { address public owner; address public nominatedOwner; bool private _initialized; bool private _transferredAtInit; function setOwner(address _owner) public { require(_owner != address(0), "Owner address cannot be 0"); require(!_initialized, "Already initialized, use nominateNewOwner"); _initialized = true; owner = _owner; emit OwnerChanged(address(0), _owner); } function nominateNewOwner(address _owner) external onlyOwner { nominatedOwner = _owner; emit OwnerNominated(_owner); } function acceptOwnership() external { require(msg.sender == nominatedOwner, "You must be nominated before you can accept ownership"); emit OwnerChanged(owner, nominatedOwner); owner = nominatedOwner; nominatedOwner = address(0); } function transferOwnershipAtInit(address proxyAddress) external onlyOwner { require(proxyAddress != address(0), "Invalid address"); require(!_transferredAtInit, "Already transferred"); owner = proxyAddress; _transferredAtInit = true; emit OwnerChanged(owner, proxyAddress); } modifier onlyOwner { _onlyOwner(); _; } function _onlyOwner() private view { require(msg.sender == owner, "Only the contract owner may perform this action"); } event OwnerNominated(address newOwner); event OwnerChanged(address oldOwner, address newOwner); }
pragma solidity ^0.5.16; // Inheritance import "./ProxyOwned.sol"; // Clone of syntetix contract without constructor contract ProxyPausable is ProxyOwned { uint public lastPauseTime; bool public paused; /** * @notice Change the paused state of the contract * @dev Only the contract owner may call this. */ function setPaused(bool _paused) external onlyOwner { // Ensure we're actually changing the state before we do anything if (_paused == paused) { return; } // Set our paused state. paused = _paused; // If applicable, set the last pause time. if (paused) { lastPauseTime = now; } // Let everyone know that our pause state has changed. emit PauseChanged(paused); } event PauseChanged(bool isPaused); modifier notPaused { require(!paused, "This action cannot be performed while the contract is paused"); _; } }
// SPDX-License-Identifier: MIT pragma solidity >=0.4.24 <0.7.0; /** * @title Initializable * * @dev Helper contract to support initializer functions. To use it, replace * the constructor with a function that has the `initializer` modifier. * WARNING: Unlike constructors, initializer functions must be manually * invoked. This applies both to deploying an Initializable contract, as well * as extending an Initializable contract via inheritance. * WARNING: When used with inheritance, manual care must be taken to not invoke * a parent initializer twice, or ensure that all initializers are idempotent, * because this is not dealt with automatically as with constructors. */ contract Initializable { /** * @dev Indicates that the contract has been initialized. */ bool private initialized; /** * @dev Indicates that the contract is in the process of being initialized. */ bool private initializing; /** * @dev Modifier to use in the initializer function of a contract. */ modifier initializer() { require(initializing || isConstructor() || !initialized, "Contract instance has already been initialized"); bool isTopLevelCall = !initializing; if (isTopLevelCall) { initializing = true; initialized = true; } _; if (isTopLevelCall) { initializing = false; } } /// @dev Returns true if and only if the function is running in the constructor function isConstructor() private view returns (bool) { // extcodesize checks the size of the code stored in an address, and // address returns the current address. Since the code is still not // deployed when running a constructor, any checks on its code size will // yield zero, making it an effective way to detect if a contract is // under construction or not. address self = address(this); uint256 cs; assembly { cs := extcodesize(self) } return cs == 0; } // Reserved storage space to allow for layout changes in the future. uint256[50] private ______gap; }
pragma solidity ^0.5.16; interface IEscrowThales { /* ========== VIEWS / VARIABLES ========== */ function getStakerPeriod(address account, uint index) external view returns (uint); function getStakerAmounts(address account, uint index) external view returns (uint); function totalAccountEscrowedAmount(address account) external view returns (uint); function getStakedEscrowedBalanceForRewards(address account) external view returns (uint); function totalEscrowedRewards() external view returns (uint); function totalEscrowBalanceNotIncludedInStaking() external view returns (uint); function currentVestingPeriod() external view returns (uint); function updateCurrentPeriod() external returns (bool); function claimable(address account) external view returns (uint); function addToEscrow(address account, uint amount) external; function vest(uint amount) external returns (bool); function addTotalEscrowBalanceNotIncludedInStaking(uint amount) external; function subtractTotalEscrowBalanceNotIncludedInStaking(uint amount) external; }
pragma solidity ^0.5.16; interface IStakingThales { function updateVolume(address account, uint amount) external; /* ========== VIEWS / VARIABLES ========== */ function totalStakedAmount() external view returns (uint); function stakedBalanceOf(address account) external view returns (uint); function currentPeriodRewards() external view returns (uint); function currentPeriodFees() external view returns (uint); function getLastPeriodOfClaimedRewards(address account) external view returns (uint); function getRewardsAvailable(address account) external view returns (uint); function getRewardFeesAvailable(address account) external view returns (uint); function getAlreadyClaimedRewards(address account) external view returns (uint); function getAlreadyClaimedFees(address account) external view returns (uint); function getContractRewardFunds() external view returns (uint); function getContractFeeFunds() external view returns (uint); }
pragma solidity ^0.5.16; interface IThalesStakingRewardsPool { function addToEscrow(address account, uint amount) external; }
pragma solidity ^0.5.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. Does not include * the optional functions; to access them see `ERC20Detailed`. */ interface IERC20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `recipient`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a `Transfer` event. */ function transfer(address recipient, uint256 amount) 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 `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * > 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 amount) external returns (bool); /** * @dev Moves `amount` tokens from `sender` to `recipient` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a `Transfer` event. */ function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); /** * @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); }
pragma solidity ^0.5.0; /** * @dev Collection of functions related to the address type, */ library Address { /** * @dev Returns true if `account` is a contract. * * This test is non-exhaustive, and there may be false-negatives: during the * execution of a contract's constructor, its address will be reported as * not containing a contract. * * > It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. */ function isContract(address account) internal view returns (bool) { // This method relies in extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; // solhint-disable-next-line no-inline-assembly assembly { size := extcodesize(account) } return size > 0; } }
{ "optimizer": { "enabled": true, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"escrowThalesContract","type":"address"}],"name":"EscrowThalesChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"oldOwner","type":"address"},{"indexed":false,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnerChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnerNominated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"isPaused","type":"bool"}],"name":"PauseChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"rewardToken","type":"address"}],"name":"RewardTokenChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"stakingThales","type":"address"}],"name":"StakingThalesChanged","type":"event"},{"constant":false,"inputs":[],"name":"acceptOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"addToEscrow","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"iEscrowThales","outputs":[{"internalType":"contract IEscrowThales","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"iStakingThales","outputs":[{"internalType":"contract IStakingThales","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"initNonReentrant","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address","name":"_stakingToken","type":"address"},{"internalType":"address","name":"_rewardToken","type":"address"},{"internalType":"address","name":"_escrowToken","type":"address"}],"name":"initialize","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"lastPauseTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"lifetimeClaimedRewards","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"nominateNewOwner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"nominatedOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"rewardToken","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_escrowThalesContract","type":"address"}],"name":"setEscrow","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"setOwner","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bool","name":"_paused","type":"bool"}],"name":"setPaused","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_rewardToken","type":"address"}],"name":"setRewardToken","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_stakingThalesContract","type":"address"}],"name":"setStakingThalesContract","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"proxyAddress","type":"address"}],"name":"transferOwnershipAtInit","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b5061107b806100206000396000f3fe608060405234801561001057600080fd5b50600436106101215760003560e01c80638da5cb5b116100ad578063c3b83f5f11610071578063c3b83f5f146102ab578063ced53133146102d1578063ebc79772146102d9578063f7c618c1146102e1578063f8c8765e146102e957610121565b80638da5cb5b1461022f57806391b4ded914610237578063a5d7cb6c14610251578063b01ca88f14610259578063c10c35461461028557610121565b806353a47bb7116100f457806353a47bb7146101b75780635c975abb146101bf57806379ba5097146101db578063857afabd146101e35780638aee81271461020957610121565b806313af4035146101265780631627540c1461014e57806316c38b3c146101745780632f32415814610193575b600080fd5b61014c6004803603602081101561013c57600080fd5b50356001600160a01b0316610327565b005b61014c6004803603602081101561016457600080fd5b50356001600160a01b031661043c565b61014c6004803603602081101561018a57600080fd5b50351515610498565b61019b610512565b604080516001600160a01b039092168252519081900360200190f35b61019b610521565b6101c7610530565b604080519115158252519081900360200190f35b61014c610539565b61014c600480360360208110156101f957600080fd5b50356001600160a01b03166105f5565b61014c6004803603602081101561021f57600080fd5b50356001600160a01b03166106aa565b61019b610877565b61023f610886565b60408051918252519081900360200190f35b61019b61088c565b61014c6004803603604081101561026f57600080fd5b506001600160a01b0381351690602001356108a0565b61014c6004803603602081101561029b57600080fd5b50356001600160a01b0316610a06565b61014c600480360360208110156102c157600080fd5b50356001600160a01b0316610b7e565b61023f610c9d565b61014c610ca3565b61019b610d06565b61014c600480360360808110156102ff57600080fd5b506001600160a01b038135811691602081013582169160408201358116916060013516610d15565b6001600160a01b038116610382576040805162461bcd60e51b815260206004820152601960248201527f4f776e657220616464726573732063616e6e6f74206265203000000000000000604482015290519081900360640190fd5b603454600160a01b900460ff16156103cb5760405162461bcd60e51b8152600401808060200182810382526029815260200180610f776029913960400191505060405180910390fd5b6034805460ff60a01b1916600160a01b179055603380546001600160a01b0383166001600160a01b031990911681179091556040805160008152602081019290925280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a150565b610444610e8f565b603480546001600160a01b0383166001600160a01b0319909116811790915560408051918252517f906a1c6bd7e3091ea86693dd029a831c19049ce77f1dce2ce0bab1cacbabce229181900360200190a150565b6104a0610e8f565b60385460ff16151581151514156104b65761050f565b6038805460ff1916821515179081905560ff16156104d357426037555b6038546040805160ff90921615158252517f8fb6c181ee25a520cf3dd6565006ef91229fcfe5a989566c2a3b8c115570cec59181900360200190a15b50565b6039546001600160a01b031681565b6034546001600160a01b031681565b60385460ff1681565b6034546001600160a01b031633146105825760405162461bcd60e51b8152600401808060200182810382526035815260200180610f426035913960400191505060405180910390fd5b603354603454604080516001600160a01b03938416815292909116602083015280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a160348054603380546001600160a01b03199081166001600160a01b03841617909155169055565b6105fd610e8f565b6001600160a01b03811661064e576040805162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081859191c995cdcc81cd95d606a1b604482015290519081900360640190fd5b603880546001600160a01b0383166101008102610100600160a81b03199092169190911790915560408051918252517f3c7faa500efbd341aedbf1ee7ebd52ea36d226dda76bc01dd39b43d46f55b8d39181900360200190a150565b6106b2610e8f565b6001600160a01b038116610703576040805162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081859191c995cdcc81cd95d606a1b604482015290519081900360640190fd5b6039546001600160a01b03161561079c57603a546039546040805163095ea7b360e01b81526001600160a01b0392831660048201526000602482018190529151929093169263095ea7b39260448083019360209383900390910190829087803b15801561076f57600080fd5b505af1158015610783573d6000803e3d6000fd5b505050506040513d602081101561079957600080fd5b50505b603a80546001600160a01b0319166001600160a01b0383811691909117918290556039546040805163095ea7b360e01b81529183166004830152600019602483015251929091169163095ea7b3916044808201926020929091908290030181600087803b15801561080c57600080fd5b505af1158015610820573d6000803e3d6000fd5b505050506040513d602081101561083657600080fd5b5050604080516001600160a01b038316815290517fb74d956cf6ec7842d08ebf0ab19ec03a88c1efd4a50ea4349d30f9c4ce512e989181900360200190a150565b6033546001600160a01b031681565b60375481565b60385461010090046001600160a01b031681565b6001600160a01b0382166108ed576040805162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b604482015290519081900360640190fd5b60008111610930576040805162461bcd60e51b815260206004820152600b60248201526a0416d6f756e7420697320360ac1b604482015290519081900360640190fd5b60385461010090046001600160a01b0316331461097e5760405162461bcd60e51b815260040180806020018281038252604a815260200180610ffd604a913960600191505060405180910390fd5b6039546040805163b01ca88f60e01b81526001600160a01b038581166004830152602482018590529151919092169163b01ca88f91604480830192600092919082900301818387803b1580156109d357600080fd5b505af11580156109e7573d6000803e3d6000fd5b5050603b546109ff925090508263ffffffff610eda16565b603b555050565b610a0e610e8f565b6039546001600160a01b031615610aa757603a546039546040805163095ea7b360e01b81526001600160a01b0392831660048201526000602482018190529151929093169263095ea7b39260448083019360209383900390910190829087803b158015610a7a57600080fd5b505af1158015610a8e573d6000803e3d6000fd5b505050506040513d6020811015610aa457600080fd5b50505b603980546001600160a01b0319166001600160a01b03838116918217909255603a546040805163095ea7b360e01b8152600481019390935260001960248401525192169163095ea7b3916044808201926020929091908290030181600087803b158015610b1357600080fd5b505af1158015610b27573d6000803e3d6000fd5b505050506040513d6020811015610b3d57600080fd5b5050604080516001600160a01b038316815290517f582deb3bb18ff8ac459709ec81c864e76811e572410ccbbd535447c02aa812eb9181900360200190a150565b610b86610e8f565b6001600160a01b038116610bd3576040805162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b604482015290519081900360640190fd5b603454600160a81b900460ff1615610c28576040805162461bcd60e51b8152602060048201526013602482015272105b1c9958591e481d1c985b9cd9995c9c9959606a1b604482015290519081900360640190fd5b603380546001600160a01b038084166001600160a01b03199092168217928390556034805460ff60a81b1916600160a81b17905560408051939091168352602083019190915280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a150565b603b5481565b60365460ff1615610cf1576040805162461bcd60e51b8152602060048201526013602482015272105b1c9958591e481a5b9a5d1a585b1a5e9959606a1b604482015290519081900360640190fd5b6036805460ff19166001908117909155603555565b603a546001600160a01b031681565b600054610100900460ff1680610d2e5750610d2e610f3b565b80610d3c575060005460ff16155b610d775760405162461bcd60e51b815260040180806020018281038252602e815260200180610fcf602e913960400191505060405180910390fd5b600054610100900460ff16158015610da2576000805460ff1961ff0019909116610100171660011790555b610dab85610327565b610db3610ca3565b603880546001600160a01b0380871661010002610100600160a81b031990921691909117909155603a80548583166001600160a01b03199182161791829055603980548685169216821790556040805163095ea7b360e01b81526004810192909252600019602483015251919092169163095ea7b39160448083019260209291908290030181600087803b158015610e4a57600080fd5b505af1158015610e5e573d6000803e3d6000fd5b505050506040513d6020811015610e7457600080fd5b50508015610e88576000805461ff00191690555b5050505050565b6033546001600160a01b03163314610ed85760405162461bcd60e51b815260040180806020018281038252602f815260200180610fa0602f913960400191505060405180910390fd5b565b600082820183811015610f34576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b303b159056fe596f75206d757374206265206e6f6d696e61746564206265666f726520796f752063616e20616363657074206f776e657273686970416c726561647920696e697469616c697a65642c20757365206e6f6d696e6174654e65774f776e65724f6e6c792074686520636f6e7472616374206f776e6572206d617920706572666f726d207468697320616374696f6e436f6e747261637420696e7374616e63652068617320616c7265616479206265656e20696e697469616c697a656441646420746f20657363726f772063616e206f6e6c792062652063616c6c65642066726f6d207374616b696e67206f72206f6e676f696e672061697264726f7020636f6e747261637473a265627a7a72315820d57c0a100d823b5ac5b133295fa4d3fc19420b7a43d0a666c6aab3b9c42ca1b064736f6c63430005100032
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106101215760003560e01c80638da5cb5b116100ad578063c3b83f5f11610071578063c3b83f5f146102ab578063ced53133146102d1578063ebc79772146102d9578063f7c618c1146102e1578063f8c8765e146102e957610121565b80638da5cb5b1461022f57806391b4ded914610237578063a5d7cb6c14610251578063b01ca88f14610259578063c10c35461461028557610121565b806353a47bb7116100f457806353a47bb7146101b75780635c975abb146101bf57806379ba5097146101db578063857afabd146101e35780638aee81271461020957610121565b806313af4035146101265780631627540c1461014e57806316c38b3c146101745780632f32415814610193575b600080fd5b61014c6004803603602081101561013c57600080fd5b50356001600160a01b0316610327565b005b61014c6004803603602081101561016457600080fd5b50356001600160a01b031661043c565b61014c6004803603602081101561018a57600080fd5b50351515610498565b61019b610512565b604080516001600160a01b039092168252519081900360200190f35b61019b610521565b6101c7610530565b604080519115158252519081900360200190f35b61014c610539565b61014c600480360360208110156101f957600080fd5b50356001600160a01b03166105f5565b61014c6004803603602081101561021f57600080fd5b50356001600160a01b03166106aa565b61019b610877565b61023f610886565b60408051918252519081900360200190f35b61019b61088c565b61014c6004803603604081101561026f57600080fd5b506001600160a01b0381351690602001356108a0565b61014c6004803603602081101561029b57600080fd5b50356001600160a01b0316610a06565b61014c600480360360208110156102c157600080fd5b50356001600160a01b0316610b7e565b61023f610c9d565b61014c610ca3565b61019b610d06565b61014c600480360360808110156102ff57600080fd5b506001600160a01b038135811691602081013582169160408201358116916060013516610d15565b6001600160a01b038116610382576040805162461bcd60e51b815260206004820152601960248201527f4f776e657220616464726573732063616e6e6f74206265203000000000000000604482015290519081900360640190fd5b603454600160a01b900460ff16156103cb5760405162461bcd60e51b8152600401808060200182810382526029815260200180610f776029913960400191505060405180910390fd5b6034805460ff60a01b1916600160a01b179055603380546001600160a01b0383166001600160a01b031990911681179091556040805160008152602081019290925280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a150565b610444610e8f565b603480546001600160a01b0383166001600160a01b0319909116811790915560408051918252517f906a1c6bd7e3091ea86693dd029a831c19049ce77f1dce2ce0bab1cacbabce229181900360200190a150565b6104a0610e8f565b60385460ff16151581151514156104b65761050f565b6038805460ff1916821515179081905560ff16156104d357426037555b6038546040805160ff90921615158252517f8fb6c181ee25a520cf3dd6565006ef91229fcfe5a989566c2a3b8c115570cec59181900360200190a15b50565b6039546001600160a01b031681565b6034546001600160a01b031681565b60385460ff1681565b6034546001600160a01b031633146105825760405162461bcd60e51b8152600401808060200182810382526035815260200180610f426035913960400191505060405180910390fd5b603354603454604080516001600160a01b03938416815292909116602083015280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a160348054603380546001600160a01b03199081166001600160a01b03841617909155169055565b6105fd610e8f565b6001600160a01b03811661064e576040805162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081859191c995cdcc81cd95d606a1b604482015290519081900360640190fd5b603880546001600160a01b0383166101008102610100600160a81b03199092169190911790915560408051918252517f3c7faa500efbd341aedbf1ee7ebd52ea36d226dda76bc01dd39b43d46f55b8d39181900360200190a150565b6106b2610e8f565b6001600160a01b038116610703576040805162461bcd60e51b8152602060048201526013602482015272125b9d985b1a59081859191c995cdcc81cd95d606a1b604482015290519081900360640190fd5b6039546001600160a01b03161561079c57603a546039546040805163095ea7b360e01b81526001600160a01b0392831660048201526000602482018190529151929093169263095ea7b39260448083019360209383900390910190829087803b15801561076f57600080fd5b505af1158015610783573d6000803e3d6000fd5b505050506040513d602081101561079957600080fd5b50505b603a80546001600160a01b0319166001600160a01b0383811691909117918290556039546040805163095ea7b360e01b81529183166004830152600019602483015251929091169163095ea7b3916044808201926020929091908290030181600087803b15801561080c57600080fd5b505af1158015610820573d6000803e3d6000fd5b505050506040513d602081101561083657600080fd5b5050604080516001600160a01b038316815290517fb74d956cf6ec7842d08ebf0ab19ec03a88c1efd4a50ea4349d30f9c4ce512e989181900360200190a150565b6033546001600160a01b031681565b60375481565b60385461010090046001600160a01b031681565b6001600160a01b0382166108ed576040805162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b604482015290519081900360640190fd5b60008111610930576040805162461bcd60e51b815260206004820152600b60248201526a0416d6f756e7420697320360ac1b604482015290519081900360640190fd5b60385461010090046001600160a01b0316331461097e5760405162461bcd60e51b815260040180806020018281038252604a815260200180610ffd604a913960600191505060405180910390fd5b6039546040805163b01ca88f60e01b81526001600160a01b038581166004830152602482018590529151919092169163b01ca88f91604480830192600092919082900301818387803b1580156109d357600080fd5b505af11580156109e7573d6000803e3d6000fd5b5050603b546109ff925090508263ffffffff610eda16565b603b555050565b610a0e610e8f565b6039546001600160a01b031615610aa757603a546039546040805163095ea7b360e01b81526001600160a01b0392831660048201526000602482018190529151929093169263095ea7b39260448083019360209383900390910190829087803b158015610a7a57600080fd5b505af1158015610a8e573d6000803e3d6000fd5b505050506040513d6020811015610aa457600080fd5b50505b603980546001600160a01b0319166001600160a01b03838116918217909255603a546040805163095ea7b360e01b8152600481019390935260001960248401525192169163095ea7b3916044808201926020929091908290030181600087803b158015610b1357600080fd5b505af1158015610b27573d6000803e3d6000fd5b505050506040513d6020811015610b3d57600080fd5b5050604080516001600160a01b038316815290517f582deb3bb18ff8ac459709ec81c864e76811e572410ccbbd535447c02aa812eb9181900360200190a150565b610b86610e8f565b6001600160a01b038116610bd3576040805162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b604482015290519081900360640190fd5b603454600160a81b900460ff1615610c28576040805162461bcd60e51b8152602060048201526013602482015272105b1c9958591e481d1c985b9cd9995c9c9959606a1b604482015290519081900360640190fd5b603380546001600160a01b038084166001600160a01b03199092168217928390556034805460ff60a81b1916600160a81b17905560408051939091168352602083019190915280517fb532073b38c83145e3e5135377a08bf9aab55bc0fd7c1179cd4fb995d2a5159c9281900390910190a150565b603b5481565b60365460ff1615610cf1576040805162461bcd60e51b8152602060048201526013602482015272105b1c9958591e481a5b9a5d1a585b1a5e9959606a1b604482015290519081900360640190fd5b6036805460ff19166001908117909155603555565b603a546001600160a01b031681565b600054610100900460ff1680610d2e5750610d2e610f3b565b80610d3c575060005460ff16155b610d775760405162461bcd60e51b815260040180806020018281038252602e815260200180610fcf602e913960400191505060405180910390fd5b600054610100900460ff16158015610da2576000805460ff1961ff0019909116610100171660011790555b610dab85610327565b610db3610ca3565b603880546001600160a01b0380871661010002610100600160a81b031990921691909117909155603a80548583166001600160a01b03199182161791829055603980548685169216821790556040805163095ea7b360e01b81526004810192909252600019602483015251919092169163095ea7b39160448083019260209291908290030181600087803b158015610e4a57600080fd5b505af1158015610e5e573d6000803e3d6000fd5b505050506040513d6020811015610e7457600080fd5b50508015610e88576000805461ff00191690555b5050505050565b6033546001600160a01b03163314610ed85760405162461bcd60e51b815260040180806020018281038252602f815260200180610fa0602f913960400191505060405180910390fd5b565b600082820183811015610f34576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b303b159056fe596f75206d757374206265206e6f6d696e61746564206265666f726520796f752063616e20616363657074206f776e657273686970416c726561647920696e697469616c697a65642c20757365206e6f6d696e6174654e65774f776e65724f6e6c792074686520636f6e7472616374206f776e6572206d617920706572666f726d207468697320616374696f6e436f6e747261637420696e7374616e63652068617320616c7265616479206265656e20696e697469616c697a656441646420746f20657363726f772063616e206f6e6c792062652063616c6c65642066726f6d207374616b696e67206f72206f6e676f696e672061697264726f7020636f6e747261637473a265627a7a72315820d57c0a100d823b5ac5b133295fa4d3fc19420b7a43d0a666c6aab3b9c42ca1b064736f6c63430005100032
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 30 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
[ 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.