Source Code
Overview
MON Balance
MON Value
$0.00Latest 7 internal transactions
Advanced mode:
| Parent Transaction Hash | Block | From | To | |||
|---|---|---|---|---|---|---|
| 39043293 | 59 days ago | Contract Creation | 0 MON | |||
| 37887088 | 64 days ago | Contract Creation | 0 MON | |||
| 37885258 | 64 days ago | Contract Creation | 0 MON | |||
| 37831269 | 65 days ago | Contract Creation | 0 MON | |||
| 37827365 | 65 days ago | Contract Creation | 0 MON | |||
| 37815442 | 65 days ago | Contract Creation | 0 MON | |||
| 37670984 | 65 days ago | Contract Creation | 0 MON |
Loading...
Loading
Contract Name:
ZFFactory
Compiler Version
v0.5.16+commit.9c3226ce
Optimization Enabled:
Yes with 200 runs
Other Settings:
istanbul EvmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: AGPL-3.0-or-later
pragma solidity =0.5.16;
import "./ZFPair.sol";
import "./interfaces/IZFPair.sol";
import "./interfaces/IZFFactory.sol";
contract ZFFactory is IZFFactory {
bytes32 public constant INIT_CODE_PAIR_HASH = keccak256(abi.encodePacked(type(ZFPair).creationCode));
/// @dev Address of fee manager
address public feeTo;
/// @dev Who can set the address for fee manager
address public feeToSetter;
/// @dev Returns pair for tokens, address sorting is not required
mapping(address => mapping(address => address)) public getPair;
/// @dev All existing pairs
address[] public allPairs;
/// @dev Swap fee in basis points (1 basis point = 0.01%)
/// @dev 20 = 0.2%, 100 = 1%, 1000 = 10%
uint16 public swapFee = 20; // 0.2%, in 10000 precision
/// @dev Protocol fee as percentage of swap fee, in basis points
/// @dev default 3500 = 35% of swap fee goes to protocol
uint16 public protocolFee = 3200;
// ----- EVENTS -----
/// @dev Emitted when a new pair is created
event PairCreated(address indexed token0, address indexed token1, address pair, uint256 allPairsLength);
/// @dev Emitted when feeTo is updated
event FeeToSet(address indexed feeTo);
/// @dev Emitted when feeToSetter is updated
event FeeToSetterSet(address indexed feeToSetter);
/// @dev Emitted when swap fee is updated
event SwapFeeSet(uint16 newSwapFee);
/// @dev Emitted when protocol fee is updated
event ProtocolFeeSet(uint16 newProtocolFee);
/// @dev Emitted when swap fee override is set for a pair
event SwapFeeOverrideSet(address indexed pair, uint16 swapFeeOverride);
/// @dev Emitted when protocol fee override is set for a pair
event ProtocolFeeOverrideSet(address indexed pair, uint16 protocolFeeOverride);
modifier onlyFeeToSetter() {
require(msg.sender == feeToSetter, "ZF: FORBIDDEN");
_;
}
constructor(address _feeToSetter) public {
feeToSetter = _feeToSetter;
}
/// @dev Returns the length of all pairs
function allPairsLength() external view returns (uint256) {
return allPairs.length;
}
function createPair(address tokenA, address tokenB) external returns (address pair) {
require(tokenA != tokenB, "ZF: IDENTICAL_ADDRESSES");
(address token0, address token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
require(token0 != address(0), "ZF: ZERO_ADDRESS");
require(getPair[token0][token1] == address(0), "ZF: PAIR_EXISTS"); // single check is sufficient
bytes memory bytecode = type(ZFPair).creationCode;
bytes32 salt = keccak256(abi.encodePacked(token0, token1));
assembly {
pair := create2(0, add(bytecode, 32), mload(bytecode), salt)
}
require(pair != address(0), "ZF: FAILED_TO_CREATE_PAIR");
IZFPair(pair).initialize(token0, token1);
getPair[token0][token1] = pair;
getPair[token1][token0] = pair; // populate mapping in the reverse direction
allPairs.push(pair);
emit PairCreated(token0, token1, pair, allPairs.length);
}
/// @dev Sets the address of fee manager
function setFeeTo(address _feeTo) external onlyFeeToSetter {
feeTo = _feeTo;
emit FeeToSet(_feeTo);
}
/// @dev Sets swap fee base point
function setSwapFee(uint16 _newFee) external onlyFeeToSetter {
require(_newFee <= 1000, "ZF: SWAP_FEE_TOO_HIGH"); // max 10%
swapFee = _newFee;
emit SwapFeeSet(_newFee);
}
/// @dev Sets protocol fee
function setProtocolFee(uint16 _newFee) external onlyFeeToSetter {
require(_newFee <= 10000, "ZF: INVALID_PROTOCOL_FEE");
protocolFee = _newFee;
emit ProtocolFeeSet(_newFee);
}
/// @dev Sets the address of setter for fee manager
function setFeeToSetter(address _feeToSetter) external onlyFeeToSetter {
feeToSetter = _feeToSetter;
emit FeeToSetterSet(_feeToSetter);
}
/// @dev Sets swap fee point for a pair
function setSwapFeeOverride(address _pair, uint16 _swapFeeOverride) external onlyFeeToSetter {
ZFPair(_pair).setSwapFeeOverride(_swapFeeOverride);
emit SwapFeeOverrideSet(_pair, _swapFeeOverride);
}
/// @dev Sets protocol fee for a specific pair
function setProtocolFeeOverride(address _pair, uint16 _protocolFeeOverride) external onlyFeeToSetter {
ZFPair(_pair).setProtocolFeeOverride(_protocolFeeOverride);
emit ProtocolFeeOverrideSet(_pair, _protocolFeeOverride);
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;
import "./interfaces/IZFPair.sol";
import "./interfaces/IUniswapV2Callee.sol";
import "./ZFERC20.sol";
import "./libraries/Math.sol";
import "./libraries/UQ112x112.sol";
import "./interfaces/IERC20.sol";
import "./interfaces/IZFFactory.sol";
import "./libraries/SafeMath.sol";
contract ZFPair is IZFPair, ZFERC20 {
using SafeMath for uint256;
using UQ112x112 for uint224;
bytes4 private constant SELECTOR = bytes4(keccak256(bytes("transfer(address,uint256)")));
uint256 private constant SWAP_FEE_POINT_PRECISION_SQ = 10000_0000;
uint256 private constant SWAP_FEE_POINT_PRECISION = 10000;
uint256 private constant PROTOCOL_FEE_POINT_PRECISION = 10000;
uint256 private constant MINIMUM_LIQUIDITY = 10 ** 3;
uint16 private constant SWAP_FEE_INHERIT = uint16(-1);
uint16 private constant PROTOCOL_FEE_INHERIT = uint16(-1);
address public factory;
address public token0;
address public token1;
uint112 private reserve0; // uses single storage slot, accessible via getReserves
uint112 private reserve1; // uses single storage slot, accessible via getReserves
uint32 private blockTimestampLast; // uses single storage slot, accessible via getReserves
uint256 public price0CumulativeLast;
uint256 public price1CumulativeLast;
uint256 public kLast; // reserve0 * reserve1, as of immediately after the most recent liquidity event
uint16 public swapFeeOverride = SWAP_FEE_INHERIT;
uint16 public protocolFeeOverride = PROTOCOL_FEE_INHERIT;
uint256 private unlocked = 1;
modifier lock() {
require(unlocked == 1, "ZF: LOCKED");
unlocked = 0;
_;
unlocked = 1;
}
event Mint(address indexed sender, uint256 amount0, uint256 amount1);
event Burn(address indexed sender, uint256 amount0, uint256 amount1, address indexed to);
event Swap(
address indexed sender,
uint256 amount0In,
uint256 amount1In,
uint256 amount0Out,
uint256 amount1Out,
address indexed to
);
event Sync(uint112 reserve0, uint112 reserve1);
constructor() public {
factory = msg.sender;
}
// called once by the factory at time of deployment
function initialize(address _token0, address _token1) external {
require(msg.sender == factory, "ZF: FORBIDDEN"); // sufficient check
token0 = _token0;
token1 = _token1;
}
function getReserves() public view returns (uint112 _reserve0, uint112 _reserve1, uint32 _blockTimestampLast) {
_reserve0 = reserve0;
_reserve1 = reserve1;
_blockTimestampLast = blockTimestampLast;
}
function getReservesSimple() external view returns (uint112, uint112) {
return (reserve0, reserve1);
}
function getSwapFee() public view returns (uint16) {
uint16 _swapFeeOverride = swapFeeOverride;
return _swapFeeOverride == SWAP_FEE_INHERIT ? IZFFactory(factory).swapFee() : _swapFeeOverride;
}
function getProtocolFee() public view returns (uint256) {
uint16 _protocolFeeOverride = protocolFeeOverride;
return _protocolFeeOverride == PROTOCOL_FEE_INHERIT ? IZFFactory(factory).protocolFee() : _protocolFeeOverride;
}
function getReservesAndParameters() external view returns (uint112 _reserve0, uint112 _reserve1, uint16 _swapFee) {
_reserve0 = reserve0;
_reserve1 = reserve1;
_swapFee = getSwapFee();
}
function _getBalances(address _token0, address _token1) private view returns (uint256, uint256) {
return (IERC20(_token0).balanceOf(address(this)), IERC20(_token1).balanceOf(address(this)));
}
function _safeTransfer(address token, address to, uint256 value) private {
(bool success, bytes memory data) = token.call(abi.encodeWithSelector(SELECTOR, to, value));
require(success && (data.length == 0 || abi.decode(data, (bool))), "ZF: TRANSFER_FAILED");
}
// update reserves and, on the first call per block, price accumulators
function _update(uint256 balance0, uint256 balance1, uint112 _reserve0, uint112 _reserve1) private {
require(balance0 <= uint112(-1) && balance1 <= uint112(-1), "ZF: OVERFLOW");
uint32 blockTimestamp = uint32(block.timestamp % 2 ** 32);
uint32 timeElapsed = blockTimestamp - blockTimestampLast; // overflow is desired
if (timeElapsed > 0 && _reserve0 != 0 && _reserve1 != 0) {
// * never overflows, and + overflow is desired
price0CumulativeLast += uint256(UQ112x112.encode(_reserve1).uqdiv(_reserve0)) * timeElapsed;
price1CumulativeLast += uint256(UQ112x112.encode(_reserve0).uqdiv(_reserve1)) * timeElapsed;
}
reserve0 = uint112(balance0);
reserve1 = uint112(balance1);
blockTimestampLast = blockTimestamp;
emit Sync(reserve0, reserve1);
}
function _getFeeLiquidity(uint256 _totalSupply, uint256 _rootK2, uint256 _rootK1) private view returns (uint256) {
uint256 _protocolFee = getProtocolFee();
uint256 numerator = _totalSupply.mul(_rootK2.sub(_rootK1)).mul(_protocolFee);
uint256 denominator =
(PROTOCOL_FEE_POINT_PRECISION.sub(_protocolFee)).mul(_rootK2).add(_rootK1.mul(_protocolFee));
return numerator / denominator;
}
function _mintFee(uint112 _reserve0, uint112 _reserve1) private returns (bool feeOn) {
address _feeTo = IZFFactory(factory).feeTo();
feeOn = _feeTo != address(0);
uint256 _kLast = kLast;
if (feeOn) {
if (_kLast != 0) {
uint256 rootK = Math.sqrt(uint256(_reserve0).mul(_reserve1));
uint256 rootKLast = Math.sqrt(_kLast);
if (rootK > rootKLast) {
uint256 liquidity = _getFeeLiquidity(totalSupply, rootK, rootKLast);
if (liquidity > 0) _mint(_feeTo, liquidity);
}
}
} else if (_kLast != 0) {
kLast = 0;
}
}
/// @dev this low-level function should be called from a contract which performs important safety checks
function mint(address to) external lock returns (uint256 liquidity) {
(uint112 _reserve0, uint112 _reserve1,) = getReserves();
(uint256 balance0, uint256 balance1) = _getBalances(token0, token1);
uint256 amount0 = balance0.sub(_reserve0);
uint256 amount1 = balance1.sub(_reserve1);
bool feeOn = _mintFee(_reserve0, _reserve1);
uint256 _totalSupply = totalSupply; // gas savings, must be defined here since totalSupply can update in _mintFee
if (_totalSupply == 0) {
liquidity = Math.sqrt(amount0.mul(amount1)).sub(MINIMUM_LIQUIDITY);
_mint(address(0), MINIMUM_LIQUIDITY); // permanently lock the first MINIMUM_LIQUIDITY tokens
} else {
liquidity = Math.min(amount0.mul(_totalSupply) / _reserve0, amount1.mul(_totalSupply) / _reserve1);
}
require(liquidity > 0, "ZF: INSUFFICIENT_LIQUIDITY_MINTED");
_mint(to, liquidity);
_update(balance0, balance1, _reserve0, _reserve1);
if (feeOn) kLast = uint256(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
emit Mint(msg.sender, amount0, amount1);
}
/// @dev this low-level function should be called from a contract which performs important safety checks
function burn(address to) external lock returns (uint256 amount0, uint256 amount1) {
(uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
(address _token0, address _token1) = (token0, token1);
(uint256 balance0, uint256 balance1) = _getBalances(_token0, _token1);
uint256 liquidity = balanceOf[address(this)];
bool feeOn = _mintFee(_reserve0, _reserve1);
uint256 _totalSupply = totalSupply; // gas savings, must be defined here since totalSupply can update in _mintFee
// using balances ensures pro-rata distribution
amount0 = liquidity.mul(balance0) / _totalSupply;
amount1 = liquidity.mul(balance1) / _totalSupply;
require(amount0 > 0 && amount1 > 0, "ZF: INSUFFICIENT_LIQUIDITY_BURNED");
_burn(address(this), liquidity);
_safeTransfer(_token0, to, amount0);
_safeTransfer(_token1, to, amount1);
(balance0, balance1) = _getBalances(_token0, _token1);
_update(balance0, balance1, _reserve0, _reserve1);
if (feeOn) kLast = uint256(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
emit Burn(msg.sender, amount0, amount1, to);
}
/// @dev this low-level function should be called from a contract which performs important safety checks
function swap(uint256 amount0Out, uint256 amount1Out, address to, bytes calldata data) external lock {
require(amount0Out > 0 || amount1Out > 0, "ZF: INSUFFICIENT_OUTPUT_AMOUNT");
(uint112 _reserve0, uint112 _reserve1,) = getReserves();
require(amount0Out < _reserve0 && amount1Out < _reserve1, "ZF: INSUFFICIENT_LIQUIDITY");
uint256 balance0;
uint256 balance1;
{
// scope for _token{0,1}, avoids stack too deep errors
(address _token0, address _token1) = (token0, token1);
require(to != _token0 && to != _token1, "ZF: INVALID_TO");
if (amount0Out > 0) _safeTransfer(_token0, to, amount0Out); // optimistically transfer tokens
if (amount1Out > 0) _safeTransfer(_token1, to, amount1Out); // optimistically transfer tokens
if (data.length > 0) IUniswapV2Callee(to).uniswapV2Call(msg.sender, amount0Out, amount1Out, data);
(balance0, balance1) = _getBalances(_token0, _token1);
}
// At least one input is required.
uint256 amount0In = balance0 > _reserve0 - amount0Out ? balance0 - (_reserve0 - amount0Out) : 0;
uint256 amount1In = balance1 > _reserve1 - amount1Out ? balance1 - (_reserve1 - amount1Out) : 0;
require(amount0In > 0 || amount1In > 0, "ZF: INSUFFICIENT_INPUT_AMOUNT");
{
// Checks the K.
uint16 _swapFee = getSwapFee();
uint256 balance0Adjusted = (balance0.mul(SWAP_FEE_POINT_PRECISION).sub(amount0In.mul(_swapFee)));
uint256 balance1Adjusted = (balance1.mul(SWAP_FEE_POINT_PRECISION).sub(amount1In.mul(_swapFee)));
require(
balance0Adjusted.mul(balance1Adjusted)
>= uint256(_reserve0).mul(_reserve1).mul(SWAP_FEE_POINT_PRECISION_SQ),
"ZF: K"
);
}
_update(balance0, balance1, _reserve0, _reserve1);
emit Swap(msg.sender, amount0In, amount1In, amount0Out, amount1Out, to);
}
/**
* @dev Force balances to match reserves, taking out positive balances
*/
function skim(address to) external lock {
address _token0 = token0;
address _token1 = token1;
(uint256 balance0, uint256 balance1) = _getBalances(_token0, _token1);
_safeTransfer(_token0, to, balance0.sub(reserve0));
_safeTransfer(_token1, to, balance1.sub(reserve1));
}
/**
* @dev Force reserves to match balances
*/
function sync() external lock {
(uint256 balance0, uint256 balance1) = _getBalances(token0, token1);
_update(balance0, balance1, reserve0, reserve1);
}
/// @dev called by the factory to set the swapFeeOverride
function setSwapFeeOverride(uint16 _swapFeeOverride) external {
require(msg.sender == factory, "ZF: FORBIDDEN");
require(_swapFeeOverride <= 1000 || _swapFeeOverride == SWAP_FEE_INHERIT, "INVALID_FEE"); //max 10%
swapFeeOverride = _swapFeeOverride;
}
/// @dev Called by factory to set pair-specific protocol fee
function setProtocolFeeOverride(uint16 _protocolFee) external {
require(msg.sender == factory, "ZF: FORBIDDEN");
require(_protocolFee <= PROTOCOL_FEE_POINT_PRECISION, "INVALID PROTOCOL_FEE"); // max 100%
protocolFeeOverride = _protocolFee;
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.5.0;
interface IZFPair {
event Approval(address indexed owner, address indexed spender, uint256 value);
event Transfer(address indexed from, address indexed to, uint256 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 (uint256);
function balanceOf(address owner) external view returns (uint256);
function allowance(address owner, address spender) external view returns (uint256);
function approve(address spender, uint256 value) external returns (bool);
function transfer(address to, uint256 value) external returns (bool);
function transferFrom(address from, address to, uint256 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 (uint256);
function permit(address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s)
external;
event Mint(address indexed sender, uint256 amount0, uint256 amount1);
event Burn(address indexed sender, uint256 amount0, uint256 amount1, address indexed to);
event Swap(
address indexed sender,
uint256 amount0In,
uint256 amount1In,
uint256 amount0Out,
uint256 amount1Out,
address indexed to
);
event Sync(uint112 reserve0, uint112 reserve1);
// function MINIMUM_LIQUIDITY() external pure returns (uint256);
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 getReservesAndParameters() external view returns (uint112 reserve0, uint112 reserve1, uint16 swapFee);
function price0CumulativeLast() external view returns (uint256);
function price1CumulativeLast() external view returns (uint256);
function kLast() external view returns (uint256);
function mint(address to) external returns (uint256 liquidity);
function burn(address to) external returns (uint256 amount0, uint256 amount1);
function swap(uint256 amount0Out, uint256 amount1Out, address to, bytes calldata data) external;
function skim(address to) external;
function sync() external;
function initialize(address, address) external;
}// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.5.0;
interface IZFFactory {
event PairCreated(address indexed token0, address indexed token1, address pair, uint256);
function feeTo() external view returns (address);
function feeToSetter() external view returns (address);
function getPair(address tokenA, address tokenB) external view returns (address pair);
function allPairs(uint256) external view returns (address pair);
function allPairsLength() external view returns (uint256);
function createPair(address tokenA, address tokenB) external returns (address pair);
function setFeeTo(address) external;
function setFeeToSetter(address) external;
function INIT_CODE_PAIR_HASH() external view returns (bytes32);
function swapFee() external view returns (uint16);
function protocolFee() external view returns (uint16);
function setSwapFee(uint16 newFee) external;
function setProtocolFee(uint16 newFee) external;
function setSwapFeeOverride(address pair, uint16 swapFeeOverride) external;
function setProtocolFeeOverride(address pair, uint16 protocolFeeOverride) external;
}// SPDX-License-Identifier: AGPL-3.0-or-later
pragma solidity >=0.5.0;
/// @dev Uniswap V2 callee interface
interface IUniswapV2Callee {
function uniswapV2Call(address sender, uint256 amount0, uint256 amount1, bytes calldata data) external;
}// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;
import "./interfaces/IZFERC20.sol";
import "./libraries/SafeMath.sol";
contract ZFERC20 is IZFERC20 {
using SafeMath for uint256;
string public constant name = "zkSwap Finance LPs";
string public constant symbol = "ZF-LP";
uint8 public constant decimals = 18;
uint256 public totalSupply;
mapping(address => uint256) public balanceOf;
mapping(address => mapping(address => uint256)) public allowance;
bytes32 public DOMAIN_SEPARATOR;
// keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
bytes32 public constant PERMIT_TYPEHASH = 0x6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9;
mapping(address => uint256) public nonces;
event Approval(address indexed owner, address indexed spender, uint256 value);
event Transfer(address indexed from, address indexed to, uint256 value);
constructor() public {
uint256 chainId;
assembly {
chainId := chainid()
}
DOMAIN_SEPARATOR = keccak256(
abi.encode(
keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"),
keccak256(bytes(name)),
keccak256(bytes("1")),
chainId,
address(this)
)
);
}
function _mint(address to, uint256 value) internal {
totalSupply = totalSupply.add(value);
balanceOf[to] = balanceOf[to].add(value);
emit Transfer(address(0), to, value);
}
function _burn(address from, uint256 value) internal {
balanceOf[from] = balanceOf[from].sub(value);
totalSupply = totalSupply.sub(value);
emit Transfer(from, address(0), value);
}
function _approve(address owner, address spender, uint256 value) private {
allowance[owner][spender] = value;
emit Approval(owner, spender, value);
}
function _transfer(address from, address to, uint256 value) private {
balanceOf[from] = balanceOf[from].sub(value);
balanceOf[to] = balanceOf[to].add(value);
emit Transfer(from, to, value);
}
function approve(address spender, uint256 value) external returns (bool) {
_approve(msg.sender, spender, value);
return true;
}
function transfer(address to, uint256 value) external returns (bool) {
_transfer(msg.sender, to, value);
return true;
}
function transferFrom(address from, address to, uint256 value) external returns (bool) {
if (allowance[from][msg.sender] != uint256(-1)) {
allowance[from][msg.sender] = allowance[from][msg.sender].sub(value);
}
_transfer(from, to, value);
return true;
}
function permit(address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s)
external
{
require(deadline >= block.timestamp, "ZF: EXPIRED");
bytes32 digest = keccak256(
abi.encodePacked(
"\x19\x01",
DOMAIN_SEPARATOR,
keccak256(abi.encode(PERMIT_TYPEHASH, owner, spender, value, nonces[owner]++, deadline))
)
);
address recoveredAddress = ecrecover(digest, v, r, s);
require(recoveredAddress != address(0) && recoveredAddress == owner, "ZF: INVALID_SIGNATURE");
_approve(owner, spender, value);
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;
// a library for performing various math operations
library Math {
function min(uint256 x, uint256 y) internal pure returns (uint256 z) {
z = x < y ? x : y;
}
// babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method)
function sqrt(uint256 y) internal pure returns (uint256 z) {
if (y > 3) {
z = y;
uint256 x = y / 2 + 1;
while (x < z) {
z = x;
x = (y / x + x) / 2;
}
} else if (y != 0) {
z = 1;
}
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;
// a library for handling binary fixed point numbers (https://en.wikipedia.org/wiki/Q_(number_format))
// range: [0, 2**112 - 1]
// resolution: 1 / 2**112
library UQ112x112 {
uint224 constant Q112 = 2 ** 112;
// encode a uint112 as a UQ112x112
function encode(uint112 y) internal pure returns (uint224 z) {
z = uint224(y) * Q112; // never overflows
}
// divide a UQ112x112 by a uint112, returning a UQ112x112
function uqdiv(uint224 x, uint112 y) internal pure returns (uint224 z) {
z = x / uint224(y);
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.5.0;
interface IERC20 {
event Approval(address indexed owner, address indexed spender, uint256 value);
event Transfer(address indexed from, address indexed to, uint256 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 (uint256);
function balanceOf(address owner) external view returns (uint256);
function allowance(address owner, address spender) external view returns (uint256);
function approve(address spender, uint256 value) external returns (bool);
function transfer(address to, uint256 value) external returns (bool);
function transferFrom(address from, address to, uint256 value) external returns (bool);
}// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.5.0 <0.7.0;
// a library for performing overflow-safe math, courtesy of DappHub (https://github.com/dapphub/ds-math)
library SafeMath {
function add(uint256 x, uint256 y) internal pure returns (uint256 z) {
require((z = x + y) >= x, "ds-math-add-overflow");
}
function sub(uint256 x, uint256 y) internal pure returns (uint256 z) {
require((z = x - y) <= x, "ds-math-sub-underflow");
}
function mul(uint256 x, uint256 y) internal pure returns (uint256 z) {
require(y == 0 || (z = x * y) / y == x, "ds-math-mul-overflow");
}
}// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.5.0;
interface IZFERC20 {
event Approval(address indexed owner, address indexed spender, uint256 value);
event Transfer(address indexed from, address indexed to, uint256 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 (uint256);
function balanceOf(address owner) external view returns (uint256);
function allowance(address owner, address spender) external view returns (uint256);
function approve(address spender, uint256 value) external returns (bool);
function transfer(address to, uint256 value) external returns (bool);
function transferFrom(address from, address to, uint256 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 (uint256);
function permit(address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s)
external;
}{
"remappings": [
"forge-std/=vendor/forge-std/src/",
"@openzeppelin/contracts/=vendor/openzeppelin-contracts-v3.4.2-solc-0.7/contracts/",
"solmate/src/=vendor/solmate/src/",
"solidity-bytes-utils/contracts/=vendor/solidity-bytes-utils/contracts/",
"@uniswap/lib/contracts/=vendor/solidity-lib/contracts/",
"@zf/=vendor/@zf/",
"base64-sol/=vendor/base64-sol/",
"devtools/=vendor/devtools/",
"ds-test/=vendor/ds-test/src/",
"layerzero-v2/=vendor/layerzero-v2/",
"openzeppelin-contracts-upgradeable-v5.2.0/=vendor/openzeppelin-contracts-upgradeable-v5.2.0/contracts/",
"openzeppelin-contracts-v3.4.2-solc-0.7/=vendor/openzeppelin-contracts-v3.4.2-solc-0.7/contracts/",
"openzeppelin-contracts-v4.9.3/=vendor/openzeppelin-contracts-v4.9.3/contracts/",
"openzeppelin-contracts-v5.2.0/=vendor/openzeppelin-contracts-v5.2.0/contracts/",
"solidity-lib/=vendor/solidity-lib/contracts/",
"uniswap-v2-core/=vendor/uniswap-v2-core/contracts/"
],
"optimizer": {
"enabled": true,
"runs": 200
},
"metadata": {
"useLiteralContent": false
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
},
"evmVersion": "istanbul"
}Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"address","name":"_feeToSetter","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"feeTo","type":"address"}],"name":"FeeToSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"feeToSetter","type":"address"}],"name":"FeeToSetterSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"token0","type":"address"},{"indexed":true,"internalType":"address","name":"token1","type":"address"},{"indexed":false,"internalType":"address","name":"pair","type":"address"},{"indexed":false,"internalType":"uint256","name":"allPairsLength","type":"uint256"}],"name":"PairCreated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":false,"internalType":"uint16","name":"protocolFeeOverride","type":"uint16"}],"name":"ProtocolFeeOverrideSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint16","name":"newProtocolFee","type":"uint16"}],"name":"ProtocolFeeSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":false,"internalType":"uint16","name":"swapFeeOverride","type":"uint16"}],"name":"SwapFeeOverrideSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint16","name":"newSwapFee","type":"uint16"}],"name":"SwapFeeSet","type":"event"},{"constant":true,"inputs":[],"name":"INIT_CODE_PAIR_HASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"allPairs","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"allPairsLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"tokenA","type":"address"},{"internalType":"address","name":"tokenB","type":"address"}],"name":"createPair","outputs":[{"internalType":"address","name":"pair","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"feeTo","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"feeToSetter","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"getPair","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"protocolFee","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_feeTo","type":"address"}],"name":"setFeeTo","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_feeToSetter","type":"address"}],"name":"setFeeToSetter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint16","name":"_newFee","type":"uint16"}],"name":"setProtocolFee","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_pair","type":"address"},{"internalType":"uint16","name":"_protocolFeeOverride","type":"uint16"}],"name":"setProtocolFeeOverride","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint16","name":"_newFee","type":"uint16"}],"name":"setSwapFee","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_pair","type":"address"},{"internalType":"uint16","name":"_swapFeeOverride","type":"uint16"}],"name":"setSwapFeeOverride","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"swapFee","outputs":[{"internalType":"uint16","name":"","type":"uint16"}],"payable":false,"stateMutability":"view","type":"function"}]Contract Creation Code
608060405260048054601461ffff199091161763ffff00001916630c80000017905534801561002d57600080fd5b506040516131833803806131838339818101604052602081101561005057600080fd5b5051600180546001600160a01b0319166001600160a01b03909216919091179055613103806100806000396000f3fe608060405234801561001057600080fd5b50600436106100f55760003560e01c80637074c6c611610097578063c9c6539611610066578063c9c6539614610235578063e4467f3514610263578063e6a4390514610284578063f46901ed146102b2576100f5565b80637074c6c6146101b65780639cd05bfd146101e6578063a2e74af614610207578063b0e21e8a1461022d576100f5565b80631e3dd18b116100d35780631e3dd18b1461015857806354cf2aeb14610175578063574f2ba3146101945780635855a25a146101ae576100f5565b8063017e7e58146100fa57806307cd27571461011e578063094b741514610150575b600080fd5b6101026102d8565b604080516001600160a01b039092168252519081900360200190f35b61014e6004803603604081101561013457600080fd5b5080356001600160a01b0316906020013561ffff166102e7565b005b6101026103e0565b6101026004803603602081101561016e57600080fd5b50356103ef565b61017d610416565b6040805161ffff9092168252519081900360200190f35b61019c610420565b60408051918252519081900360200190f35b61019c610426565b61014e600480360360408110156101cc57600080fd5b5080356001600160a01b0316906020013561ffff166104b9565b61014e600480360360208110156101fc57600080fd5b503561ffff166105b2565b61014e6004803603602081101561021d57600080fd5b50356001600160a01b031661069e565b61017d610737565b6101026004803603604081101561024b57600080fd5b506001600160a01b0381358116916020013516610747565b61014e6004803603602081101561027957600080fd5b503561ffff16610abe565b6101026004803603604081101561029a57600080fd5b506001600160a01b0381358116916020013516610bbc565b61014e600480360360208110156102c857600080fd5b50356001600160a01b0316610be2565b6000546001600160a01b031681565b6001546001600160a01b03163314610336576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6040805163731315ab60e11b815261ffff8316600482015290516001600160a01b0384169163e6262b5691602480830192600092919082900301818387803b15801561038157600080fd5b505af1158015610395573d6000803e3d6000fd5b50506040805161ffff8516815290516001600160a01b03861693507fab255117c9b60bfc6d2c214487e52244310800a0ea02febbdadf7f8c77fcebfa92509081900360200190a25050565b6001546001600160a01b031681565b600381815481106103fc57fe5b6000918252602090912001546001600160a01b0316905081565b60045461ffff1681565b60035490565b60405161043560208201610c79565b6020820181038252601f19601f820116604052506040516020018082805190602001908083835b6020831061047b5780518252601f19909201916020918201910161045c565b6001836020036101000a0380198251168184511680821785525050505050509050019150506040516020818303038152906040528051906020012081565b6001546001600160a01b03163314610508576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b60408051634d6a675f60e11b815261ffff8316600482015290516001600160a01b03841691639ad4cebe91602480830192600092919082900301818387803b15801561055357600080fd5b505af1158015610567573d6000803e3d6000fd5b50506040805161ffff8516815290516001600160a01b03861693507f924b4791b7c55a990c08d388d91b326029348d49513924796352cd511fcc127f92509081900360200190a25050565b6001546001600160a01b03163314610601576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6103e88161ffff161115610654576040805162461bcd60e51b81526020600482015260156024820152740b48c7440a6ae82a0be8c8a8abea89e9ebe90928e9605b1b604482015290519081900360640190fd5b6004805461ffff831661ffff19909116811790915560408051918252517f314601873cd91fabbbd5895f1406000e6b4aac39146f61b73890fa37c8ebf7ae9181900360200190a150565b6001546001600160a01b031633146106ed576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600180546001600160a01b0319166001600160a01b0383169081179091556040517f8008d425488ae0d33c41ff5a8b69005015ef67d5d450003935eb06ab91e0679c90600090a250565b60045462010000900461ffff1681565b6000816001600160a01b0316836001600160a01b031614156107b0576040805162461bcd60e51b815260206004820152601760248201527f5a463a204944454e544943414c5f414444524553534553000000000000000000604482015290519081900360640190fd5b600080836001600160a01b0316856001600160a01b0316106107d35783856107d6565b84845b90925090506001600160a01b038216610829576040805162461bcd60e51b815260206004820152601060248201526f5a463a205a45524f5f4144445245535360801b604482015290519081900360640190fd5b6001600160a01b03828116600090815260026020908152604080832085851684529091529020541615610895576040805162461bcd60e51b815260206004820152600f60248201526e5a463a20504149525f45584953545360881b604482015290519081900360640190fd5b6060604051806020016108a790610c79565b6020820181038252601f19601f8201166040525090506000838360405160200180836001600160a01b03166001600160a01b031660601b8152601401826001600160a01b03166001600160a01b031660601b815260140192505050604051602081830303815290604052805190602001209050808251602084016000f594506001600160a01b038516610981576040805162461bcd60e51b815260206004820152601960248201527f5a463a204641494c45445f544f5f4352454154455f5041495200000000000000604482015290519081900360640190fd5b6040805163485cc95560e01b81526001600160a01b038681166004830152858116602483015291519187169163485cc9559160448082019260009290919082900301818387803b1580156109d457600080fd5b505af11580156109e8573d6000803e3d6000fd5b505050506001600160a01b0384811660008181526002602081815260408084208987168086529083528185208054978d166001600160a01b031998891681179091559383528185208686528352818520805488168517905560038054600181018255958190527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b90950180549097168417909655925483519283529082015281517f0d3648bd0f6ba80134a33ba9275ac585d9d315f0ad8355cddefde31afa28d0e9929181900390910190a35050505092915050565b6001546001600160a01b03163314610b0d576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6127108161ffff161115610b68576040805162461bcd60e51b815260206004820152601860248201527f5a463a20494e56414c49445f50524f544f434f4c5f4645450000000000000000604482015290519081900360640190fd5b6004805461ffff831662010000810263ffff0000199092169190911790915560408051918252517f344ed1ad4ddd7e63e04403811e38058895ef7a656bf6d5b25d219e0083c227e69181900360200190a150565b60026020908152600092835260408084209091529082529020546001600160a01b031681565b6001546001600160a01b03163314610c31576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600080546001600160a01b0319166001600160a01b038316908117825560405190917fe7ba424f407983edfb652af33e51f926d1d41a22bb4850c65eb21c02e378957c91a250565b61244880610c878339019056fe6080604052600c805463ffff00001961ffff1990911661ffff171663ffff00001790556001600d5534801561003357600080fd5b5060405146908060526123f6823960408051918290036052018220828201825260128352717a6b537761702046696e616e6365204c507360701b6020938401528151808301835260018152603160f81b908401528151808401919091527f9c76b5368302e73f1273e0ce9f9a5e5a332502f2309fd9cf48cd77135c7b89b8818301527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606082015260808101949094523060a0808601919091528151808603909101815260c09094019052825192019190912060035550600580546001600160a01b031916331790556122cb8061012b6000396000f3fe608060405234801561001057600080fd5b50600436106102065760003560e01c806370a082311161011a578063bc25cf77116100ad578063d505accf1161007c578063d505accf14610617578063dd62ed3e14610668578063e5ba6dad14610696578063e6262b56146106cc578063fff6cae9146106ed57610206565b8063bc25cf77146105d9578063c45a0155146105ff578063d21220a714610607578063d4cadf681461060f57610206565b806395d89b41116100e957806395d89b411461057c5780639ad4cebe14610584578063a5a41031146105a5578063a9059cbb146105ad57610206565b806370a08231146104e95780637464fc3d1461050f5780637ecebe001461051757806389afcb441461053d57610206565b806330adf81f1161019d5780635909c0d51161016c5780635909c0d51461047d5780635a3d54931461048557806365193e911461048d57806365d176f5146104955780636a627842146104c357610206565b806330adf81f14610421578063313ce567146104295780633644e51514610447578063485cc9551461044f57610206565b8063095ea7b3116101d9578063095ea7b31461036d5780630dfe1681146103ad57806318160ddd146103d157806323b872dd146103eb57610206565b8063022c0d9f1461020b57806306fdde0314610299578063077cd3c3146103165780630902f1ac14610335575b600080fd5b6102976004803603608081101561022157600080fd5b8135916020810135916001600160a01b03604083013516919081019060808101606082013564010000000081111561025857600080fd5b82018360208201111561026a57600080fd5b8035906020019184600183028401116401000000008311171561028c57600080fd5b5090925090506106f5565b005b6102a1610b96565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102db5781810151838201526020016102c3565b50505050905090810190601f1680156103085780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61031e610bc4565b6040805161ffff9092168252519081900360200190f35b61033d610bd4565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b6103996004803603604081101561038357600080fd5b506001600160a01b038135169060200135610bfe565b604080519115158252519081900360200190f35b6103b5610c15565b604080516001600160a01b039092168252519081900360200190f35b6103d9610c24565b60408051918252519081900360200190f35b6103996004803603606081101561040157600080fd5b506001600160a01b03813581169160208101359091169060400135610c2a565b6103d9610cc4565b610431610ce8565b6040805160ff9092168252519081900360200190f35b6103d9610ced565b6102976004803603604081101561046557600080fd5b506001600160a01b0381358116916020013516610cf3565b6103d9610d70565b6103d9610d76565b61031e610d7c565b61049d610d86565b604080516001600160701b03938416815291909216602082015281519081900390910190f35b6103d9600480360360208110156104d957600080fd5b50356001600160a01b0316610da1565b6103d9600480360360208110156104ff57600080fd5b50356001600160a01b0316610fc8565b6103d9610fda565b6103d96004803603602081101561052d57600080fd5b50356001600160a01b0316610fe0565b6105636004803603602081101561055357600080fd5b50356001600160a01b0316610ff2565b6040805192835260208301919091528051918290030190f35b6102a16111e0565b6102976004803603602081101561059a57600080fd5b503561ffff16611201565b6103d96112c2565b610399600480360360408110156105c357600080fd5b506001600160a01b038135169060200135611366565b610297600480360360208110156105ef57600080fd5b50356001600160a01b0316611373565b6103b561143f565b6103b561144e565b61031e61145d565b610297600480360360e081101561062d57600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c001356114f7565b6103d96004803603604081101561067e57600080fd5b506001600160a01b03813581169160200135166116ea565b61069e611707565b604080516001600160701b03948516815292909316602083015261ffff168183015290519081900360600190f35b610297600480360360208110156106e257600080fd5b503561ffff1661172f565b6102976117ed565b600d54600114610739576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d558415158061074c5750600084115b61079d576040805162461bcd60e51b815260206004820152601e60248201527f5a463a20494e53554646494349454e545f4f55545055545f414d4f554e540000604482015290519081900360640190fd5b6000806107a8610bd4565b5091509150816001600160701b0316871080156107cd5750806001600160701b031686105b61081e576040805162461bcd60e51b815260206004820152601a60248201527f5a463a20494e53554646494349454e545f4c4951554944495459000000000000604482015290519081900360640190fd5b60065460075460009182916001600160a01b0391821691908116908916821480159061085c5750806001600160a01b0316896001600160a01b031614155b61089e576040805162461bcd60e51b815260206004820152600e60248201526d5a463a20494e56414c49445f544f60901b604482015290519081900360640190fd5b8a156108af576108af828a8d611888565b89156108c0576108c0818a8c611888565b861561097b57886001600160a01b03166310d1e85c338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03166001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561096257600080fd5b505af1158015610976573d6000803e3d6000fd5b505050505b6109858282611a18565b909450925060009150506001600160701b0385168a900383116109a95760006109b8565b89856001600160701b03160383035b9050600089856001600160701b03160383116109d55760006109e4565b89856001600160701b03160383035b905060008211806109f55750600081115b610a46576040805162461bcd60e51b815260206004820152601d60248201527f5a463a20494e53554646494349454e545f494e5055545f414d4f554e54000000604482015290519081900360640190fd5b6000610a5061145d565b90506000610a89610a6b8561ffff851663ffffffff611b0c16565b610a7d8861271063ffffffff611b0c16565b9063ffffffff611b6f16565b90506000610aa4610a6b8561ffff861663ffffffff611b0c16565b9050610ad66305f5e100610aca6001600160701b038c8116908c1663ffffffff611b0c16565b9063ffffffff611b0c16565b610ae6838363ffffffff611b0c16565b1015610b21576040805162461bcd60e51b81526020600482015260056024820152645a463a204b60d81b604482015290519081900360640190fd5b505050610b3084848888611bbf565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600d55505050505050505050565b604051806040016040528060128152602001717a6b537761702046696e616e6365204c507360701b81525081565b600c5462010000900461ffff1681565b6008546001600160701b0380821692600160701b830490911691600160e01b900463ffffffff1690565b6000610c0b338484611d7d565b5060015b92915050565b6006546001600160a01b031681565b60005481565b6001600160a01b038316600090815260026020908152604080832033845290915281205460001914610caf576001600160a01b0384166000908152600260209081526040808320338452909152902054610c8a908363ffffffff611b6f16565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610cba848484611ddf565b5060019392505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b601281565b60035481565b6005546001600160a01b03163314610d42576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b60095481565b600a5481565b600c5461ffff1681565b6008546001600160701b0380821691600160701b9004169091565b6000600d54600114610de7576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d81905580610df7610bd4565b506006546007549294509092506000918291610e1f916001600160a01b039182169116611a18565b90925090506000610e3f836001600160701b03871663ffffffff611b6f16565b90506000610e5c836001600160701b03871663ffffffff611b6f16565b90506000610e6a8787611e99565b60005490915080610ea757610e936103e8610a7d610e8e878763ffffffff611b0c16565b611fad565b9850610ea260006103e8611fff565b610ef6565b610ef36001600160701b038916610ec4868463ffffffff611b0c16565b81610ecb57fe5b046001600160701b038916610ee6868563ffffffff611b0c16565b81610eed57fe5b04612095565b98505b60008911610f355760405162461bcd60e51b81526004018080602001828103825260218152602001806122556021913960400191505060405180910390fd5b610f3f8a8a611fff565b610f4b86868a8a611bbf565b8115610f7b57600854610f77906001600160701b0380821691600160701b90041663ffffffff611b0c16565b600b555b6040805185815260208101859052815133927f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f928290030190a250506001600d5550949695505050505050565b60016020526000908152604090205481565b600b5481565b60046020526000908152604090205481565b600080600d54600114611039576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d81905580611049610bd4565b506006546007549294509092506001600160a01b0390811691166000806110708484611a18565b306000908152600160205260408120549294509092506110908888611e99565b600054909150806110a7848763ffffffff611b0c16565b816110ae57fe5b049a50806110c2848663ffffffff611b0c16565b816110c957fe5b04995060008b1180156110dc575060008a115b6111175760405162461bcd60e51b81526004018080602001828103825260218152602001806122766021913960400191505060405180910390fd5b61112130846120ad565b61112c878d8d611888565b611137868d8c611888565b6111418787611a18565b909550935061115285858b8b611bbf565b81156111825760085461117e906001600160701b0380821691600160701b90041663ffffffff611b0c16565b600b555b604080518c8152602081018c905281516001600160a01b038f169233927fdccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496929081900390910190a35050505050505050506001600d81905550915091565b6040518060400160405280600581526020016405a462d4c560dc1b81525081565b6005546001600160a01b03163314611250576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6127108161ffff1611156112a2576040805162461bcd60e51b8152602060048201526014602482015273494e56414c49442050524f544f434f4c5f46454560601b604482015290519081900360640190fd5b600c805461ffff909216620100000263ffff000019909216919091179055565b600c5460009061ffff6201000090910481169081146112e1578061135c565b600560009054906101000a90046001600160a01b03166001600160a01b031663b0e21e8a6040518163ffffffff1660e01b815260040160206040518083038186803b15801561132f57600080fd5b505afa158015611343573d6000803e3d6000fd5b505050506040513d602081101561135957600080fd5b50515b61ffff1691505090565b6000610c0b338484611ddf565b600d546001146113b7576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d8190556006546007546001600160a01b0391821692911690806113de8484611a18565b600854919350915061140d90859087906114089086906001600160701b031663ffffffff611b6f16565b611888565b6008546114339084908790611408908590600160701b90046001600160701b0316611b6f565b50506001600d55505050565b6005546001600160a01b031681565b6007546001600160a01b031681565b600c5460009061ffff90811690811461147657806114f1565b600560009054906101000a90046001600160a01b03166001600160a01b03166354cf2aeb6040518163ffffffff1660e01b815260040160206040518083038186803b1580156114c457600080fd5b505afa1580156114d8573d6000803e3d6000fd5b505050506040513d60208110156114ee57600080fd5b50515b91505090565b4284101561153a576040805162461bcd60e51b815260206004820152600b60248201526a16918e881156141254915160aa1b604482015290519081900360640190fd5b6003546001600160a01b0380891660008181526004602090815260408083208054600180820190925582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e280820193601f1981019281900390910190855afa158015611655573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381161580159061168b5750886001600160a01b0316816001600160a01b0316145b6116d4576040805162461bcd60e51b81526020600482015260156024820152745a463a20494e56414c49445f5349474e415455524560581b604482015290519081900360640190fd5b6116df898989611d7d565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b6008546001600160701b0380821691600160701b900416600061172861145d565b9050909192565b6005546001600160a01b0316331461177e576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6103e88161ffff16111580611796575061ffff818116145b6117d5576040805162461bcd60e51b815260206004820152600b60248201526a494e56414c49445f46454560a81b604482015290519081900360640190fd5b600c805461ffff191661ffff92909216919091179055565b600d54600114611831576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d8190556006546007548291611856916001600160a01b039182169116611a18565b600854919350915061187f90839083906001600160701b0380821691600160701b900416611bbf565b50506001600d55565b604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009460609489169392918291908083835b602083106119355780518252601f199092019160209182019101611916565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114611997576040519150601f19603f3d011682016040523d82523d6000602084013e61199c565b606091505b50915091508180156119ca5750805115806119ca57508080602001905160208110156119c757600080fd5b50515b611a11576040805162461bcd60e51b815260206004820152601360248201527216918e881514905394d1915497d19052531151606a1b604482015290519081900360640190fd5b5050505050565b604080516370a0823160e01b8152306004820152905160009182916001600160a01b038616916370a08231916024808301926020929190829003018186803b158015611a6357600080fd5b505afa158015611a77573d6000803e3d6000fd5b505050506040513d6020811015611a8d57600080fd5b5051604080516370a0823160e01b815230600482015290516001600160a01b038616916370a08231916024808301926020929190829003018186803b158015611ad557600080fd5b505afa158015611ae9573d6000803e3d6000fd5b505050506040513d6020811015611aff57600080fd5b5051909590945092505050565b6000811580611b2757505080820282828281611b2457fe5b04145b610c0f576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6d756c2d6f766572666c6f7760601b604482015290519081900360640190fd5b80820382811115610c0f576040805162461bcd60e51b815260206004820152601560248201527464732d6d6174682d7375622d756e646572666c6f7760581b604482015290519081900360640190fd5b6001600160701b038411801590611bdd57506001600160701b038311155b611c1d576040805162461bcd60e51b815260206004820152600c60248201526b5a463a204f564552464c4f5760a01b604482015290519081900360640190fd5b60085463ffffffff42811691600160e01b90048116820390811615801590611c4d57506001600160701b03841615155b8015611c6157506001600160701b03831615155b15611cd2578063ffffffff16611c8f85611c7a8661214b565b6001600160e01b03169063ffffffff61215d16565b600980546001600160e01b03929092169290920201905563ffffffff8116611cba84611c7a8761214b565b600a80546001600160e01b0392909216929092020190555b600880546dffffffffffffffffffffffffffff19166001600160701b03888116919091176dffffffffffffffffffffffffffff60701b1916600160701b8883168102919091176001600160e01b0316600160e01b63ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316600090815260016020526040902054611e08908263ffffffff611b6f16565b6001600160a01b038085166000908152600160205260408082209390935590841681522054611e3d908263ffffffff61218216565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b600080600560009054906101000a90046001600160a01b03166001600160a01b031663017e7e586040518163ffffffff1660e01b815260040160206040518083038186803b158015611eea57600080fd5b505afa158015611efe573d6000803e3d6000fd5b505050506040513d6020811015611f1457600080fd5b5051600b546001600160a01b038216158015945091925090611f99578015611f94576000611f57610e8e6001600160701b0388811690881663ffffffff611b0c16565b90506000611f6483611fad565b905080821115611f91576000611f7d60005484846121d1565b90508015611f8f57611f8f8582611fff565b505b50505b611fa5565b8015611fa5576000600b555b505092915050565b60006003821115611ff0575080600160028204015b81811015611fea57809150600281828581611fd957fe5b040181611fe257fe5b049050611fc2565b50611ffa565b8115611ffa575060015b919050565b600054612012908263ffffffff61218216565b60009081556001600160a01b03831681526001602052604090205461203d908263ffffffff61218216565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b60008183106120a457816120a6565b825b9392505050565b6001600160a01b0382166000908152600160205260409020546120d6908263ffffffff611b6f16565b6001600160a01b03831660009081526001602052604081209190915554612103908263ffffffff611b6f16565b60009081556040805183815290516001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a35050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b0384168161217a57fe5b049392505050565b80820182811015610c0f576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6164642d6f766572666c6f7760601b604482015290519081900360640190fd5b6000806121dc6112c2565b9050600061220482610aca6121f7888863ffffffff611b6f16565b899063ffffffff611b0c16565b9050600061223d61221b868563ffffffff611b0c16565b61223188610aca6127108863ffffffff611b6f16565b9063ffffffff61218216565b905080828161224857fe5b0497965050505050505056fe5a463a20494e53554646494349454e545f4c49515549444954595f4d494e5445445a463a20494e53554646494349454e545f4c49515549444954595f4255524e4544a265627a7a723158205462e560a0a7a6eb0fbbb9089aa0a37e07e39c0f23a5e6c377cc60e33ab7f0b764736f6c63430005100032454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429a265627a7a7231582047b32ee559231eb91e50d2d4b2078d75816bdcfd9591a7d7886137e61893022664736f6c634300051000320000000000000000000000004bc9b68c77a9cd6071a21c6d9d4ae7f2ee921960
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106100f55760003560e01c80637074c6c611610097578063c9c6539611610066578063c9c6539614610235578063e4467f3514610263578063e6a4390514610284578063f46901ed146102b2576100f5565b80637074c6c6146101b65780639cd05bfd146101e6578063a2e74af614610207578063b0e21e8a1461022d576100f5565b80631e3dd18b116100d35780631e3dd18b1461015857806354cf2aeb14610175578063574f2ba3146101945780635855a25a146101ae576100f5565b8063017e7e58146100fa57806307cd27571461011e578063094b741514610150575b600080fd5b6101026102d8565b604080516001600160a01b039092168252519081900360200190f35b61014e6004803603604081101561013457600080fd5b5080356001600160a01b0316906020013561ffff166102e7565b005b6101026103e0565b6101026004803603602081101561016e57600080fd5b50356103ef565b61017d610416565b6040805161ffff9092168252519081900360200190f35b61019c610420565b60408051918252519081900360200190f35b61019c610426565b61014e600480360360408110156101cc57600080fd5b5080356001600160a01b0316906020013561ffff166104b9565b61014e600480360360208110156101fc57600080fd5b503561ffff166105b2565b61014e6004803603602081101561021d57600080fd5b50356001600160a01b031661069e565b61017d610737565b6101026004803603604081101561024b57600080fd5b506001600160a01b0381358116916020013516610747565b61014e6004803603602081101561027957600080fd5b503561ffff16610abe565b6101026004803603604081101561029a57600080fd5b506001600160a01b0381358116916020013516610bbc565b61014e600480360360208110156102c857600080fd5b50356001600160a01b0316610be2565b6000546001600160a01b031681565b6001546001600160a01b03163314610336576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6040805163731315ab60e11b815261ffff8316600482015290516001600160a01b0384169163e6262b5691602480830192600092919082900301818387803b15801561038157600080fd5b505af1158015610395573d6000803e3d6000fd5b50506040805161ffff8516815290516001600160a01b03861693507fab255117c9b60bfc6d2c214487e52244310800a0ea02febbdadf7f8c77fcebfa92509081900360200190a25050565b6001546001600160a01b031681565b600381815481106103fc57fe5b6000918252602090912001546001600160a01b0316905081565b60045461ffff1681565b60035490565b60405161043560208201610c79565b6020820181038252601f19601f820116604052506040516020018082805190602001908083835b6020831061047b5780518252601f19909201916020918201910161045c565b6001836020036101000a0380198251168184511680821785525050505050509050019150506040516020818303038152906040528051906020012081565b6001546001600160a01b03163314610508576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b60408051634d6a675f60e11b815261ffff8316600482015290516001600160a01b03841691639ad4cebe91602480830192600092919082900301818387803b15801561055357600080fd5b505af1158015610567573d6000803e3d6000fd5b50506040805161ffff8516815290516001600160a01b03861693507f924b4791b7c55a990c08d388d91b326029348d49513924796352cd511fcc127f92509081900360200190a25050565b6001546001600160a01b03163314610601576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6103e88161ffff161115610654576040805162461bcd60e51b81526020600482015260156024820152740b48c7440a6ae82a0be8c8a8abea89e9ebe90928e9605b1b604482015290519081900360640190fd5b6004805461ffff831661ffff19909116811790915560408051918252517f314601873cd91fabbbd5895f1406000e6b4aac39146f61b73890fa37c8ebf7ae9181900360200190a150565b6001546001600160a01b031633146106ed576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600180546001600160a01b0319166001600160a01b0383169081179091556040517f8008d425488ae0d33c41ff5a8b69005015ef67d5d450003935eb06ab91e0679c90600090a250565b60045462010000900461ffff1681565b6000816001600160a01b0316836001600160a01b031614156107b0576040805162461bcd60e51b815260206004820152601760248201527f5a463a204944454e544943414c5f414444524553534553000000000000000000604482015290519081900360640190fd5b600080836001600160a01b0316856001600160a01b0316106107d35783856107d6565b84845b90925090506001600160a01b038216610829576040805162461bcd60e51b815260206004820152601060248201526f5a463a205a45524f5f4144445245535360801b604482015290519081900360640190fd5b6001600160a01b03828116600090815260026020908152604080832085851684529091529020541615610895576040805162461bcd60e51b815260206004820152600f60248201526e5a463a20504149525f45584953545360881b604482015290519081900360640190fd5b6060604051806020016108a790610c79565b6020820181038252601f19601f8201166040525090506000838360405160200180836001600160a01b03166001600160a01b031660601b8152601401826001600160a01b03166001600160a01b031660601b815260140192505050604051602081830303815290604052805190602001209050808251602084016000f594506001600160a01b038516610981576040805162461bcd60e51b815260206004820152601960248201527f5a463a204641494c45445f544f5f4352454154455f5041495200000000000000604482015290519081900360640190fd5b6040805163485cc95560e01b81526001600160a01b038681166004830152858116602483015291519187169163485cc9559160448082019260009290919082900301818387803b1580156109d457600080fd5b505af11580156109e8573d6000803e3d6000fd5b505050506001600160a01b0384811660008181526002602081815260408084208987168086529083528185208054978d166001600160a01b031998891681179091559383528185208686528352818520805488168517905560038054600181018255958190527fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b90950180549097168417909655925483519283529082015281517f0d3648bd0f6ba80134a33ba9275ac585d9d315f0ad8355cddefde31afa28d0e9929181900390910190a35050505092915050565b6001546001600160a01b03163314610b0d576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6127108161ffff161115610b68576040805162461bcd60e51b815260206004820152601860248201527f5a463a20494e56414c49445f50524f544f434f4c5f4645450000000000000000604482015290519081900360640190fd5b6004805461ffff831662010000810263ffff0000199092169190911790915560408051918252517f344ed1ad4ddd7e63e04403811e38058895ef7a656bf6d5b25d219e0083c227e69181900360200190a150565b60026020908152600092835260408084209091529082529020546001600160a01b031681565b6001546001600160a01b03163314610c31576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600080546001600160a01b0319166001600160a01b038316908117825560405190917fe7ba424f407983edfb652af33e51f926d1d41a22bb4850c65eb21c02e378957c91a250565b61244880610c878339019056fe6080604052600c805463ffff00001961ffff1990911661ffff171663ffff00001790556001600d5534801561003357600080fd5b5060405146908060526123f6823960408051918290036052018220828201825260128352717a6b537761702046696e616e6365204c507360701b6020938401528151808301835260018152603160f81b908401528151808401919091527f9c76b5368302e73f1273e0ce9f9a5e5a332502f2309fd9cf48cd77135c7b89b8818301527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606082015260808101949094523060a0808601919091528151808603909101815260c09094019052825192019190912060035550600580546001600160a01b031916331790556122cb8061012b6000396000f3fe608060405234801561001057600080fd5b50600436106102065760003560e01c806370a082311161011a578063bc25cf77116100ad578063d505accf1161007c578063d505accf14610617578063dd62ed3e14610668578063e5ba6dad14610696578063e6262b56146106cc578063fff6cae9146106ed57610206565b8063bc25cf77146105d9578063c45a0155146105ff578063d21220a714610607578063d4cadf681461060f57610206565b806395d89b41116100e957806395d89b411461057c5780639ad4cebe14610584578063a5a41031146105a5578063a9059cbb146105ad57610206565b806370a08231146104e95780637464fc3d1461050f5780637ecebe001461051757806389afcb441461053d57610206565b806330adf81f1161019d5780635909c0d51161016c5780635909c0d51461047d5780635a3d54931461048557806365193e911461048d57806365d176f5146104955780636a627842146104c357610206565b806330adf81f14610421578063313ce567146104295780633644e51514610447578063485cc9551461044f57610206565b8063095ea7b3116101d9578063095ea7b31461036d5780630dfe1681146103ad57806318160ddd146103d157806323b872dd146103eb57610206565b8063022c0d9f1461020b57806306fdde0314610299578063077cd3c3146103165780630902f1ac14610335575b600080fd5b6102976004803603608081101561022157600080fd5b8135916020810135916001600160a01b03604083013516919081019060808101606082013564010000000081111561025857600080fd5b82018360208201111561026a57600080fd5b8035906020019184600183028401116401000000008311171561028c57600080fd5b5090925090506106f5565b005b6102a1610b96565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102db5781810151838201526020016102c3565b50505050905090810190601f1680156103085780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61031e610bc4565b6040805161ffff9092168252519081900360200190f35b61033d610bd4565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b6103996004803603604081101561038357600080fd5b506001600160a01b038135169060200135610bfe565b604080519115158252519081900360200190f35b6103b5610c15565b604080516001600160a01b039092168252519081900360200190f35b6103d9610c24565b60408051918252519081900360200190f35b6103996004803603606081101561040157600080fd5b506001600160a01b03813581169160208101359091169060400135610c2a565b6103d9610cc4565b610431610ce8565b6040805160ff9092168252519081900360200190f35b6103d9610ced565b6102976004803603604081101561046557600080fd5b506001600160a01b0381358116916020013516610cf3565b6103d9610d70565b6103d9610d76565b61031e610d7c565b61049d610d86565b604080516001600160701b03938416815291909216602082015281519081900390910190f35b6103d9600480360360208110156104d957600080fd5b50356001600160a01b0316610da1565b6103d9600480360360208110156104ff57600080fd5b50356001600160a01b0316610fc8565b6103d9610fda565b6103d96004803603602081101561052d57600080fd5b50356001600160a01b0316610fe0565b6105636004803603602081101561055357600080fd5b50356001600160a01b0316610ff2565b6040805192835260208301919091528051918290030190f35b6102a16111e0565b6102976004803603602081101561059a57600080fd5b503561ffff16611201565b6103d96112c2565b610399600480360360408110156105c357600080fd5b506001600160a01b038135169060200135611366565b610297600480360360208110156105ef57600080fd5b50356001600160a01b0316611373565b6103b561143f565b6103b561144e565b61031e61145d565b610297600480360360e081101561062d57600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c001356114f7565b6103d96004803603604081101561067e57600080fd5b506001600160a01b03813581169160200135166116ea565b61069e611707565b604080516001600160701b03948516815292909316602083015261ffff168183015290519081900360600190f35b610297600480360360208110156106e257600080fd5b503561ffff1661172f565b6102976117ed565b600d54600114610739576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d558415158061074c5750600084115b61079d576040805162461bcd60e51b815260206004820152601e60248201527f5a463a20494e53554646494349454e545f4f55545055545f414d4f554e540000604482015290519081900360640190fd5b6000806107a8610bd4565b5091509150816001600160701b0316871080156107cd5750806001600160701b031686105b61081e576040805162461bcd60e51b815260206004820152601a60248201527f5a463a20494e53554646494349454e545f4c4951554944495459000000000000604482015290519081900360640190fd5b60065460075460009182916001600160a01b0391821691908116908916821480159061085c5750806001600160a01b0316896001600160a01b031614155b61089e576040805162461bcd60e51b815260206004820152600e60248201526d5a463a20494e56414c49445f544f60901b604482015290519081900360640190fd5b8a156108af576108af828a8d611888565b89156108c0576108c0818a8c611888565b861561097b57886001600160a01b03166310d1e85c338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03166001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561096257600080fd5b505af1158015610976573d6000803e3d6000fd5b505050505b6109858282611a18565b909450925060009150506001600160701b0385168a900383116109a95760006109b8565b89856001600160701b03160383035b9050600089856001600160701b03160383116109d55760006109e4565b89856001600160701b03160383035b905060008211806109f55750600081115b610a46576040805162461bcd60e51b815260206004820152601d60248201527f5a463a20494e53554646494349454e545f494e5055545f414d4f554e54000000604482015290519081900360640190fd5b6000610a5061145d565b90506000610a89610a6b8561ffff851663ffffffff611b0c16565b610a7d8861271063ffffffff611b0c16565b9063ffffffff611b6f16565b90506000610aa4610a6b8561ffff861663ffffffff611b0c16565b9050610ad66305f5e100610aca6001600160701b038c8116908c1663ffffffff611b0c16565b9063ffffffff611b0c16565b610ae6838363ffffffff611b0c16565b1015610b21576040805162461bcd60e51b81526020600482015260056024820152645a463a204b60d81b604482015290519081900360640190fd5b505050610b3084848888611bbf565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600d55505050505050505050565b604051806040016040528060128152602001717a6b537761702046696e616e6365204c507360701b81525081565b600c5462010000900461ffff1681565b6008546001600160701b0380821692600160701b830490911691600160e01b900463ffffffff1690565b6000610c0b338484611d7d565b5060015b92915050565b6006546001600160a01b031681565b60005481565b6001600160a01b038316600090815260026020908152604080832033845290915281205460001914610caf576001600160a01b0384166000908152600260209081526040808320338452909152902054610c8a908363ffffffff611b6f16565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610cba848484611ddf565b5060019392505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b601281565b60035481565b6005546001600160a01b03163314610d42576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b60095481565b600a5481565b600c5461ffff1681565b6008546001600160701b0380821691600160701b9004169091565b6000600d54600114610de7576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d81905580610df7610bd4565b506006546007549294509092506000918291610e1f916001600160a01b039182169116611a18565b90925090506000610e3f836001600160701b03871663ffffffff611b6f16565b90506000610e5c836001600160701b03871663ffffffff611b6f16565b90506000610e6a8787611e99565b60005490915080610ea757610e936103e8610a7d610e8e878763ffffffff611b0c16565b611fad565b9850610ea260006103e8611fff565b610ef6565b610ef36001600160701b038916610ec4868463ffffffff611b0c16565b81610ecb57fe5b046001600160701b038916610ee6868563ffffffff611b0c16565b81610eed57fe5b04612095565b98505b60008911610f355760405162461bcd60e51b81526004018080602001828103825260218152602001806122556021913960400191505060405180910390fd5b610f3f8a8a611fff565b610f4b86868a8a611bbf565b8115610f7b57600854610f77906001600160701b0380821691600160701b90041663ffffffff611b0c16565b600b555b6040805185815260208101859052815133927f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f928290030190a250506001600d5550949695505050505050565b60016020526000908152604090205481565b600b5481565b60046020526000908152604090205481565b600080600d54600114611039576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d81905580611049610bd4565b506006546007549294509092506001600160a01b0390811691166000806110708484611a18565b306000908152600160205260408120549294509092506110908888611e99565b600054909150806110a7848763ffffffff611b0c16565b816110ae57fe5b049a50806110c2848663ffffffff611b0c16565b816110c957fe5b04995060008b1180156110dc575060008a115b6111175760405162461bcd60e51b81526004018080602001828103825260218152602001806122766021913960400191505060405180910390fd5b61112130846120ad565b61112c878d8d611888565b611137868d8c611888565b6111418787611a18565b909550935061115285858b8b611bbf565b81156111825760085461117e906001600160701b0380821691600160701b90041663ffffffff611b0c16565b600b555b604080518c8152602081018c905281516001600160a01b038f169233927fdccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496929081900390910190a35050505050505050506001600d81905550915091565b6040518060400160405280600581526020016405a462d4c560dc1b81525081565b6005546001600160a01b03163314611250576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6127108161ffff1611156112a2576040805162461bcd60e51b8152602060048201526014602482015273494e56414c49442050524f544f434f4c5f46454560601b604482015290519081900360640190fd5b600c805461ffff909216620100000263ffff000019909216919091179055565b600c5460009061ffff6201000090910481169081146112e1578061135c565b600560009054906101000a90046001600160a01b03166001600160a01b031663b0e21e8a6040518163ffffffff1660e01b815260040160206040518083038186803b15801561132f57600080fd5b505afa158015611343573d6000803e3d6000fd5b505050506040513d602081101561135957600080fd5b50515b61ffff1691505090565b6000610c0b338484611ddf565b600d546001146113b7576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d8190556006546007546001600160a01b0391821692911690806113de8484611a18565b600854919350915061140d90859087906114089086906001600160701b031663ffffffff611b6f16565b611888565b6008546114339084908790611408908590600160701b90046001600160701b0316611b6f565b50506001600d55505050565b6005546001600160a01b031681565b6007546001600160a01b031681565b600c5460009061ffff90811690811461147657806114f1565b600560009054906101000a90046001600160a01b03166001600160a01b03166354cf2aeb6040518163ffffffff1660e01b815260040160206040518083038186803b1580156114c457600080fd5b505afa1580156114d8573d6000803e3d6000fd5b505050506040513d60208110156114ee57600080fd5b50515b91505090565b4284101561153a576040805162461bcd60e51b815260206004820152600b60248201526a16918e881156141254915160aa1b604482015290519081900360640190fd5b6003546001600160a01b0380891660008181526004602090815260408083208054600180820190925582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e280820193601f1981019281900390910190855afa158015611655573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381161580159061168b5750886001600160a01b0316816001600160a01b0316145b6116d4576040805162461bcd60e51b81526020600482015260156024820152745a463a20494e56414c49445f5349474e415455524560581b604482015290519081900360640190fd5b6116df898989611d7d565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b6008546001600160701b0380821691600160701b900416600061172861145d565b9050909192565b6005546001600160a01b0316331461177e576040805162461bcd60e51b815260206004820152600d60248201526c2d231d102327a92124a22222a760991b604482015290519081900360640190fd5b6103e88161ffff16111580611796575061ffff818116145b6117d5576040805162461bcd60e51b815260206004820152600b60248201526a494e56414c49445f46454560a81b604482015290519081900360640190fd5b600c805461ffff191661ffff92909216919091179055565b600d54600114611831576040805162461bcd60e51b815260206004820152600a60248201526916918e881313d0d2d15160b21b604482015290519081900360640190fd5b6000600d8190556006546007548291611856916001600160a01b039182169116611a18565b600854919350915061187f90839083906001600160701b0380821691600160701b900416611bbf565b50506001600d55565b604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009460609489169392918291908083835b602083106119355780518252601f199092019160209182019101611916565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114611997576040519150601f19603f3d011682016040523d82523d6000602084013e61199c565b606091505b50915091508180156119ca5750805115806119ca57508080602001905160208110156119c757600080fd5b50515b611a11576040805162461bcd60e51b815260206004820152601360248201527216918e881514905394d1915497d19052531151606a1b604482015290519081900360640190fd5b5050505050565b604080516370a0823160e01b8152306004820152905160009182916001600160a01b038616916370a08231916024808301926020929190829003018186803b158015611a6357600080fd5b505afa158015611a77573d6000803e3d6000fd5b505050506040513d6020811015611a8d57600080fd5b5051604080516370a0823160e01b815230600482015290516001600160a01b038616916370a08231916024808301926020929190829003018186803b158015611ad557600080fd5b505afa158015611ae9573d6000803e3d6000fd5b505050506040513d6020811015611aff57600080fd5b5051909590945092505050565b6000811580611b2757505080820282828281611b2457fe5b04145b610c0f576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6d756c2d6f766572666c6f7760601b604482015290519081900360640190fd5b80820382811115610c0f576040805162461bcd60e51b815260206004820152601560248201527464732d6d6174682d7375622d756e646572666c6f7760581b604482015290519081900360640190fd5b6001600160701b038411801590611bdd57506001600160701b038311155b611c1d576040805162461bcd60e51b815260206004820152600c60248201526b5a463a204f564552464c4f5760a01b604482015290519081900360640190fd5b60085463ffffffff42811691600160e01b90048116820390811615801590611c4d57506001600160701b03841615155b8015611c6157506001600160701b03831615155b15611cd2578063ffffffff16611c8f85611c7a8661214b565b6001600160e01b03169063ffffffff61215d16565b600980546001600160e01b03929092169290920201905563ffffffff8116611cba84611c7a8761214b565b600a80546001600160e01b0392909216929092020190555b600880546dffffffffffffffffffffffffffff19166001600160701b03888116919091176dffffffffffffffffffffffffffff60701b1916600160701b8883168102919091176001600160e01b0316600160e01b63ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316600090815260016020526040902054611e08908263ffffffff611b6f16565b6001600160a01b038085166000908152600160205260408082209390935590841681522054611e3d908263ffffffff61218216565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b600080600560009054906101000a90046001600160a01b03166001600160a01b031663017e7e586040518163ffffffff1660e01b815260040160206040518083038186803b158015611eea57600080fd5b505afa158015611efe573d6000803e3d6000fd5b505050506040513d6020811015611f1457600080fd5b5051600b546001600160a01b038216158015945091925090611f99578015611f94576000611f57610e8e6001600160701b0388811690881663ffffffff611b0c16565b90506000611f6483611fad565b905080821115611f91576000611f7d60005484846121d1565b90508015611f8f57611f8f8582611fff565b505b50505b611fa5565b8015611fa5576000600b555b505092915050565b60006003821115611ff0575080600160028204015b81811015611fea57809150600281828581611fd957fe5b040181611fe257fe5b049050611fc2565b50611ffa565b8115611ffa575060015b919050565b600054612012908263ffffffff61218216565b60009081556001600160a01b03831681526001602052604090205461203d908263ffffffff61218216565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b60008183106120a457816120a6565b825b9392505050565b6001600160a01b0382166000908152600160205260409020546120d6908263ffffffff611b6f16565b6001600160a01b03831660009081526001602052604081209190915554612103908263ffffffff611b6f16565b60009081556040805183815290516001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a35050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b0384168161217a57fe5b049392505050565b80820182811015610c0f576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6164642d6f766572666c6f7760601b604482015290519081900360640190fd5b6000806121dc6112c2565b9050600061220482610aca6121f7888863ffffffff611b6f16565b899063ffffffff611b0c16565b9050600061223d61221b868563ffffffff611b0c16565b61223188610aca6127108863ffffffff611b6f16565b9063ffffffff61218216565b905080828161224857fe5b0497965050505050505056fe5a463a20494e53554646494349454e545f4c49515549444954595f4d494e5445445a463a20494e53554646494349454e545f4c49515549444954595f4255524e4544a265627a7a723158205462e560a0a7a6eb0fbbb9089aa0a37e07e39c0f23a5e6c377cc60e33ab7f0b764736f6c63430005100032454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429a265627a7a7231582047b32ee559231eb91e50d2d4b2078d75816bdcfd9591a7d7886137e61893022664736f6c63430005100032
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
0000000000000000000000004bc9b68c77a9cd6071a21c6d9d4ae7f2ee921960
-----Decoded View---------------
Arg [0] : _feeToSetter (address): 0x4BC9b68c77A9CD6071A21c6d9d4AE7f2eE921960
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000004bc9b68c77a9cd6071a21c6d9d4ae7f2ee921960
Loading...
Loading
Loading...
Loading
Loading...
Loading
Net Worth in USD
$0.29
Net Worth in MON
Token Allocations
ETH
100.00%
Multichain Portfolio | 35 Chains
| Chain | Token | Portfolio % | Price | Amount | Value |
|---|---|---|---|---|---|
| BSC | 100.00% | $2,949.73 | 0.0001 | $0.2949 |
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.