This nametag was submitted by Kleros Curate.
More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 8,428 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Renounce Ownersh... | 12650903 | 1122 days ago | IN | 0 ETH | 0.00039503 | ||||
Zap In | 12579277 | 1133 days ago | IN | 0.001 ETH | 0.00031255 | ||||
Zap In | 12578868 | 1133 days ago | IN | 0.0001 ETH | 0.00029615 | ||||
Toggle Contract ... | 12493545 | 1146 days ago | IN | 0 ETH | 0.00180288 | ||||
Zap In | 12382368 | 1163 days ago | IN | 0.00282989 ETH | 0.00428164 | ||||
Zap In | 12382350 | 1163 days ago | IN | 0.002829 ETH | 0.01588524 | ||||
Zap In | 12382313 | 1163 days ago | IN | 0 ETH | 0.0084531 | ||||
Zap In | 12381994 | 1163 days ago | IN | 0 ETH | 0.01820568 | ||||
Zap In | 12183133 | 1194 days ago | IN | 0 ETH | 0.01015805 | ||||
Zap In | 12174761 | 1195 days ago | IN | 2.8 ETH | 0.0360608 | ||||
Zap In | 11890337 | 1239 days ago | IN | 0 ETH | 0.004375 | ||||
Zap In | 11878839 | 1241 days ago | IN | 0.08 ETH | 0.02919536 | ||||
Zap In | 11878839 | 1241 days ago | IN | 0.1 ETH | 0.03183926 | ||||
Zap In | 11874787 | 1242 days ago | IN | 0.8 ETH | 0.05059165 | ||||
Zap In | 11871477 | 1242 days ago | IN | 6 ETH | 0.12530403 | ||||
Zap In | 11871423 | 1242 days ago | IN | 0.21 ETH | 0.06385975 | ||||
Zap In | 11871182 | 1242 days ago | IN | 0 ETH | 0.02906695 | ||||
Zap In | 11871111 | 1242 days ago | IN | 8 ETH | 0.07354375 | ||||
Zap In | 11870891 | 1242 days ago | IN | 0.1 ETH | 0.05853118 | ||||
Zap In | 11870797 | 1242 days ago | IN | 20 ETH | 0.0760423 | ||||
Zap In | 11870783 | 1242 days ago | IN | 0.5 ETH | 0.04080476 | ||||
Zap In | 11870739 | 1242 days ago | IN | 0 ETH | 0.06303458 | ||||
Zap In | 11870676 | 1242 days ago | IN | 0.3 ETH | 0.03644476 | ||||
Zap In | 11870670 | 1242 days ago | IN | 0 ETH | 0.06468147 | ||||
Zap In | 11870504 | 1242 days ago | IN | 12 ETH | 0.03876286 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
12382368 | 1163 days ago | 0.00282989 ETH | ||||
12382350 | 1163 days ago | 0.002829 ETH | ||||
12174761 | 1195 days ago | 2.8 ETH | ||||
11878839 | 1241 days ago | 0.08 ETH | ||||
11878839 | 1241 days ago | 0.1 ETH | ||||
11874787 | 1242 days ago | 0.8 ETH | ||||
11871477 | 1242 days ago | 6 ETH | ||||
11871423 | 1242 days ago | 0.21 ETH | ||||
11871111 | 1242 days ago | 8 ETH | ||||
11870891 | 1242 days ago | 0.1 ETH | ||||
11870797 | 1242 days ago | 20 ETH | ||||
11870783 | 1242 days ago | 0.5 ETH | ||||
11870676 | 1242 days ago | 0.3 ETH | ||||
11870504 | 1242 days ago | 12 ETH | ||||
11870477 | 1242 days ago | 1 ETH | ||||
11870283 | 1242 days ago | 1 ETH | ||||
11870277 | 1242 days ago | 5 ETH | ||||
11870273 | 1242 days ago | 1 ETH | ||||
11870266 | 1242 days ago | 7 ETH | ||||
11869940 | 1242 days ago | 1.5 ETH | ||||
11869903 | 1242 days ago | 0.28 ETH | ||||
11869845 | 1242 days ago | 0.264 ETH | ||||
11869830 | 1242 days ago | 20 ETH | ||||
11869788 | 1242 days ago | 1 ETH | ||||
11869753 | 1242 days ago | 10 ETH |
Loading...
Loading
Contract Name:
UniswapV2_ZapIn_General_V3_0_1
Compiler Version
v0.5.17+commit.d19bba13
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2020-12-14 */ // ███████╗░█████╗░██████╗░██████╗░███████╗██████╗░░░░███████╗██╗ // ╚════██║██╔══██╗██╔══██╗██╔══██╗██╔════╝██╔══██╗░░░██╔════╝██║ // ░░███╔═╝███████║██████╔╝██████╔╝█████╗░░██████╔╝░░░█████╗░░██║ // ██╔══╝░░██╔══██║██╔═══╝░██╔═══╝░██╔══╝░░██╔══██╗░░░██╔══╝░░██║ // ███████╗██║░░██║██║░░░░░██║░░░░░███████╗██║░░██║██╗██║░░░░░██║ // ╚══════╝╚═╝░░╚═╝╚═╝░░░░░╚═╝░░░░░╚══════╝╚═╝░░╚═╝╚═╝╚═╝░░░░░╚═╝ // Copyright (C) 2020 zapper // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 2 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // ///@author Zapper ///@notice This contract adds liquidity to Uniswap V2 pools using ETH or any ERC20 Token. // SPDX-License-Identifier: GPLv2 pragma solidity ^0.5.5; /** * @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. * * 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 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 ); } /** * @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) { return sub(a, b, "SafeMath: subtraction overflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot overflow. * * _Available since v2.4.0._ */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b <= a, errorMessage); 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-contracts/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) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message 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. * * _Available since v2.4.0._ */ function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { // Solidity only automatically asserts when dividing by 0 require(b > 0, errorMessage); 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) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message 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. * * _Available since v2.4.0._ */ function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // According to EIP-1052, 0x0 is the value returned for not-yet created accounts // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned // for accounts without code, i.e. `keccak256('')` bytes32 codehash; bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470; // solhint-disable-next-line no-inline-assembly assembly { codehash := extcodehash(account) } return (codehash != accountHash && codehash != 0x0); } /** * @dev Converts an `address` into `address payable`. Note that this is * simply a type cast: the actual underlying value is not changed. * * _Available since v2.4.0._ */ function toPayable(address account) internal pure returns (address payable) { return address(uint160(account)); } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. * * _Available since v2.4.0._ */ function sendValue(address payable recipient, uint256 amount) internal { require( address(this).balance >= amount, "Address: insufficient balance" ); // solhint-disable-next-line avoid-call-value (bool success, ) = recipient.call.value(amount)(""); require( success, "Address: unable to send value, recipient may have reverted" ); } } /** * @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, "SafeERC20: decreased allowance below zero" ); 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" ); } } } /** * @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. * * _Since v2.5.0:_ this module is now much more gas efficient, given net gas * metering changes introduced in the Istanbul hardfork. */ contract ReentrancyGuard { bool private _notEntered; constructor() internal { // Storing an initial 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 percetange 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. _notEntered = true; } /** * @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() { // On the first call to nonReentrant, _notEntered will be true require(_notEntered, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _notEntered = false; _; // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _notEntered = true; } } /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ contract Context { // Empty internal constructor, to prevent people from mistakenly deploying // an instance of this contract, which should be used via inheritance. constructor() internal {} // solhint-disable-previous-line no-empty-blocks function _msgSender() internal view returns (address payable) { return msg.sender; } function _msgData() internal view returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ contract Ownable is Context { address payable public _owner; event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() internal { address payable msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(isOwner(), "Ownable: caller is not the owner"); _; } /** * @dev Returns true if the caller is the current owner. */ function isOwner() public view returns (bool) { return _msgSender() == _owner; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address payable newOwner) public onlyOwner { _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). */ function _transferOwnership(address payable newOwner) internal { require( newOwner != address(0), "Ownable: new owner is the zero address" ); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } // import "@uniswap/lib/contracts/libraries/Babylonian.sol"; library Babylonian { function sqrt(uint256 y) internal pure returns (uint256 z) { if (y > 3) { z = y; uint256 x = y / 2 + 1; while (x < z) { z = x; x = (y / x + x) / 2; } } else if (y != 0) { z = 1; } // else z = 0 } } interface IWETH { function deposit() external payable; function transfer(address to, uint256 value) external returns (bool); function withdraw(uint256) external; } interface IUniswapV2Factory { function getPair(address tokenA, address tokenB) external view returns (address); } interface IUniswapV2Router02 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns ( uint256 amountA, uint256 amountB, uint256 liquidity ); function addLiquidityETH( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external payable returns ( uint256 amountToken, uint256 amountETH, uint256 liquidity ); function removeLiquidity( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETH( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountToken, uint256 amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETHWithPermit( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountToken, uint256 amountETH); function swapExactTokensForTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapTokensForExactTokens( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactETHForTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapTokensForExactETH( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactTokensForETH( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapETHForExactTokens( uint256 amountOut, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountETH); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function quote( uint256 amountA, uint256 reserveA, uint256 reserveB ) external pure returns (uint256 amountB); function getAmountOut( uint256 amountIn, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountOut); function getAmountIn( uint256 amountOut, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountIn); function getAmountsOut(uint256 amountIn, address[] calldata path) external view returns (uint256[] memory amounts); function getAmountsIn(uint256 amountOut, address[] calldata path) external view returns (uint256[] memory amounts); } interface IUniswapV2Pair { function token0() external pure returns (address); function token1() external pure returns (address); function getReserves() external view returns ( uint112 _reserve0, uint112 _reserve1, uint32 _blockTimestampLast ); } contract UniswapV2_ZapIn_General_V3_0_1 is ReentrancyGuard, Ownable { using SafeMath for uint256; using Address for address; using SafeERC20 for IERC20; bool public stopped = false; uint16 public goodwill; address private constant zgoodwillAddress = 0xE737b6AfEC2320f616297e59445b60a11e3eF75F; IUniswapV2Factory private constant UniSwapV2FactoryAddress = IUniswapV2Factory( 0x5C69bEe701ef814a2B6a3EDD4B1652CB9cc5aA6f ); IUniswapV2Router02 private constant uniswapRouter = IUniswapV2Router02( 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D ); address private constant wethTokenAddress = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2; uint256 private constant deadline = 0xf000000000000000000000000000000000000000000000000000000000000000; constructor(uint16 _goodwill) public { goodwill = _goodwill; } // circuit breaker modifiers modifier stopInEmergency { if (stopped) { revert("Temporarily Paused"); } else { _; } } /** @notice This function is used to invest in given Uniswap V2 pair through ETH/ERC20 Tokens @param _FromTokenContractAddress The ERC20 token used for investment (address(0x00) if ether) @param _pairAddress The Uniswap pair address @param _amount The amount of fromToken to invest @param _minPoolTokens Reverts if less tokens received than this @param _allowanceTarget Spender for the first swap @param _swapTarget Excecution target for the first swap @param swapData DEX quote data @return Amount of LP bought */ function ZapIn( address _FromTokenContractAddress, address _pairAddress, uint256 _amount, uint256 _minPoolTokens, address _allowanceTarget, address _swapTarget, bytes calldata swapData ) external payable nonReentrant stopInEmergency returns (uint256) { uint256 toInvest; if (_FromTokenContractAddress == address(0)) { require(msg.value > 0, "Error: ETH not sent"); toInvest = msg.value; } else { require(msg.value == 0, "Error: ETH sent"); require(_amount > 0, "Error: Invalid ERC amount"); IERC20(_FromTokenContractAddress).safeTransferFrom( msg.sender, address(this), _amount ); toInvest = _amount; } uint256 LPBought = _performZapIn( _FromTokenContractAddress, _pairAddress, toInvest, _allowanceTarget, _swapTarget, swapData ); require(LPBought >= _minPoolTokens, "ERR: High Slippage"); //transfer goodwill uint256 goodwillPortion = _transferGoodwill(_pairAddress, LPBought); IERC20(_pairAddress).safeTransfer( msg.sender, SafeMath.sub(LPBought, goodwillPortion) ); return SafeMath.sub(LPBought, goodwillPortion); } function _getPairTokens(address _pairAddress) internal pure returns (address token0, address token1) { IUniswapV2Pair uniPair = IUniswapV2Pair(_pairAddress); token0 = uniPair.token0(); token1 = uniPair.token1(); } function _performZapIn( address _FromTokenContractAddress, address _pairAddress, uint256 _amount, address _allowanceTarget, address _swapTarget, bytes memory swapData ) internal returns (uint256) { uint256 intermediateAmt; address intermediateToken; (address _ToUniswapToken0, address _ToUniswapToken1) = _getPairTokens( _pairAddress ); if ( _FromTokenContractAddress != _ToUniswapToken0 && _FromTokenContractAddress != _ToUniswapToken1 ) { // swap to intermediate (intermediateAmt, intermediateToken) = _fillQuote( _FromTokenContractAddress, _pairAddress, _amount, _allowanceTarget, _swapTarget, swapData ); } else { intermediateToken = _FromTokenContractAddress; intermediateAmt = _amount; } // divide intermediate into appropriate amount to add liquidity (uint256 token0Bought, uint256 token1Bought) = _swapIntermediate( intermediateToken, _ToUniswapToken0, _ToUniswapToken1, intermediateAmt ); return _uniDeposit( _ToUniswapToken0, _ToUniswapToken1, token0Bought, token1Bought ); } function _uniDeposit( address _ToUnipoolToken0, address _ToUnipoolToken1, uint256 token0Bought, uint256 token1Bought ) internal returns (uint256) { IERC20(_ToUnipoolToken0).safeApprove(address(uniswapRouter), 0); IERC20(_ToUnipoolToken1).safeApprove(address(uniswapRouter), 0); IERC20(_ToUnipoolToken0).safeApprove( address(uniswapRouter), token0Bought ); IERC20(_ToUnipoolToken1).safeApprove( address(uniswapRouter), token1Bought ); (uint256 amountA, uint256 amountB, uint256 LP) = uniswapRouter .addLiquidity( _ToUnipoolToken0, _ToUnipoolToken1, token0Bought, token1Bought, 1, 1, address(this), deadline ); //Returning Residue in token0, if any. if (token0Bought.sub(amountA) > 0) { IERC20(_ToUnipoolToken0).safeTransfer( msg.sender, token0Bought.sub(amountA) ); } //Returning Residue in token1, if any if (token1Bought.sub(amountB) > 0) { IERC20(_ToUnipoolToken1).safeTransfer( msg.sender, token1Bought.sub(amountB) ); } return LP; } function _fillQuote( address _fromTokenAddress, address _pairAddress, uint256 _amount, address _allowanceTarget, address _swapTarget, bytes memory swapCallData ) internal returns (uint256 amountBought, address intermediateToken) { uint256 valueToSend; if (_fromTokenAddress == address(0)) { valueToSend = _amount; } else { IERC20 fromToken = IERC20(_fromTokenAddress); fromToken.safeApprove(address(_allowanceTarget), 0); fromToken.safeApprove(address(_allowanceTarget), _amount); } (address _token0, address _token1) = _getPairTokens(_pairAddress); IERC20 token0 = IERC20(_token0); IERC20 token1 = IERC20(_token1); uint256 initialBalance0 = token0.balanceOf(address(this)); uint256 initialBalance1 = token1.balanceOf(address(this)); (bool success, ) = _swapTarget.call.value(valueToSend)(swapCallData); require(success, "Error Swapping Tokens 1"); uint256 finalBalance0 = token0.balanceOf(address(this)).sub( initialBalance0 ); uint256 finalBalance1 = token1.balanceOf(address(this)).sub( initialBalance1 ); if (finalBalance0 > finalBalance1) { amountBought = finalBalance0; intermediateToken = _token0; } else { amountBought = finalBalance1; intermediateToken = _token1; } require(amountBought > 0, "Swapped to Invalid Intermediate"); } function _swapIntermediate( address _toContractAddress, address _ToUnipoolToken0, address _ToUnipoolToken1, uint256 _amount ) internal returns (uint256 token0Bought, uint256 token1Bought) { IUniswapV2Pair pair = IUniswapV2Pair( UniSwapV2FactoryAddress.getPair(_ToUnipoolToken0, _ToUnipoolToken1) ); (uint256 res0, uint256 res1, ) = pair.getReserves(); if (_toContractAddress == _ToUnipoolToken0) { uint256 amountToSwap = calculateSwapInAmount(res0, _amount); //if no reserve or a new pair is created if (amountToSwap <= 0) amountToSwap = _amount.div(2); token1Bought = _token2Token( _toContractAddress, _ToUnipoolToken1, amountToSwap ); token0Bought = _amount.sub(amountToSwap); } else { uint256 amountToSwap = calculateSwapInAmount(res1, _amount); //if no reserve or a new pair is created if (amountToSwap <= 0) amountToSwap = _amount.div(2); token0Bought = _token2Token( _toContractAddress, _ToUnipoolToken0, amountToSwap ); token1Bought = _amount.sub(amountToSwap); } } function calculateSwapInAmount(uint256 reserveIn, uint256 userIn) internal pure returns (uint256) { return Babylonian .sqrt( reserveIn.mul(userIn.mul(3988000) + reserveIn.mul(3988009)) ) .sub(reserveIn.mul(1997)) / 1994; } /** @notice This function is used to swap ERC20 <> ERC20 @param _FromTokenContractAddress The token address to swap from. @param _ToTokenContractAddress The token address to swap to. @param tokens2Trade The amount of tokens to swap @return tokenBought The quantity of tokens bought */ function _token2Token( address _FromTokenContractAddress, address _ToTokenContractAddress, uint256 tokens2Trade ) internal returns (uint256 tokenBought) { if (_FromTokenContractAddress == _ToTokenContractAddress) { return tokens2Trade; } IERC20(_FromTokenContractAddress).safeApprove( address(uniswapRouter), 0 ); IERC20(_FromTokenContractAddress).safeApprove( address(uniswapRouter), tokens2Trade ); address pair = UniSwapV2FactoryAddress.getPair( _FromTokenContractAddress, _ToTokenContractAddress ); require(pair != address(0), "No Swap Available"); address[] memory path = new address[](2); path[0] = _FromTokenContractAddress; path[1] = _ToTokenContractAddress; tokenBought = uniswapRouter.swapExactTokensForTokens( tokens2Trade, 1, path, address(this), deadline )[path.length - 1]; require(tokenBought > 0, "Error Swapping Tokens 2"); } /** @notice This function is used to calculate and transfer goodwill @param _tokenContractAddress Token in which goodwill is deducted @param tokens2Trade The total amount of tokens to be zapped in @return The quantity of goodwill deducted */ function _transferGoodwill( address _tokenContractAddress, uint256 tokens2Trade ) internal returns (uint256 goodwillPortion) { goodwillPortion = SafeMath.div( SafeMath.mul(tokens2Trade, goodwill), 10000 ); if (goodwillPortion == 0) { return 0; } IERC20(_tokenContractAddress).safeTransfer( zgoodwillAddress, goodwillPortion ); } function set_new_goodwill(uint16 _new_goodwill) public onlyOwner { require( _new_goodwill >= 0 && _new_goodwill < 10000, "GoodWill Value not allowed" ); goodwill = _new_goodwill; } function inCaseTokengetsStuck(IERC20 _TokenAddress) public onlyOwner { uint256 qty = _TokenAddress.balanceOf(address(this)); _TokenAddress.safeTransfer(owner(), qty); } // - to Pause the contract function toggleContractActive() public onlyOwner { stopped = !stopped; } // - to withdraw any ETH balance sitting in the contract function withdraw() public onlyOwner { uint256 contractBalance = address(this).balance; address payable _to = owner().toPayable(); _to.transfer(contractBalance); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"uint16","name":"_goodwill","type":"uint16"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"constant":false,"inputs":[{"internalType":"address","name":"_FromTokenContractAddress","type":"address"},{"internalType":"address","name":"_pairAddress","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"uint256","name":"_minPoolTokens","type":"uint256"},{"internalType":"address","name":"_allowanceTarget","type":"address"},{"internalType":"address","name":"_swapTarget","type":"address"},{"internalType":"bytes","name":"swapData","type":"bytes"}],"name":"ZapIn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[],"name":"_owner","outputs":[{"internalType":"address payable","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"goodwill","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"contract IERC20","name":"_TokenAddress","type":"address"}],"name":"inCaseTokengetsStuck","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint16","name":"_new_goodwill","type":"uint16"}],"name":"set_new_goodwill","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"stopped","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"toggleContractActive","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address payable","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"withdraw","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
60806040526000805460ff60a81b1916905534801561001d57600080fd5b5060405161203b38038061203b8339818101604052602081101561004057600080fd5b50516000805460ff191660011781556100606001600160e01b036100d716565b60008054610100600160a81b0319166101006001600160a01b038416908102919091178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506000805461ffff909216600160b01b0261ffff60b01b199092169190911790556100db565b3390565b611f51806100ea6000396000f3fe6080604052600436106100a75760003560e01c80638da5cb5b116100645780638da5cb5b146101755780638f32d59b146101a6578063b10e1dbc146101bb578063b2bdfa7b146101e9578063bf6411b2146101fe578063f2fde38b146102b5576100a7565b80631385d24c146100ac5780633ccfd60b146100c3578063551196d5146100d85780635de0398e1461010b578063715018a61461013757806375f12b211461014c575b600080fd5b3480156100b857600080fd5b506100c16102e8565b005b3480156100cf57600080fd5b506100c1610350565b3480156100e457600080fd5b506100c1600480360360208110156100fb57600080fd5b50356001600160a01b03166103f1565b34801561011757600080fd5b506101206104d6565b6040805161ffff9092168252519081900360200190f35b34801561014357600080fd5b506100c16104e7565b34801561015857600080fd5b5061016161057d565b604080519115158252519081900360200190f35b34801561018157600080fd5b5061018a61058d565b604080516001600160a01b039092168252519081900360200190f35b3480156101b257600080fd5b506101616105a1565b3480156101c757600080fd5b506100c1600480360360208110156101de57600080fd5b503561ffff166105ca565b3480156101f557600080fd5b5061018a61068d565b6102a3600480360360e081101561021457600080fd5b6001600160a01b0382358116926020810135821692604082013592606083013592608081013582169260a08201359092169181019060e0810160c082013564010000000081111561026457600080fd5b82018360208201111561027657600080fd5b8035906020019184600183028401116401000000008311171561029857600080fd5b5090925090506106a1565b60408051918252519081900360200190f35b3480156102c157600080fd5b506100c1600480360360208110156102d857600080fd5b50356001600160a01b031661095d565b6102f06105a1565b61032f576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6000805460ff60a81b198116600160a81b9182900460ff1615909102179055565b6103586105a1565b610397576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b4760006103b36103a561058d565b6001600160a01b03166109b0565b6040519091506001600160a01b0382169083156108fc029084906000818181858888f193505050501580156103ec573d6000803e3d6000fd5b505050565b6103f96105a1565b610438576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b604080516370a0823160e01b815230600482015290516000916001600160a01b038416916370a0823191602480820192602092909190829003018186803b15801561048257600080fd5b505afa158015610496573d6000803e3d6000fd5b505050506040513d60208110156104ac57600080fd5b505190506104d26104bb61058d565b6001600160a01b038416908363ffffffff6109b716565b5050565b600054600160b01b900461ffff1681565b6104ef6105a1565b61052e576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b600080546040516101009091046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a360008054610100600160a81b0319169055565b600054600160a81b900460ff1681565b60005461010090046001600160a01b031690565b6000805461010090046001600160a01b03166105bb610a09565b6001600160a01b031614905090565b6105d26105a1565b610611576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6127108161ffff161061066b576040805162461bcd60e51b815260206004820152601a60248201527f476f6f6457696c6c2056616c7565206e6f7420616c6c6f776564000000000000604482015290519081900360640190fd5b6000805461ffff909216600160b01b0261ffff60b01b19909216919091179055565b60005461010090046001600160a01b031681565b6000805460ff166106f9576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b6000805460ff191690819055600160a81b900460ff1615610756576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b60006001600160a01b038a166107b857600034116107b1576040805162461bcd60e51b8152602060048201526013602482015272115c9c9bdc8e88115512081b9bdd081cd95b9d606a1b604482015290519081900360640190fd5b5034610870565b34156107fd576040805162461bcd60e51b815260206004820152600f60248201526e115c9c9bdc8e88115512081cd95b9d608a1b604482015290519081900360640190fd5b60008811610852576040805162461bcd60e51b815260206004820152601960248201527f4572726f723a20496e76616c69642045524320616d6f756e7400000000000000604482015290519081900360640190fd5b61086d6001600160a01b038b1633308b63ffffffff610a0d16565b50865b60006108b68b8b848a8a8a8a8080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250610a6d92505050565b905087811015610902576040805162461bcd60e51b81526020600482015260126024820152714552523a204869676820536c69707061676560701b604482015290519081900360640190fd5b600061090e8b83610b0a565b90506109353361091e8484610b73565b6001600160a01b038e16919063ffffffff6109b716565b61093f8282610b73565b93505050506000805460ff1916600117905598975050505050505050565b6109656105a1565b6109a4576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6109ad81610bbc565b50565b805b919050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b1790526103ec908490610c67565b3390565b604080516001600160a01b0385811660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052610a67908590610c67565b50505050565b6000806000806000610a7e8a610e1f565b91509150816001600160a01b03168b6001600160a01b031614158015610ab65750806001600160a01b03168b6001600160a01b031614155b15610ad357610ac98b8b8b8b8b8b610f05565b9094509250610ada565b8a92508893505b600080610ae9858585896112d3565b91509150610af9848484846114b6565b9d9c50505050505050505050505050565b60008054610b3090610b28908490600160b01b900461ffff166116d9565b612710611732565b905080610b3f57506000610b6d565b610b6d6001600160a01b03841673e737b6afec2320f616297e59445b60a11e3ef75f8363ffffffff6109b716565b92915050565b6000610bb583836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611774565b9392505050565b6001600160a01b038116610c015760405162461bcd60e51b8152600401808060200182810382526026815260200180611e566026913960400191505060405180910390fd5b600080546040516001600160a01b038085169361010090930416917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b610c79826001600160a01b031661180b565b610cca576040805162461bcd60e51b815260206004820152601f60248201527f5361666545524332303a2063616c6c20746f206e6f6e2d636f6e747261637400604482015290519081900360640190fd5b60006060836001600160a01b0316836040518082805190602001908083835b60208310610d085780518252601f199092019160209182019101610ce9565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114610d6a576040519150601f19603f3d011682016040523d82523d6000602084013e610d6f565b606091505b509150915081610dc6576040805162461bcd60e51b815260206004820181905260248201527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564604482015290519081900360640190fd5b805115610a6757808060200190516020811015610de257600080fd5b5051610a675760405162461bcd60e51b815260040180806020018281038252602a815260200180611ebd602a913960400191505060405180910390fd5b6000806000839050806001600160a01b0316630dfe16816040518163ffffffff1660e01b815260040160206040518083038186803b158015610e6057600080fd5b505afa158015610e74573d6000803e3d6000fd5b505050506040513d6020811015610e8a57600080fd5b50516040805163d21220a760e01b815290519194506001600160a01b0383169163d21220a791600480820192602092909190829003018186803b158015610ed057600080fd5b505afa158015610ee4573d6000803e3d6000fd5b505050506040513d6020811015610efa57600080fd5b505192949293505050565b600080806001600160a01b038916610f1e575085610f56565b88610f3a6001600160a01b03821688600063ffffffff61184716565b610f546001600160a01b038216888a63ffffffff61184716565b505b600080610f628a610e1f565b604080516370a0823160e01b81523060048201529051929450909250839183916000916001600160a01b038516916370a08231916024808301926020929190829003018186803b158015610fb557600080fd5b505afa158015610fc9573d6000803e3d6000fd5b505050506040513d6020811015610fdf57600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b15801561102d57600080fd5b505afa158015611041573d6000803e3d6000fd5b505050506040513d602081101561105757600080fd5b50516040518b519192506000916001600160a01b038e16918a918e9190819060208401908083835b6020831061109e5780518252601f19909201916020918201910161107f565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611100576040519150601f19603f3d011682016040523d82523d6000602084013e611105565b606091505b505090508061115b576040805162461bcd60e51b815260206004820152601760248201527f4572726f72205377617070696e6720546f6b656e732031000000000000000000604482015290519081900360640190fd5b60006111ef84876001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111b757600080fd5b505afa1580156111cb573d6000803e3d6000fd5b505050506040513d60208110156111e157600080fd5b50519063ffffffff610b7316565b9050600061124d84876001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111b757600080fd5b90508082111561126257819b50889a50611269565b809b50879a505b60008c116112be576040805162461bcd60e51b815260206004820152601f60248201527f5377617070656420746f20496e76616c696420496e7465726d65646961746500604482015290519081900360640190fd5b50505050505050505050965096945050505050565b6040805163e6a4390560e01b81526001600160a01b03858116600483015284166024820152905160009182918291735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b15801561133d57600080fd5b505afa158015611351573d6000803e3d6000fd5b505050506040513d602081101561136757600080fd5b505160408051630240bc6b60e21b8152905191925060009182916001600160a01b03851691630902f1ac91600480820192606092909190829003018186803b1580156113b257600080fd5b505afa1580156113c6573d6000803e3d6000fd5b505050506040513d60608110156113dc57600080fd5b5080516020909101516dffffffffffffffffffffffffffff91821693501690506001600160a01b03898116908916141561145f57600061141c838861195a565b90506000811161143a5761143787600263ffffffff61173216565b90505b6114458a89836119ce565b9450611457878263ffffffff610b7316565b9550506114aa565b600061146b828861195a565b9050600081116114895761148687600263ffffffff61173216565b90505b6114948a8a836119ce565b95506114a6878263ffffffff610b7316565b9450505b50505094509492505050565b60006114e66001600160a01b038616737a250d5630b4cf539739df2c5dacb4c659f2488d8363ffffffff61184716565b6115156001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d600063ffffffff61184716565b6115436001600160a01b038616737a250d5630b4cf539739df2c5dacb4c659f2488d8563ffffffff61184716565b6115716001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d8463ffffffff61184716565b6040805162e8e33760e81b81526001600160a01b03878116600483015286166024820152604481018590526064810184905260016084820181905260a48201523060c4820152600f60fc1b60e4820152905160009182918291737a250d5630b4cf539739df2c5dacb4c659f2488d9163e8e33700916101048082019260609290919082900301818787803b15801561160857600080fd5b505af115801561161c573d6000803e3d6000fd5b505050506040513d606081101561163257600080fd5b50805160208201516040909201519094509092509050600061165a878563ffffffff610b7316565b111561168b5761168b33611674888663ffffffff610b7316565b6001600160a01b038b16919063ffffffff6109b716565b600061169d868463ffffffff610b7316565b11156116ce576116ce336116b7878563ffffffff610b7316565b6001600160a01b038a16919063ffffffff6109b716565b979650505050505050565b6000826116e857506000610b6d565b828202828482816116f557fe5b0414610bb55760405162461bcd60e51b8152600401808060200182810382526021815260200180611e7c6021913960400191505060405180910390fd5b6000610bb583836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611d9f565b600081848411156118035760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156117c85781810151838201526020016117b0565b50505050905090810190601f1680156117f55780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061183f57508115155b949350505050565b8015806118cd575060408051636eb1769f60e11b81523060048201526001600160a01b03848116602483015291519185169163dd62ed3e91604480820192602092909190829003018186803b15801561189f57600080fd5b505afa1580156118b3573d6000803e3d6000fd5b505050506040513d60208110156118c957600080fd5b5051155b6119085760405162461bcd60e51b8152600401808060200182810382526036815260200180611ee76036913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b1790526103ec908490610c67565b60006107ca6119bf611974856107cd63ffffffff6116d916565b6119b36119ae61198d88623cda2963ffffffff6116d916565b6119a088623cda2063ffffffff6116d916565b89910163ffffffff6116d916565b611e04565b9063ffffffff610b7316565b816119c657fe5b049392505050565b6000826001600160a01b0316846001600160a01b031614156119f1575080610bb5565b611a206001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d600063ffffffff61184716565b611a4e6001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d8463ffffffff61184716565b6040805163e6a4390560e01b81526001600160a01b038681166004830152851660248201529051600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b158015611ab457600080fd5b505afa158015611ac8573d6000803e3d6000fd5b505050506040513d6020811015611ade57600080fd5b505190506001600160a01b038116611b31576040805162461bcd60e51b81526020600482015260116024820152704e6f205377617020417661696c61626c6560781b604482015290519081900360640190fd5b60408051600280825260608083018452926020830190803883390190505090508581600081518110611b5f57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508481600181518110611b8d57fe5b6001600160a01b039092166020928302919091018201526040516338ed173960e01b8152600481018681526001602483018190523060648401819052600f60fc1b6084850181905260a060448601908152875160a48701528751737a250d5630b4cf539739df2c5dacb4c659f2488d976338ed1739978d978b9695949093909260c490920191878101910280838360005b83811015611c36578181015183820152602001611c1e565b505050509050019650505050505050600060405180830381600087803b158015611c5f57600080fd5b505af1158015611c73573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015611c9c57600080fd5b8101908080516040519392919084640100000000821115611cbc57600080fd5b908301906020820185811115611cd157600080fd5b8251866020820283011164010000000082111715611cee57600080fd5b82525081516020918201928201910280838360005b83811015611d1b578181015183820152602001611d03565b50505050905001604052505050600182510381518110611d3757fe5b6020026020010151925060008311611d96576040805162461bcd60e51b815260206004820152601760248201527f4572726f72205377617070696e6720546f6b656e732032000000000000000000604482015290519081900360640190fd5b50509392505050565b60008183611dee5760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156117c85781810151838201526020016117b0565b506000838581611dfa57fe5b0495945050505050565b60006003821115611e47575080600160028204015b81811015611e4157809150600281828581611e3057fe5b040181611e3957fe5b049050611e19565b506109b2565b81156109b25750600191905056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a265627a7a72315820dd813a01da25f897d40875d57eb7a804d6845a809425938a98459b0f90ce399264736f6c634300051100320000000000000000000000000000000000000000000000000000000000000000
Deployed Bytecode
0x6080604052600436106100a75760003560e01c80638da5cb5b116100645780638da5cb5b146101755780638f32d59b146101a6578063b10e1dbc146101bb578063b2bdfa7b146101e9578063bf6411b2146101fe578063f2fde38b146102b5576100a7565b80631385d24c146100ac5780633ccfd60b146100c3578063551196d5146100d85780635de0398e1461010b578063715018a61461013757806375f12b211461014c575b600080fd5b3480156100b857600080fd5b506100c16102e8565b005b3480156100cf57600080fd5b506100c1610350565b3480156100e457600080fd5b506100c1600480360360208110156100fb57600080fd5b50356001600160a01b03166103f1565b34801561011757600080fd5b506101206104d6565b6040805161ffff9092168252519081900360200190f35b34801561014357600080fd5b506100c16104e7565b34801561015857600080fd5b5061016161057d565b604080519115158252519081900360200190f35b34801561018157600080fd5b5061018a61058d565b604080516001600160a01b039092168252519081900360200190f35b3480156101b257600080fd5b506101616105a1565b3480156101c757600080fd5b506100c1600480360360208110156101de57600080fd5b503561ffff166105ca565b3480156101f557600080fd5b5061018a61068d565b6102a3600480360360e081101561021457600080fd5b6001600160a01b0382358116926020810135821692604082013592606083013592608081013582169260a08201359092169181019060e0810160c082013564010000000081111561026457600080fd5b82018360208201111561027657600080fd5b8035906020019184600183028401116401000000008311171561029857600080fd5b5090925090506106a1565b60408051918252519081900360200190f35b3480156102c157600080fd5b506100c1600480360360208110156102d857600080fd5b50356001600160a01b031661095d565b6102f06105a1565b61032f576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6000805460ff60a81b198116600160a81b9182900460ff1615909102179055565b6103586105a1565b610397576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b4760006103b36103a561058d565b6001600160a01b03166109b0565b6040519091506001600160a01b0382169083156108fc029084906000818181858888f193505050501580156103ec573d6000803e3d6000fd5b505050565b6103f96105a1565b610438576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b604080516370a0823160e01b815230600482015290516000916001600160a01b038416916370a0823191602480820192602092909190829003018186803b15801561048257600080fd5b505afa158015610496573d6000803e3d6000fd5b505050506040513d60208110156104ac57600080fd5b505190506104d26104bb61058d565b6001600160a01b038416908363ffffffff6109b716565b5050565b600054600160b01b900461ffff1681565b6104ef6105a1565b61052e576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b600080546040516101009091046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a360008054610100600160a81b0319169055565b600054600160a81b900460ff1681565b60005461010090046001600160a01b031690565b6000805461010090046001600160a01b03166105bb610a09565b6001600160a01b031614905090565b6105d26105a1565b610611576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6127108161ffff161061066b576040805162461bcd60e51b815260206004820152601a60248201527f476f6f6457696c6c2056616c7565206e6f7420616c6c6f776564000000000000604482015290519081900360640190fd5b6000805461ffff909216600160b01b0261ffff60b01b19909216919091179055565b60005461010090046001600160a01b031681565b6000805460ff166106f9576040805162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015290519081900360640190fd5b6000805460ff191690819055600160a81b900460ff1615610756576040805162461bcd60e51b815260206004820152601260248201527115195b5c1bdc985c9a5b1e4814185d5cd95960721b604482015290519081900360640190fd5b60006001600160a01b038a166107b857600034116107b1576040805162461bcd60e51b8152602060048201526013602482015272115c9c9bdc8e88115512081b9bdd081cd95b9d606a1b604482015290519081900360640190fd5b5034610870565b34156107fd576040805162461bcd60e51b815260206004820152600f60248201526e115c9c9bdc8e88115512081cd95b9d608a1b604482015290519081900360640190fd5b60008811610852576040805162461bcd60e51b815260206004820152601960248201527f4572726f723a20496e76616c69642045524320616d6f756e7400000000000000604482015290519081900360640190fd5b61086d6001600160a01b038b1633308b63ffffffff610a0d16565b50865b60006108b68b8b848a8a8a8a8080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250610a6d92505050565b905087811015610902576040805162461bcd60e51b81526020600482015260126024820152714552523a204869676820536c69707061676560701b604482015290519081900360640190fd5b600061090e8b83610b0a565b90506109353361091e8484610b73565b6001600160a01b038e16919063ffffffff6109b716565b61093f8282610b73565b93505050506000805460ff1916600117905598975050505050505050565b6109656105a1565b6109a4576040805162461bcd60e51b81526020600482018190526024820152600080516020611e9d833981519152604482015290519081900360640190fd5b6109ad81610bbc565b50565b805b919050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b1790526103ec908490610c67565b3390565b604080516001600160a01b0385811660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b179052610a67908590610c67565b50505050565b6000806000806000610a7e8a610e1f565b91509150816001600160a01b03168b6001600160a01b031614158015610ab65750806001600160a01b03168b6001600160a01b031614155b15610ad357610ac98b8b8b8b8b8b610f05565b9094509250610ada565b8a92508893505b600080610ae9858585896112d3565b91509150610af9848484846114b6565b9d9c50505050505050505050505050565b60008054610b3090610b28908490600160b01b900461ffff166116d9565b612710611732565b905080610b3f57506000610b6d565b610b6d6001600160a01b03841673e737b6afec2320f616297e59445b60a11e3ef75f8363ffffffff6109b716565b92915050565b6000610bb583836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611774565b9392505050565b6001600160a01b038116610c015760405162461bcd60e51b8152600401808060200182810382526026815260200180611e566026913960400191505060405180910390fd5b600080546040516001600160a01b038085169361010090930416917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b610c79826001600160a01b031661180b565b610cca576040805162461bcd60e51b815260206004820152601f60248201527f5361666545524332303a2063616c6c20746f206e6f6e2d636f6e747261637400604482015290519081900360640190fd5b60006060836001600160a01b0316836040518082805190602001908083835b60208310610d085780518252601f199092019160209182019101610ce9565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114610d6a576040519150601f19603f3d011682016040523d82523d6000602084013e610d6f565b606091505b509150915081610dc6576040805162461bcd60e51b815260206004820181905260248201527f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564604482015290519081900360640190fd5b805115610a6757808060200190516020811015610de257600080fd5b5051610a675760405162461bcd60e51b815260040180806020018281038252602a815260200180611ebd602a913960400191505060405180910390fd5b6000806000839050806001600160a01b0316630dfe16816040518163ffffffff1660e01b815260040160206040518083038186803b158015610e6057600080fd5b505afa158015610e74573d6000803e3d6000fd5b505050506040513d6020811015610e8a57600080fd5b50516040805163d21220a760e01b815290519194506001600160a01b0383169163d21220a791600480820192602092909190829003018186803b158015610ed057600080fd5b505afa158015610ee4573d6000803e3d6000fd5b505050506040513d6020811015610efa57600080fd5b505192949293505050565b600080806001600160a01b038916610f1e575085610f56565b88610f3a6001600160a01b03821688600063ffffffff61184716565b610f546001600160a01b038216888a63ffffffff61184716565b505b600080610f628a610e1f565b604080516370a0823160e01b81523060048201529051929450909250839183916000916001600160a01b038516916370a08231916024808301926020929190829003018186803b158015610fb557600080fd5b505afa158015610fc9573d6000803e3d6000fd5b505050506040513d6020811015610fdf57600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b15801561102d57600080fd5b505afa158015611041573d6000803e3d6000fd5b505050506040513d602081101561105757600080fd5b50516040518b519192506000916001600160a01b038e16918a918e9190819060208401908083835b6020831061109e5780518252601f19909201916020918201910161107f565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114611100576040519150601f19603f3d011682016040523d82523d6000602084013e611105565b606091505b505090508061115b576040805162461bcd60e51b815260206004820152601760248201527f4572726f72205377617070696e6720546f6b656e732031000000000000000000604482015290519081900360640190fd5b60006111ef84876001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111b757600080fd5b505afa1580156111cb573d6000803e3d6000fd5b505050506040513d60208110156111e157600080fd5b50519063ffffffff610b7316565b9050600061124d84876001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111b757600080fd5b90508082111561126257819b50889a50611269565b809b50879a505b60008c116112be576040805162461bcd60e51b815260206004820152601f60248201527f5377617070656420746f20496e76616c696420496e7465726d65646961746500604482015290519081900360640190fd5b50505050505050505050965096945050505050565b6040805163e6a4390560e01b81526001600160a01b03858116600483015284166024820152905160009182918291735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b15801561133d57600080fd5b505afa158015611351573d6000803e3d6000fd5b505050506040513d602081101561136757600080fd5b505160408051630240bc6b60e21b8152905191925060009182916001600160a01b03851691630902f1ac91600480820192606092909190829003018186803b1580156113b257600080fd5b505afa1580156113c6573d6000803e3d6000fd5b505050506040513d60608110156113dc57600080fd5b5080516020909101516dffffffffffffffffffffffffffff91821693501690506001600160a01b03898116908916141561145f57600061141c838861195a565b90506000811161143a5761143787600263ffffffff61173216565b90505b6114458a89836119ce565b9450611457878263ffffffff610b7316565b9550506114aa565b600061146b828861195a565b9050600081116114895761148687600263ffffffff61173216565b90505b6114948a8a836119ce565b95506114a6878263ffffffff610b7316565b9450505b50505094509492505050565b60006114e66001600160a01b038616737a250d5630b4cf539739df2c5dacb4c659f2488d8363ffffffff61184716565b6115156001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d600063ffffffff61184716565b6115436001600160a01b038616737a250d5630b4cf539739df2c5dacb4c659f2488d8563ffffffff61184716565b6115716001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d8463ffffffff61184716565b6040805162e8e33760e81b81526001600160a01b03878116600483015286166024820152604481018590526064810184905260016084820181905260a48201523060c4820152600f60fc1b60e4820152905160009182918291737a250d5630b4cf539739df2c5dacb4c659f2488d9163e8e33700916101048082019260609290919082900301818787803b15801561160857600080fd5b505af115801561161c573d6000803e3d6000fd5b505050506040513d606081101561163257600080fd5b50805160208201516040909201519094509092509050600061165a878563ffffffff610b7316565b111561168b5761168b33611674888663ffffffff610b7316565b6001600160a01b038b16919063ffffffff6109b716565b600061169d868463ffffffff610b7316565b11156116ce576116ce336116b7878563ffffffff610b7316565b6001600160a01b038a16919063ffffffff6109b716565b979650505050505050565b6000826116e857506000610b6d565b828202828482816116f557fe5b0414610bb55760405162461bcd60e51b8152600401808060200182810382526021815260200180611e7c6021913960400191505060405180910390fd5b6000610bb583836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611d9f565b600081848411156118035760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156117c85781810151838201526020016117b0565b50505050905090810190601f1680156117f55780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061183f57508115155b949350505050565b8015806118cd575060408051636eb1769f60e11b81523060048201526001600160a01b03848116602483015291519185169163dd62ed3e91604480820192602092909190829003018186803b15801561189f57600080fd5b505afa1580156118b3573d6000803e3d6000fd5b505050506040513d60208110156118c957600080fd5b5051155b6119085760405162461bcd60e51b8152600401808060200182810382526036815260200180611ee76036913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b1790526103ec908490610c67565b60006107ca6119bf611974856107cd63ffffffff6116d916565b6119b36119ae61198d88623cda2963ffffffff6116d916565b6119a088623cda2063ffffffff6116d916565b89910163ffffffff6116d916565b611e04565b9063ffffffff610b7316565b816119c657fe5b049392505050565b6000826001600160a01b0316846001600160a01b031614156119f1575080610bb5565b611a206001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d600063ffffffff61184716565b611a4e6001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d8463ffffffff61184716565b6040805163e6a4390560e01b81526001600160a01b038681166004830152851660248201529051600091735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f9163e6a4390591604480820192602092909190829003018186803b158015611ab457600080fd5b505afa158015611ac8573d6000803e3d6000fd5b505050506040513d6020811015611ade57600080fd5b505190506001600160a01b038116611b31576040805162461bcd60e51b81526020600482015260116024820152704e6f205377617020417661696c61626c6560781b604482015290519081900360640190fd5b60408051600280825260608083018452926020830190803883390190505090508581600081518110611b5f57fe5b60200260200101906001600160a01b031690816001600160a01b0316815250508481600181518110611b8d57fe5b6001600160a01b039092166020928302919091018201526040516338ed173960e01b8152600481018681526001602483018190523060648401819052600f60fc1b6084850181905260a060448601908152875160a48701528751737a250d5630b4cf539739df2c5dacb4c659f2488d976338ed1739978d978b9695949093909260c490920191878101910280838360005b83811015611c36578181015183820152602001611c1e565b505050509050019650505050505050600060405180830381600087803b158015611c5f57600080fd5b505af1158015611c73573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015611c9c57600080fd5b8101908080516040519392919084640100000000821115611cbc57600080fd5b908301906020820185811115611cd157600080fd5b8251866020820283011164010000000082111715611cee57600080fd5b82525081516020918201928201910280838360005b83811015611d1b578181015183820152602001611d03565b50505050905001604052505050600182510381518110611d3757fe5b6020026020010151925060008311611d96576040805162461bcd60e51b815260206004820152601760248201527f4572726f72205377617070696e6720546f6b656e732032000000000000000000604482015290519081900360640190fd5b50509392505050565b60008183611dee5760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156117c85781810151838201526020016117b0565b506000838581611dfa57fe5b0495945050505050565b60006003821115611e47575080600160028204015b81811015611e4157809150600281828581611e3057fe5b040181611e3957fe5b049050611e19565b506109b2565b81156109b25750600191905056fe4f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725361666545524332303a204552433230206f7065726174696f6e20646964206e6f7420737563636565645361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a265627a7a72315820dd813a01da25f897d40875d57eb7a804d6845a809425938a98459b0f90ce399264736f6c63430005110032
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000000000000000000000000000000000000000000000
-----Decoded View---------------
Arg [0] : _goodwill (uint16): 0
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000000
Deployed Bytecode Sourcemap
30237:12813:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42696:86;;8:9:-1;5:2;;;30:1;27;20:12;5:2;42696:86:0;;;:::i;:::-;;42852:195;;8:9:-1;5:2;;;30:1;27;20:12;5:2;42852:195:0;;;:::i;42465:191::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;42465:191:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42465:191:0;-1:-1:-1;;;;;42465:191:0;;:::i;30446:22::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;30446:22:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;22718:140;;8:9:-1;5:2;;;30:1;27;20:12;5:2;22718:140:0;;;:::i;30412:27::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;30412:27:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;21907:79;;8:9:-1;5:2;;;30:1;27;20:12;5:2;21907:79:0;;;:::i;:::-;;;;-1:-1:-1;;;;;21907:79:0;;;;;;;;;;;;;;22273:94;;8:9:-1;5:2;;;30:1;27;20:12;5:2;22273:94:0;;;:::i;42219:238::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;42219:238:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42219:238:0;;;;:::i;21402:29::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;21402:29:0;;;:::i;31940:1451::-;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;31940:1451:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;31940:1451:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;31940:1451:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;-1:-1;31940:1451:0;;-1:-1:-1;31940:1451:0;-1:-1:-1;31940:1451:0;:::i;:::-;;;;;;;;;;;;;;;;23013:117;;8:9:-1;5:2;;;30:1;27;20:12;5:2;23013:117:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;23013:117:0;-1:-1:-1;;;;;23013:117:0;;:::i;42696:86::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;42767:7;;;-1:-1:-1;;;;42756:18:0;;-1:-1:-1;;;42767:7:0;;;;;;42766:8;42756:18;;;;;;42696:86::o;42852:195::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;42926:21;42900:23;42980:19;:7;:5;:7::i;:::-;-1:-1:-1;;;;;42980:17:0;;:19::i;:::-;43010:29;;42958:41;;-1:-1:-1;;;;;;43010:12:0;;;:29;;;;;43023:15;;43010:29;;;;43023:15;43010:12;:29;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;43010:29:0;22176:1;;42852:195::o;42465:191::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;42559:38;;;-1:-1:-1;;;42559:38:0;;42591:4;42559:38;;;;;;42545:11;;-1:-1:-1;;;;;42559:23:0;;;;;:38;;;;;;;;;;;;;;;:23;:38;;;5:2:-1;;;;30:1;27;20:12;5:2;42559:38:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;42559:38:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;42559:38:0;;-1:-1:-1;42608:40:0;42635:7;:5;:7::i;:::-;-1:-1:-1;;;;;42608:26:0;;;42644:3;42608:40;:26;:40;:::i;:::-;22176:1;42465:191;:::o;30446:22::-;;;-1:-1:-1;;;30446:22:0;;;;;:::o;22718:140::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;22817:1;22801:6;;22780:40;;22801:6;;;;-1:-1:-1;;;;;22801:6:0;;22780:40;;22817:1;;22780:40;22848:1;22831:19;;-1:-1:-1;;;;;;22831:19:0;;;22718:140::o;30412:27::-;;;-1:-1:-1;;;30412:27:0;;;;;:::o;21907:79::-;21945:7;21972:6;;;;-1:-1:-1;;;;;21972:6:0;;21907:79::o;22273:94::-;22313:4;22353:6;;;;;-1:-1:-1;;;;;22353:6:0;22337:12;:10;:12::i;:::-;-1:-1:-1;;;;;22337:22:0;;22330:29;;22273:94;:::o;42219:238::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;42355:5;42339:13;:21;;;42295:119;;;;;-1:-1:-1;;;42295:119:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;42425:8;:24;;;;;;-1:-1:-1;;;42425:24:0;-1:-1:-1;;;;42425:24:0;;;;;;;;;42219:238::o;21402:29::-;;;;;;-1:-1:-1;;;;;21402:29:0;;:::o;31940:1451::-;32250:7;19542:11;;;;19534:55;;;;;-1:-1:-1;;;19534:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;19681:5;19667:19;;-1:-1:-1;;19667:19:0;;;;;-1:-1:-1;;;31256:7:0;;19667:19;31256:7;31252:102;;;31280:28;;;-1:-1:-1;;;31280:28:0;;;;;;;;;;;;-1:-1:-1;;;31280:28:0;;;;;;;;;;;;;;31252:102;32270:16;-1:-1:-1;;;;;32301:39:0;;32297:491;;32377:1;32365:9;:13;32357:45;;;;;-1:-1:-1;;;32357:45:0;;;;;;;;;;;;-1:-1:-1;;;32357:45:0;;;;;;;;;;;;;;;-1:-1:-1;32428:9:0;32297:491;;;32478:9;:14;32470:42;;;;;-1:-1:-1;;;32470:42:0;;;;;;;;;;;;-1:-1:-1;;;32470:42:0;;;;;;;;;;;;;;;32545:1;32535:7;:11;32527:49;;;;;-1:-1:-1;;;32527:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;32591:152;-1:-1:-1;;;;;32591:50:0;;32660:10;32697:4;32721:7;32591:152;:50;:152;:::i;:::-;-1:-1:-1;32769:7:0;32297:491;32800:16;32819:194;32847:25;32887:12;32914:8;32937:16;32968:11;32994:8;;32819:194;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;32819:13:0;;-1:-1:-1;;;32819:194:0:i;:::-;32800:213;;33044:14;33032:8;:26;;33024:57;;;;;-1:-1:-1;;;33024:57:0;;;;;;;;;;;;-1:-1:-1;;;33024:57:0;;;;;;;;;;;;;;;33123:23;33149:41;33167:12;33181:8;33149:17;:41::i;:::-;33123:67;;33203:123;33251:10;33276:39;33289:8;33299:15;33276:12;:39::i;:::-;-1:-1:-1;;;;;33203:33:0;;;:123;;:33;:123;:::i;:::-;33344:39;33357:8;33367:15;33344:12;:39::i;:::-;33337:46;;;;;19847:11;:18;;-1:-1:-1;;19847:18:0;19861:4;19847:18;;;31940:1451;;-1:-1:-1;;;;;;;;31940:1451:0:o;23013:117::-;22119:9;:7;:9::i;:::-;22111:54;;;;;-1:-1:-1;;;22111:54:0;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;22111:54:0;;;;;;;;;;;;;;;23094:28;23113:8;23094:18;:28::i;:::-;23013:117;:::o;11877:159::-;12019:7;11877:159;;;;:::o;14023:247::-;14193:58;;;-1:-1:-1;;;;;14193:58:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;14193:58:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;14140:122:0;;14173:5;;14140:18;:122::i;20659:98::-;20739:10;20659:98;:::o;14278:284::-;14475:68;;;-1:-1:-1;;;;;14475:68:0;;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;14475:68:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;14422:132:0;;14455:5;;14422:18;:132::i;:::-;14278:284;;;;:::o;33684:1513::-;33930:7;33950:23;33984:25;34021:24;34047;34075:52;34104:12;34075:14;:52::i;:::-;34020:107;;;;34187:16;-1:-1:-1;;;;;34158:45:0;:25;-1:-1:-1;;;;;34158:45:0;;;:107;;;;;34249:16;-1:-1:-1;;;;;34220:45:0;:25;-1:-1:-1;;;;;34220:45:0;;;34158:107;34140:576;;;34368:218;34397:25;34441:12;34472:7;34498:16;34533:11;34563:8;34368:10;:218::i;:::-;34329:257;;-1:-1:-1;34329:257:0;-1:-1:-1;34140:576:0;;;34639:25;34619:45;;34697:7;34679:25;;34140:576;34800:20;34822;34846:152;34878:17;34910:16;34941;34972:15;34846:17;:152::i;:::-;34799:199;;;;35031:158;35061:16;35096;35131:12;35162;35031:11;:158::i;:::-;35011:178;33684:1513;-1:-1:-1;;;;;;;;;;;;;33684:1513:0:o;41732:479::-;41855:23;41963:8;;41909:94;;41936:36;;41949:12;;-1:-1:-1;;;41963:8:0;;;;41936:12;:36::i;:::-;41987:5;41909:12;:94::i;:::-;41891:112;-1:-1:-1;42020:20:0;42016:61;;-1:-1:-1;42064:1:0;42057:8;;42016:61;42089:114;-1:-1:-1;;;;;42089:42:0;;30528;42177:15;42089:114;:42;:114;:::i;:::-;41732:479;;;;:::o;6077:136::-;6135:7;6162:43;6166:1;6169;6162:43;;;;;;;;;;;;;;;;;:3;:43::i;:::-;6155:50;6077:136;-1:-1:-1;;;6077:136:0:o;23236:274::-;-1:-1:-1;;;;;23332:22:0;;23310:110;;;;-1:-1:-1;;;23310:110:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23457:6;;;23436:38;;-1:-1:-1;;;;;23436:38:0;;;;23457:6;;;;;;23436:38;;;23485:6;:17;;-1:-1:-1;;;;;23485:17:0;;;;;-1:-1:-1;;;;;;23485:17:0;;;;;;;;;23236:274::o;16633:1176::-;17237:27;17245:5;-1:-1:-1;;;;;17237:25:0;;:27::i;:::-;17229:71;;;;;-1:-1:-1;;;17229:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;17374:12;17388:23;17423:5;-1:-1:-1;;;;;17415:19:0;17435:4;17415:25;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;17415:25:0;;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;17373:67:0;;;;17459:7;17451:52;;;;;-1:-1:-1;;;17451:52:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17520:17;;:21;17516:286;;17693:10;17682:30;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17682:30:0;17656:134;;;;-1:-1:-1;;;17656:134:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33399:277;33495:14;33511;33543:22;33583:12;33543:53;;33616:7;-1:-1:-1;;;;;33616:14:0;;:16;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;33616:16:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;33616:16:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;33616:16:0;33652;;;-1:-1:-1;;;33652:16:0;;;;33616;;-1:-1:-1;;;;;;33652:14:0;;;;;:16;;;;;33616;;33652;;;;;;;;:14;:16;;;5:2:-1;;;;30:1;27;20:12;5:2;33652:16:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;33652:16:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;33652:16:0;33399:277;;33652:16;;-1:-1:-1;;;33399:277:0:o;36629:1613::-;36868:20;;;-1:-1:-1;;;;;36962:31:0;;36958:300;;-1:-1:-1;37024:7:0;36958:300;;;37090:17;37123:51;-1:-1:-1;;;;;37123:21:0;;37153:16;37064;37123:51;:21;:51;:::i;:::-;37189:57;-1:-1:-1;;;;;37189:21:0;;37219:16;37238:7;37189:57;:21;:57;:::i;:::-;36958:300;;37271:15;37288;37307:28;37322:12;37307:14;:28::i;:::-;37456:31;;;-1:-1:-1;;;37456:31:0;;37481:4;37456:31;;;;;;37270:65;;-1:-1:-1;37270:65:0;;-1:-1:-1;37270:65:0;;;;37346:13;;-1:-1:-1;;;;;37456:16:0;;;;;:31;;;;;;;;;;;;;;:16;:31;;;5:2:-1;;;;30:1;27;20:12;5:2;37456:31:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;37456:31:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;37456:31:0;37524;;;-1:-1:-1;;;37524:31:0;;37549:4;37524:31;;;;;;37456;;-1:-1:-1;37498:23:0;;-1:-1:-1;;;;;37524:16:0;;;;;:31;;;;;37456;;37524;;;;;;;:16;:31;;;5:2:-1;;;;30:1;27;20:12;5:2;37524:31:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;37524:31:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;37524:31:0;37587:49;;;;37524:31;;-1:-1:-1;37569:12:0;;-1:-1:-1;;;;;37587:16:0;;;37610:11;;37623:12;;37587:49;;;37524:31;37587:49;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;37587:49:0;;;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;37568:68:0;;;37655:7;37647:43;;;;;-1:-1:-1;;;37647:43:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;37703:21;37727:76;37777:15;37727:6;-1:-1:-1;;;;;37727:16:0;;37752:4;37727:31;;;;;;;;;;;;;-1:-1:-1;;;;;37727:31:0;-1:-1:-1;;;;;37727:31:0;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;37727:31:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;37727:31:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;37727:31:0;;:76;:35;:76;:::i;:::-;37703:100;;37814:21;37838:76;37888:15;37838:6;-1:-1:-1;;;;;37838:16:0;;37863:4;37838:31;;;;;;;;;;;;;-1:-1:-1;;;;;37838:31:0;-1:-1:-1;;;;;37838:31:0;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;37838:76:0;37814:100;;37947:13;37931;:29;37927:235;;;37992:13;37977:28;;38040:7;38020:27;;37927:235;;;38095:13;38080:28;;38143:7;38123:27;;37927:235;38197:1;38182:12;:16;38174:60;;;;;-1:-1:-1;;;38174:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;36629:1613;;;;;;;;;;;;;;;;;;;:::o;38250:1343::-;38541:67;;;-1:-1:-1;;;38541:67:0;;-1:-1:-1;;;;;38541:67:0;;;;;;;;;;;;;;;38435:20;;;;;;30677:42;;38541:31;;:67;;;;;;;;;;;;;;;30677:42;38541:67;;;5:2:-1;;;;30:1;27;20:12;5:2;38541:67:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38541:67:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;38541:67:0;38663:18;;;-1:-1:-1;;;38663:18:0;;;;38541:67;;-1:-1:-1;38631:12:0;;;;-1:-1:-1;;;;;38663:16:0;;;;;:18;;;;;;;;;;;;;;;:16;:18;;;5:2:-1;;;;30:1;27;20:12;5:2;38663:18:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38663:18:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;38663:18:0;;;;;;;38630:51;;;;;-1:-1:-1;38630:51:0;;-1:-1:-1;;;;;;38696:38:0;;;;;;;38692:894;;;38751:20;38774:36;38796:4;38802:7;38774:21;:36::i;:::-;38751:59;;38899:1;38883:12;:17;38879:52;;38917:14;:7;38929:1;38917:14;:11;:14;:::i;:::-;38902:29;;38879:52;38961:130;38992:18;39029:16;39064:12;38961;:130::i;:::-;38946:145;-1:-1:-1;39121:25:0;:7;39133:12;39121:25;:11;:25;:::i;:::-;39106:40;;38692:894;;;;39179:20;39202:36;39224:4;39230:7;39202:21;:36::i;:::-;39179:59;;39327:1;39311:12;:17;39307:52;;39345:14;:7;39357:1;39345:14;:11;:14;:::i;:::-;39330:29;;39307:52;39389:130;39420:18;39457:16;39492:12;39389;:130::i;:::-;39374:145;-1:-1:-1;39549:25:0;:7;39561:12;39549:25;:11;:25;:::i;:::-;39534:40;;38692:894;;38250:1343;;;;;;;;;;:::o;35205:1416::-;35383:7;35403:63;-1:-1:-1;;;;;35403:36:0;;30816:42;35383:7;35403:63;:36;:63;:::i;:::-;35477;-1:-1:-1;;;;;35477:36:0;;30816:42;35538:1;35477:63;:36;:63;:::i;:::-;35553:111;-1:-1:-1;;;;;35553:36:0;;30816:42;35641:12;35553:111;:36;:111;:::i;:::-;35675;-1:-1:-1;;;;;35675:36:0;;30816:42;35763:12;35675:111;:36;:111;:::i;:::-;35848:250;;;-1:-1:-1;;;35848:250:0;;-1:-1:-1;;;;;35848:250:0;;;;;;;;;;;;;;;;;;;;;;;;;36019:1;35848:250;;;;;;;;;;36059:4;35848:250;;;;-1:-1:-1;;;35848:250:0;;;;;;35800:15;;;;;;30816:42;;35848:40;;:250;;;;;;;;;;;;;;;35800:15;30816:42;35848:250;;;5:2:-1;;;;30:1;27;20:12;5:2;35848:250:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;35848:250:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;35848:250:0;;;;;;;;;;;;;-1:-1:-1;35848:250:0;;-1:-1:-1;35848:250:0;-1:-1:-1;36191:1:0;36163:25;:12;35848:250;36163:25;:16;:25;:::i;:::-;:29;36159:187;;;36209:125;36265:10;36294:25;:12;36311:7;36294:25;:16;:25;:::i;:::-;-1:-1:-1;;;;;36209:37:0;;;:125;;:37;:125;:::i;:::-;36437:1;36409:25;:12;36426:7;36409:25;:16;:25;:::i;:::-;:29;36405:187;;;36455:125;36511:10;36540:25;:12;36557:7;36540:25;:16;:25;:::i;:::-;-1:-1:-1;;;;;36455:37:0;;;:125;;:37;:125;:::i;:::-;36611:2;35205:1416;-1:-1:-1;;;;;;;35205:1416:0:o;7027:471::-;7085:7;7330:6;7326:47;;-1:-1:-1;7360:1:0;7353:8;;7326:47;7397:5;;;7401:1;7397;:5;:1;7421:5;;;;;:10;7413:56;;;;-1:-1:-1;;;7413:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7966:132;8024:7;8051:39;8055:1;8058;8051:39;;;;;;;;;;;;;;;;;:3;:39::i;6550:226::-;6670:7;6706:12;6698:6;;;;6690:29;;;;-1:-1:-1;;;6690:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;6690:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;6742:5:0;;;6550:226::o;11001:659::-;11061:4;11560:20;;11390:66;11609:23;;;;;;:42;;-1:-1:-1;11636:15:0;;;11609:42;11601:51;11001:659;-1:-1:-1;;;;11001:659:0:o;14570:706::-;14988:10;;;14987:62;;-1:-1:-1;15004:39:0;;;-1:-1:-1;;;15004:39:0;;15028:4;15004:39;;;;-1:-1:-1;;;;;15004:39:0;;;;;;;;;:15;;;;;;:39;;;;;;;;;;;;;;;:15;:39;;;5:2:-1;;;;30:1;27;20:12;5:2;15004:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;15004:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;15004:39:0;:44;14987:62;14965:166;;;;-1:-1:-1;;;14965:166:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15195:62;;;-1:-1:-1;;;;;15195:62:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;15195:62:0;;;;;;;;25:18:-1;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;15142:126:0;;15175:5;;15142:18;:126::i;39601:345::-;39717:7;39934:4;39762:169;39911:19;:9;39925:4;39911:19;:13;:19;:::i;:::-;39762:126;39814:59;39850:22;:9;39864:7;39850:22;:13;:22;:::i;:::-;39828:19;:6;39839:7;39828:19;:10;:19;:::i;:::-;39814:9;;39828:44;39814:59;:13;:59;:::i;:::-;39762:33;:126::i;:::-;:148;:169;:148;:169;:::i;:::-;:176;;;;;;;39601:345;-1:-1:-1;;;39601:345:0:o;40275:1176::-;40439:19;40504:23;-1:-1:-1;;;;;40475:52:0;:25;-1:-1:-1;;;;;40475:52:0;;40471:104;;;-1:-1:-1;40551:12:0;40544:19;;40471:104;40585:109;-1:-1:-1;;;;;40585:45:0;;30816:42;40682:1;40585:109;:45;:109;:::i;:::-;40705:120;-1:-1:-1;;;;;40705:45:0;;30816:42;40802:12;40705:120;:45;:120;:::i;:::-;40853;;;-1:-1:-1;;;40853:120:0;;-1:-1:-1;;;;;40853:120:0;;;;;;;;;;;;;;;40838:12;;30677:42;;40853:31;;:120;;;;;;;;;;;;;;;30677:42;40853:120;;;5:2:-1;;;;30:1;27;20:12;5:2;40853:120:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;40853:120:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;40853:120:0;;-1:-1:-1;;;;;;40992:18:0;;40984:48;;;;;-1:-1:-1;;;40984:48:0;;;;;;;;;;;;-1:-1:-1;;;40984:48:0;;;;;;;;;;;;;;;41067:16;;;41081:1;41067:16;;;41043:21;41067:16;;;;;41043:21;41067:16;;;;;105:10:-1;41067:16:0;88:34:-1;136:17;;-1:-1;41067:16:0;41043:40;;41104:25;41094:4;41099:1;41094:7;;;;;;;;;;;;;:35;-1:-1:-1;;;;;41094:35:0;;;-1:-1:-1;;;;;41094:35:0;;;;;41150:23;41140:4;41145:1;41140:7;;;;;;;;-1:-1:-1;;;;;41140:33:0;;;:7;;;;;;;;;;:33;41200:162;;-1:-1:-1;;;41200:162:0;;;;;;;;41280:1;41200:162;;;;;;41323:4;41200:162;;;;;;-1:-1:-1;;;41200:162:0;;;;;;;;;;;;;;;;;;;;;30816:42;;41200:38;;41253:12;;41296:4;;41323;31023:66;41200:162;;;;;;;;;;;;;;;;;-1:-1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;41200:162:0;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;41200:162:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;41200:162:0;;;;;;39:16:-1;36:1;17:17;2:54;101:4;41200:162:0;80:15:-1;;;-1:-1;;76:31;65:43;;120:4;113:20;13:2;5:11;;2:2;;;29:1;26;19:12;2:2;41200:162:0;;;;;;;;;;;;;19:11:-1;14:3;11:20;8:2;;;44:1;41;34:12;8:2;62:21;;;;123:4;114:14;;138:31;;;135:2;;;182:1;179;172:12;135:2;219:3;213:10;331:9;325:2;311:12;307:21;289:16;285:44;282:59;261:11;247:12;244:29;233:116;230:2;;;362:1;359;352:12;230:2;373:25;;-1:-1;41200:162:0;;421:4:-1;412:14;;;;41200:162:0;;;;;412:14:-1;41200:162:0;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;41200:162:0;;;;;;;;;;;41377:1;41363:4;:11;:15;41200:179;;;;;;;;;;;;;;41186:193;;41414:1;41400:11;:15;41392:51;;;;;-1:-1:-1;;;41392:51:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;40275:1176;;;;;;;:::o;8628:379::-;8748:7;8850:12;8843:5;8835:28;;;;-1:-1:-1;;;8835:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27:10:-1;;8:100;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;8835:28:0;;8874:9;8890:1;8886;:5;;;;;;;8628:379;-1:-1:-1;;;;;8628:379:0:o;23605:335::-;23653:9;23683:1;23679;:5;23675:235;;;-1:-1:-1;23705:1:0;23741;23737;23733:5;;:9;23757:92;23768:1;23764;:5;23757:92;;;23794:1;23790:5;;23832:1;23827;23823;23819;:5;;;;;;:9;23818:15;;;;;;23814:19;;23757:92;;;23675:235;;;;23870:6;;23866:44;;-1:-1:-1;23897:1:0;23605:335;;;:::o
Swarm Source
bzzr://dd813a01da25f897d40875d57eb7a804d6845a809425938a98459b0f90ce3992
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 26 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
[ 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.