ETH Price: $1,949.44 (-1.24%)
 

Overview

ETH Balance

4.116723019004894107 ETH

Eth Value

$8,025.31 (@ $1,949.44/ETH)

Token Holdings

More Info

Private Name Tags

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Transfer225771142025-05-27 22:30:23270 days ago1748385023IN
0x8A37FaEc...d72385333
0.00005 ETH0.000053672.55586491
Swap Exact Token...150345012022-06-27 13:04:561336 days ago1656335096IN
0x8A37FaEc...d72385333
0.00823859 ETH0.0089394247.04215795
Swap Exact Token...150340352022-06-27 11:02:051336 days ago1656327725IN
0x8A37FaEc...d72385333
0.00810629 ETH0.0163383545.84454973
Swap Exact Token...150332092022-06-27 7:23:231336 days ago1656314603IN
0x8A37FaEc...d72385333
0.00815856 ETH0.0068717933.46936654
Swap Exact Token...150328542022-06-27 5:56:351336 days ago1656309395IN
0x8A37FaEc...d72385333
0.00822276 ETH0.0041707519.85806662
Swap Exact Token...150325372022-06-27 4:37:021336 days ago1656304622IN
0x8A37FaEc...d72385333
0.00817702 ETH0.0062144231.66826971
Swap Exact Token...150323162022-06-27 3:33:341336 days ago1656300814IN
0x8A37FaEc...d72385333
0.00820955 ETH0.0083279936.66457668
Swap Exact Token...150318552022-06-27 1:29:311336 days ago1656293371IN
0x8A37FaEc...d72385333
0.00823499 ETH0.0082903139.30623171
Swap Exact Token...150313432022-06-26 23:05:271336 days ago1656284727IN
0x8A37FaEc...d72385333
0.00822784 ETH0.0174191754.27176222
Swap Exact ETH F...150311202022-06-26 22:04:261337 days ago1656281066IN
0x8A37FaEc...d72385333
0.90810146 ETH0.0136758969.71558547
Swap Exact ETH F...150310912022-06-26 21:55:301337 days ago1656280530IN
0x8A37FaEc...d72385333
1.50807047 ETH0.0139649667.07895107
Swap Exact Token...150310822022-06-26 21:52:411337 days ago1656280361IN
0x8A37FaEc...d72385333
0.00807158 ETH0.0069503732.95139009
Swap Exact ETH F...150295892022-06-26 15:11:051337 days ago1656256265IN
0x8A37FaEc...d72385333
0.06821863 ETH0.0149348768.20915296
Swap Exact ETH F...150294202022-06-26 14:25:271337 days ago1656253527IN
0x8A37FaEc...d72385333
0.8381272 ETH0.0088577845.15430431
Swap Exact Token...150293982022-06-26 14:20:481337 days ago1656253248IN
0x8A37FaEc...d72385333
0.00812812 ETH0.0157714765.56969874
Swap Exact Token...150293332022-06-26 14:03:561337 days ago1656252236IN
0x8A37FaEc...d72385333
0.00813882 ETH0.0131999167.33585027
Swap Exact Token...150289142022-06-26 12:13:081337 days ago1656245588IN
0x8A37FaEc...d72385333
0.00783735 ETH0.013941190.53430578
Swap Exact ETH F...150286012022-06-26 10:43:311337 days ago1656240211IN
0x8A37FaEc...d72385333
0.06101794 ETH0.0052064324.84177979
Swap Exact ETH F...150285612022-06-26 10:33:011337 days ago1656239581IN
0x8A37FaEc...d72385333
0.06403632 ETH0.0061225429.21285565
Swap ETH For Exa...150285522022-06-26 10:30:031337 days ago1656239403IN
0x8A37FaEc...d72385333
0.06931898 ETH0.0056332725.12151804
Swap Exact Token...150232582022-06-25 10:29:071338 days ago1656152947IN
0x8A37FaEc...d72385333
0.00816116 ETH0.0087290936.14246917
Swap Exact ETH F...150225342022-06-25 7:15:471338 days ago1656141347IN
0x8A37FaEc...d72385333
1.00813382 ETH0.0048321833.7594267
Swap Exact Token...150224042022-06-25 6:39:501338 days ago1656139190IN
0x8A37FaEc...d72385333
0.0082424 ETH0.0052537834.60852129
Swap Exact Token...150221842022-06-25 5:38:501338 days ago1656135530IN
0x8A37FaEc...d72385333
0.0081536 ETH0.0051572225.29897347
Swap Exact ETH F...150204072022-06-24 21:49:491339 days ago1656107389IN
0x8A37FaEc...d72385333
1.00815816 ETH0.0059123431.7613741
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Method Block
From
To
Transfer150345012022-06-27 13:04:561336 days ago1656335096
0x8A37FaEc...d72385333
0.00823859 ETH
Transfer150340352022-06-27 11:02:051336 days ago1656327725
0x8A37FaEc...d72385333
0.00810629 ETH
Transfer150332092022-06-27 7:23:231336 days ago1656314603
0x8A37FaEc...d72385333
1.35936843 ETH
Transfer150332092022-06-27 7:23:231336 days ago1656314603
0x8A37FaEc...d72385333
0.00815856 ETH
Transfer150332092022-06-27 7:23:231336 days ago1656314603
0x8A37FaEc...d72385333
1.367527 ETH
Transfer150328542022-06-27 5:56:351336 days ago1656309395
0x8A37FaEc...d72385333
0.00822276 ETH
Transfer150325372022-06-27 4:37:021336 days ago1656304622
0x8A37FaEc...d72385333
0.00817702 ETH
Transfer150323162022-06-27 3:33:341336 days ago1656300814
0x8A37FaEc...d72385333
0.00820955 ETH
Transfer150318552022-06-27 1:29:311336 days ago1656293371
0x8A37FaEc...d72385333
3.03112099 ETH
Transfer150318552022-06-27 1:29:311336 days ago1656293371
0x8A37FaEc...d72385333
0.00823499 ETH
Transfer150318552022-06-27 1:29:311336 days ago1656293371
0x8A37FaEc...d72385333
3.03935598 ETH
Transfer150313432022-06-26 23:05:271336 days ago1656284727
0x8A37FaEc...d72385333
0.00822784 ETH
Deposit150311202022-06-26 22:04:261337 days ago1656281066
0x8A37FaEc...d72385333
0.9 ETH
Transfer150311202022-06-26 22:04:261337 days ago1656281066
0x8A37FaEc...d72385333
0.00810146 ETH
Deposit150310912022-06-26 21:55:301337 days ago1656280530
0x8A37FaEc...d72385333
1.5 ETH
Transfer150310912022-06-26 21:55:301337 days ago1656280530
0x8A37FaEc...d72385333
0.00807047 ETH
Transfer150310822022-06-26 21:52:411337 days ago1656280361
0x8A37FaEc...d72385333
2.08648465 ETH
Transfer150310822022-06-26 21:52:411337 days ago1656280361
0x8A37FaEc...d72385333
0.00807158 ETH
Transfer150310822022-06-26 21:52:411337 days ago1656280361
0x8A37FaEc...d72385333
2.09455624 ETH
Deposit150295892022-06-26 15:11:051337 days ago1656256265
0x8A37FaEc...d72385333
0.06 ETH
Transfer150295892022-06-26 15:11:051337 days ago1656256265
0x8A37FaEc...d72385333
0.00821863 ETH
Deposit150294202022-06-26 14:25:271337 days ago1656253527
0x8A37FaEc...d72385333
0.83 ETH
Transfer150294202022-06-26 14:25:271337 days ago1656253527
0x8A37FaEc...d72385333
0.0081272 ETH
Transfer150293982022-06-26 14:20:481337 days ago1656253248
0x8A37FaEc...d72385333
0.94186536 ETH
Transfer150293982022-06-26 14:20:481337 days ago1656253248
0x8A37FaEc...d72385333
0.00812812 ETH
View All Internal Transactions
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
MistXRouter

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 1000 runs

Other Settings:
default evmVersion
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

import './interfaces/IERC20.sol';
import './interfaces/IUniswap.sol';
import './interfaces/IWETH.sol';
import './libraries/SafeERC20.sol';
import './libraries/TransferHelper.sol';
import './libraries/Managable.sol';

/// @author Nathan Worsley (https://github.com/CodeForcer)
/// @title MistX Router with generic Uniswap-style support
/// @notice If you came here just to copy my stuff, you NGMI - learn to code!
contract MistXRouter is Managable {
  /***********************
  + Global Settings      +
  ***********************/

  using SafeERC20 for IERC20;

  // Managers are permissioned for critical functionality
  mapping (address => bool) public managers;
  address public tipjar;

  address public immutable WETH;
  address public immutable factory;
  bytes32 public immutable initHash;

  receive() external payable {}
  fallback() external payable {}

  constructor(
    address _WETH,
    address _factory,
    bytes32 _initHash,
    address _owner,
    address _tipjar
  ) Managable(_owner) {
    WETH = _WETH;
    factory = _factory;
    initHash = _initHash;
    managers[_owner] = true;
    tipjar = _tipjar;
  }

  /***********************
  + Structures           +
  ***********************/

  struct Swap {
    uint256 amount0;
    uint256 amount1;
    address[] path;
    address to;
    uint256 deadline;
  }

  /***********************
  + Swap wrappers        +
  ***********************/

  function swapExactETHForTokens(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    deposit(_bribe);

    require(_swap.path[0] == WETH, 'MistXRouter: INVALID_PATH');
    uint amountIn = msg.value - _bribe;
    IWETH(WETH).deposit{value: amountIn}();
    assert(IWETH(WETH).transfer(pairFor(_swap.path[0], _swap.path[1]), amountIn));
    uint balanceBefore = IERC20(_swap.path[_swap.path.length - 1]).balanceOf(_swap.to);
    _swapSupportingFeeOnTransferTokens(_swap.path, _swap.to);
    require(
      IERC20(_swap.path[_swap.path.length - 1]).balanceOf(_swap.to) - balanceBefore >= _swap.amount1,
      'MistXRouter: INSUFFICIENT_OUTPUT_AMOUNT'
    );
  }

  function swapETHForExactTokens(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    deposit(_bribe);

    require(_swap.path[0] == WETH, 'UniswapV2Router: INVALID_PATH');
    uint[] memory amounts = getAmountsIn(_swap.amount1, _swap.path);
    require(amounts[0] <= msg.value - _bribe, 'UniswapV2Router: EXCESSIVE_INPUT_AMOUNT');
    IWETH(WETH).deposit{value: amounts[0]}();
    assert(IWETH(WETH).transfer(pairFor(_swap.path[0], _swap.path[1]), amounts[0]));
    _swapPath(amounts, _swap.path, _swap.to);

    // refund dust eth, if any
    if (msg.value - _bribe > amounts[0]) {
      (bool success, ) = msg.sender.call{value: msg.value - _bribe - amounts[0]}(new bytes(0));
      require(success, 'safeTransferETH: ETH transfer failed');
    }
  }

  function swapExactTokensForTokens(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    deposit(_bribe);

    TransferHelper.safeTransferFrom(
      _swap.path[0], msg.sender, pairFor(_swap.path[0], _swap.path[1]), _swap.amount0
    );
    uint balanceBefore = IERC20(_swap.path[_swap.path.length - 1]).balanceOf(_swap.to);
    _swapSupportingFeeOnTransferTokens(_swap.path, _swap.to);
    require(
      IERC20(_swap.path[_swap.path.length - 1]).balanceOf(_swap.to) - balanceBefore >= _swap.amount1,
      'MistXRouter: INSUFFICIENT_OUTPUT_AMOUNT'
    );
  }

  function swapTokensForExactTokens(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    deposit(_bribe);

    uint[] memory amounts = getAmountsIn(_swap.amount0, _swap.path);
    require(amounts[0] <= _swap.amount1, 'MistXRouter: EXCESSIVE_INPUT_AMOUNT');
    TransferHelper.safeTransferFrom(
      _swap.path[0], msg.sender, pairFor(_swap.path[0], _swap.path[1]), amounts[0]
    );
    _swapPath(amounts, _swap.path, _swap.to);
  }

  function swapTokensForExactETH(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    require(_swap.path[_swap.path.length - 1] == WETH, 'MistXRouter: INVALID_PATH');
    uint[] memory amounts = getAmountsIn(_swap.amount0, _swap.path);
    require(amounts[0] <= _swap.amount1, 'MistXRouter: EXCESSIVE_INPUT_AMOUNT');
    TransferHelper.safeTransferFrom(
        _swap.path[0], msg.sender, pairFor(_swap.path[0], _swap.path[1]), amounts[0]
    );
    _swapPath(amounts, _swap.path, address(this));
    IWETH(WETH).withdraw(amounts[amounts.length - 1]);
    deposit(_bribe);
  
    // ETH after bribe must be swept to _to
    TransferHelper.safeTransferETH(_swap.to, amounts[amounts.length - 1] - _bribe);
  }

  function swapExactTokensForETH(
    Swap calldata _swap,
    uint256 _bribe
  ) external payable {
    require(_swap.path[_swap.path.length - 1] == WETH, 'MistXRouter: INVALID_PATH');
    TransferHelper.safeTransferFrom(
      _swap.path[0], msg.sender, pairFor(_swap.path[0], _swap.path[1]), _swap.amount0
    );
    _swapSupportingFeeOnTransferTokens(_swap.path, address(this));
    uint amountOut = IERC20(WETH).balanceOf(address(this));
    require(amountOut >= _swap.amount1, 'MistXRouter: INSUFFICIENT_OUTPUT_AMOUNT');
    IWETH(WETH).withdraw(amountOut);

    deposit(_bribe);
  
    // ETH after bribe must be swept to _to
    TransferHelper.safeTransferETH(_swap.to, amountOut - _bribe);
  }

  /***********************
  + Library              +
  ***********************/

  // calculates the CREATE2 address for a pair without making any external calls
  function pairFor(address tokenA, address tokenB) internal view returns (address pair) {
    (address token0, address token1) = sortTokens(tokenA, tokenB);
    uint hashed = uint(keccak256(abi.encodePacked(
      hex'ff',
      factory,
      keccak256(abi.encodePacked(token0, token1)),
      initHash // init code hash
    )));
    pair = address(uint160(hashed));
  }

  function sortTokens(address tokenA, address tokenB) internal pure returns (address token0, address token1) {
    require(tokenA != tokenB, 'MistXLibrary: IDENTICAL_ADDRESSES');
    (token0, token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
    require(token0 != address(0), 'MistXLibrary: ZERO_ADDRESS');
  }

  // fetches and sorts the reserves for a pair
  function getReserves(address tokenA, address tokenB) internal view returns (uint reserveA, uint reserveB) {
    (address token0,) = sortTokens(tokenA, tokenB);
    (uint reserve0, uint reserve1,) = IUniswapV2Pair(pairFor(tokenA, tokenB)).getReserves();
    (reserveA, reserveB) = tokenA == token0 ? (reserve0, reserve1) : (reserve1, reserve0);
  }

  // given some amount of an asset and pair reserves, returns an equivalent amount of the other asset
  function quote(uint amountA, uint reserveA, uint reserveB) internal pure returns (uint amountB) {
    require(amountA > 0, 'MistXLibrary: INSUFFICIENT_AMOUNT');
    require(reserveA > 0 && reserveB > 0, 'MistXLibrary: INSUFFICIENT_LIQUIDITY');
    amountB = amountA * (reserveB) / reserveA;
  }

  // given an input amount of an asset and pair reserves, returns the maximum output amount of the other asset
  function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) internal pure returns (uint amountOut) {
    require(amountIn > 0, 'MistXLibrary: INSUFFICIENT_INPUT_AMOUNT');
    require(reserveIn > 0 && reserveOut > 0, 'MistXLibrary: INSUFFICIENT_LIQUIDITY');
    uint amountInWithFee = amountIn * 997;
    uint numerator = amountInWithFee * reserveOut;
    uint denominator = reserveIn * 1000 + amountInWithFee;
    amountOut = numerator / denominator;
  }

  // given an output amount of an asset and pair reserves, returns a required input amount of the other asset
  function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) internal pure returns (uint amountIn) {
    require(amountOut > 0, 'MistXLibrary: INSUFFICIENT_OUTPUT_AMOUNT');
    require(reserveIn > 0 && reserveOut > 0, 'MistXLibrary: INSUFFICIENT_LIQUIDITY');
    uint numerator = reserveIn * amountOut * 1000;
    uint denominator = (reserveOut - amountOut) * 997;
    amountIn = (numerator / denominator) + 1;
  }

  // performs chained getAmountOut calculations on any number of pairs
  function getAmountsOut(uint amountIn, address[] memory path) internal view returns (uint[] memory amounts) {
    require(path.length >= 2, 'MistXLibrary: INVALID_PATH');
    amounts = new uint[](path.length);
    amounts[0] = amountIn;
    for (uint i; i < path.length - 1; i++) {
      (uint reserveIn, uint reserveOut) = getReserves(path[i], path[i + 1]);
      amounts[i + 1] = getAmountOut(amounts[i], reserveIn, reserveOut);
    }
  }

  // performs chained getAmountIn calculations on any number of pairs
  function getAmountsIn(uint amountOut, address[] memory path) internal view returns (uint[] memory amounts) {
    require(path.length >= 2, 'MistXLibrary: INVALID_PATH');
    amounts = new uint[](path.length);
    amounts[amounts.length - 1] = amountOut;
    for (uint i = path.length - 1; i > 0; i--) {
      (uint reserveIn, uint reserveOut) = getReserves(path[i - 1], path[i]);
      amounts[i - 1] = getAmountIn(amounts[i], reserveIn, reserveOut);
    }
  }

  /***********************
  + Support functions    +
  ***********************/

  function deposit(uint256 value) public payable {
    (bool sent, bytes memory data) = tipjar.call{value: value}(new bytes(0));
    require(sent, "Failed to send Ether");
  }

  function _swapSupportingFeeOnTransferTokens(
    address[] memory path,
    address _to
  ) internal virtual {
    for (uint i; i < path.length - 1; i++) {
      (address input, address output) = (path[i], path[i + 1]);
      (address token0,) = sortTokens(input, output);
      IUniswapV2Pair pair = IUniswapV2Pair(pairFor(input, output));
      uint amountInput;
      uint amountOutput;
      {
        (uint reserve0, uint reserve1,) = pair.getReserves();
        (uint reserveInput, uint reserveOutput) = input == token0 ? (reserve0, reserve1) : (reserve1, reserve0);
        amountInput = IERC20(input).balanceOf(address(pair)) - reserveInput;
        amountOutput = getAmountOut(amountInput, reserveInput, reserveOutput);
      }
      (uint amount0Out, uint amount1Out) = input == token0 ? (uint(0), amountOutput) : (amountOutput, uint(0));
      address to = i < path.length - 2 ? pairFor(output, path[i + 2]) : _to;
      pair.swap(amount0Out, amount1Out, to, new bytes(0));
    }
  }

  function _swapPath(
    uint[] memory amounts,
    address[] memory path,
    address _to
  ) internal virtual {
    for (uint i; i < path.length - 1; i++) {
      (address input, address output) = (path[i], path[i + 1]);
      (address token0,) = sortTokens(input, output);
      uint amountOut = amounts[i + 1];
      (uint amount0Out, uint amount1Out) = input == token0 ? (uint(0), amountOut) : (amountOut, uint(0));
      address to = i < path.length - 2 ? pairFor(output, path[i + 2]) : _to;
      IUniswapV2Pair(pairFor(input, output)).swap(
        amount0Out, amount1Out, to, new bytes(0)
      );
    }
  }

  /***********************
  + Administration       +
  ***********************/

  modifier onlyManager() {
    require(managers[msg.sender] == true, "Only managers can call this");
    _;
  }

  function addManager(
    address _manager
  ) external onlyOwner {
    managers[_manager] = true;
  }

  function removeManager(
    address _manager
  ) external onlyOwner {
    managers[_manager] = false;
  }

  function changeTipjar(
    address _tipjar
  ) external onlyOwner {
    tipjar = _tipjar;
  }

  function rescueStuckETH(
    uint256 _amount,
    address _to
  ) external onlyManager {
    payable(_to).transfer(_amount);
  }

  function rescueStuckToken(
    address _tokenContract,
    uint256 _value,
    address _to
  ) external onlyManager {
    IERC20(_tokenContract).safeTransfer(_to, _value);
  }
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

interface IERC20 {
  event Approval(address indexed owner, address indexed spender, uint value);
  event Transfer(address indexed from, address indexed to, uint value);

  function name() external view returns (string memory);
  function symbol() external view returns (string memory);
  function decimals() external view returns (uint8);
  function totalSupply() external view returns (uint);
  function balanceOf(address owner) external view returns (uint);
  function allowance(address owner, address spender) external view returns (uint);

  function approve(address spender, uint value) external returns (bool);
  function transfer(address to, uint value) external returns (bool);
  function transferFrom(address from, address to, uint value) external returns (bool);
}

File 3 of 8 : IUniswap.sol
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

interface IUniswapRouter {
  function WETH() external view 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 factory() external view returns (address);

  function getAmountIn(
    uint256 amountOut,
    uint256 reserveIn,
    uint256 reserveOut
  ) external pure returns (uint256 amountIn);

  function getAmountOut(
    uint256 amountIn,
    uint256 reserveIn,
    uint256 reserveOut
  ) external pure returns (uint256 amountOut);

  function getAmountsIn(
    uint256 amountOut,
    address[] memory path
  ) external view returns (uint256[] memory amounts);

  function getAmountsOut(
    uint256 amountIn,
    address[] memory path
  ) external view returns (uint256[] memory amounts);

  function quote(
    uint256 amountA,
    uint256 reserveA,
    uint256 reserveB
  ) external pure returns (uint256 amountB);

  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 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 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 swapETHForExactTokens(
    uint256 amountOut,
    address[] memory path,
    address to,
    uint256 deadline
  ) external payable returns (uint256[] memory amounts);

  function swapExactETHForTokens(
    uint256 amountOutMin,
    address[] memory path,
    address to,
    uint256 deadline
  ) external payable returns (uint256[] memory amounts);

  function swapExactTokensForETH(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] memory path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapExactTokensForTokens(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] memory path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapTokensForExactETH(
    uint256 amountOut,
    uint256 amountInMax,
    address[] memory path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapTokensForExactTokens(
    uint256 amountOut,
    uint256 amountInMax,
    address[] memory path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapExactTokensForTokensSupportingFeeOnTransferTokens(
    uint amountIn,
    uint amountOutMin,
    address[] calldata path,
    address to,
    uint deadline
  ) external;

  function swapExactETHForTokensSupportingFeeOnTransferTokens(
    uint amountOutMin,
    address[] calldata path,
    address to,
    uint deadline
  ) external payable;

  function swapExactTokensForETHSupportingFeeOnTransferTokens(
    uint amountIn,
    uint amountOutMin,
    address[] calldata path,
    address to,
    uint deadline
  ) external;

  receive() external payable;
}

interface IUniswapV2Pair {
  event Approval(address indexed owner, address indexed spender, uint value);
  event Transfer(address indexed from, address indexed to, uint value);

  function name() external pure returns (string memory);
  function symbol() external pure returns (string memory);
  function decimals() external pure returns (uint8);
  function totalSupply() external view returns (uint);
  function balanceOf(address owner) external view returns (uint);
  function allowance(address owner, address spender) external view returns (uint);

  function approve(address spender, uint value) external returns (bool);
  function transfer(address to, uint value) external returns (bool);
  function transferFrom(address from, address to, uint value) external returns (bool);

  function DOMAIN_SEPARATOR() external view returns (bytes32);
  function PERMIT_TYPEHASH() external pure returns (bytes32);
  function nonces(address owner) external view returns (uint);

  function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;

  event Mint(address indexed sender, uint amount0, uint amount1);
  event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
  event Swap(
    address indexed sender,
    uint amount0In,
    uint amount1In,
    uint amount0Out,
    uint amount1Out,
    address indexed to
  );

  event Sync(uint112 reserve0, uint112 reserve1);

  function MINIMUM_LIQUIDITY() external pure returns (uint);
  function factory() external view returns (address);
  function token0() external view returns (address);
  function token1() external view returns (address);
  function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
  function price0CumulativeLast() external view returns (uint);
  function price1CumulativeLast() external view returns (uint);
  function kLast() external view returns (uint);

  function mint(address to) external returns (uint liquidity);
  function burn(address to) external returns (uint amount0, uint amount1);
  function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
  function skim(address to) external;
  function sync() external;

  function initialize(address, address) external;
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

interface IWETH {
  function deposit() external payable;
  function transfer(address to, uint value) external returns (bool);
  function withdraw(uint) external;
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

import "../interfaces/IERC20.sol";
import "./Address.sol";

library SafeERC20 {
  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 {
    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) + 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) - value;
    _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
  }

  function _callOptionalReturn(IERC20 token, bytes memory data) private {
    bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
    if (returndata.length > 0) {
      require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
    }
  }
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

// helper methods for interacting with ERC20 tokens and sending ETH that do not consistently return true/false
library TransferHelper {
  function safeApprove(
    address token,
    address to,
    uint256 value
  ) internal {
    // bytes4(keccak256(bytes('approve(address,uint256)')));
    (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0x095ea7b3, to, value));
    require(
      success && (data.length == 0 || abi.decode(data, (bool))),
      'TransferHelper::safeApprove: approve failed'
    );
  }

  function safeTransfer(
    address token,
    address to,
    uint256 value
  ) internal {
    // bytes4(keccak256(bytes('transfer(address,uint256)')));
    (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0xa9059cbb, to, value));
    require(
      success && (data.length == 0 || abi.decode(data, (bool))),
      'TransferHelper::safeTransfer: transfer failed'
    );
  }

  function safeTransferFrom(
    address token,
    address from,
    address to,
    uint256 value
  ) internal {
    // bytes4(keccak256(bytes('transferFrom(address,address,uint256)')));
    (bool success, bytes memory data) = token.call(abi.encodeWithSelector(0x23b872dd, from, to, value));
    require(
      success && (data.length == 0 || abi.decode(data, (bool))),
      'TransferHelper::transferFrom: transferFrom failed'
    );
  }

  function safeTransferETH(address to, uint256 value) internal {
    (bool success, ) = to.call{value: value}(new bytes(0));
    require(success, 'TransferHelper::safeTransferETH: ETH transfer failed');
  }
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

import "../libraries/SafeERC20.sol";
import "../interfaces/IERC20.sol";
import "../interfaces/IWETH.sol";


abstract contract Managable {
  using SafeERC20 for IERC20;

  address public owner;

  /***********************
  + Construct / Kill     +
  ***********************/

  constructor(address _owner) {
    owner = _owner;
  }

  function destroy(address payable recipient) external onlyOwner {

    selfdestruct(recipient);
  }

  /***********************
  + Management          +
  ***********************/

  modifier onlyOwner() {
    require(msg.sender == owner, "Only the owner can call this");
    _;
  }

  function changeOwner(
    address _newOwner
  ) external onlyOwner {
    owner = _newOwner;
  }
}

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.4;

library Address {
    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;
      assembly { codehash := extcodehash(account) }
      return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
      require(address(this).balance >= amount, "Address: insufficient balance");

      (bool success, ) = recipient.call{ value: amount }("");
      require(success, "Address: unable to send value, recipient may have reverted");
    }

    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
      return _functionCallWithValue(target, data, 0, errorMessage);
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
      return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
      require(address(this).balance >= value, "Address: insufficient balance for call");
      return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
      require(isContract(target), "Address: call to non-contract");

      (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
      if (success) {
        return returndata;
      } else {
        if (returndata.length > 0) {
          assembly {
            let returndata_size := mload(returndata)
            revert(add(32, returndata), returndata_size)
          }
        } else {
          revert(errorMessage);
        }
      }
    }
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 1000
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "metadata": {
    "useLiteralContent": true
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"address","name":"_WETH","type":"address"},{"internalType":"address","name":"_factory","type":"address"},{"internalType":"bytes32","name":"_initHash","type":"bytes32"},{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address","name":"_tipjar","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"stateMutability":"payable","type":"fallback"},{"inputs":[],"name":"WETH","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_manager","type":"address"}],"name":"addManager","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_newOwner","type":"address"}],"name":"changeOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tipjar","type":"address"}],"name":"changeTipjar","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address payable","name":"recipient","type":"address"}],"name":"destroy","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"initHash","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"managers","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_manager","type":"address"}],"name":"removeManager","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"rescueStuckETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenContract","type":"address"},{"internalType":"uint256","name":"_value","type":"uint256"},{"internalType":"address","name":"_to","type":"address"}],"name":"rescueStuckToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapETHForExactTokens","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapExactETHForTokens","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapExactTokensForETH","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapExactTokensForTokens","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapTokensForExactETH","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"},{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct MistXRouter.Swap","name":"_swap","type":"tuple"},{"internalType":"uint256","name":"_bribe","type":"uint256"}],"name":"swapTokensForExactTokens","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"tipjar","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60e06040523480156200001157600080fd5b5060405162003370380380620033708339810160408190526200003491620000c5565b600080546001600160a01b03199081166001600160a01b039485169081178355606097881b6001600160601b03199081166080529690971b90951660a05260c093909352938252600160208190526040909220805460ff19169092179091556002805490921692169190911790556200012b565b80516001600160a01b0381168114620000c057600080fd5b919050565b600080600080600060a08688031215620000dd578081fd5b620000e886620000a8565b9450620000f860208701620000a8565b9350604086015192506200010f60608701620000a8565b91506200011f60808701620000a8565b90509295509295909350565b60805160601c60a05160601c60c0516131b4620001bc6000396000818161031b0152611d6b01526000818161035d0152611d300152600081816102d40152818161057e015281816107840152818161089b0152818161093901528181610bed015281816110db015281816111a2015281816112160152818161163201528181611795015261183101526131b46000f3fe60806040526004361061014a5760003560e01c8063a8261e9b116100b4578063bce633c51161006e578063c463a5bf11610056578063c463a5bf1461037f578063f4d34ca61461039f578063fdff9b4d146103bf57005b8063bce633c514610309578063c45a01551461034b57005b8063ac18de431161009c578063ac18de43146102a2578063ad5c4648146102c2578063b6b55f25146102f657005b8063a8261e9b1461026f578063a9483edc1461028f57005b806354d51de4116101055780638da5cb5b116100ed5780638da5cb5b146101ff578063982ea0201461023c578063a6f9dae11461024f57005b806354d51de4146101d957806359848cc4146101ec57005b80632d06177a116101335780632d06177a14610193578063465406a7146101b35780634f66c92a146101c657005b8062f55d9d146101535780632c29cb301461017357005b3661015157005b005b34801561015f57600080fd5b5061015161016e366004612e46565b6103ff565b34801561017f57600080fd5b5061015161018e366004612e46565b61046a565b34801561019f57600080fd5b506101516101ae366004612e46565b6104f3565b6101516101c1366004612eca565b610574565b6101516101d4366004612eca565b61092f565b6101516101e7366004612eca565b610cfb565b6101516101fa366004612eca565b610fb9565b34801561020b57600080fd5b5060005461021f906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b61015161024a366004612eca565b6110c8565b34801561025b57600080fd5b5061015161026a366004612e46565b611596565b34801561027b57600080fd5b5060025461021f906001600160a01b031681565b61015161029d366004612eca565b61161f565b3480156102ae57600080fd5b506101516102bd366004612e46565b611a9f565b3480156102ce57600080fd5b5061021f7f000000000000000000000000000000000000000000000000000000000000000081565b610151610304366004612f54565b611b1a565b34801561031557600080fd5b5061033d7f000000000000000000000000000000000000000000000000000000000000000081565b604051908152602001610233565b34801561035757600080fd5b5061021f7f000000000000000000000000000000000000000000000000000000000000000081565b34801561038b57600080fd5b5061015161039a366004612f84565b611bdd565b3480156103ab57600080fd5b506101516103ba366004612e69565b611c78565b3480156103cb57600080fd5b506103ef6103da366004612e46565b60016020526000908152604090205460ff1681565b6040519015158152602001610233565b6000546001600160a01b0316331461045e5760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c20746869730000000060448201526064015b60405180910390fd5b806001600160a01b0316ff5b6000546001600160a01b031633146104c45760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000546001600160a01b0316331461054d5760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b6001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000166105ab604084018461303c565b60016105ba604087018761303c565b6105c59291506130db565b8181106105e257634e487b7160e01b600052603260045260246000fd5b90506020020160208101906105f79190612e46565b6001600160a01b03161461064d5760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b61072361065d604084018461303c565b600081811061067c57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906106919190612e46565b3361071c6106a2604087018761303c565b60008181106106c157634e487b7160e01b600052603260045260246000fd5b90506020020160208101906106d69190612e46565b6106e3604088018861303c565b600181811061070257634e487b7160e01b600052603260045260246000fd5b90506020020160208101906107179190612e46565b611cf1565b8535611e09565b61076c610733604084018461303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250309250611f81915050565b6040516370a0823160e01b81523060048201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316906370a082319060240160206040518083038186803b1580156107ce57600080fd5b505afa1580156107e2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108069190612f6c565b9050826020013581101561086c5760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b6040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690632e1a7d4d90602401600060405180830381600087803b1580156108e757600080fd5b505af11580156108fb573d6000803e3d6000fd5b5050505061090882611b1a565b61092a61091b6080850160608601612e46565b61092584846130db565b6122a5565b505050565b6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016610966604084018461303c565b6001610975604087018761303c565b6109809291506130db565b81811061099d57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906109b29190612e46565b6001600160a01b031614610a085760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b6000610a538335610a1c604086018661303c565b8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061238892505050565b9050826020013581600081518110610a7b57634e487b7160e01b600052603260045260246000fd5b60200260200101511115610add5760405162461bcd60e51b815260206004820152602360248201527f4d69737458526f757465723a204558434553534956455f494e5055545f414d4f60448201526215539560ea1b6064820152608401610455565b610ba1610aed604085018561303c565b6000818110610b0c57634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610b219190612e46565b33610b73610b32604088018861303c565b6000818110610b5157634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610b669190612e46565b6106e3604089018961303c565b84600081518110610b9457634e487b7160e01b600052603260045260246000fd5b6020026020010151611e09565b610beb81610bb2604086018661303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250309250612570915050565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316632e1a7d4d8260018451610c2991906130db565b81518110610c4757634e487b7160e01b600052603260045260246000fd5b60200260200101516040518263ffffffff1660e01b8152600401610c6d91815260200190565b600060405180830381600087803b158015610c8757600080fd5b505af1158015610c9b573d6000803e3d6000fd5b50505050610ca882611b1a565b61092a610cbb6080850160608601612e46565b838360018551610ccb91906130db565b81518110610ce957634e487b7160e01b600052603260045260246000fd5b602002602001015161092591906130db565b610d0481611b1a565b610d1461065d604084018461303c565b6000610d23604084018461303c565b6001610d32604087018761303c565b610d3d9291506130db565b818110610d5a57634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610d6f9190612e46565b6001600160a01b03166370a08231610d8d6080860160608701612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b158015610dcc57600080fd5b505afa158015610de0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e049190612f6c565b9050610e5d610e16604085018561303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610e58925050506080860160608701612e46565b611f81565b602083013581610e70604086018661303c565b6001610e7f604089018961303c565b610e8a9291506130db565b818110610ea757634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610ebc9190612e46565b6001600160a01b03166370a08231610eda6080880160608901612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b158015610f1957600080fd5b505afa158015610f2d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f519190612f6c565b610f5b91906130db565b101561092a5760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b610fc281611b1a565b6000610fd68335610a1c604086018661303c565b9050826020013581600081518110610ffe57634e487b7160e01b600052603260045260246000fd5b602002602001015111156110605760405162461bcd60e51b815260206004820152602360248201527f4d69737458526f757465723a204558434553534956455f494e5055545f414d4f60448201526215539560ea1b6064820152608401610455565b611070610aed604085018561303c565b61092a81611081604086018661303c565b808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506110c3925050506080870160608801612e46565b612570565b6110d181611b1a565b6001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016611108604084018461303c565b600081811061112757634e487b7160e01b600052603260045260246000fd5b905060200201602081019061113c9190612e46565b6001600160a01b0316146111925760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b600061119e82346130db565b90507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b1580156111fb57600080fd5b505af115801561120f573d6000803e3d6000fd5b50505050507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663a9059cbb6112568580604001906106a2919061303c565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b15801561129e57600080fd5b505af11580156112b2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d69190612eaa565b6112f057634e487b7160e01b600052600160045260246000fd5b60006112ff604085018561303c565b600161130e604088018861303c565b6113199291506130db565b81811061133657634e487b7160e01b600052603260045260246000fd5b905060200201602081019061134b9190612e46565b6001600160a01b03166370a082316113696080870160608801612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b1580156113a857600080fd5b505afa1580156113bc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113e09190612f6c565b90506114346113f2604086018661303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610e58925050506080870160608801612e46565b602084013581611447604087018761303c565b600161145660408a018a61303c565b6114619291506130db565b81811061147e57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906114939190612e46565b6001600160a01b03166370a082316114b16080890160608a01612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b1580156114f057600080fd5b505afa158015611504573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115289190612f6c565b61153291906130db565b10156115905760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b50505050565b6000546001600160a01b031633146115f05760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b61162881611b1a565b6001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001661165f604084018461303c565b600081811061167e57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906116939190612e46565b6001600160a01b0316146116e95760405162461bcd60e51b815260206004820152601d60248201527f556e69737761705632526f757465723a20494e56414c49445f504154480000006044820152606401610455565b60006117006020840135610a1c604086018661303c565b905061170c82346130db565b8160008151811061172d57634e487b7160e01b600052603260045260246000fd5b602002602001015111156117935760405162461bcd60e51b815260206004820152602760248201527f556e69737761705632526f757465723a204558434553534956455f494e50555460448201526617d05353d5539560ca1b6064820152608401610455565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663d0e30db0826000815181106117e357634e487b7160e01b600052603260045260246000fd5b60200260200101516040518263ffffffff1660e01b81526004016000604051808303818588803b15801561181657600080fd5b505af115801561182a573d6000803e3d6000fd5b50505050507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663a9059cbb6118718580604001906106a2919061303c565b8360008151811061189257634e487b7160e01b600052603260045260246000fd5b60200260200101516040518363ffffffff1660e01b81526004016118cb9291906001600160a01b03929092168252602082015260400190565b602060405180830381600087803b1580156118e557600080fd5b505af11580156118f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061191d9190612eaa565b61193757634e487b7160e01b600052600160045260246000fd5b61194881611081604086018661303c565b8060008151811061196957634e487b7160e01b600052603260045260246000fd5b6020026020010151823461197d91906130db565b111561092a576000336001600160a01b0316826000815181106119b057634e487b7160e01b600052603260045260246000fd5b602002602001015184346119c491906130db565b6119ce91906130db565b604080516000815260208101918290526119e791612fdf565b60006040518083038185875af1925050503d8060008114611a24576040519150601f19603f3d011682016040523d82523d6000602084013e611a29565b606091505b50509050806115905760405162461bcd60e51b8152602060048201526024808201527f736166655472616e736665724554483a20455448207472616e7366657220666160448201527f696c6564000000000000000000000000000000000000000000000000000000006064820152608401610455565b6000546001600160a01b03163314611af95760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6001600160a01b03166000908152600160205260409020805460ff19169055565b60025460408051600080825260208201928390529283926001600160a01b03909116918591611b499190612fdf565b60006040518083038185875af1925050503d8060008114611b86576040519150601f19603f3d011682016040523d82523d6000602084013e611b8b565b606091505b50915091508161092a5760405162461bcd60e51b815260206004820152601460248201527f4661696c656420746f2073656e642045746865720000000000000000000000006044820152606401610455565b3360009081526001602081905260409091205460ff16151514611c425760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c79206d616e61676572732063616e2063616c6c207468697300000000006044820152606401610455565b6040516001600160a01b0382169083156108fc029084906000818181858888f1935050505015801561092a573d6000803e3d6000fd5b3360009081526001602081905260409091205460ff16151514611cdd5760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c79206d616e61676572732063616e2063616c6c207468697300000000006044820152606401610455565b61092a6001600160a01b038416828461273d565b6000806000611d0085856127bd565b6040516bffffffffffffffffffffffff19606084811b8216602084015283901b16603482015291935091506000907f000000000000000000000000000000000000000000000000000000000000000090604801604051602081830303815290604052805190602001207f0000000000000000000000000000000000000000000000000000000000000000604051602001611de7939291907fff00000000000000000000000000000000000000000000000000000000000000815260609390931b6bffffffffffffffffffffffff191660018401526015830191909152603582015260550190565b60408051601f1981840301815291905280516020909101209695505050505050565b604080516001600160a01b0385811660248301528481166044830152606480830185905283518084039091018152608490920183526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f23b872dd000000000000000000000000000000000000000000000000000000001790529151600092839290881691611e9b9190612fdf565b6000604051808303816000865af19150503d8060008114611ed8576040519150601f19603f3d011682016040523d82523d6000602084013e611edd565b606091505b5091509150818015611f07575080511580611f07575080806020019051810190611f079190612eaa565b611f795760405162461bcd60e51b815260206004820152603160248201527f5472616e7366657248656c7065723a3a7472616e7366657246726f6d3a20747260448201527f616e7366657246726f6d206661696c65640000000000000000000000000000006064820152608401610455565b505050505050565b60005b60018351611f9291906130db565b81101561092a57600080848381518110611fbc57634e487b7160e01b600052603260045260246000fd5b602002602001015185846001611fd29190613084565b81518110611ff057634e487b7160e01b600052603260045260246000fd5b602002602001015191509150600061200883836127bd565b50905060006120178484611cf1565b9050600080600080846001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b15801561205857600080fd5b505afa15801561206c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906120909190612f11565b506dffffffffffffffffffffffffffff1691506dffffffffffffffffffffffffffff169150600080876001600160a01b03168a6001600160a01b0316146120d85782846120db565b83835b6040516370a0823160e01b81526001600160a01b038a8116600483015292945090925083918c16906370a082319060240160206040518083038186803b15801561212457600080fd5b505afa158015612138573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061215c9190612f6c565b61216691906130db565b95506121738683836128cd565b945050505050600080856001600160a01b0316886001600160a01b03161461219d578260006121a1565b6000835b91509150600060028c516121b591906130db565b8a106121c1578a6121fc565b6121fc888d6121d18d6002613084565b815181106121ef57634e487b7160e01b600052603260045260246000fd5b6020026020010151611cf1565b604080516000815260208101918290527f022c0d9f000000000000000000000000000000000000000000000000000000009091529091506001600160a01b0387169063022c0d9f90612257908690869086906024810161300e565b600060405180830381600087803b15801561227157600080fd5b505af1158015612285573d6000803e3d6000fd5b50505050505050505050505050808061229d90613135565b915050611f84565b604080516000808252602082019092526001600160a01b0384169083906040516122cf9190612fdf565b60006040518083038185875af1925050503d806000811461230c576040519150601f19603f3d011682016040523d82523d6000602084013e612311565b606091505b505090508061092a5760405162461bcd60e51b815260206004820152603460248201527f5472616e7366657248656c7065723a3a736166655472616e736665724554483a60448201527f20455448207472616e73666572206661696c65640000000000000000000000006064820152608401610455565b60606002825110156123dc5760405162461bcd60e51b815260206004820152601a60248201527f4d697374584c6962726172793a20494e56414c49445f504154480000000000006044820152606401610455565b815167ffffffffffffffff81111561240457634e487b7160e01b600052604160045260246000fd5b60405190808252806020026020018201604052801561242d578160200160208202803683370190505b50905082816001835161244091906130db565b8151811061245e57634e487b7160e01b600052603260045260246000fd5b60200260200101818152505060006001835161247a91906130db565b90505b8015612569576000806124e8856124956001866130db565b815181106124b357634e487b7160e01b600052603260045260246000fd5b60200260200101518685815181106124db57634e487b7160e01b600052603260045260246000fd5b60200260200101516129e4565b9150915061251e84848151811061250f57634e487b7160e01b600052603260045260246000fd5b60200260200101518383612ac9565b8461252a6001866130db565b8151811061254857634e487b7160e01b600052603260045260246000fd5b602002602001018181525050505080806125619061311e565b91505061247d565b5092915050565b60005b6001835161258191906130db565b811015611590576000808483815181106125ab57634e487b7160e01b600052603260045260246000fd5b6020026020010151858460016125c19190613084565b815181106125df57634e487b7160e01b600052603260045260246000fd5b60200260200101519150915060006125f783836127bd565b509050600087612608866001613084565b8151811061262657634e487b7160e01b600052603260045260246000fd5b60200260200101519050600080836001600160a01b0316866001600160a01b03161461265457826000612658565b6000835b91509150600060028a5161266c91906130db565b88106126785788612688565b612688868b6121d18b6002613084565b90506126948787611cf1565b6001600160a01b031663022c0d9f84848460006040519080825280601f01601f1916602001820160405280156126d1576020820181803683370190505b506040518563ffffffff1660e01b81526004016126f1949392919061300e565b600060405180830381600087803b15801561270b57600080fd5b505af115801561271f573d6000803e3d6000fd5b5050505050505050505050808061273590613135565b915050612573565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb0000000000000000000000000000000000000000000000000000000017905261092a908490612bfb565b600080826001600160a01b0316846001600160a01b031614156128485760405162461bcd60e51b815260206004820152602160248201527f4d697374584c6962726172793a204944454e544943414c5f414444524553534560448201527f53000000000000000000000000000000000000000000000000000000000000006064820152608401610455565b826001600160a01b0316846001600160a01b03161061286857828461286b565b83835b90925090506001600160a01b0382166128c65760405162461bcd60e51b815260206004820152601a60248201527f4d697374584c6962726172793a205a45524f5f414444524553530000000000006044820152606401610455565b9250929050565b600080841161292e5760405162461bcd60e51b815260206004820152602760248201527f4d697374584c6962726172793a20494e53554646494349454e545f494e50555460448201526617d05353d5539560ca1b6064820152608401610455565b60008311801561293e5750600082115b6129965760405162461bcd60e51b8152602060048201526024808201527f4d697374584c6962726172793a20494e53554646494349454e545f4c495155496044820152634449545960e01b6064820152608401610455565b60006129a4856103e56130bc565b905060006129b284836130bc565b90506000826129c3876103e86130bc565b6129cd9190613084565b90506129d9818361309c565b979650505050505050565b60008060006129f385856127bd565b509050600080612a038787611cf1565b6001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b158015612a3b57600080fd5b505afa158015612a4f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a739190612f11565b506dffffffffffffffffffffffffffff1691506dffffffffffffffffffffffffffff169150826001600160a01b0316876001600160a01b031614612ab8578082612abb565b81815b909890975095505050505050565b6000808411612b405760405162461bcd60e51b815260206004820152602860248201527f4d697374584c6962726172793a20494e53554646494349454e545f4f5554505560448201527f545f414d4f554e540000000000000000000000000000000000000000000000006064820152608401610455565b600083118015612b505750600082115b612ba85760405162461bcd60e51b8152602060048201526024808201527f4d697374584c6962726172793a20494e53554646494349454e545f4c495155496044820152634449545960e01b6064820152608401610455565b6000612bb485856130bc565b612bc0906103e86130bc565b90506000612bce86856130db565b612bda906103e56130bc565b9050612be6818361309c565b612bf1906001613084565b9695505050505050565b6000612c50826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316612ce09092919063ffffffff16565b80519091501561092a5780806020019051810190612c6e9190612eaa565b61092a5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610455565b6060612cef8484600085612cf7565b949350505050565b6060612d0285612dea565b612d4e5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610455565b600080866001600160a01b03168587604051612d6a9190612fdf565b60006040518083038185875af1925050503d8060008114612da7576040519150601f19603f3d011682016040523d82523d6000602084013e612dac565b606091505b50915091508115612dc0579150612cef9050565b805115612dd05780518082602001fd5b8360405162461bcd60e51b81526004016104559190612ffb565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470818114801590612cef575050151592915050565b80516dffffffffffffffffffffffffffff81168114612e4157600080fd5b919050565b600060208284031215612e57578081fd5b8135612e6281613166565b9392505050565b600080600060608486031215612e7d578182fd5b8335612e8881613166565b9250602084013591506040840135612e9f81613166565b809150509250925092565b600060208284031215612ebb578081fd5b81518015158114612e62578182fd5b60008060408385031215612edc578182fd5b823567ffffffffffffffff811115612ef2578283fd5b830160a08186031215612f03578283fd5b946020939093013593505050565b600080600060608486031215612f25578283fd5b612f2e84612e23565b9250612f3c60208501612e23565b9150604084015163ffffffff81168114612e9f578182fd5b600060208284031215612f65578081fd5b5035919050565b600060208284031215612f7d578081fd5b5051919050565b60008060408385031215612f96578182fd5b823591506020830135612fa881613166565b809150509250929050565b60008151808452612fcb8160208601602086016130f2565b601f01601f19169290920160200192915050565b60008251612ff18184602087016130f2565b9190910192915050565b602081526000612e626020830184612fb3565b8481528360208201526001600160a01b0383166040820152608060608201526000612bf16080830184612fb3565b6000808335601e19843603018112613052578283fd5b83018035915067ffffffffffffffff82111561306c578283fd5b6020019150600581901b36038213156128c657600080fd5b6000821982111561309757613097613150565b500190565b6000826130b757634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156130d6576130d6613150565b500290565b6000828210156130ed576130ed613150565b500390565b60005b8381101561310d5781810151838201526020016130f5565b838111156115905750506000910152565b60008161312d5761312d613150565b506000190190565b600060001982141561314957613149613150565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b038116811461317b57600080fd5b5056fea2646970667358221220928f0521120bbba076c79e52646f69d69b986e1b6d04fdfb8957221170c28f6164736f6c63430008040033000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc20000000000000000000000005c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f00000000000000000000000035c8561bad5b9aee1de494da4c18b9aae2b1520d000000000000000000000000a619308dbedf2429636ef8c099707d3c9a37e23d

Deployed Bytecode

0x60806040526004361061014a5760003560e01c8063a8261e9b116100b4578063bce633c51161006e578063c463a5bf11610056578063c463a5bf1461037f578063f4d34ca61461039f578063fdff9b4d146103bf57005b8063bce633c514610309578063c45a01551461034b57005b8063ac18de431161009c578063ac18de43146102a2578063ad5c4648146102c2578063b6b55f25146102f657005b8063a8261e9b1461026f578063a9483edc1461028f57005b806354d51de4116101055780638da5cb5b116100ed5780638da5cb5b146101ff578063982ea0201461023c578063a6f9dae11461024f57005b806354d51de4146101d957806359848cc4146101ec57005b80632d06177a116101335780632d06177a14610193578063465406a7146101b35780634f66c92a146101c657005b8062f55d9d146101535780632c29cb301461017357005b3661015157005b005b34801561015f57600080fd5b5061015161016e366004612e46565b6103ff565b34801561017f57600080fd5b5061015161018e366004612e46565b61046a565b34801561019f57600080fd5b506101516101ae366004612e46565b6104f3565b6101516101c1366004612eca565b610574565b6101516101d4366004612eca565b61092f565b6101516101e7366004612eca565b610cfb565b6101516101fa366004612eca565b610fb9565b34801561020b57600080fd5b5060005461021f906001600160a01b031681565b6040516001600160a01b0390911681526020015b60405180910390f35b61015161024a366004612eca565b6110c8565b34801561025b57600080fd5b5061015161026a366004612e46565b611596565b34801561027b57600080fd5b5060025461021f906001600160a01b031681565b61015161029d366004612eca565b61161f565b3480156102ae57600080fd5b506101516102bd366004612e46565b611a9f565b3480156102ce57600080fd5b5061021f7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b610151610304366004612f54565b611b1a565b34801561031557600080fd5b5061033d7f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f81565b604051908152602001610233565b34801561035757600080fd5b5061021f7f0000000000000000000000005c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f81565b34801561038b57600080fd5b5061015161039a366004612f84565b611bdd565b3480156103ab57600080fd5b506101516103ba366004612e69565b611c78565b3480156103cb57600080fd5b506103ef6103da366004612e46565b60016020526000908152604090205460ff1681565b6040519015158152602001610233565b6000546001600160a01b0316331461045e5760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c20746869730000000060448201526064015b60405180910390fd5b806001600160a01b0316ff5b6000546001600160a01b031633146104c45760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6002805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000546001600160a01b0316331461054d5760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b6001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2166105ab604084018461303c565b60016105ba604087018761303c565b6105c59291506130db565b8181106105e257634e487b7160e01b600052603260045260246000fd5b90506020020160208101906105f79190612e46565b6001600160a01b03161461064d5760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b61072361065d604084018461303c565b600081811061067c57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906106919190612e46565b3361071c6106a2604087018761303c565b60008181106106c157634e487b7160e01b600052603260045260246000fd5b90506020020160208101906106d69190612e46565b6106e3604088018861303c565b600181811061070257634e487b7160e01b600052603260045260246000fd5b90506020020160208101906107179190612e46565b611cf1565b8535611e09565b61076c610733604084018461303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250309250611f81915050565b6040516370a0823160e01b81523060048201526000907f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b0316906370a082319060240160206040518083038186803b1580156107ce57600080fd5b505afa1580156107e2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108069190612f6c565b9050826020013581101561086c5760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b6040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031690632e1a7d4d90602401600060405180830381600087803b1580156108e757600080fd5b505af11580156108fb573d6000803e3d6000fd5b5050505061090882611b1a565b61092a61091b6080850160608601612e46565b61092584846130db565b6122a5565b505050565b6001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc216610966604084018461303c565b6001610975604087018761303c565b6109809291506130db565b81811061099d57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906109b29190612e46565b6001600160a01b031614610a085760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b6000610a538335610a1c604086018661303c565b8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061238892505050565b9050826020013581600081518110610a7b57634e487b7160e01b600052603260045260246000fd5b60200260200101511115610add5760405162461bcd60e51b815260206004820152602360248201527f4d69737458526f757465723a204558434553534956455f494e5055545f414d4f60448201526215539560ea1b6064820152608401610455565b610ba1610aed604085018561303c565b6000818110610b0c57634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610b219190612e46565b33610b73610b32604088018861303c565b6000818110610b5157634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610b669190612e46565b6106e3604089018961303c565b84600081518110610b9457634e487b7160e01b600052603260045260246000fd5b6020026020010151611e09565b610beb81610bb2604086018661303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250309250612570915050565b7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b0316632e1a7d4d8260018451610c2991906130db565b81518110610c4757634e487b7160e01b600052603260045260246000fd5b60200260200101516040518263ffffffff1660e01b8152600401610c6d91815260200190565b600060405180830381600087803b158015610c8757600080fd5b505af1158015610c9b573d6000803e3d6000fd5b50505050610ca882611b1a565b61092a610cbb6080850160608601612e46565b838360018551610ccb91906130db565b81518110610ce957634e487b7160e01b600052603260045260246000fd5b602002602001015161092591906130db565b610d0481611b1a565b610d1461065d604084018461303c565b6000610d23604084018461303c565b6001610d32604087018761303c565b610d3d9291506130db565b818110610d5a57634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610d6f9190612e46565b6001600160a01b03166370a08231610d8d6080860160608701612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b158015610dcc57600080fd5b505afa158015610de0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e049190612f6c565b9050610e5d610e16604085018561303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610e58925050506080860160608701612e46565b611f81565b602083013581610e70604086018661303c565b6001610e7f604089018961303c565b610e8a9291506130db565b818110610ea757634e487b7160e01b600052603260045260246000fd5b9050602002016020810190610ebc9190612e46565b6001600160a01b03166370a08231610eda6080880160608901612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b158015610f1957600080fd5b505afa158015610f2d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f519190612f6c565b610f5b91906130db565b101561092a5760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b610fc281611b1a565b6000610fd68335610a1c604086018661303c565b9050826020013581600081518110610ffe57634e487b7160e01b600052603260045260246000fd5b602002602001015111156110605760405162461bcd60e51b815260206004820152602360248201527f4d69737458526f757465723a204558434553534956455f494e5055545f414d4f60448201526215539560ea1b6064820152608401610455565b611070610aed604085018561303c565b61092a81611081604086018661303c565b808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506110c3925050506080870160608801612e46565b612570565b6110d181611b1a565b6001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc216611108604084018461303c565b600081811061112757634e487b7160e01b600052603260045260246000fd5b905060200201602081019061113c9190612e46565b6001600160a01b0316146111925760405162461bcd60e51b815260206004820152601960248201527f4d69737458526f757465723a20494e56414c49445f50415448000000000000006044820152606401610455565b600061119e82346130db565b90507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b1580156111fb57600080fd5b505af115801561120f573d6000803e3d6000fd5b50505050507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663a9059cbb6112568580604001906106a2919061303c565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b15801561129e57600080fd5b505af11580156112b2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d69190612eaa565b6112f057634e487b7160e01b600052600160045260246000fd5b60006112ff604085018561303c565b600161130e604088018861303c565b6113199291506130db565b81811061133657634e487b7160e01b600052603260045260246000fd5b905060200201602081019061134b9190612e46565b6001600160a01b03166370a082316113696080870160608801612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b1580156113a857600080fd5b505afa1580156113bc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113e09190612f6c565b90506114346113f2604086018661303c565b80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610e58925050506080870160608801612e46565b602084013581611447604087018761303c565b600161145660408a018a61303c565b6114619291506130db565b81811061147e57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906114939190612e46565b6001600160a01b03166370a082316114b16080890160608a01612e46565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260240160206040518083038186803b1580156114f057600080fd5b505afa158015611504573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115289190612f6c565b61153291906130db565b10156115905760405162461bcd60e51b815260206004820152602760248201527f4d69737458526f757465723a20494e53554646494349454e545f4f555450555460448201526617d05353d5539560ca1b6064820152608401610455565b50505050565b6000546001600160a01b031633146115f05760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b61162881611b1a565b6001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc21661165f604084018461303c565b600081811061167e57634e487b7160e01b600052603260045260246000fd5b90506020020160208101906116939190612e46565b6001600160a01b0316146116e95760405162461bcd60e51b815260206004820152601d60248201527f556e69737761705632526f757465723a20494e56414c49445f504154480000006044820152606401610455565b60006117006020840135610a1c604086018661303c565b905061170c82346130db565b8160008151811061172d57634e487b7160e01b600052603260045260246000fd5b602002602001015111156117935760405162461bcd60e51b815260206004820152602760248201527f556e69737761705632526f757465723a204558434553534956455f494e50555460448201526617d05353d5539560ca1b6064820152608401610455565b7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663d0e30db0826000815181106117e357634e487b7160e01b600052603260045260246000fd5b60200260200101516040518263ffffffff1660e01b81526004016000604051808303818588803b15801561181657600080fd5b505af115801561182a573d6000803e3d6000fd5b50505050507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663a9059cbb6118718580604001906106a2919061303c565b8360008151811061189257634e487b7160e01b600052603260045260246000fd5b60200260200101516040518363ffffffff1660e01b81526004016118cb9291906001600160a01b03929092168252602082015260400190565b602060405180830381600087803b1580156118e557600080fd5b505af11580156118f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061191d9190612eaa565b61193757634e487b7160e01b600052600160045260246000fd5b61194881611081604086018661303c565b8060008151811061196957634e487b7160e01b600052603260045260246000fd5b6020026020010151823461197d91906130db565b111561092a576000336001600160a01b0316826000815181106119b057634e487b7160e01b600052603260045260246000fd5b602002602001015184346119c491906130db565b6119ce91906130db565b604080516000815260208101918290526119e791612fdf565b60006040518083038185875af1925050503d8060008114611a24576040519150601f19603f3d011682016040523d82523d6000602084013e611a29565b606091505b50509050806115905760405162461bcd60e51b8152602060048201526024808201527f736166655472616e736665724554483a20455448207472616e7366657220666160448201527f696c6564000000000000000000000000000000000000000000000000000000006064820152608401610455565b6000546001600160a01b03163314611af95760405162461bcd60e51b815260206004820152601c60248201527f4f6e6c7920746865206f776e65722063616e2063616c6c2074686973000000006044820152606401610455565b6001600160a01b03166000908152600160205260409020805460ff19169055565b60025460408051600080825260208201928390529283926001600160a01b03909116918591611b499190612fdf565b60006040518083038185875af1925050503d8060008114611b86576040519150601f19603f3d011682016040523d82523d6000602084013e611b8b565b606091505b50915091508161092a5760405162461bcd60e51b815260206004820152601460248201527f4661696c656420746f2073656e642045746865720000000000000000000000006044820152606401610455565b3360009081526001602081905260409091205460ff16151514611c425760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c79206d616e61676572732063616e2063616c6c207468697300000000006044820152606401610455565b6040516001600160a01b0382169083156108fc029084906000818181858888f1935050505015801561092a573d6000803e3d6000fd5b3360009081526001602081905260409091205460ff16151514611cdd5760405162461bcd60e51b815260206004820152601b60248201527f4f6e6c79206d616e61676572732063616e2063616c6c207468697300000000006044820152606401610455565b61092a6001600160a01b038416828461273d565b6000806000611d0085856127bd565b6040516bffffffffffffffffffffffff19606084811b8216602084015283901b16603482015291935091506000907f0000000000000000000000005c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f90604801604051602081830303815290604052805190602001207f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f604051602001611de7939291907fff00000000000000000000000000000000000000000000000000000000000000815260609390931b6bffffffffffffffffffffffff191660018401526015830191909152603582015260550190565b60408051601f1981840301815291905280516020909101209695505050505050565b604080516001600160a01b0385811660248301528481166044830152606480830185905283518084039091018152608490920183526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f23b872dd000000000000000000000000000000000000000000000000000000001790529151600092839290881691611e9b9190612fdf565b6000604051808303816000865af19150503d8060008114611ed8576040519150601f19603f3d011682016040523d82523d6000602084013e611edd565b606091505b5091509150818015611f07575080511580611f07575080806020019051810190611f079190612eaa565b611f795760405162461bcd60e51b815260206004820152603160248201527f5472616e7366657248656c7065723a3a7472616e7366657246726f6d3a20747260448201527f616e7366657246726f6d206661696c65640000000000000000000000000000006064820152608401610455565b505050505050565b60005b60018351611f9291906130db565b81101561092a57600080848381518110611fbc57634e487b7160e01b600052603260045260246000fd5b602002602001015185846001611fd29190613084565b81518110611ff057634e487b7160e01b600052603260045260246000fd5b602002602001015191509150600061200883836127bd565b50905060006120178484611cf1565b9050600080600080846001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b15801561205857600080fd5b505afa15801561206c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906120909190612f11565b506dffffffffffffffffffffffffffff1691506dffffffffffffffffffffffffffff169150600080876001600160a01b03168a6001600160a01b0316146120d85782846120db565b83835b6040516370a0823160e01b81526001600160a01b038a8116600483015292945090925083918c16906370a082319060240160206040518083038186803b15801561212457600080fd5b505afa158015612138573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061215c9190612f6c565b61216691906130db565b95506121738683836128cd565b945050505050600080856001600160a01b0316886001600160a01b03161461219d578260006121a1565b6000835b91509150600060028c516121b591906130db565b8a106121c1578a6121fc565b6121fc888d6121d18d6002613084565b815181106121ef57634e487b7160e01b600052603260045260246000fd5b6020026020010151611cf1565b604080516000815260208101918290527f022c0d9f000000000000000000000000000000000000000000000000000000009091529091506001600160a01b0387169063022c0d9f90612257908690869086906024810161300e565b600060405180830381600087803b15801561227157600080fd5b505af1158015612285573d6000803e3d6000fd5b50505050505050505050505050808061229d90613135565b915050611f84565b604080516000808252602082019092526001600160a01b0384169083906040516122cf9190612fdf565b60006040518083038185875af1925050503d806000811461230c576040519150601f19603f3d011682016040523d82523d6000602084013e612311565b606091505b505090508061092a5760405162461bcd60e51b815260206004820152603460248201527f5472616e7366657248656c7065723a3a736166655472616e736665724554483a60448201527f20455448207472616e73666572206661696c65640000000000000000000000006064820152608401610455565b60606002825110156123dc5760405162461bcd60e51b815260206004820152601a60248201527f4d697374584c6962726172793a20494e56414c49445f504154480000000000006044820152606401610455565b815167ffffffffffffffff81111561240457634e487b7160e01b600052604160045260246000fd5b60405190808252806020026020018201604052801561242d578160200160208202803683370190505b50905082816001835161244091906130db565b8151811061245e57634e487b7160e01b600052603260045260246000fd5b60200260200101818152505060006001835161247a91906130db565b90505b8015612569576000806124e8856124956001866130db565b815181106124b357634e487b7160e01b600052603260045260246000fd5b60200260200101518685815181106124db57634e487b7160e01b600052603260045260246000fd5b60200260200101516129e4565b9150915061251e84848151811061250f57634e487b7160e01b600052603260045260246000fd5b60200260200101518383612ac9565b8461252a6001866130db565b8151811061254857634e487b7160e01b600052603260045260246000fd5b602002602001018181525050505080806125619061311e565b91505061247d565b5092915050565b60005b6001835161258191906130db565b811015611590576000808483815181106125ab57634e487b7160e01b600052603260045260246000fd5b6020026020010151858460016125c19190613084565b815181106125df57634e487b7160e01b600052603260045260246000fd5b60200260200101519150915060006125f783836127bd565b509050600087612608866001613084565b8151811061262657634e487b7160e01b600052603260045260246000fd5b60200260200101519050600080836001600160a01b0316866001600160a01b03161461265457826000612658565b6000835b91509150600060028a5161266c91906130db565b88106126785788612688565b612688868b6121d18b6002613084565b90506126948787611cf1565b6001600160a01b031663022c0d9f84848460006040519080825280601f01601f1916602001820160405280156126d1576020820181803683370190505b506040518563ffffffff1660e01b81526004016126f1949392919061300e565b600060405180830381600087803b15801561270b57600080fd5b505af115801561271f573d6000803e3d6000fd5b5050505050505050505050808061273590613135565b915050612573565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb0000000000000000000000000000000000000000000000000000000017905261092a908490612bfb565b600080826001600160a01b0316846001600160a01b031614156128485760405162461bcd60e51b815260206004820152602160248201527f4d697374584c6962726172793a204944454e544943414c5f414444524553534560448201527f53000000000000000000000000000000000000000000000000000000000000006064820152608401610455565b826001600160a01b0316846001600160a01b03161061286857828461286b565b83835b90925090506001600160a01b0382166128c65760405162461bcd60e51b815260206004820152601a60248201527f4d697374584c6962726172793a205a45524f5f414444524553530000000000006044820152606401610455565b9250929050565b600080841161292e5760405162461bcd60e51b815260206004820152602760248201527f4d697374584c6962726172793a20494e53554646494349454e545f494e50555460448201526617d05353d5539560ca1b6064820152608401610455565b60008311801561293e5750600082115b6129965760405162461bcd60e51b8152602060048201526024808201527f4d697374584c6962726172793a20494e53554646494349454e545f4c495155496044820152634449545960e01b6064820152608401610455565b60006129a4856103e56130bc565b905060006129b284836130bc565b90506000826129c3876103e86130bc565b6129cd9190613084565b90506129d9818361309c565b979650505050505050565b60008060006129f385856127bd565b509050600080612a038787611cf1565b6001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b158015612a3b57600080fd5b505afa158015612a4f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a739190612f11565b506dffffffffffffffffffffffffffff1691506dffffffffffffffffffffffffffff169150826001600160a01b0316876001600160a01b031614612ab8578082612abb565b81815b909890975095505050505050565b6000808411612b405760405162461bcd60e51b815260206004820152602860248201527f4d697374584c6962726172793a20494e53554646494349454e545f4f5554505560448201527f545f414d4f554e540000000000000000000000000000000000000000000000006064820152608401610455565b600083118015612b505750600082115b612ba85760405162461bcd60e51b8152602060048201526024808201527f4d697374584c6962726172793a20494e53554646494349454e545f4c495155496044820152634449545960e01b6064820152608401610455565b6000612bb485856130bc565b612bc0906103e86130bc565b90506000612bce86856130db565b612bda906103e56130bc565b9050612be6818361309c565b612bf1906001613084565b9695505050505050565b6000612c50826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316612ce09092919063ffffffff16565b80519091501561092a5780806020019051810190612c6e9190612eaa565b61092a5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f742073756363656564000000000000000000000000000000000000000000006064820152608401610455565b6060612cef8484600085612cf7565b949350505050565b6060612d0285612dea565b612d4e5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610455565b600080866001600160a01b03168587604051612d6a9190612fdf565b60006040518083038185875af1925050503d8060008114612da7576040519150601f19603f3d011682016040523d82523d6000602084013e612dac565b606091505b50915091508115612dc0579150612cef9050565b805115612dd05780518082602001fd5b8360405162461bcd60e51b81526004016104559190612ffb565b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470818114801590612cef575050151592915050565b80516dffffffffffffffffffffffffffff81168114612e4157600080fd5b919050565b600060208284031215612e57578081fd5b8135612e6281613166565b9392505050565b600080600060608486031215612e7d578182fd5b8335612e8881613166565b9250602084013591506040840135612e9f81613166565b809150509250925092565b600060208284031215612ebb578081fd5b81518015158114612e62578182fd5b60008060408385031215612edc578182fd5b823567ffffffffffffffff811115612ef2578283fd5b830160a08186031215612f03578283fd5b946020939093013593505050565b600080600060608486031215612f25578283fd5b612f2e84612e23565b9250612f3c60208501612e23565b9150604084015163ffffffff81168114612e9f578182fd5b600060208284031215612f65578081fd5b5035919050565b600060208284031215612f7d578081fd5b5051919050565b60008060408385031215612f96578182fd5b823591506020830135612fa881613166565b809150509250929050565b60008151808452612fcb8160208601602086016130f2565b601f01601f19169290920160200192915050565b60008251612ff18184602087016130f2565b9190910192915050565b602081526000612e626020830184612fb3565b8481528360208201526001600160a01b0383166040820152608060608201526000612bf16080830184612fb3565b6000808335601e19843603018112613052578283fd5b83018035915067ffffffffffffffff82111561306c578283fd5b6020019150600581901b36038213156128c657600080fd5b6000821982111561309757613097613150565b500190565b6000826130b757634e487b7160e01b81526012600452602481fd5b500490565b60008160001904831182151516156130d6576130d6613150565b500290565b6000828210156130ed576130ed613150565b500390565b60005b8381101561310d5781810151838201526020016130f5565b838111156115905750506000910152565b60008161312d5761312d613150565b506000190190565b600060001982141561314957613149613150565b5060010190565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b038116811461317b57600080fd5b5056fea2646970667358221220928f0521120bbba076c79e52646f69d69b986e1b6d04fdfb8957221170c28f6164736f6c63430008040033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc20000000000000000000000005c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f00000000000000000000000035c8561bad5b9aee1de494da4c18b9aae2b1520d000000000000000000000000a619308dbedf2429636ef8c099707d3c9a37e23d

-----Decoded View---------------
Arg [0] : _WETH (address): 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2
Arg [1] : _factory (address): 0x5C69bEe701ef814a2B6a3EDD4B1652CB9cc5aA6f
Arg [2] : _initHash (bytes32): 0x96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f
Arg [3] : _owner (address): 0x35C8561bAd5b9aeE1de494da4c18B9aAe2b1520d
Arg [4] : _tipjar (address): 0xa619308DBEdF2429636ef8c099707d3c9a37e23d

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2
Arg [1] : 0000000000000000000000005c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f
Arg [2] : 96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f
Arg [3] : 00000000000000000000000035c8561bad5b9aee1de494da4c18b9aae2b1520d
Arg [4] : 000000000000000000000000a619308dbedf2429636ef8c099707d3c9a37e23d


Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading
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.