Contract 0x5e58e0ced3a272caeb8ba00f4a4c2805df6be495 4

 

Contract Overview

Balance:
0 MATIC

MATIC Value:
$0.00

Token:
 
Txn Hash
Method
Block
From
To
Value [Txn Fee]
0xc98e3b9c5a245a1f40f6759e3d5eecff1f0f2fb4bf7b403043afab4c52ec8202Swap385676992023-01-27 0:17:241 day 16 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.064543407752110.12203852
0xa392ba2eea574c705e742f6e9f2d528fd7708fa6aaf6e710c0651c993064500cSwap385671122023-01-26 23:56:361 day 16 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.080859275437117.649428098
0x62ffcdec865bdafc7874f746304cc421b015d39e7fc17b24a8d11cbbcaf3a071Swap384989292023-01-25 6:34:413 days 10 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.03706906725671.695885857
0x4a3cd365e0ac87ec396a4ccaa42049b382d829fb3dc576206bae6640eadbb4f5Swap384971722023-01-25 5:32:033 days 11 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.03950260954976.402639585
0x3fbcbfed3598aa24deb86dc6091848adfdb1e3ac4d13b9589144660c02b35dffSwap384954392023-01-25 4:30:073 days 12 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04100075210279.300221461
0x1bbfd4e81cd45ca2f8f1e2ed016f039e631c24246c48156b53a576cfa4dd9f94Swap384934752023-01-25 3:18:473 days 13 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.05690057201110.052321733
0xb3b90b99e91fff2e457ccdfb3e52bd88f59eb0d7823ee27e9d85e83d1857df49Swap384795432023-01-24 18:55:323 days 21 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04782687310692.502733112
0x079e2af0fcd5ab29c2e69afeed8750f86d524627e2e662ee86346b2f20e28407Swap384709292023-01-24 13:37:464 days 3 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.101232409711172.680535328
0xaab906689fb3fc9e38b954b087e478df4b3bab851da6dcf1921ea30ae4f287a8Swap384624942023-01-24 8:33:394 days 8 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.094361400657107.813877183
0x219464b12f14b014415922e8f7a64e9fc5fac5f407b43022b0710b1f2b64db48Swap384105802023-01-23 1:33:575 days 15 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.0460671733589.099269195
0xe249f0ece11c6f48262ed00fd07740edf7da432887490f77081221b9fb8fbef9Swap384085452023-01-23 0:20:495 days 16 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.053349815216103.18474527
0x318b00c918b8e332246b019debbaf988c708afcfc935f13da6fee624ab5216dbSwap384021332023-01-22 20:28:365 days 20 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04670389035292.317693382
0xb606640a4526fed5ba3c9f35bf4bcbab0df0d5fd20fddf0205cf51e7632dad06Swap384011722023-01-22 19:53:595 days 20 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.03504864018769.279231212
0x03fbd29399eed5ad67fe84fda304f7fe353545d721be1b81f8c93bee456550c6Swap383294362023-01-21 0:38:077 days 16 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.072897207167133.470056279
0x3544bf454b53062fc290b0c316b519b5904e388d89ec835d91b07a99e9bfd263Swap383099672023-01-20 12:54:598 days 3 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.057948336304112.078819694
0xe07225737ba4f9756188fe35c5197c4d914272a1f54a11bf66f76f5811ec273cSwap383031332023-01-20 8:48:548 days 8 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.061228213849104.444191347
0xb718779fbbb39be3c06b59e2b95003ae37ab2e4e78a02464471ffeef6ba3e461Swap383005582023-01-20 7:15:568 days 9 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04314939917885.291674268
0x59edf45cdfffb2e151c46f7faee2a92b8c5b271e9a8e3c6856caf33a9edf5b9cSwap382820052023-01-19 19:32:058 days 21 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04806475417292.96282275
0x1a156709aad7a4b41d871815adafbe26378ceed6cdc46c2b21620b37eac1e0bfSwap382803762023-01-19 18:32:118 days 22 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.05166965091658.449831353
0xef3e5a3c9da7c96e4e3e87df4b7d892d6083942c5df354efd9233c7965464f3cSwap382468852023-01-18 22:20:239 days 18 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04364273531686.266831882
0x17b9c5fe2df8f182fa77d494d2f7fa66034e97414838b3420e37ed58b7d9b71dSwap382455172023-01-18 21:31:559 days 19 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.03532036590269.816340456
0x3ba079b5c68ae1fa882d5b2d29238d90b8299093552fb059f7f85dcbe056219fSwap382431842023-01-18 20:09:199 days 20 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04035817368868.856503257
0x44f9ca2ba988aabd49f0d61e89683ee39c3da5c806e4a5f89601b1f8225a5e71Swap382431052023-01-18 20:06:319 days 20 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.03527435519169.159706831
0xdc60f3767ec5e92a7633c902d6365131d49af7738b193d7eb1f925899717e351Swap382279882023-01-18 10:43:3210 days 6 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04065661536580.364289204
0xe7c28726f61cb901cd8ad5c36fb8216cb67ef8cb1bd49a0b7770b6e223fb51d1Swap382106452023-01-17 23:54:2910 days 16 hrs ago0x9f8c767a407b74dd35f2916c21114186d5cc8ab2 IN  0x5e58e0ced3a272caeb8ba00f4a4c2805df6be4950 MATIC0.04319183415785.375553777
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0xa1c17d4d02b59113c61c9462c13cff5a87968f1b37068366d3c7f26b4f178320165726342021-07-06 18:52:14570 days 22 hrs ago 0x668ad0ed2622c62e24f0d5ab6b6ac1b9d2cd4ac7  Contract Creation0 MATIC
[ Download CSV Export 
Loading

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

Contract Name:
JetswapPair

Compiler Version
v0.5.16+commit.9c3226ce

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at polygonscan.com on 2021-07-06
*/

pragma solidity =0.5.16;

interface IJetswapFactory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    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(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

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

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

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

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

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

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

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

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

    function initialize(address, address) external;
}

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

// 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');
    }
}

contract JetswapERC20 is IJetswapERC20 {
    using SafeMath for uint;

    string public constant name = 'Jetswap LPs';
    string public constant symbol = 'pWINGS-LP';
    uint8 public constant decimals = 18;
    uint  public totalSupply;
    mapping(address => uint) public balanceOf;
    mapping(address => mapping(address => uint)) 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 => uint) public nonces;

    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, 'Jetswap: 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, 'Jetswap: INVALID_SIGNATURE');
        _approve(owner, spender, value);
    }
}

// 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;
    }

    // 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;
        }
    }
}

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

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

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

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

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

contract JetswapPair is IJetswapPair, JetswapERC20 {
    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;

    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

    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, 'Jetswap: 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))), 'Jetswap: 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;
    }

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

    // 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), 'Jetswap: 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);
    }

    // if fee is on, mint liquidity equivalent to 1/6th of the growth in sqrt(k)
    function _mintFee(uint112 _reserve0, uint112 _reserve1) private returns (bool feeOn) {
        address feeTo = IJetswapFactory(factory).feeTo();
        feeOn = feeTo != address(0);
        uint _kLast = kLast; // gas savings
        if (feeOn) {
            if (_kLast != 0) {
                uint rootK = Math.sqrt(uint(_reserve0).mul(_reserve1));
                uint rootKLast = Math.sqrt(_kLast);
                if (rootK > rootKLast) {
                    uint numerator = totalSupply.mul(rootK.sub(rootKLast));
                    uint denominator = rootK.mul(5).add(rootKLast);
                    uint liquidity = numerator / denominator;
                    if (liquidity > 0) _mint(feeTo, liquidity);
                }
            }
        } else if (_kLast != 0) {
            kLast = 0;
        }
    }

    // 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 = IERC20(token0).balanceOf(address(this));
        uint balance1 = IERC20(token1).balanceOf(address(this));
        uint amount0 = balance0.sub(_reserve0);
        uint amount1 = balance1.sub(_reserve1);

        bool feeOn = _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, 'Jetswap: INSUFFICIENT_LIQUIDITY_MINTED');
        _mint(to, liquidity);

        _update(balance0, balance1, _reserve0, _reserve1);
        if (feeOn) 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
    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 = IERC20(_token0).balanceOf(address(this));
        uint balance1 = IERC20(_token1).balanceOf(address(this));
        uint liquidity = balanceOf[address(this)];

        bool feeOn = _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, 'Jetswap: INSUFFICIENT_LIQUIDITY_BURNED');
        _burn(address(this), liquidity);
        _safeTransfer(_token0, to, amount0);
        _safeTransfer(_token1, to, amount1);
        balance0 = IERC20(_token0).balanceOf(address(this));
        balance1 = IERC20(_token1).balanceOf(address(this));

        _update(balance0, balance1, _reserve0, _reserve1);
        if (feeOn) 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, 'Jetswap: INSUFFICIENT_OUTPUT_AMOUNT');
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        require(amount0Out < _reserve0 && amount1Out < _reserve1, 'Jetswap: 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, 'Jetswap: 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) IJetswapCallee(to).jetswapCall(msg.sender, amount0Out, amount1Out, data);
        balance0 = IERC20(_token0).balanceOf(address(this));
        balance1 = IERC20(_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, 'Jetswap: INSUFFICIENT_INPUT_AMOUNT');
        { // scope for reserve{0,1}Adjusted, avoids stack too deep errors
        uint balance0Adjusted = balance0.mul(1000).sub(amount0In.mul(1));
        uint balance1Adjusted = balance1.mul(1000).sub(amount1In.mul(1));
        require(balance0Adjusted.mul(balance1Adjusted) >= uint(_reserve0).mul(_reserve1).mul(1000**2), 'Jetswap: 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, IERC20(_token0).balanceOf(address(this)).sub(reserve0));
        _safeTransfer(_token1, to, IERC20(_token1).balanceOf(address(this)).sub(reserve1));
    }

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

contract JetswapFactory is IJetswapFactory {
    bytes32 public constant INIT_CODE_PAIR_HASH = keccak256(abi.encodePacked(type(JetswapPair).creationCode));

    address public feeTo;
    address public feeToSetter;

    mapping(address => mapping(address => address)) public getPair;
    address[] public allPairs;

    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    constructor(address _feeToSetter) public {
        feeToSetter = _feeToSetter;
    }

    function allPairsLength() external view returns (uint) {
        return allPairs.length;
    }

    function createPair(address tokenA, address tokenB) external returns (address pair) {
        require(tokenA != tokenB, 'Jetswap: IDENTICAL_ADDRESSES');
        (address token0, address token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
        require(token0 != address(0), 'Jetswap: ZERO_ADDRESS');
        require(getPair[token0][token1] == address(0), 'Jetswap: PAIR_EXISTS'); // single check is sufficient
        bytes memory bytecode = type(JetswapPair).creationCode;
        bytes32 salt = keccak256(abi.encodePacked(token0, token1));
        assembly {
            pair := create2(0, add(bytecode, 32), mload(bytecode), salt)
        }
        IJetswapPair(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);
    }

    function setFeeTo(address _feeTo) external {
        require(msg.sender == feeToSetter, 'Jetswap: FORBIDDEN');
        feeTo = _feeTo;
    }

    function setFeeToSetter(address _feeToSetter) external {
        require(msg.sender == feeToSetter, 'Jetswap: FORBIDDEN');
        feeToSetter = _feeToSetter;
    }
}

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":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"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"}],"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":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":[{"internalType":"address","name":"to","type":"address"}],"name":"skim","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"}]

60806040526001600c5534801561001557600080fd5b5060405146908060526123648239604080519182900360520182208282018252600b83526a4a657473776170204c507360a81b6020938401528151808301835260018152603160f81b908401528151808401919091527f9f41533d66e226d33d95ae8fa4757ee3d8b68363d9e2dbba77370d4587e955ae818301527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606082015260808101949094523060a0808601919091528151808603909101815260c09094019052825192019190912060035550600580546001600160a01b0319163317905561225e806101066000396000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c80636a627842116100f9578063ba9a7a5611610097578063d21220a711610071578063d21220a714610534578063d505accf1461053c578063dd62ed3e1461058d578063fff6cae9146105bb576101a9565b8063ba9a7a56146104fe578063bc25cf7714610506578063c45a01551461052c576101a9565b80637ecebe00116100d35780637ecebe001461046557806389afcb441461048b57806395d89b41146104ca578063a9059cbb146104d2576101a9565b80636a6278421461041157806370a08231146104375780637464fc3d1461045d576101a9565b806323b872dd116101665780633644e515116101405780633644e515146103cb578063485cc955146103d35780635909c0d5146104015780635a3d549314610409576101a9565b806323b872dd1461036f57806330adf81f146103a5578063313ce567146103ad576101a9565b8063022c0d9f146101ae57806306fdde031461023c5780630902f1ac146102b9578063095ea7b3146102f15780630dfe16811461033157806318160ddd14610355575b600080fd5b61023a600480360360808110156101c457600080fd5b8135916020810135916001600160a01b0360408301351691908101906080810160608201356401000000008111156101fb57600080fd5b82018360208201111561020d57600080fd5b8035906020019184600183028401116401000000008311171561022f57600080fd5b5090925090506105c3565b005b610244610b0e565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561027e578181015183820152602001610266565b50505050905090810190601f1680156102ab5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102c1610b35565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b61031d6004803603604081101561030757600080fd5b506001600160a01b038135169060200135610b5f565b604080519115158252519081900360200190f35b610339610b76565b604080516001600160a01b039092168252519081900360200190f35b61035d610b85565b60408051918252519081900360200190f35b61031d6004803603606081101561038557600080fd5b506001600160a01b03813581169160208101359091169060400135610b8b565b61035d610c25565b6103b5610c49565b6040805160ff9092168252519081900360200190f35b61035d610c4e565b61023a600480360360408110156103e957600080fd5b506001600160a01b0381358116916020013516610c54565b61035d610cd6565b61035d610cdc565b61035d6004803603602081101561042757600080fd5b50356001600160a01b0316610ce2565b61035d6004803603602081101561044d57600080fd5b50356001600160a01b0316610fe0565b61035d610ff2565b61035d6004803603602081101561047b57600080fd5b50356001600160a01b0316610ff8565b6104b1600480360360208110156104a157600080fd5b50356001600160a01b031661100a565b6040805192835260208301919091528051918290030190f35b6102446113ae565b61031d600480360360408110156104e857600080fd5b506001600160a01b0381351690602001356113d3565b61035d6113e0565b61023a6004803603602081101561051c57600080fd5b50356001600160a01b03166113e6565b61033961154f565b61033961155e565b61023a600480360360e081101561055257600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c0013561156d565b61035d600480360360408110156105a357600080fd5b506001600160a01b038135811691602001351661176d565b61023a61178a565b600c5460011461060c576040805162461bcd60e51b815260206004820152600f60248201526e12995d1cddd85c0e881313d0d2d151608a1b604482015290519081900360640190fd5b6000600c558415158061061f5750600084115b61065a5760405162461bcd60e51b81526004018080602001828103825260238152602001806122076023913960400191505060405180910390fd5b600080610665610b35565b5091509150816001600160701b03168710801561068a5750806001600160701b031686105b6106db576040805162461bcd60e51b815260206004820152601f60248201527f4a6574737761703a20494e53554646494349454e545f4c495155494449545900604482015290519081900360640190fd5b60065460075460009182916001600160a01b039182169190811690891682148015906107195750806001600160a01b0316896001600160a01b031614155b610760576040805162461bcd60e51b81526020600482015260136024820152724a6574737761703a20494e56414c49445f544f60681b604482015290519081900360640190fd5b8a1561077157610771828a8d6118ea565b891561078257610782818a8c6118ea565b861561083d57886001600160a01b0316633fc01685338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03166001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561082457600080fd5b505af1158015610838573d6000803e3d6000fd5b505050505b604080516370a0823160e01b815230600482015290516001600160a01b038416916370a08231916024808301926020929190829003018186803b15801561088357600080fd5b505afa158015610897573d6000803e3d6000fd5b505050506040513d60208110156108ad57600080fd5b5051604080516370a0823160e01b815230600482015290519195506001600160a01b038316916370a0823191602480820192602092909190829003018186803b1580156108f957600080fd5b505afa15801561090d573d6000803e3d6000fd5b505050506040513d602081101561092357600080fd5b5051925060009150506001600160701b0385168a90038311610946576000610955565b89856001600160701b03160383035b9050600089856001600160701b0316038311610972576000610981565b89856001600160701b03160383035b905060008211806109925750600081115b6109cd5760405162461bcd60e51b81526004018080602001828103825260228152602001806121996022913960400191505060405180910390fd5b6000610a016109e384600163ffffffff611a8416565b6109f5876103e863ffffffff611a8416565b9063ffffffff611ae716565b90506000610a196109e384600163ffffffff611a8416565b9050610a4a620f4240610a3e6001600160701b038b8116908b1663ffffffff611a8416565b9063ffffffff611a8416565b610a5a838363ffffffff611a8416565b1015610a9a576040805162461bcd60e51b815260206004820152600a6024820152694a6574737761703a204b60b01b604482015290519081900360640190fd5b5050610aa884848888611b37565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600c55505050505050505050565b6040518060400160405280600b81526020016a4a657473776170204c507360a81b81525081565b6008546001600160701b0380821692600160701b830490911691600160e01b900463ffffffff1690565b6000610b6c338484611cfa565b5060015b92915050565b6006546001600160a01b031681565b60005481565b6001600160a01b038316600090815260026020908152604080832033845290915281205460001914610c10576001600160a01b0384166000908152600260209081526040808320338452909152902054610beb908363ffffffff611ae716565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610c1b848484611d5c565b5060019392505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b601281565b60035481565b6005546001600160a01b03163314610ca8576040805162461bcd60e51b81526020600482015260126024820152712532ba39bbb0b81d102327a92124a22222a760711b604482015290519081900360640190fd5b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b60095481565b600a5481565b6000600c54600114610d2d576040805162461bcd60e51b815260206004820152600f60248201526e12995d1cddd85c0e881313d0d2d151608a1b604482015290519081900360640190fd5b6000600c81905580610d3d610b35565b50600654604080516370a0823160e01b815230600482015290519395509193506000926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015610d9157600080fd5b505afa158015610da5573d6000803e3d6000fd5b505050506040513d6020811015610dbb57600080fd5b5051600754604080516370a0823160e01b815230600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015610e0e57600080fd5b505afa158015610e22573d6000803e3d6000fd5b505050506040513d6020811015610e3857600080fd5b505190506000610e57836001600160701b03871663ffffffff611ae716565b90506000610e74836001600160701b03871663ffffffff611ae716565b90506000610e828787611e16565b60005490915080610ebf57610eab6103e86109f5610ea6878763ffffffff611a8416565b611f74565b9850610eba60006103e8611fc6565b610f0e565b610f0b6001600160701b038916610edc868463ffffffff611a8416565b81610ee357fe5b046001600160701b038916610efe868563ffffffff611a8416565b81610f0557fe5b0461205c565b98505b60008911610f4d5760405162461bcd60e51b81526004018080602001828103825260268152602001806121e16026913960400191505060405180910390fd5b610f578a8a611fc6565b610f6386868a8a611b37565b8115610f9357600854610f8f906001600160701b0380821691600160701b90041663ffffffff611a8416565b600b555b6040805185815260208101859052815133927f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f928290030190a250506001600c5550949695505050505050565b60016020526000908152604090205481565b600b5481565b60046020526000908152604090205481565b600080600c54600114611056576040805162461bcd60e51b815260206004820152600f60248201526e12995d1cddd85c0e881313d0d2d151608a1b604482015290519081900360640190fd5b6000600c81905580611066610b35565b50600654600754604080516370a0823160e01b815230600482015290519496509294506001600160a01b039182169391169160009184916370a08231916024808301926020929190829003018186803b1580156110c257600080fd5b505afa1580156110d6573d6000803e3d6000fd5b505050506040513d60208110156110ec57600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b15801561113a57600080fd5b505afa15801561114e573d6000803e3d6000fd5b505050506040513d602081101561116457600080fd5b5051306000908152600160205260408120549192506111838888611e16565b6000549091508061119a848763ffffffff611a8416565b816111a157fe5b049a50806111b5848663ffffffff611a8416565b816111bc57fe5b04995060008b1180156111cf575060008a115b61120a5760405162461bcd60e51b81526004018080602001828103825260268152602001806121bb6026913960400191505060405180910390fd5b6112143084612074565b61121f878d8d6118ea565b61122a868d8c6118ea565b604080516370a0823160e01b815230600482015290516001600160a01b038916916370a08231916024808301926020929190829003018186803b15801561127057600080fd5b505afa158015611284573d6000803e3d6000fd5b505050506040513d602081101561129a57600080fd5b5051604080516370a0823160e01b815230600482015290519196506001600160a01b038816916370a0823191602480820192602092909190829003018186803b1580156112e657600080fd5b505afa1580156112fa573d6000803e3d6000fd5b505050506040513d602081101561131057600080fd5b5051935061132085858b8b611b37565b81156113505760085461134c906001600160701b0380821691600160701b90041663ffffffff611a8416565b600b555b604080518c8152602081018c905281516001600160a01b038f169233927fdccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496929081900390910190a35050505050505050506001600c81905550915091565b6040518060400160405280600981526020016807057494e47532d4c560bc1b81525081565b6000610b6c338484611d5c565b6103e881565b600c5460011461142f576040805162461bcd60e51b815260206004820152600f60248201526e12995d1cddd85c0e881313d0d2d151608a1b604482015290519081900360640190fd5b6000600c55600654600754600854604080516370a0823160e01b815230600482015290516001600160a01b0394851694909316926114de92859287926114d9926001600160701b03169185916370a0823191602480820192602092909190829003018186803b1580156114a157600080fd5b505afa1580156114b5573d6000803e3d6000fd5b505050506040513d60208110156114cb57600080fd5b50519063ffffffff611ae716565b6118ea565b600854604080516370a0823160e01b8152306004820152905161154592849287926114d992600160701b90046001600160701b0316916001600160a01b038616916370a0823191602480820192602092909190829003018186803b1580156114a157600080fd5b50506001600c5550565b6005546001600160a01b031681565b6007546001600160a01b031681565b428410156115b5576040805162461bcd60e51b815260206004820152601060248201526f12995d1cddd85c0e881156141254915160821b604482015290519081900360640190fd5b6003546001600160a01b0380891660008181526004602090815260408083208054600180820190925582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e280820193601f1981019281900390910190855afa1580156116d0573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906117065750886001600160a01b0316816001600160a01b0316145b611757576040805162461bcd60e51b815260206004820152601a60248201527f4a6574737761703a20494e56414c49445f5349474e4154555245000000000000604482015290519081900360640190fd5b611762898989611cfa565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b600c546001146117d3576040805162461bcd60e51b815260206004820152600f60248201526e12995d1cddd85c0e881313d0d2d151608a1b604482015290519081900360640190fd5b6000600c55600654604080516370a0823160e01b815230600482015290516118e3926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561182457600080fd5b505afa158015611838573d6000803e3d6000fd5b505050506040513d602081101561184e57600080fd5b5051600754604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561189b57600080fd5b505afa1580156118af573d6000803e3d6000fd5b505050506040513d60208110156118c557600080fd5b50516008546001600160701b0380821691600160701b900416611b37565b6001600c55565b604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009460609489169392918291908083835b602083106119975780518252601f199092019160209182019101611978565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d80600081146119f9576040519150601f19603f3d011682016040523d82523d6000602084013e6119fe565b606091505b5091509150818015611a2c575080511580611a2c5750808060200190516020811015611a2957600080fd5b50515b611a7d576040805162461bcd60e51b815260206004820152601860248201527f4a6574737761703a205452414e534645525f4641494c45440000000000000000604482015290519081900360640190fd5b5050505050565b6000811580611a9f57505080820282828281611a9c57fe5b04145b610b70576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6d756c2d6f766572666c6f7760601b604482015290519081900360640190fd5b80820382811115610b70576040805162461bcd60e51b815260206004820152601560248201527464732d6d6174682d7375622d756e646572666c6f7760581b604482015290519081900360640190fd5b6001600160701b038411801590611b5557506001600160701b038311155b611b9a576040805162461bcd60e51b81526020600482015260116024820152704a6574737761703a204f564552464c4f5760781b604482015290519081900360640190fd5b60085463ffffffff42811691600160e01b90048116820390811615801590611bca57506001600160701b03841615155b8015611bde57506001600160701b03831615155b15611c4f578063ffffffff16611c0c85611bf786612112565b6001600160e01b03169063ffffffff61212416565b600980546001600160e01b03929092169290920201905563ffffffff8116611c3784611bf787612112565b600a80546001600160e01b0392909216929092020190555b600880546dffffffffffffffffffffffffffff19166001600160701b03888116919091176dffffffffffffffffffffffffffff60701b1916600160701b8883168102919091176001600160e01b0316600160e01b63ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316600090815260016020526040902054611d85908263ffffffff611ae716565b6001600160a01b038085166000908152600160205260408082209390935590841681522054611dba908263ffffffff61214916565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b600080600560009054906101000a90046001600160a01b03166001600160a01b031663017e7e586040518163ffffffff1660e01b815260040160206040518083038186803b158015611e6757600080fd5b505afa158015611e7b573d6000803e3d6000fd5b505050506040513d6020811015611e9157600080fd5b5051600b546001600160a01b038216158015945091925090611f60578015611f5b576000611ed4610ea66001600160701b0388811690881663ffffffff611a8416565b90506000611ee183611f74565b905080821115611f58576000611f0f611f00848463ffffffff611ae716565b6000549063ffffffff611a8416565b90506000611f3483611f2886600563ffffffff611a8416565b9063ffffffff61214916565b90506000818381611f4157fe5b0490508015611f5457611f548782611fc6565b5050505b50505b611f6c565b8015611f6c576000600b555b505092915050565b60006003821115611fb7575080600160028204015b81811015611fb157809150600281828581611fa057fe5b040181611fa957fe5b049050611f89565b50611fc1565b8115611fc1575060015b919050565b600054611fd9908263ffffffff61214916565b60009081556001600160a01b038316815260016020526040902054612004908263ffffffff61214916565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b600081831061206b578161206d565b825b9392505050565b6001600160a01b03821660009081526001602052604090205461209d908263ffffffff611ae716565b6001600160a01b038316600090815260016020526040812091909155546120ca908263ffffffff611ae716565b60009081556040805183815290516001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a35050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b0384168161214157fe5b049392505050565b80820182811015610b70576040805162461bcd60e51b815260206004820152601460248201527364732d6d6174682d6164642d6f766572666c6f7760601b604482015290519081900360640190fdfe4a6574737761703a20494e53554646494349454e545f494e5055545f414d4f554e544a6574737761703a20494e53554646494349454e545f4c49515549444954595f4255524e45444a6574737761703a20494e53554646494349454e545f4c49515549444954595f4d494e5445444a6574737761703a20494e53554646494349454e545f4f55545055545f414d4f554e54a265627a7a7231582013f9b777465d01f72c04e17a019dc5b8f3faa41839b89637fe5144ea22144f5664736f6c63430005100032454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429

Deployed ByteCode Sourcemap

10351:9653:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10351:9653:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17536:1875;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;17536:1875:0;;;;;;;;;;;;-1:-1:-1;;;;;17536:1875:0;;;;;;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;17536:1875:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;17536:1875:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;-1:-1;17536:1875:0;;-1:-1:-1;17536:1875:0;-1:-1:-1;17536:1875:0;:::i;:::-;;4899:43;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;4899:43:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11364:231;;;:::i;:::-;;;;-1:-1:-1;;;;;11364:231:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6950:147;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;6950:147:0;;-1:-1:-1;;;;;6950:147:0;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;10655:21;;;:::i;:::-;;;;-1:-1:-1;;;;;10655:21:0;;;;;;;;;;;;;;5041:24;;;:::i;:::-;;;;;;;;;;;;;;;;7252:301;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;7252:301:0;;;;;;;;;;;;;;;;;:::i;5333:108::-;;;:::i;4999:35::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;5190:31;;;:::i;12422:208::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;12422:208:0;;;;;;;;;;:::i;11006:32::-;;;:::i;11045:::-;;;:::i;14610:1238::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;14610:1238:0;-1:-1:-1;;;;;14610:1238:0;;:::i;5072:41::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;5072:41:0;-1:-1:-1;;;;;5072:41:0;;:::i;11084:17::-;;;:::i;5448:38::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;5448:38:0;-1:-1:-1;;;;;5448:38:0;;:::i;15960:1464::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;15960:1464:0;-1:-1:-1;;;;;15960:1464:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;4949:43;;;:::i;7105:139::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;7105:139:0;;-1:-1:-1;;;;;7105:139:0;;;;;;:::i;10476:46::-;;;:::i;19460:334::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19460:334:0;-1:-1:-1;;;;;19460:334:0;;:::i;10626:22::-;;;:::i;10683:21::-;;;:::i;7561:670::-;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;7561:670:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;7561:670:0;;;;;;;;:::i;5120:61::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;5120:61:0;;;;;;;;;;:::i;19843:158::-;;;:::i;17536:1875::-;11257:8;;11269:1;11257:13;11249:41;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;;;;11312:1;11301:8;:12;17650:14;;;;:32;;;17681:1;17668:10;:14;17650:32;17642:80;;;;-1:-1:-1;;;17642:80:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17734:17;17753;17775:13;:11;:13::i;:::-;-1:-1:-1;17733:55:0;;-1:-1:-1;17733:55:0;-1:-1:-1;;;;;;17822:22:0;;;;:48;;;;-1:-1:-1;;;;;;17848:22:0;;;;17822:48;17814:92;;;;;-1:-1:-1;;;17814:92:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;18051:6;;18086;;17919:13;;;;-1:-1:-1;;;;;18051:6:0;;;;18086;;;;18111:13;;;;;;;:30;;-1:-1:-1;;;;;;18128:13:0;;;;;;;;18111:30;18103:62;;;;;-1:-1:-1;;;18103:62:0;;;;;;;;;;;;-1:-1:-1;;;18103:62:0;;;;;;;;;;;;;;;18180:14;;18176:58;;18196:38;18210:7;18219:2;18223:10;18196:13;:38::i;:::-;18283:14;;18279:58;;18299:38;18313:7;18322:2;18326:10;18299:13;:38::i;:::-;18386:15;;18382:93;;18418:2;-1:-1:-1;;;;;18403:30:0;;18434:10;18446;18458;18470:4;;18403:72;;;;;;;;;;;;;-1:-1:-1;;;;;18403:72:0;-1:-1:-1;;;;;18403:72:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;93:3;85:6;81:16;74:27;137:4;133:9;126:4;121:3;117:14;113:30;106:37;;169:3;161:6;157:16;147:26;;18403:72:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;18403:72:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;18403:72:0;;;;18382:93;18497:40;;;-1:-1:-1;;;18497:40:0;;18531:4;18497:40;;;;;;-1:-1:-1;;;;;18497:25:0;;;-1:-1:-1;;18497:40:0;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;18497:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;18497:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;18497:40:0;18559;;;-1:-1:-1;;;18559:40:0;;18593:4;18559:40;;;;;;18497;;-1:-1:-1;;;;;;18559:25:0;;;-1:-1:-1;;18559:40:0;;;;;18497;;18559;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;18559:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;18559:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;18559:40:0;;-1:-1:-1;18621:14:0;;-1:-1:-1;;;;;;;18649:22:0;;;;;18638:33;;:75;;18712:1;18638:75;;;-1:-1:-1;;;;;18686:22:0;;;;;18674:35;;18638:75;18621:92;-1:-1:-1;18724:14:0;-1:-1:-1;;;;;18752:22:0;;;;;18741:33;;:75;;18815:1;18741:75;;;-1:-1:-1;;;;;18789:22:0;;;;;18777:35;;18741:75;18724:92;;18847:1;18835:9;:13;:30;;;;18864:1;18852:9;:13;18835:30;18827:77;;;;-1:-1:-1;;;18827:77:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18990:21;19014:40;19037:16;:9;19051:1;19037:16;:13;:16;:::i;:::-;19014:18;:8;19027:4;19014:18;:12;:18;:::i;:::-;:22;:40;:22;:40;:::i;:::-;18990:64;-1:-1:-1;19065:21:0;19089:40;19112:16;:9;19126:1;19112:16;:13;:16;:::i;19089:40::-;19065:64;-1:-1:-1;19190:43:0;19225:7;19190:30;-1:-1:-1;;;;;19190:15:0;;;;:30;;:19;:30::i;:::-;:34;:43;:34;:43;:::i;:::-;19148:38;:16;19169;19148:38;:20;:38;:::i;:::-;:85;;19140:108;;;;;-1:-1:-1;;;19140:108:0;;;;;;;;;;;;-1:-1:-1;;;19140:108:0;;;;;;;;;;;;;;;11324:1;;19272:49;19280:8;19290;19300:9;19311;19272:7;:49::i;:::-;19337:66;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19337:66:0;;;19342:10;;19337:66;;;;;;;;;-1:-1:-1;;11347:1:0;11336:8;:12;-1:-1:-1;;;;;;;;;17536:1875:0:o;4899:43::-;;;;;;;;;;;;;-1:-1:-1;;;4899:43:0;;;;;:::o;11364:231::-;11497:8;;-1:-1:-1;;;;;11497:8:0;;;;-1:-1:-1;;;11528:8:0;;;;;;-1:-1:-1;;;11569:18:0;;;;;11364:231::o;6950:147::-;7014:4;7031:36;7040:10;7052:7;7061:5;7031:8;:36::i;:::-;-1:-1:-1;7085:4:0;6950:147;;;;;:::o;10655:21::-;;;-1:-1:-1;;;;;10655:21:0;;:::o;5041:24::-;;;;:::o;7252:301::-;-1:-1:-1;;;;;7351:15:0;;7330:4;7351:15;;;:9;:15;;;;;;;;7367:10;7351:27;;;;;;;;-1:-1:-1;;7351:39:0;7347:140;;-1:-1:-1;;;;;7437:15:0;;;;;;:9;:15;;;;;;;;7453:10;7437:27;;;;;;;;:38;;7469:5;7437:31;:38::i;:::-;-1:-1:-1;;;;;7407:15:0;;;;;;:9;:15;;;;;;;;7423:10;7407:27;;;;;;;:68;7347:140;7497:26;7507:4;7513:2;7517:5;7497:9;:26::i;:::-;-1:-1:-1;7541:4:0;7252:301;;;;;:::o;5333:108::-;5375:66;5333:108;:::o;4999:35::-;5032:2;4999:35;:::o;5190:31::-;;;;:::o;12422:208::-;12518:7;;-1:-1:-1;;;;;12518:7:0;12504:10;:21;12496:52;;;;;-1:-1:-1;;;12496:52:0;;;;;;;;;;;;-1:-1:-1;;;12496:52:0;;;;;;;;;;;;;;;12579:6;:16;;-1:-1:-1;;;;;12579:16:0;;;-1:-1:-1;;;;;;12579:16:0;;;;;;;12606:6;:16;;;;;;;;;;;12422:208::o;11006:32::-;;;;:::o;11045:::-;;;;:::o;14610:1238::-;14659:14;11257:8;;11269:1;11257:13;11249:41;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;;;;11312:1;11301:8;:12;;;11312:1;14728:13;:11;:13::i;:::-;-1:-1:-1;14790:6:0;;14783:39;;;-1:-1:-1;;;14783:39:0;;14816:4;14783:39;;;;;;14686:55;;-1:-1:-1;14686:55:0;;-1:-1:-1;;;;;;;;14790:6:0;;;;-1:-1:-1;;14783:39:0;;;;;;;;;;;;;;14790:6;14783:39;;;5:2:-1;;;;30:1;27;20:12;5:2;14783:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;14783:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;14783:39:0;14856:6;;14849:39;;;-1:-1:-1;;;14849:39:0;;14882:4;14849:39;;;;;;14783;;-1:-1:-1;;;;;;;;14856:6:0;;;;-1:-1:-1;;14849:39:0;;;;;14783;;14849;;;;;;;;14856:6;14849:39;;;5:2:-1;;;;30:1;27;20:12;5:2;14849:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;14849:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;14849:39:0;;-1:-1:-1;14899:12:0;14914:23;:8;-1:-1:-1;;;;;14914:23:0;;:12;:23::i;:::-;14899:38;-1:-1:-1;14948:12:0;14963:23;:8;-1:-1:-1;;;;;14963:23:0;;:12;:23::i;:::-;14948:38;;14999:10;15012:30;15021:9;15032;15012:8;:30::i;:::-;15053:17;15073:11;14999:43;;-1:-1:-1;15177:17:0;15173:352;;15223:54;10517:5;15223:31;15233:20;:7;15245;15233:20;:11;:20;:::i;:::-;15223:9;:31::i;:54::-;15211:66;;15291:36;15305:1;10517:5;15291;:36::i;:::-;15173:352;;;15427:86;-1:-1:-1;;;;;15436:37:0;;:25;:7;15448:12;15436:11;:25::i;:::-;:37;;;;;;-1:-1:-1;;;;;15475:37:0;;:25;:7;15487:12;15475:11;:25::i;:::-;:37;;;;;;15427:8;:86::i;:::-;15415:98;;15173:352;15555:1;15543:9;:13;15535:64;;;;-1:-1:-1;;;15535:64:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15610:20;15616:2;15620:9;15610:5;:20::i;:::-;15643:49;15651:8;15661;15671:9;15682;15643:7;:49::i;:::-;15707:5;15703:47;;;15741:8;;15722:28;;-1:-1:-1;;;;;15727:8:0;;;;-1:-1:-1;;;15741:8:0;;;15722:18;:28::i;:::-;15714:5;:36;15703:47;15806:34;;;;;;;;;;;;;;15811:10;;15806:34;;;;;;;;-1:-1:-1;;11347:1:0;11336:8;:12;-1:-1:-1;14610:1238:0;;;-1:-1:-1;;;;;;14610:1238:0:o;5072:41::-;;;;;;;;;;;;;:::o;11084:17::-;;;;:::o;5448:38::-;;;;;;;;;;;;;:::o;15960:1464::-;16009:12;16023;11257:8;;11269:1;11257:13;11249:41;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;;;;11312:1;11301:8;:12;;;11312:1;16090:13;:11;:13::i;:::-;-1:-1:-1;16147:6:0;;16228;;16307:40;;;-1:-1:-1;;;16307:40:0;;16341:4;16307:40;;;;;;16048:55;;-1:-1:-1;16048:55:0;;-1:-1:-1;;;;;;16147:6:0;;;;16228;;;-1:-1:-1;;16147:6:0;;-1:-1:-1;;16307:40:0;;;;;;;;;;;;;;16147:6;16307:40;;;5:2:-1;;;;30:1;27;20:12;5:2;16307:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;16307:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16307:40:0;16374;;;-1:-1:-1;;;16374:40:0;;16408:4;16374:40;;;;;;16307;;-1:-1:-1;;;;;;;;16374:25:0;;;-1:-1:-1;;16374:40:0;;;;;16307;;16374;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;16374:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;16374:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16374:40:0;16460:4;16425:14;16442:24;;;:9;16374:40;16442:24;;;;;16374:40;;-1:-1:-1;16492:30:0;16501:9;16512;16492:8;:30::i;:::-;16533:17;16553:11;16479:43;;-1:-1:-1;16553:11:0;16663:23;:9;16677:8;16663:23;:13;:23;:::i;:::-;:38;;;;;;;-1:-1:-1;16796:12:0;16770:23;:9;16784:8;16770:23;:13;:23;:::i;:::-;:38;;;;;;16760:48;;16885:1;16875:7;:11;:26;;;;;16900:1;16890:7;:11;16875:26;16867:77;;;;-1:-1:-1;;;16867:77:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16955:31;16969:4;16976:9;16955:5;:31::i;:::-;16997:35;17011:7;17020:2;17024:7;16997:13;:35::i;:::-;17043;17057:7;17066:2;17070:7;17043:13;:35::i;:::-;17100:40;;;-1:-1:-1;;;17100:40:0;;17134:4;17100:40;;;;;;-1:-1:-1;;;;;17100:25:0;;;-1:-1:-1;;17100:40:0;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;17100:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;17100:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17100:40:0;17162;;;-1:-1:-1;;;17162:40:0;;17196:4;17162:40;;;;;;17100;;-1:-1:-1;;;;;;17162:25:0;;;-1:-1:-1;;17162:40:0;;;;;17100;;17162;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;17162:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;17162:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17162:40:0;;-1:-1:-1;17215:49:0;17223:8;17162:40;17243:9;17254;17215:7;:49::i;:::-;17279:5;17275:47;;;17313:8;;17294:28;;-1:-1:-1;;;;;17299:8:0;;;;-1:-1:-1;;;17313:8:0;;;17294:18;:28::i;:::-;17286:5;:36;17275:47;17378:38;;;;;;;;;;;;;;-1:-1:-1;;;;;17378:38:0;;;17383:10;;17378:38;;;;;;;;;;;11324:1;;;;;;;;;11347;11336:8;:12;;;;15960:1464;;;:::o;4949:43::-;;;;;;;;;;;;;-1:-1:-1;;;4949:43:0;;;;;:::o;7105:139::-;7165:4;7182:32;7192:10;7204:2;7208:5;7182:9;:32::i;10476:46::-;10517:5;10476:46;:::o;19460:334::-;11257:8;;11269:1;11257:13;11249:41;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;;;;11312:1;11301:8;:12;19529:6;;19579;;19683:8;;19638:40;;;-1:-1:-1;;;19638:40:0;;19672:4;19638:40;;;;;;-1:-1:-1;;;;;19529:6:0;;;;19579;;;;19611:82;;19529:6;;19634:2;;19638:54;;-1:-1:-1;;;;;19683:8:0;;19529:6;;-1:-1:-1;;19638:40:0;;;;;;;;;;;;;;;19529:6;19638:40;;;5:2:-1;;;;30:1;27;20:12;5:2;19638:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19638:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19638:40:0;;:54;:44;:54;:::i;:::-;19611:13;:82::i;:::-;19776:8;;19731:40;;;-1:-1:-1;;;19731:40:0;;19765:4;19731:40;;;;;;19704:82;;19718:7;;19727:2;;19731:54;;-1:-1:-1;;;19776:8:0;;-1:-1:-1;;;;;19776:8:0;;-1:-1:-1;;;;;19731:25:0;;;-1:-1:-1;;19731:40:0;;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;19704:82:0;-1:-1:-1;;11347:1:0;11336:8;:12;-1:-1:-1;19460:334:0:o;10626:22::-;;;-1:-1:-1;;;;;10626:22:0;;:::o;10683:21::-;;;-1:-1:-1;;;;;10683:21:0;;:::o;7561:670::-;7707:15;7695:8;:27;;7687:56;;;;;-1:-1:-1;;;7687:56:0;;;;;;;;;;;;-1:-1:-1;;;7687:56:0;;;;;;;;;;;;;;;7859:16;;-1:-1:-1;;;;;7955:13:0;;;7754:14;7955:13;;;:6;:13;;;;;;;;:15;;-1:-1:-1;7955:15:0;;;;;;7904:77;;5375:66;7904:77;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;7904:77:0;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;7904:77:0;;;;;7894:88;;;;;;-1:-1:-1;;;7795:202:0;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;7795:202:0;;;;;;7771:237;;;;;;;;;8046:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7754:14;;-1:-1:-1;8046:26:0;;;;;-1:-1:-1;;8046:26:0;;;;;;;;;;-1:-1:-1;8046:26:0;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;8046:26:0;;-1:-1:-1;;8046:26:0;;;-1:-1:-1;;;;;;;8091:30:0;;;;;;:59;;-1:-1:-1;;;;;;8125:25:0;;;;;;;8091:59;8083:98;;;;;-1:-1:-1;;;8083:98:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;8192:31;8201:5;8208:7;8217:5;8192:8;:31::i;:::-;7561:670;;;;;;;;;:::o;5120:61::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;19843:158::-;11257:8;;11269:1;11257:13;11249:41;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;-1:-1:-1;;;11249:41:0;;;;;;;;;;;;;;;11312:1;11301:8;:12;19899:6;;19892:39;;;-1:-1:-1;;;19892:39:0;;19925:4;19892:39;;;;;;19884:109;;-1:-1:-1;;;;;19899:6:0;;-1:-1:-1;;19892:39:0;;;;;;;;;;;;;;19899:6;19892:39;;;5:2:-1;;;;30:1;27;20:12;5:2;19892:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19892:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19892:39:0;19940:6;;19933:39;;;-1:-1:-1;;;19933:39:0;;19966:4;19933:39;;;;;;-1:-1:-1;;;;;19940:6:0;;;;-1:-1:-1;;19933:39:0;;;;;19892;;19933;;;;;;;;19940:6;19933:39;;;5:2:-1;;;;30:1;27;20:12;5:2;19933:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19933:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19933:39:0;19974:8;;-1:-1:-1;;;;;19974:8:0;;;;-1:-1:-1;;;19984:8:0;;;19884:7;:109::i;:::-;11347:1;11336:8;:12;19843:158::o;11603:285::-;10581:34;;;;;;;;;;;;;;;;;11731:43;;-1:-1:-1;;;;;11731:43:0;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;11731:43:0;;;;;;25:18:-1;;;61:17;;-1:-1;;;;;182:15;-1:-1;;;179:29;160:49;;11720:55:0;;;;-1:-1:-1;;11699:17:0;;11720:10;;;11731:43;11720:55;;;25:18:-1;11720:55:0;;25:18:-1;36:153;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;11720:55:0;;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;11684:91:0;;;;11794:7;:57;;;;-1:-1:-1;11806:11:0;;:16;;:44;;;11837:4;11826:24;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;11826:24:0;11806:44;11786:94;;;;;-1:-1:-1;;;11786:94:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11603:285;;;;;:::o;4672:142::-;4724:6;4751;;;:30;;-1:-1:-1;;4766:5:0;;;4780:1;4775;4766:5;4775:1;4761:15;;;;;:20;4751:30;4743:63;;;;;-1:-1:-1;;;4743:63:0;;;;;;;;;;;;-1:-1:-1;;;4743:63:0;;;;;;;;;;;;;;4535:129;4619:5;;;4614:16;;;;4606:50;;;;;-1:-1:-1;;;4606:50:0;;;;;;;;;;;;-1:-1:-1;;;4606:50:0;;;;;;;;;;;;;;12715:858;-1:-1:-1;;;;;12827:23:0;;;;;:50;;-1:-1:-1;;;;;;12854:23:0;;;12827:50;12819:80;;;;;-1:-1:-1;;;12819:80:0;;;;;;;;;;;;-1:-1:-1;;;12819:80:0;;;;;;;;;;;;;;;13014:18;;12941:23;:15;:23;;;-1:-1:-1;;;13014:18:0;;;;12997:35;;;13070:15;;;;;;:33;;-1:-1:-1;;;;;;13089:14:0;;;;13070:33;:51;;;;-1:-1:-1;;;;;;13107:14:0;;;;13070:51;13066:336;;;13276:11;13223:64;;13228:44;13262:9;13228:27;13245:9;13228:16;:27::i;:::-;-1:-1:-1;;;;;13228:33:0;;;:44::i;:::-;13199:20;:88;;-1:-1:-1;;;;;13223:50:0;;;;:64;;;;13199:88;;;13326:64;;;13331:44;13365:9;13331:27;13348:9;13331:16;:27::i;:44::-;13302:20;:88;;-1:-1:-1;;;;;13326:50:0;;;;:64;;;;13302:88;;;13066:336;13412:8;:28;;-1:-1:-1;;13412:28:0;-1:-1:-1;;;;;13412:28:0;;;;;;;-1:-1:-1;;;;13451:28:0;-1:-1:-1;;;13451:28:0;;;;;;;;;-1:-1:-1;;;;;13490:35:0;-1:-1:-1;;;13490:35:0;;;;;;;;;13541:24;;;13546:8;;;13541:24;;13556:8;;;;;;;13541:24;;;;;;;;;;;;;;;;;12715:858;;;;;;:::o;6545:169::-;-1:-1:-1;;;;;6626:16:0;;;;;;;:9;:16;;;;;;;;:25;;;;;;;;;;;;;:33;;;6675:31;;;;;;;;;;;;;;;;;6545:169;;;:::o;6722:220::-;-1:-1:-1;;;;;6816:15:0;;;;;;-1:-1:-1;6816:15:0;;;;;;:26;;6836:5;6816:19;:26::i;:::-;-1:-1:-1;;;;;6798:15:0;;;;;;;-1:-1:-1;6798:15:0;;;;;;:44;;;;6869:13;;;;;;;:24;;6887:5;6869:17;:24::i;:::-;-1:-1:-1;;;;;6853:13:0;;;;;;;-1:-1:-1;6853:13:0;;;;;;;;;:40;;;;6909:25;;;;;;;6853:13;;6909:25;;;;;;;;;;;;;6722:220;;;:::o;13663:835::-;13791:7;;13775:32;;;-1:-1:-1;;;13775:32:0;;;;13736:10;;;;-1:-1:-1;;;;;13791:7:0;;;;13775:30;;:32;;;;;;;;;;;;;;;13791:7;13775:32;;;5:2:-1;;;;30:1;27;20:12;5:2;13775:32:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;13775:32:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;13775:32:0;13870:5;;-1:-1:-1;;;;;13826:19:0;;;;;;-1:-1:-1;13775:32:0;;-1:-1:-1;13870:5:0;13901:590;;13931:11;;13927:494;;13963:10;13976:41;13986:30;-1:-1:-1;;;;;13986:15:0;;;;:30;;:19;:30::i;13976:41::-;13963:54;;14036:14;14053:17;14063:6;14053:9;:17::i;:::-;14036:34;;14101:9;14093:5;:17;14089:317;;;14135:14;14152:37;14168:20;:5;14178:9;14168:20;:9;:20;:::i;:::-;14152:11;;;:37;:15;:37;:::i;:::-;14135:54;-1:-1:-1;14212:16:0;14231:27;14248:9;14231:12;:5;14241:1;14231:12;:9;:12;:::i;:::-;:16;:27;:16;:27;:::i;:::-;14212:46;;14281:14;14310:11;14298:9;:23;;;;;;;-1:-1:-1;14348:13:0;;14344:42;;14363:23;14369:5;14376:9;14363:5;:23::i;:::-;14089:317;;;;13927:494;;;13901:590;;;14442:11;;14438:53;;14478:1;14470:5;:9;14438:53;13663:835;;;;;;:::o;8525:303::-;8570:6;8597:1;8593;:5;8589:232;;;-1:-1:-1;8619:1:0;8652;8648;8644:5;;:9;8668:92;8679:1;8675;:5;8668:92;;;8705:1;8701:5;;8743:1;8738;8734;8730;:5;;;;;;:9;8729:15;;;;;;8725:19;;8668:92;;;8589:232;;;;8781:6;;8777:44;;-1:-1:-1;8808:1:0;8777:44;8525:303;;;:::o;6119:201::-;6192:11;;:22;;6208:5;6192:22;:15;:22;:::i;:::-;6178:11;:36;;;-1:-1:-1;;;;;6241:13:0;;;;-1:-1:-1;6241:13:0;;;;;;:24;;6259:5;6241:17;:24::i;:::-;-1:-1:-1;;;;;6225:13:0;;;;;;-1:-1:-1;6225:13:0;;;;;;;;:40;;;;6281:31;;;;;;;6225:13;;;;6281:31;;;;;;;;;;6119:201;;:::o;8311:96::-;8363:6;8390:1;8386;:5;:13;;8398:1;8386:13;;;8394:1;8386:13;8382:17;8311:96;-1:-1:-1;;;8311:96:0:o;6328:209::-;-1:-1:-1;;;;;6407:15:0;;;;;;-1:-1:-1;6407:15:0;;;;;;:26;;6427:5;6407:19;:26::i;:::-;-1:-1:-1;;;;;6389:15:0;;;;;;-1:-1:-1;6389:15:0;;;;;:44;;;;6458:11;:22;;6474:5;6458:15;:22::i;:::-;6444:11;:36;;;6496:33;;;;;;;;-1:-1:-1;;;;;6496:33:0;;;;;;;;;;;;;6328:209;;:::o;9097:120::-;-1:-1:-1;;;;;9173:10:0;-1:-1:-1;;;9173:17:0;;9097:120::o;9288:108::-;9348:9;-1:-1:-1;;;;;9378:10:0;;-1:-1:-1;;;;;9374:14:0;;9378:10;9374:14;;;;;;9288:108;-1:-1:-1;;;9288:108:0:o;4399:128::-;4483:5;;;4478:16;;;;4470:49;;;;;-1:-1:-1;;;4470:49:0;;;;;;;;;;;;-1:-1:-1;;;4470:49:0;;;;;;;;;;;;;

Swarm Source

bzzr://13f9b777465d01f72c04e17a019dc5b8f3faa41839b89637fe5144ea22144f56
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.