Token Zircon

Overview ERC20

Price
$0.00 @ 0.000000 MOVR
Fully Diluted Market Cap
Total Supply:
0.000173 ZPT

Holders:
4 addresses

Transfers:
-

Contract:
0x1a8D41A276Ec175A5C76dE5857D0Ee2Bcdc902560x1a8D41A276Ec175A5C76dE5857D0Ee2Bcdc90256

Decimals:
18

Social Profiles:
Not Available, Update ?

Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

Click here to update the token ICO / general information
# Exchange Pair Price  24H Volume % Volume

Similar Match Source Code
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0xCE21B290B23AcB2A7AA2f8BF2c21ACBa3A9aE75a

Contract Name:
ZirconPair

Compiler Version
v0.5.16+commit.9c3226ce

Optimization Enabled:
Yes with 1 runs

Other Settings:
default evmVersion
File 1 of 10 : ZirconPair.sol
// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;

import './libraries/Math.sol';
import './libraries/UQ112x112.sol';
//import './interfaces/IERC20.sol';
import './interfaces/IZirconPair.sol';
import '@uniswap/v2-core/contracts/interfaces/IUniswapV2Callee.sol';
import './libraries/SafeMath.sol';
import "./ZirconERC20.sol";
import "./interfaces/IZirconFactory.sol";
import '@uniswap/v2-core/contracts/interfaces/IUniswapV2ERC20.sol';

//import "./libraries/ZirconLibrary.sol";
import "./energy/interfaces/IZirconEnergyRevenue.sol";

contract ZirconPair is IZirconPair, ZirconERC20 { //Name change does not affect ABI
    using SafeMath for uint;
    using UQ112x112 for uint224;

    uint public constant MINIMUM_LIQUIDITY = 10**3;
    bytes4 private constant SELECTOR = bytes4(keccak256(bytes('transfer(address,uint256)')));

    address public factory;
    address public token0;
    address public token1;

    address public energyRevenueAddress;

    uint112 private reserve0;           // uses single storage slot, accessible via getReserves
    uint112 private reserve1;           // us es single storage slot, accessible via getReserves
    uint32 private blockTimestampLast; // uses single storage slot, accessible via getReserves

    uint public price0CumulativeLast;
    uint public price1CumulativeLast;
    uint public kLast; // reserve0 * reserve1, as of immediately after the most recent liquidity event

    uint private unlocked = 1;
    modifier lock() {
        require(unlocked == 1, 'UniswapV2: LOCKED');
        unlocked = 0;
        _;
        unlocked = 1;
    }

    function getReserves()  public view returns  (uint112 _reserve0, uint112 _reserve1, uint32 _blockTimestampLast) {
        _reserve0 = reserve0;
        _reserve1 = reserve1;
        _blockTimestampLast = blockTimestampLast;
    }

    function _safeTransfer(address token, address to, uint value) private {
        (bool success, bytes memory data) = token.call(abi.encodeWithSelector(SELECTOR, to, value));
        require(success && (data.length == 0 || abi.decode(data, (bool))), 'UniswapV2: TRANSFER_FAILED');
    }

    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);


    constructor() public {
        factory = msg.sender;
    }

    function tryLock() external lock {}

    // called once by the factory at time of deployment
    function initialize(address _token0, address _token1, address _energy) external {
        require(msg.sender == factory, 'ZirconPair: FORBIDDEN'); // sufficient check
        token0 = _token0;
        token1 = _token1;
        energyRevenueAddress = _energy;
    }

    // update reserves and, on the first call per block, price accumulators
    function _update(uint balance0, uint balance1,
        uint112 _reserve0, uint112 _reserve1) private {
        require(balance0 <= uint112(-1) && balance1 <= uint112(-1), 'UniswapV2: 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 += uint(UQ112x112.encode(_reserve1).uqdiv(_reserve0)) * timeElapsed;
            price1CumulativeLast += uint(UQ112x112.encode(_reserve0).uqdiv(_reserve1)) * timeElapsed;
        }
        reserve0 = uint112(balance0);
        reserve1 = uint112(balance1);
        blockTimestampLast = blockTimestamp;
        emit Sync(reserve0, reserve1);
    }

    //Wrapper around mintFee primarily aimed to be called by Pylon
    //Access control is unnecessary, if anyone calls it they just waste gas compounding fees for us
    //The wrapper is necessary to make sure the reserves it passes to mintFee are actual
    function publicMintFee() external lock {
        (uint112 _reserve0, uint112 _reserve1,) = getReserves();

        _mintFee(_reserve0, _reserve1);

        kLast = uint(reserve0).mul(reserve1); //Reserves don't change from mintFee
    }

    // if fee is on, mint liquidity equivalent to 1/6th of the growth in sqrt(k)
    function _mintFee(uint112 _reserve0, uint112 _reserve1) private {
    uint _kLast = kLast; // gas savings
        if (_kLast != 0) {
            uint rootK = Math.sqrt(uint(_reserve0).mul(_reserve1));
            uint rootKLast = Math.sqrt(_kLast);
            if (rootK > rootKLast) {
                uint dynamicRatio = IZirconFactory(factory).dynamicRatio();
                uint numerator = (rootK.sub(rootKLast)).mul(1e18);
                uint denominator = rootK.mul(dynamicRatio).add(rootKLast);
                uint liquidityPercentage = numerator / denominator;

                if (liquidityPercentage > 0) {
                    //                    console.log("C ore: liqPercentage", liquidityPercentage);
                    _mint(energyRevenueAddress, liquidityPercentage.mul(totalSupply)/1e18);
                    //                    _mint(energyRevenueAddress, liquidityPercentage.mul(totalSupply)/1e18);
                    uint totalPercentage = ((rootK.sub(rootKLast)).mul(1e18))/rootKLast;
                    IZirconEnergyRevenue(energyRevenueAddress).calculate(totalPercentage.sub(liquidityPercentage));
                }
            }
        }
    }

    // this low-level function should be called from a contract which performs important safety checks
    function mint(address to) external lock returns (uint liquidity) {
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        uint balance0 = IUniswapV2ERC20(token0).balanceOf(address(this));
        uint balance1 = IUniswapV2ERC20(token1).balanceOf(address(this));
        uint amount0 = balance0.sub(_reserve0);
        uint amount1 = balance1.sub(_reserve1);

        _mintFee(_reserve0, _reserve1);
        uint _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, 'UniswapV2: INSUFFICIENT_LIQUIDITY_MINTED');
        _mint(to, liquidity);

        _update(balance0, balance1, _reserve0, _reserve1);
        kLast = uint(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
        emit Mint(msg.sender, amount0, amount1);
    }

    // this low-level function should be called from a contract which performs important safety checks
    // TODO: will be better if we pass the output amount
    function mintOneSide(address to, bool isReserve0) external lock returns (uint liquidity, uint amount0, uint amount1) {
        require(totalSupply > 0, 'UniswapV2: Use mint to start pair');
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings

        uint balance0 = IUniswapV2ERC20(token0).balanceOf(address(this));
        uint balance1 = IUniswapV2ERC20(token1).balanceOf(address(this));
        amount0 = balance0.sub(_reserve0);
        amount1 = balance1.sub(_reserve1);

        uint _liquidityFee = IZirconFactory(factory).liquidityFee();
        uint k;

        //We use growth in sqrt(k) to calculate amount of pool tokens to mint. This implicitly takes care of slippage.
        //Fee is slightly more than half total amount to account for residue you'd have if you swapped then minted normally

        if (isReserve0){
            require(amount0 > 1, "ZP: Insufficient Amount");
            k = Math.sqrt(uint(reserve0 + (amount0.mul(10000-(_liquidityFee/2 + 1))/10000)).mul(balance1));
        }else{
            require(amount1 > 1, "ZP: Insufficient Amount");
            k = Math.sqrt(balance0.mul(uint(reserve1 + (amount1.mul(10000-(_liquidityFee/2 + 1))/10000))));
        }
        uint kBefore = Math.sqrt(uint(reserve0).mul(reserve1));

        uint numerator = (k.sub(kBefore)).mul(totalSupply);
        uint denominator = kBefore;
        liquidity = numerator / denominator;
        reserve0 = uint112(balance0);
        reserve1 = uint112(balance1);
        _mintFee(_reserve0, _reserve1);

        require(liquidity > 0, 'UniswapV2: INSUFFICIENT_LIQUIDITY_MINTED');
        _mint(to, liquidity);
        _update(balance0, balance1, _reserve0, _reserve1);
        kLast = uint(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
        emit Mint(msg.sender, amount0, amount1);
    }

    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut, uint fee) internal pure returns (uint amountOut) {
        require(amountIn > 0, 'UV2: IIA');
        require(reserveIn > 0 && reserveOut > 0, 'UV2: IL');
        uint amountInWithFee = amountIn.mul(10000-fee);
        uint numerator = amountInWithFee.mul(reserveOut);
        uint denominator = reserveIn.mul(10000).add(amountInWithFee);
        amountOut = numerator / denominator;
    }

    // this low-level function should be called from a contract which performs important safety checks
    // TODO: Test this function
    // TODO: maybe allow burning both sides to one
    function burnOneSide(address to, bool isReserve0) external lock returns (uint amount) {
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        address _token0 = token0;                                // gas savings
        address _token1 = token1;                                // gas savings
        uint amount0;
        uint amount1;
        uint balance0 = IUniswapV2ERC20(_token0).balanceOf(address(this));
        uint balance1 = IUniswapV2ERC20(_token1).balanceOf(address(this));
        uint liquidity = balanceOf[address(this)];
        uint _liquidityFee = IZirconFactory(factory).liquidityFee();

        _mintFee(_reserve0, _reserve1);
        uint _totalSupply = totalSupply; // gas savings, must be defined here since totalSupply can update in _mintFee
        amount0 = liquidity.mul(balance0) / _totalSupply; // using balances ensures pro-rata distribution
        amount1 = liquidity.mul(balance1) / _totalSupply; // using balances ensures pro-rata distribution
        if (isReserve0) {
            amount0 += getAmountOut(amount1, _reserve1 - amount1, _reserve0 - amount0, _liquidityFee);
            amount = amount0;
            require(amount < balance0, "UniswapV2: EXTENSION_NOT_ENOUGH_LIQUIDITY");
        }else{
            amount1 += getAmountOut(amount0, _reserve0 - amount0, _reserve1 - amount1, _liquidityFee);
            amount = amount1;
            require(amount < balance1, "UniswapV2: EXTENSION_NOT_ENOUGH_LIQUIDITY");
        }
        require(amount0 > 0 && amount1 > 0, 'UniswapV2: INSUFFICIENT_LIQUIDITY_BURNED');
        _burn(address(this), liquidity);
        if (isReserve0) {
            _safeTransfer(_token0, to, amount);
        }else{
            _safeTransfer(_token1, to, amount);
        }
        balance0 = IUniswapV2ERC20(_token0).balanceOf(address(this));
        balance1 = IUniswapV2ERC20(_token1).balanceOf(address(this));

        _update(balance0, balance1, _reserve0, _reserve1);
        kLast = uint(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
        emit Burn(msg.sender, amount0, amount1, to);
    }

    // this low-level function should be called from a contract which performs important safety checks
    function burn(address to) external lock returns (uint amount0, uint amount1) {
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        address _token0 = token0;                                // gas savings
        address _token1 = token1;                                // gas savings
        uint balance0 = IUniswapV2ERC20(_token0).balanceOf(address(this));
        uint balance1 = IUniswapV2ERC20(_token1).balanceOf(address(this));
        uint liquidity = balanceOf[address(this)];
        _mintFee(_reserve0, _reserve1);
        uint _totalSupply = totalSupply; // gas savings, must be defined here since totalSupply can update in _mintFee
        amount0 = liquidity.mul(balance0) / _totalSupply; // using balances ensures pro-rata distribution
        amount1 = liquidity.mul(balance1) / _totalSupply; // using balances ensures pro-rata distribution
        require(amount0 > 0 && amount1 > 0, 'UniswapV2: INSUFFICIENT_LIQUIDITY_BURNED');
        _burn(address(this), liquidity);
        _safeTransfer(_token0, to, amount0);
        _safeTransfer(_token1, to, amount1);
        balance0 = IUniswapV2ERC20(_token0).balanceOf(address(this));
        balance1 = IUniswapV2ERC20(_token1).balanceOf(address(this));

        _update(balance0, balance1, _reserve0, _reserve1);
        kLast = uint(reserve0).mul(reserve1); // reserve0 and reserve1 are up-to-date
        emit Burn(msg.sender, amount0, amount1, to);
    }

    // this low-level function should be called from a contract which performs important safety checks
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data)  external lock {
        require(amount0Out > 0 || amount1Out > 0, 'UniswapV2: INSUFFICIENT_OUTPUT_AMOUNT');
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        require(amount0Out < _reserve0 && amount1Out < _reserve1, 'UniswapV2: INSUFFICIENT_LIQUIDITY');

        uint balance0;
        uint balance1;
        { // scope for _token{0,1}, avoids stack too deep errors
            address _token0 = token0;
            address _token1 = token1;
            require(to != _token0 && to != _token1, 'UniswapV2: 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 = IUniswapV2ERC20(_token0).balanceOf(address(this));
            balance1 = IUniswapV2ERC20(_token1).balanceOf(address(this));
        }
        uint amount0In = balance0 > _reserve0 - amount0Out ? balance0 - (_reserve0 - amount0Out) : 0;
        uint amount1In = balance1 > _reserve1 - amount1Out ? balance1 - (_reserve1 - amount1Out) : 0;
        require(amount0In > 0 || amount1In > 0, 'UniswapV2: INSUFFICIENT_INPUT_AMOUNT');
        { // scope for reserve{0,1}Adjusted, avoids stack too deep errors
            uint _liquidityFee = IZirconFactory(factory).liquidityFee();
            uint balance0Adjusted = balance0.mul(10000).sub(amount0In.mul(_liquidityFee));
            uint balance1Adjusted = balance1.mul(10000).sub(amount1In.mul(_liquidityFee));
            require(balance0Adjusted.mul(balance1Adjusted) >= uint(_reserve0).mul(_reserve1).mul(10000**2), 'UniswapV2: K');
        }

        _update(balance0, balance1, _reserve0, _reserve1);
        emit Swap(msg.sender, amount0In, amount1In, amount0Out, amount1Out, to);
    }

    // force balances to match reserves
//    function skim(address to)  external lock {
//        address _token0 = token0; // gas savings
//        address _token1 = token1; // gas savings
//        _safeTransfer(_token0, to, IUniswapV2ERC20(_token0).balanceOf(address(this)).sub(reserve0));
//        _safeTransfer(_token1, to, IUniswapV2ERC20(_token1).balanceOf(address(this)).sub(reserve1));
//    }

    // force reserves to match balances
    function sync() external lock {
        _update(IUniswapV2ERC20(token0).balanceOf(address(this)), IUniswapV2ERC20(token1).balanceOf(address(this)), reserve0, reserve1);
    }

    function changeEnergyRevAddress(address _revAddress) external {
        require(msg.sender == factory, 'UniswapV2: NOT_ALLOWED');
        energyRevenueAddress = _revAddress;
    }
}

File 2 of 10 : Math.sol
// SPDX-License-Identifier: GPL-3.0
pragma solidity =0.5.16;
// a library for performing various math operations
library Math {
    function min(uint x, uint y) internal pure returns (uint z) {
        z = x < y ? x : y;
    }
    function max(uint x, uint y) internal pure returns (uint z) {
        z = x > y ? x : y;
    }
    // babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method)
    function sqrt(uint y) internal pure returns (uint z) {
        if (y > 3) {
            z = y;
            uint x = y / 2 + 1;
            while (x < z) {
                z = x;
                x = (y / x + x) / 2;
            }
        } else if (y != 0) {
            z = 1;
        }
    }
}

File 3 of 10 : UQ112x112.sol
// 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);
    }
}

File 4 of 10 : IZirconPair.sol
// SPDX-License-Identifier: GPL-3.0

pragma solidity >=0.5.16;

interface IZirconPair {
    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 energyRevenueAddress() external pure returns (address);
    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 burnOneSide(address to, bool isReserve0) external returns (uint amount);
    function mintOneSide(address to, bool isReserve0) external returns (uint liquidity, uint amount0, uint amount1);
    function publicMintFee() external;
    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 tryLock() external;

    function initialize(address, address, address) external;
    function changeEnergyRevAddress(address _revAddress) external;

}

File 5 of 10 : IUniswapV2Callee.sol
pragma solidity >=0.5.0;

interface IUniswapV2Callee {
    function uniswapV2Call(address sender, uint amount0, uint amount1, bytes calldata data) external;
}

File 6 of 10 : SafeMath.sol
// SPDX-License-Identifier: GPL-3.0

pragma solidity =0.5.16;

// a library for performing overflow-safe math, courtesy of DappHub (https://github.com/dapphub/ds-math)

library SafeMath {
    function add(uint x, uint y) internal pure returns (uint z) {
        require((z = x + y) >= x, 'ds-math-add-overflow');
    }

    function sub(uint x, uint y) internal pure returns (uint z) {
        require((z = x - y) <= x, 'ds-math-sub-underflow');
    }

    function mul(uint x, uint y) internal pure returns (uint z) {
        require(y == 0 || (z = x * y) / y == x, 'ds-math-mul-overflow');
    }
}

File 7 of 10 : ZirconERC20.sol
pragma solidity =0.5.16;
import './libraries/SafeMath.sol';
import '@uniswap/v2-core/contracts/interfaces/IUniswapV2ERC20.sol';

contract ZirconERC20 is IUniswapV2ERC20 {
    using SafeMath for uint;
    // TODO: change name of token
    string public constant name = 'Zircon';
    string public constant symbol = 'ZPT';
    uint8 public constant decimals = 18;
    uint public totalSupply;
    mapping(address => uint)  public balanceOf;
    mapping(address => mapping(address => uint)) public allowance;
    // keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
    bytes32 public constant PERMIT_TYPEHASH = 0x6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9;
    mapping(address => uint) public nonces;
    bytes32 public DOMAIN_SEPARATOR;

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

    constructor() public {
        uint 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, uint value) internal {
        totalSupply = totalSupply.add(value);
        balanceOf[to] = balanceOf[to].add(value);
        emit Transfer(address(0), to, value);
    }

    function _burn(address from, uint value) internal {
        balanceOf[from] = balanceOf[from].sub(value);
        totalSupply = totalSupply.sub(value);
        emit Transfer(from, address(0), value);
    }

    function _approve(address owner, address spender, uint value) private {
        allowance[owner][spender] = value;
        emit Approval(owner, spender, value);
    }

    function _transfer(address from, address to, uint value) private {
        balanceOf[from] = balanceOf[from].sub(value);
        balanceOf[to] = balanceOf[to].add(value);
        emit Transfer(from, to, value);
    }

    function approve(address spender, uint value) external returns (bool) {
        _approve(msg.sender, spender, value);
        return true;
    }

    function transfer(address to, uint value) external returns (bool) {
        _transfer(msg.sender, to, value);
        return true;
    }

    function transferFrom(address from, address to, uint value) external returns (bool) {
        if (allowance[from][msg.sender] != uint(-1)) {
            allowance[from][msg.sender] = allowance[from][msg.sender].sub(value);
        }
        _transfer(from, to, value);
        return true;
    }

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external {
        require(deadline >= block.timestamp, 'UniswapV2: 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, 'UniswapV2: INVALID_SIGNATURE');
        _approve(owner, spender, value);
    }
}

File 8 of 10 : IZirconFactory.sol
pragma solidity >=0.5.16;

interface IZirconFactory {
    //    function feeTo() external view returns (address);
    //    function feeToSetter() external view returns (address);
    //    function migrator() external view returns (address);
    function energyFactory() external view returns (address);

    function getPair(address, address) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);
    function dynamicRatio() external view returns (uint);
    function liquidityFee() external view returns (uint);
    function setLiquidityFee(uint _liquidityFee) external;

    function pairCodeHash() external pure returns (bytes32);
    function createPair(address tokenA, address tokenB, address _pylonFactory) external returns (address pair);

    function setMigrator(address _migrator) external;
    function setFeeToSetter(address _feeToSetter) external;
    function changeEnergyRevAddress(address _pairAddress, address _tokenA, address _tokenB, address _pylonFactory) external returns (address newEnergy);

    function changeEnergyFactoryAddress(address _newEnergyFactory) external;
    function setDynamicRatio(uint _dynamicRatio) external;

}

File 9 of 10 : IUniswapV2ERC20.sol
pragma solidity >=0.5.0;

interface IUniswapV2ERC20 {
    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;
}

File 10 of 10 : IZirconEnergyRevenue.sol
pragma solidity =0.5.16;

interface IZirconEnergyRevenue {
    function initialize(address _pair, address _tokenA, address _tokenB, address energy0, address energy1, address pylon0, address pylon1) external;
    function calculate(uint percentage) external;
    function migrateLiquidity(address newEnergy) external;
    function getBalanceFromPair() external returns (uint);
    function feeValue1() external returns (uint);
    function feeValue0() external returns (uint);
    function getFees(address _token, uint _amount, address _to) external;
    function setFeeValue(uint _feeValue0, uint _feeValue1) external;
}

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

Contract Security Audit

Contract ABI

[{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"Burn","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"}],"name":"Mint","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0In","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1In","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount0Out","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1Out","type":"uint256"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"Swap","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint112","name":"reserve0","type":"uint112"},{"indexed":false,"internalType":"uint112","name":"reserve1","type":"uint112"}],"name":"Sync","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"constant":true,"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"MINIMUM_LIQUIDITY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"PERMIT_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"burn","outputs":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"bool","name":"isReserve0","type":"bool"}],"name":"burnOneSide","outputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_revAddress","type":"address"}],"name":"changeEnergyRevAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"energyRevenueAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"getReserves","outputs":[{"internalType":"uint112","name":"_reserve0","type":"uint112"},{"internalType":"uint112","name":"_reserve1","type":"uint112"},{"internalType":"uint32","name":"_blockTimestampLast","type":"uint32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_token0","type":"address"},{"internalType":"address","name":"_token1","type":"address"},{"internalType":"address","name":"_energy","type":"address"}],"name":"initialize","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"kLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"mint","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"bool","name":"isReserve0","type":"bool"}],"name":"mintOneSide","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"},{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"price0CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"price1CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"publicMintFee","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"amount0Out","type":"uint256"},{"internalType":"uint256","name":"amount1Out","type":"uint256"},{"internalType":"address","name":"to","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"swap","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"sync","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"token0","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"token1","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"tryLock","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]

60806040526001600d5534801561001557600080fd5b506040514690806052612fcb823960408051918290036052018220828201825260068352652d34b931b7b760d11b6020938401528151808301835260018152603160f81b908401528151808401919091527f94c6df7cbb14f58e7ac6d9fa315f8346b33ef43dae2423c0e0e94673dd9e65ff818301527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606082015260808101949094523060a0808601919091528151808603909101815260c09094019052825192019190912060045550600580546001600160a01b03191633179055612eca806101016000396000f3fe608060405234801561001057600080fd5b50600436106101805760003560e01c8063022c0d9f1461018557806306fdde03146102115780630902f1ac1461028e578063095ea7b3146102c65780630dfe16811461030657806311816b041461032a578063145f3c271461033257806318160ddd1461033a57806323b872dd146103545780632ce510901461038a57806330adf81f146103b8578063313ce567146103c05780633644e515146103de578063432275e6146103e657806353ddd944146104325780635909c0d5146104585780635a3d5493146104605780636a627842146104685780636da996361461048e57806370a08231146104965780637464fc3d146104bc5780637ecebe00146104c457806389afcb44146104ea57806395d89b4114610529578063a9059cbb14610531578063ba9a7a561461055d578063c0c53b8b14610565578063c45a01551461059d578063d21220a7146105a5578063d505accf146105ad578063dd62ed3e146105fe578063fff6cae91461062c575b600080fd5b61020f6004803603608081101561019b57600080fd5b8135916020810135916001600160a01b036040830135169190810190608081016060820135600160201b8111156101d157600080fd5b8201836020820111156101e357600080fd5b803590602001918460018302840111600160201b8311171561020457600080fd5b509092509050610634565b005b610219610bdc565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561025357818101518382015260200161023b565b50505050905090810190601f1680156102805780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b610296610bfe565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b6102f2600480360360408110156102dc57600080fd5b506001600160a01b038135169060200135610c28565b604080519115158252519081900360200190f35b61030e610c3f565b604080516001600160a01b039092168252519081900360200190f35b61020f610c4e565b61020f610c9a565b610342610d30565b60408051918252519081900360200190f35b6102f26004803603606081101561036a57600080fd5b506001600160a01b03813581169160208101359091169060400135610d36565b610342600480360360408110156103a057600080fd5b506001600160a01b0381351690602001351515610dd0565b6103426112bb565b6103c86112cd565b6040805160ff9092168252519081900360200190f35b6103426112d2565b610414600480360360408110156103fc57600080fd5b506001600160a01b03813516906020013515156112d8565b60408051938452602084019290925282820152519081900360600190f35b61020f6004803603602081101561044857600080fd5b50356001600160a01b03166117b3565b61034261182d565b610342611833565b6103426004803603602081101561047e57600080fd5b50356001600160a01b0316611839565b61030e611b0f565b610342600480360360208110156104ac57600080fd5b50356001600160a01b0316611b1e565b610342611b30565b610342600480360360208110156104da57600080fd5b50356001600160a01b0316611b36565b6105106004803603602081101561050057600080fd5b50356001600160a01b0316611b48565b6040805192835260208301919091528051918290030190f35b610219611ecb565b6102f26004803603604081101561054757600080fd5b506001600160a01b038135169060200135611eea565b610342611ef7565b61020f6004803603606081101561057b57600080fd5b506001600160a01b038135811691602081013582169160409091013516611efd565b61030e611f93565b61030e611fa2565b61020f600480360360e08110156105c357600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c00135611fb1565b6103426004803603604081101561061457600080fd5b506001600160a01b03813581169160200135166121a0565b61020f6121bd565b600d54600114610679576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d558415158061068c5750600084115b6106c75760405162461bcd60e51b8152600401808060200182810382526025815260200180612cf26025913960400191505060405180910390fd5b6000806106d2610bfe565b5091509150816001600160701b0316871080156106f75750806001600160701b031686105b6107325760405162461bcd60e51b8152600401808060200182810382526021815260200180612d5b6021913960400191505060405180910390fd5b60065460075460009182916001600160a01b039182169190811690891682148015906107705750806001600160a01b0316896001600160a01b031614155b6107b9576040805162461bcd60e51b8152602060048201526015602482015274556e697377617056323a20494e56414c49445f544f60581b604482015290519081900360640190fd5b8a156107ca576107ca828a8d612312565b89156107db576107db818a8c612312565b861561089657886001600160a01b03166310d1e85c338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03166001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561087d57600080fd5b505af1158015610891573d6000803e3d6000fd5b505050505b604080516370a0823160e01b815230600482015290516001600160a01b038416916370a08231916024808301926020929190829003018186803b1580156108dc57600080fd5b505afa1580156108f0573d6000803e3d6000fd5b505050506040513d602081101561090657600080fd5b5051604080516370a0823160e01b815230600482015290519195506001600160a01b038316916370a0823191602480820192602092909190829003018186803b15801561095257600080fd5b505afa158015610966573d6000803e3d6000fd5b505050506040513d602081101561097c57600080fd5b5051925060009150506001600160701b0385168a9003831161099f5760006109ae565b89856001600160701b03160383035b9050600089856001600160701b03160383116109cb5760006109da565b89856001600160701b03160383035b905060008211806109eb5750600081115b610a265760405162461bcd60e51b8152600401808060200182810382526024815260200180612d176024913960400191505060405180910390fd5b60055460408051632604632d60e21b815290516000926001600160a01b0316916398118cb4916004808301926020929190829003018186803b158015610a6b57600080fd5b505afa158015610a7f573d6000803e3d6000fd5b505050506040513d6020811015610a9557600080fd5b505190506000610acc610aae858463ffffffff6124a516565b610ac08861271063ffffffff6124a516565b9063ffffffff61250816565b90506000610ae3610aae858563ffffffff6124a516565b9050610b156305f5e100610b096001600160701b038c8116908c1663ffffffff6124a516565b9063ffffffff6124a516565b610b25838363ffffffff6124a516565b1015610b67576040805162461bcd60e51b815260206004820152600c60248201526b556e697377617056323a204b60a01b604482015290519081900360640190fd5b505050610b7684848888612558565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600d55505050505050505050565b604051806040016040528060068152602001652d34b931b7b760d11b81525081565b6009546001600160701b0380821692600160701b830490911691600160e01b900463ffffffff1690565b6000610c3533848461270f565b5060015b92915050565b6006546001600160a01b031681565b600d54600114610c93576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6001600d55565b600d54600114610cdf576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d81905580610cef610bfe565b5091509150610cfe8282612771565b600954610d24906001600160701b0380821691600160701b90041663ffffffff6124a516565b600c5550506001600d55565b60005481565b6001600160a01b038316600090815260026020908152604080832033845290915281205460001914610dbb576001600160a01b0384166000908152600260209081526040808320338452909152902054610d96908363ffffffff61250816565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610dc6848484612960565b5060019392505050565b6000600d54600114610e17576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d81905580610e27610bfe565b50600654600754604080516370a0823160e01b815230600482015290519496509294506001600160a01b03918216939116916000918291829186916370a08231916024808301926020929190829003018186803b158015610e8757600080fd5b505afa158015610e9b573d6000803e3d6000fd5b505050506040513d6020811015610eb157600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038716916370a08231916024808301926020929190829003018186803b158015610eff57600080fd5b505afa158015610f13573d6000803e3d6000fd5b505050506040513d6020811015610f2957600080fd5b5051306000908152600160209081526040808320546005548251632604632d60e21b8152925195965090946001600160a01b03909116926398118cb49260048082019391829003018186803b158015610f8157600080fd5b505afa158015610f95573d6000803e3d6000fd5b505050506040513d6020811015610fab57600080fd5b50519050610fb98a8a612771565b60005480610fcd848763ffffffff6124a516565b81610fd457fe5b04965080610fe8848663ffffffff6124a516565b81610fef57fe5b0495508c156110645761101a86878c6001600160701b031603898e6001600160701b03160385612a08565b87019650869b50848c1061105f5760405162461bcd60e51b8152600401808060200182810382526029815260200180612e2d6029913960400191505060405180910390fd5b6110cb565b61108687888d6001600160701b031603888d6001600160701b03160385612a08565b86019550859b50838c106110cb5760405162461bcd60e51b8152600401808060200182810382526029815260200180612e2d6029913960400191505060405180910390fd5b6000871180156110db5750600086115b6111165760405162461bcd60e51b8152600401808060200182810382526028815260200180612d7c6028913960400191505060405180910390fd5b6111203084612af1565b8c1561113657611131898f8e612312565b611141565b611141888f8e612312565b604080516370a0823160e01b815230600482015290516001600160a01b038b16916370a08231916024808301926020929190829003018186803b15801561118757600080fd5b505afa15801561119b573d6000803e3d6000fd5b505050506040513d60208110156111b157600080fd5b5051604080516370a0823160e01b815230600482015290519196506001600160a01b038a16916370a0823191602480820192602092909190829003018186803b1580156111fd57600080fd5b505afa158015611211573d6000803e3d6000fd5b505050506040513d602081101561122757600080fd5b5051935061123785858d8d612558565b60095461125d906001600160701b0380821691600160701b90041663ffffffff6124a516565b600c819055508d6001600160a01b0316336001600160a01b0316600080516020612e0d8339815191528989604051808381526020018281526020019250505060405180910390a350506001600d5550979a9950505050505050505050565b600080516020612e7683398151915281565b601281565b60045481565b6000806000600d54600114611322576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d819055546113655760405162461bcd60e51b8152600401808060200182810382526021815260200180612dec6021913960400191505060405180910390fd5b600080611370610bfe565b50600654604080516370a0823160e01b815230600482015290519395509193506000926001600160a01b03909116916370a08231916024808301926020929190829003018186803b1580156113c457600080fd5b505afa1580156113d8573d6000803e3d6000fd5b505050506040513d60208110156113ee57600080fd5b5051600754604080516370a0823160e01b815230600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561144157600080fd5b505afa158015611455573d6000803e3d6000fd5b505050506040513d602081101561146b57600080fd5b50519050611488826001600160701b03861663ffffffff61250816565b95506114a3816001600160701b03851663ffffffff61250816565b94506000600560009054906101000a90046001600160a01b03166001600160a01b03166398118cb46040518163ffffffff1660e01b815260040160206040518083038186803b1580156114f557600080fd5b505afa158015611509573d6000803e3d6000fd5b505050506040513d602081101561151f57600080fd5b50519050600089156115c6576001881161157a576040805162461bcd60e51b815260206004820152601760248201527616940e88125b9cdd59999a58da595b9d08105b5bdd5b9d604a1b604482015290519081900360640190fd5b6115bf6115ba846127106115978c600288048303600019016124a5565b8161159e57fe5b6009546001600160701b0316919004019063ffffffff6124a516565b612b7d565b905061165a565b60018711611615576040805162461bcd60e51b815260206004820152601760248201527616940e88125b9cdd59999a58da595b9d08105b5bdd5b9d604a1b604482015290519081900360640190fd5b6116576115ba6127106116318a600287048303600019016124a5565b8161163857fe5b6009548892909104600160701b9091046001600160701b0316016124a5565b90505b600954600090611687906115ba906001600160701b0380821691600160701b90041663ffffffff6124a516565b905060006116a4600054610b09848661250890919063ffffffff16565b9050818082816116b057fe5b600980546001600160701b038a8116600160701b02600160701b600160e01b0319918d166001600160701b03199093169290921716179055049b506116f58989612771565b60008c116117345760405162461bcd60e51b8152600401808060200182810382526028815260200180612dc46028913960400191505060405180910390fd5b61173e8e8d612bcf565b61174a87878b8b612558565b600954611770906001600160701b0380821691600160701b90041663ffffffff6124a516565b600c55604080518c8152602081018c905281513392600080516020612d3b833981519152928290030190a25050505050505050506001600d819055509250925092565b6005546001600160a01b0316331461180b576040805162461bcd60e51b8152602060048201526016602482015275155b9a5cddd85c158c8e881393d517d0531313d5d15160521b604482015290519081900360640190fd5b600880546001600160a01b0319166001600160a01b0392909216919091179055565b600a5481565b600b5481565b6000600d54600114611880576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d81905580611890610bfe565b50600654604080516370a0823160e01b815230600482015290519395509193506000926001600160a01b03909116916370a08231916024808301926020929190829003018186803b1580156118e457600080fd5b505afa1580156118f8573d6000803e3d6000fd5b505050506040513d602081101561190e57600080fd5b5051600754604080516370a0823160e01b815230600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561196157600080fd5b505afa158015611975573d6000803e3d6000fd5b505050506040513d602081101561198b57600080fd5b5051905060006119aa836001600160701b03871663ffffffff61250816565b905060006119c7836001600160701b03871663ffffffff61250816565b90506119d38686612771565b60005480611a08576119f46103e8610ac06115ba868663ffffffff6124a516565b9750611a0360006103e8612bcf565b611a57565b611a546001600160701b038816611a25858463ffffffff6124a516565b81611a2c57fe5b046001600160701b038816611a47858563ffffffff6124a516565b81611a4e57fe5b04612c53565b97505b60008811611a965760405162461bcd60e51b8152600401808060200182810382526028815260200180612dc46028913960400191505060405180910390fd5b611aa08989612bcf565b611aac85858989612558565b600954611ad2906001600160701b0380821691600160701b90041663ffffffff6124a516565b600c55604080518481526020810184905281513392600080516020612d3b833981519152928290030190a250506001600d55509395945050505050565b6008546001600160a01b031681565b60016020526000908152604090205481565b600c5481565b60036020526000908152604090205481565b600080600d54600114611b90576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d81905580611ba0610bfe565b50600654600754604080516370a0823160e01b815230600482015290519496509294506001600160a01b039182169391169160009184916370a08231916024808301926020929190829003018186803b158015611bfc57600080fd5b505afa158015611c10573d6000803e3d6000fd5b505050506040513d6020811015611c2657600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b158015611c7457600080fd5b505afa158015611c88573d6000803e3d6000fd5b505050506040513d6020811015611c9e57600080fd5b505130600090815260016020526040902054909150611cbd8787612771565b60005480611cd1838663ffffffff6124a516565b81611cd857fe5b04995080611cec838563ffffffff6124a516565b81611cf357fe5b04985060008a118015611d065750600089115b611d415760405162461bcd60e51b8152600401808060200182810382526028815260200180612d7c6028913960400191505060405180910390fd5b611d4b3083612af1565b611d56868c8c612312565b611d61858c8b612312565b604080516370a0823160e01b815230600482015290516001600160a01b038816916370a08231916024808301926020929190829003018186803b158015611da757600080fd5b505afa158015611dbb573d6000803e3d6000fd5b505050506040513d6020811015611dd157600080fd5b5051604080516370a0823160e01b815230600482015290519195506001600160a01b038716916370a0823191602480820192602092909190829003018186803b158015611e1d57600080fd5b505afa158015611e31573d6000803e3d6000fd5b505050506040513d6020811015611e4757600080fd5b50519250611e5784848a8a612558565b600954611e7d906001600160701b0380821691600160701b90041663ffffffff6124a516565b600c55604080518b8152602081018b905281516001600160a01b038e16923392600080516020612e0d833981519152929081900390910190a350505050505050506001600d81905550915091565b6040518060400160405280600381526020016216941560ea1b81525081565b6000610c35338484612960565b6103e881565b6005546001600160a01b03163314611f54576040805162461bcd60e51b81526020600482015260156024820152742d34b931b7b72830b4b91d102327a92124a22222a760591b604482015290519081900360640190fd5b600680546001600160a01b039485166001600160a01b031991821617909155600780549385169382169390931790925560088054919093169116179055565b6005546001600160a01b031681565b6007546001600160a01b031681565b42841015611ffb576040805162461bcd60e51b8152602060048201526012602482015271155b9a5cddd85c158c8e881156141254915160721b604482015290519081900360640190fd5b6004546001600160a01b038089166000818152600360209081526040808320805460018082019092558251600080516020612e768339815191528186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e280820193601f1981019281900390910190855afa158015612104573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381161580159061213a5750886001600160a01b0316816001600160a01b0316145b61218a576040805162461bcd60e51b815260206004820152601c60248201527b556e697377617056323a20494e56414c49445f5349474e415455524560201b604482015290519081900360640190fd5b61219589898961270f565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b600d54600114612202576040805162461bcd60e51b81526020600482015260116024820152600080516020612da4833981519152604482015290519081900360640190fd5b6000600d55600654604080516370a0823160e01b81523060048201529051610c93926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561225357600080fd5b505afa158015612267573d6000803e3d6000fd5b505050506040513d602081101561227d57600080fd5b5051600754604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b1580156122ca57600080fd5b505afa1580156122de573d6000803e3d6000fd5b505050506040513d60208110156122f457600080fd5b50516009546001600160701b0380821691600160701b900416612558565b60408051808201825260198152787472616e7366657228616464726573732c75696e743235362960381b60209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009460609489169392918291908083835b602083106123bb5780518252601f19909201916020918201910161239c565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d806000811461241d576040519150601f19603f3d011682016040523d82523d6000602084013e612422565b606091505b5091509150818015612450575080511580612450575080806020019051602081101561244d57600080fd5b50515b61249e576040805162461bcd60e51b815260206004820152601a602482015279155b9a5cddd85c158c8e881514905394d1915497d1905253115160321b604482015290519081900360640190fd5b5050505050565b60008115806124c0575050808202828282816124bd57fe5b04145b610c39576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6d756c2d6f766572666c6f7760601b604482015290519081900360640190fd5b80820382811115610c39576040805162461bcd60e51b815260206004820152601560248201527464732d6d6174682d7375622d756e646572666c6f7760581b604482015290519081900360640190fd5b6001600160701b03841180159061257657506001600160701b038311155b6125bd576040805162461bcd60e51b8152602060048201526013602482015272556e697377617056323a204f564552464c4f5760681b604482015290519081900360640190fd5b60095463ffffffff42811691600160e01b900481168203908116158015906125ed57506001600160701b03841615155b801561260157506001600160701b03831615155b15612672578063ffffffff1661262f8561261a86612c6b565b6001600160e01b03169063ffffffff612c7d16565b600a80546001600160e01b03929092169290920201905563ffffffff811661265a8461261a87612c6b565b600b80546001600160e01b0392909216929092020190555b600980546001600160701b0319166001600160701b0388811691909117600160701b600160e01b031916600160701b8883168102919091176001600160e01b0316600160e01b63ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b600c54801561295b57600061279b6115ba6001600160701b0386811690861663ffffffff6124a516565b905060006127a883612b7d565b90508082111561249e5760055460408051637ac9059160e11b815290516000926001600160a01b03169163f5920b22916004808301926020929190829003018186803b1580156127f757600080fd5b505afa15801561280b573d6000803e3d6000fd5b505050506040513d602081101561282157600080fd5b505190506000612843670de0b6b3a7640000610b09868663ffffffff61250816565b905060006128678461285b878663ffffffff6124a516565b9063ffffffff612ca216565b9050600081838161287457fe5b0490508015612195576008546000546128b9916001600160a01b031690670de0b6b3a7640000906128ac90859063ffffffff6124a516565b816128b357fe5b04612bcf565b6000856128d8670de0b6b3a7640000610b098a8463ffffffff61250816565b816128df57fe5b60085491900491506001600160a01b031663b9d92de8612905838563ffffffff61250816565b6040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b15801561293b57600080fd5b505af115801561294f573d6000803e3d6000fd5b50505050505050505050505b505050565b6001600160a01b038316600090815260016020526040902054612989908263ffffffff61250816565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546129be908263ffffffff612ca216565b6001600160a01b038084166000818152600160209081526040918290209490945580518581529051919392871692600080516020612e5683398151915292918290030190a3505050565b6000808511612a49576040805162461bcd60e51b81526020600482015260086024820152675556323a2049494160c01b604482015290519081900360640190fd5b600084118015612a595750600083115b612a94576040805162461bcd60e51b815260206004820152600760248201526615558c8e88125360ca1b604482015290519081900360640190fd5b6000612aab8661271085900363ffffffff6124a516565b90506000612abf828663ffffffff6124a516565b90506000612ad98361285b8961271063ffffffff6124a516565b9050808281612ae457fe5b0498975050505050505050565b6001600160a01b038216600090815260016020526040902054612b1a908263ffffffff61250816565b6001600160a01b03831660009081526001602052604081209190915554612b47908263ffffffff61250816565b60009081556040805183815290516001600160a01b03851691600080516020612e56833981519152919081900360200190a35050565b60006003821115612bc0575080600160028204015b81811015612bba57809150600281828581612ba957fe5b040181612bb257fe5b049050612b92565b50612bca565b8115612bca575060015b919050565b600054612be2908263ffffffff612ca216565b60009081556001600160a01b038316815260016020526040902054612c0d908263ffffffff612ca216565b6001600160a01b0383166000818152600160209081526040808320949094558351858152935192939192600080516020612e568339815191529281900390910190a35050565b6000818310612c625781612c64565b825b9392505050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b03841681612c9a57fe5b049392505050565b80820182811015610c39576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6164642d6f766572666c6f7760601b604482015290519081900360640190fdfe556e697377617056323a20494e53554646494349454e545f4f55545055545f414d4f554e54556e697377617056323a20494e53554646494349454e545f494e5055545f414d4f554e544c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f556e697377617056323a20494e53554646494349454e545f4c4951554944495459556e697377617056323a20494e53554646494349454e545f4c49515549444954595f4255524e4544556e697377617056323a204c4f434b4544000000000000000000000000000000556e697377617056323a20494e53554646494349454e545f4c49515549444954595f4d494e544544556e697377617056323a20557365206d696e7420746f2073746172742070616972dccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496556e697377617056323a20455854454e53494f4e5f4e4f545f454e4f5547485f4c4951554944495459ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9a265627a7a72315820c8e54a44b3e92083a84070a82d95cdccc0051c1bc1018b6a6aea8f455f04320264736f6c63430005100032454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429

Loading