Contract 0x4f03233c742ea20e73b46d5e33242b7770274ab8 9

 
 
Txn Hash
Method
Block
From
To
Value [Txn Fee]
0x3ef51aab9cf0722303ccdf12267f71ea0647d93fe0ad8109c193ad452f4f571bApprove481920262023-10-01 8:35:281 day 7 hrs ago0x50d41fee16049e99a2375d6028adc03df371566f IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.001682913981 69.755201084
0x98665901cf19c5d766837eab7081c3d73b9e74643a063642f56af1cf8fb4de50Approve479080562023-09-24 0:26:108 days 15 hrs ago0x39e6a6f25e188f0e20201629b470f30bbc34741b IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.001853979744 76.845716001
0x5d74d770ed76ddffd0bf231f822d9c91245aa080867d62d6b020ecfe7fde9052Approve478835852023-09-23 9:24:279 days 6 hrs ago ken27.polygon  IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.002008966239 83.311198452
0x68d818d2acb616ee57a5fae692250581cb2ef05aa2257628eda7d19e67842f13Approve478835372023-09-23 9:22:459 days 6 hrs ago ken27.polygon  IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.001990123432 82.488743799
0xdad4b1698c180b68974ce826bba015b342e7621ff26ba1a38eab38a3a765d336Approve478650352023-09-22 22:01:049 days 17 hrs ago0xad7c32dced2bc4e5d410b513c389a360fc6559ed IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.004239795249 91.901748149
0xac35c15983b4e84d16b31136c1c0783a44a38d767b770cbf76a4f0e03e9c62a2Approve473199942023-09-09 4:34:0723 days 11 hrs ago mintsquire.nft  IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.003160506131
0x5374d8ecc7bcec681a72f8ccde14511fa6fb17aba3536775c447a121f19d6e69Approve468611872023-08-28 15:20:0835 days 36 mins ago0x6196f20ce96b9831e7252a6a6e9601f54bcce894 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.002874268304 119.135716832
0x0e75113d573862d57dd21815afbce547f8e4174b9af554782375aaf20c2ae11fApprove468300042023-08-27 20:47:0735 days 19 hrs ago0x6ac2d1b5b0160398f5d8a61ab2a97c24e2b350c0 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.002575381377 106.74713492
0x3966570d6650f88dc77aa6ff39c505cbc47da9143be485d0cd9d6e726cb87f0bApprove462230722023-08-12 16:52:3450 days 23 hrs ago0x150f6f923c56415bb9c18d1e38b12ce52da2aaf4 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.002536495148 105.135337324
0xed2f780920ecca5a65e14bfbf06d5a8d0fb63d7c0cf109bb1fc63054f0df41baApprove462226202023-08-12 16:36:3250 days 23 hrs ago0x150f6f923c56415bb9c18d1e38b12ce52da2aaf4 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.003298968642 126.271478321
0x8ea5af80760a7812181c6375da006353bf9b51ee6c155697a3f7134e7e70fb01Approve461493532023-08-10 20:19:1852 days 19 hrs ago car82mini.wallet  IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.0022908395
0x912eebf0c0abbbcd38b318f805ecc9cbe4e6891abb6f746edcf58fb4829a26b5Approve460204342023-08-07 13:48:0156 days 2 hrs ago0x335696b23ec6fce2ee8e4d4c6078ef55bb87357a IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.00179050149774.214602413
0x16cf42b27e489244305568a6bce6174126986c5661df3ee8156be2e29a501a37Transfer460082332023-08-07 6:28:3456 days 9 hrs ago0x4f57b82e7464f9c1a885ce24a7be71f6c7e3b467 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.004790992763 102.467977665
0x730f35fb743f70c6650ccfd2348c766d86715ef35962098bb8dcbc073d2865d1Approve459746492023-08-06 10:08:1357 days 5 hrs ago0xb8ad9f6072f96c6fa9ee44290cc3cb3dac163b9a IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.00340930366 73.900022984
0x710cf610725507f1b248f606d4389c26a17ba49f8c4cfab5067b540b80d1be64Transfer458828992023-08-04 2:53:3259 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0x12f1d2a305af269a0960aa35c396d879716ed4467215bdb1efead9da20b1bb62Transfer458828982023-08-04 2:53:3059 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0xb93316bc46a5f6a191794083c093dedcbcd78e0b331657057b474105c3c25f94Transfer458828982023-08-04 2:53:3059 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0x00fa0edcee23a0657c48c9ed0536eba35593a68e75dbe8d59d397b83d6de89e1Transfer458828972023-08-04 2:53:2859 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0xabf46dd917fd53b0c0cdc694d2888a59890b460c4258675866b37f287a57b746Transfer458828972023-08-04 2:53:2859 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0xd1bab77778589d9f3c53ee3a05df0915e8142fb66b59b72887692374a6609a96Transfer458828962023-08-04 2:53:2659 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0xad3cfc94ee496b22ee6c880dff4f4a2cf63c9c54bc4ebae52c7420f5ba31f484Transfer458828962023-08-04 2:53:2659 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.007850971475322.064711624
0x14192827c6f636add2477fa4e3f82abbe397d954de78ae42319b8de7a81ad7ceTransfer458828952023-08-04 2:53:2259 days 13 hrs ago0x09727441dd96b87ca4d522765399dc0e01b62b0e IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.015058457656322.064711624
0x4efc417b60ac86025f3bdd346d77c96b70fb80137f0b6e2d65c76d61ac6a099cApprove455531002023-07-26 20:35:0667 days 19 hrs ago0xa76a1ac11b8eb741d32be6930dd831f8dff54ea4 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.001951067382 80.869907277
0x655e9c8c57bdef1d0e90413a1806783b06358560300ecc0c4fdbdd2ffb4d861eApprove455041102023-07-25 14:21:2769 days 1 hr ago0x86c7562d374fbc157f2629e2de256342916d4709 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.006632710469 274.919608268
0x59e91bcde5318e68c67c36823c93ab5397ed11fd144abd2bdae3518ee14f840cApprove455038202023-07-25 14:10:3969 days 1 hr ago0x86c7562d374fbc157f2629e2de256342916d4709 IN  0x4f03233c742ea20e73b46d5e33242b7770274ab80 MATIC0.003937183099 163.192535
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0xc8a5b66f6dd8c25dbac5289c6eb642cc4e6ba94b75af04fc9d4a1fbc9665082f195018732021-09-25 15:33:30737 days 23 mins ago CafeSwap: Factory  Contract Creation0 MATIC
[ Download CSV Export 
Loading

Similar Match Source Code
This contract matches the deployed ByteCode of the Source Code for Contract 0xaE5Faf42D7a9F637b82987b3c177F2f46fd5F3bB
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
CafePair

Compiler Version
v0.5.16+commit.9c3226ce

Optimization Enabled:
Yes with 9999 runs

Other Settings:
istanbul EvmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at PolygonScan.com on 2021-09-17
*/

// File: contracts/interfaces/ICafePair.sol

pragma solidity >=0.5.0;

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

// File: contracts/interfaces/ICafeERC20.sol

pragma solidity >=0.5.0;

interface ICafeERC20 {
    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: contracts/libraries/SafeMath.sol

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: contracts/CafeERC20.sol

pragma solidity =0.5.16;



contract CafeERC20 is ICafeERC20 {
    using SafeMath for uint;

    string public constant name = 'CafeSwap LPs';
    string public constant symbol = 'Cafe-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, 'Cafe: 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, 'Cafe: INVALID_SIGNATURE');
        _approve(owner, spender, value);
    }
}

// File: contracts/libraries/Math.sol

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

    // 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: contracts/libraries/UQ112x112.sol

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: contracts/interfaces/IERC20.sol

pragma solidity >=0.5.0;

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

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

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

// File: contracts/interfaces/ICafeFactory.sol

pragma solidity >=0.5.0;

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

// File: contracts/interfaces/ICafeCallee.sol

pragma solidity >=0.5.0;

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

// File: contracts/CafePair.sol

pragma solidity =0.5.16;









contract CafePair is ICafePair, CafeERC20 {
    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, 'Cafe: 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))), 'Cafe: 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, 'Cafe: 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), 'Cafe: 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 = ICafeFactory(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(3).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, 'Cafe: 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, 'Cafe: 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, 'Cafe: INSUFFICIENT_OUTPUT_AMOUNT');
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        require(amount0Out < _reserve0 && amount1Out < _reserve1, 'Cafe: 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, 'Cafe: 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) ICafeCallee(to).cafeCall(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, 'Cafe: INSUFFICIENT_INPUT_AMOUNT');
        { // scope for reserve{0,1}Adjusted, avoids stack too deep errors
        uint balance0Adjusted = balance0.mul(1000).sub(amount0In.mul(2));
        uint balance1Adjusted = balance1.mul(1000).sub(amount1In.mul(2));
        require(balance0Adjusted.mul(balance1Adjusted) >= uint(_reserve0).mul(_reserve1).mul(1000**2), 'Cafe: 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 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"}]

60806040526001600c5534801561001557600080fd5b5060405146908060526126cc8239604080519182900360520182208282018252600c83526b4361666553776170204c507360a01b6020938401528151808301835260018152603160f81b908401528151808401919091527fad088432db31b304fd1cb1fdd8ad51262720cc3f506bdaeb03b74b41f2cad87b818301527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606082015260808101949094523060a0808601919091528151808603909101815260c09094019052825192019190912060035550600580546001600160a01b031916331790556125c5806101076000396000f3fe608060405234801561001057600080fd5b50600436106101b95760003560e01c80636a627842116100f9578063ba9a7a5611610097578063d21220a711610071578063d21220a71461054b578063d505accf14610553578063dd62ed3e146105a4578063fff6cae9146105d2576101b9565b8063ba9a7a5614610515578063bc25cf771461051d578063c45a015514610543576101b9565b80637ecebe00116100d35780637ecebe001461047c57806389afcb44146104a257806395d89b41146104e1578063a9059cbb146104e9576101b9565b80636a6278421461042857806370a082311461044e5780637464fc3d14610474576101b9565b806323b872dd116101665780633644e515116101405780633644e515146103e2578063485cc955146103ea5780635909c0d5146104185780635a3d549314610420576101b9565b806323b872dd1461038657806330adf81f146103bc578063313ce567146103c4576101b9565b8063095ea7b311610197578063095ea7b3146103085780630dfe16811461034857806318160ddd1461036c576101b9565b8063022c0d9f146101be57806306fdde031461024c5780630902f1ac146102c9575b600080fd5b61024a600480360360808110156101d457600080fd5b8135916020810135916001600160a01b03604083013516919081019060808101606082013564010000000081111561020b57600080fd5b82018360208201111561021d57600080fd5b8035906020019184600183028401116401000000008311171561023f57600080fd5b5090925090506105da565b005b610254610bad565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561028e578181015183820152602001610276565b50505050905090810190601f1680156102bb5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102d1610be6565b604080516dffffffffffffffffffffffffffff948516815292909316602083015263ffffffff168183015290519081900360600190f35b6103346004803603604081101561031e57600080fd5b506001600160a01b038135169060200135610c3b565b604080519115158252519081900360200190f35b610350610c52565b604080516001600160a01b039092168252519081900360200190f35b610374610c61565b60408051918252519081900360200190f35b6103346004803603606081101561039c57600080fd5b506001600160a01b03813581169160208101359091169060400135610c67565b610374610d1f565b6103cc610d43565b6040805160ff9092168252519081900360200190f35b610374610d48565b61024a6004803603604081101561040057600080fd5b506001600160a01b0381358116916020013516610d4e565b610374610df3565b610374610df9565b6103746004803603602081101561043e57600080fd5b50356001600160a01b0316610dff565b6103746004803603602081101561046457600080fd5b50356001600160a01b0316611139565b61037461114b565b6103746004803603602081101561049257600080fd5b50356001600160a01b0316611151565b6104c8600480360360208110156104b857600080fd5b50356001600160a01b0316611163565b6040805192835260208301919091528051918290030190f35b610254611527565b610334600480360360408110156104ff57600080fd5b506001600160a01b038135169060200135611560565b61037461156d565b61024a6004803603602081101561053357600080fd5b50356001600160a01b0316611573565b610350611703565b610350611712565b61024a600480360360e081101561056957600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c00135611721565b610374600480360360408110156105ba57600080fd5b506001600160a01b0381358116916020013516611985565b61024a6119a2565b600c54600114610631576040805162461bcd60e51b815260206004820152600c60248201527f436166653a204c4f434b45440000000000000000000000000000000000000000604482015290519081900360640190fd5b6000600c55841515806106445750600084115b610695576040805162461bcd60e51b815260206004820181905260248201527f436166653a20494e53554646494349454e545f4f55545055545f414d4f554e54604482015290519081900360640190fd5b6000806106a0610be6565b5091509150816dffffffffffffffffffffffffffff16871080156106d35750806dffffffffffffffffffffffffffff1686105b610724576040805162461bcd60e51b815260206004820152601c60248201527f436166653a20494e53554646494349454e545f4c495155494449545900000000604482015290519081900360640190fd5b60065460075460009182916001600160a01b039182169190811690891682148015906107625750806001600160a01b0316896001600160a01b031614155b6107b3576040805162461bcd60e51b815260206004820152601060248201527f436166653a20494e56414c49445f544f00000000000000000000000000000000604482015290519081900360640190fd5b8a156107c4576107c4828a8d611b22565b89156107d5576107d5818a8c611b22565b861561089057886001600160a01b031663ec78ce50338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03166001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561087757600080fd5b505af115801561088b573d6000803e3d6000fd5b505050505b604080516370a0823160e01b815230600482015290516001600160a01b038416916370a08231916024808301926020929190829003018186803b1580156108d657600080fd5b505afa1580156108ea573d6000803e3d6000fd5b505050506040513d602081101561090057600080fd5b5051604080516370a0823160e01b815230600482015290519195506001600160a01b038316916370a0823191602480820192602092909190829003018186803b15801561094c57600080fd5b505afa158015610960573d6000803e3d6000fd5b505050506040513d602081101561097657600080fd5b5051925060009150506dffffffffffffffffffffffffffff85168a900383116109a05760006109b6565b89856dffffffffffffffffffffffffffff160383035b9050600089856dffffffffffffffffffffffffffff160383116109da5760006109f0565b89856dffffffffffffffffffffffffffff160383035b90506000821180610a015750600081115b610a52576040805162461bcd60e51b815260206004820152601f60248201527f436166653a20494e53554646494349454e545f494e5055545f414d4f554e5400604482015290519081900360640190fd5b6000610a86610a6884600263ffffffff611d0816565b610a7a876103e863ffffffff611d0816565b9063ffffffff611d7416565b90506000610a9e610a6884600263ffffffff611d0816565b9050610ad6620f4240610aca6dffffffffffffffffffffffffffff8b8116908b1663ffffffff611d0816565b9063ffffffff611d0816565b610ae6838363ffffffff611d0816565b1015610b39576040805162461bcd60e51b815260206004820152600760248201527f436166653a204b00000000000000000000000000000000000000000000000000604482015290519081900360640190fd5b5050610b4784848888611dcc565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600c55505050505050505050565b6040518060400160405280600c81526020017f4361666553776170204c5073000000000000000000000000000000000000000081525081565b6008546dffffffffffffffffffffffffffff808216926e0100000000000000000000000000008304909116917c0100000000000000000000000000000000000000000000000000000000900463ffffffff1690565b6000610c4833848461206e565b5060015b92915050565b6006546001600160a01b031681565b60005481565b6001600160a01b03831660009081526002602090815260408083203384529091528120547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff14610d0a576001600160a01b0384166000908152600260209081526040808320338452909152902054610ce5908363ffffffff611d7416565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610d158484846120d0565b5060019392505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b601281565b60035481565b6005546001600160a01b03163314610dad576040805162461bcd60e51b815260206004820152600f60248201527f436166653a20464f5242494444454e0000000000000000000000000000000000604482015290519081900360640190fd5b600680546001600160a01b039384167fffffffffffffffffffffffff00000000000000000000000000000000000000009182161790915560078054929093169116179055565b60095481565b600a5481565b6000600c54600114610e58576040805162461bcd60e51b815260206004820152600c60248201527f436166653a204c4f434b45440000000000000000000000000000000000000000604482015290519081900360640190fd5b6000600c81905580610e68610be6565b50600654604080516370a0823160e01b815230600482015290519395509193506000926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015610ebc57600080fd5b505afa158015610ed0573d6000803e3d6000fd5b505050506040513d6020811015610ee657600080fd5b5051600754604080516370a0823160e01b815230600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015610f3957600080fd5b505afa158015610f4d573d6000803e3d6000fd5b505050506040513d6020811015610f6357600080fd5b505190506000610f89836dffffffffffffffffffffffffffff871663ffffffff611d7416565b90506000610fad836dffffffffffffffffffffffffffff871663ffffffff611d7416565b90506000610fbb878761218a565b60005490915080610ff857610fe46103e8610a7a610fdf878763ffffffff611d0816565b6122ef565b9850610ff360006103e8612341565b611055565b6110526dffffffffffffffffffffffffffff891661101c868463ffffffff611d0816565b8161102357fe5b046dffffffffffffffffffffffffffff8916611045868563ffffffff611d0816565b8161104c57fe5b046123d7565b98505b600089116110945760405162461bcd60e51b815260040180806020018281038252602381526020018061254b6023913960400191505060405180910390fd5b61109e8a8a612341565b6110aa86868a8a611dcc565b81156110ec576008546110e8906dffffffffffffffffffffffffffff808216916e01000000000000000000000000000090041663ffffffff611d0816565b600b555b6040805185815260208101859052815133927f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f928290030190a250506001600c5550949695505050505050565b60016020526000908152604090205481565b600b5481565b60046020526000908152604090205481565b600080600c546001146111bd576040805162461bcd60e51b815260206004820152600c60248201527f436166653a204c4f434b45440000000000000000000000000000000000000000604482015290519081900360640190fd5b6000600c819055806111cd610be6565b50600654600754604080516370a0823160e01b815230600482015290519496509294506001600160a01b039182169391169160009184916370a08231916024808301926020929190829003018186803b15801561122957600080fd5b505afa15801561123d573d6000803e3d6000fd5b505050506040513d602081101561125357600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b1580156112a157600080fd5b505afa1580156112b5573d6000803e3d6000fd5b505050506040513d60208110156112cb57600080fd5b5051306000908152600160205260408120549192506112ea888861218a565b60005490915080611301848763ffffffff611d0816565b8161130857fe5b049a508061131c848663ffffffff611d0816565b8161132357fe5b04995060008b118015611336575060008a115b6113715760405162461bcd60e51b815260040180806020018281038252602381526020018061256e6023913960400191505060405180910390fd5b61137b30846123ef565b611386878d8d611b22565b611391868d8c611b22565b604080516370a0823160e01b815230600482015290516001600160a01b038916916370a08231916024808301926020929190829003018186803b1580156113d757600080fd5b505afa1580156113eb573d6000803e3d6000fd5b505050506040513d602081101561140157600080fd5b5051604080516370a0823160e01b815230600482015290519196506001600160a01b038816916370a0823191602480820192602092909190829003018186803b15801561144d57600080fd5b505afa158015611461573d6000803e3d6000fd5b505050506040513d602081101561147757600080fd5b5051935061148785858b8b611dcc565b81156114c9576008546114c5906dffffffffffffffffffffffffffff808216916e01000000000000000000000000000090041663ffffffff611d0816565b600b555b604080518c8152602081018c905281516001600160a01b038f169233927fdccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496929081900390910190a35050505050505050506001600c81905550915091565b6040518060400160405280600781526020017f436166652d4c500000000000000000000000000000000000000000000000000081525081565b6000610c483384846120d0565b6103e881565b600c546001146115ca576040805162461bcd60e51b815260206004820152600c60248201527f436166653a204c4f434b45440000000000000000000000000000000000000000604482015290519081900360640190fd5b6000600c55600654600754600854604080516370a0823160e01b815230600482015290516001600160a01b039485169490931692611680928592879261167b926dffffffffffffffffffffffffffff169185916370a0823191602480820192602092909190829003018186803b15801561164357600080fd5b505afa158015611657573d6000803e3d6000fd5b505050506040513d602081101561166d57600080fd5b50519063ffffffff611d7416565b611b22565b600854604080516370a0823160e01b815230600482015290516116f9928492879261167b926e01000000000000000000000000000090046dffffffffffffffffffffffffffff16916001600160a01b038616916370a0823191602480820192602092909190829003018186803b15801561164357600080fd5b50506001600c5550565b6005546001600160a01b031681565b6007546001600160a01b031681565b42841015611776576040805162461bcd60e51b815260206004820152600d60248201527f436166653a204558504952454400000000000000000000000000000000000000604482015290519081900360640190fd5b6003546001600160a01b0380891660008181526004602090815260408083208054600180820190925582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e0850182528051908301207f19010000000000000000000000000000000000000000000000000000000000006101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e2808201937fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe081019281900390910190855afa1580156118ca573d6000803e3d6000fd5b50506040517fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe001519150506001600160a01b0381161580159061191e5750886001600160a01b0316816001600160a01b0316145b61196f576040805162461bcd60e51b815260206004820152601760248201527f436166653a20494e56414c49445f5349474e4154555245000000000000000000604482015290519081900360640190fd5b61197a89898961206e565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b600c546001146119f9576040805162461bcd60e51b815260206004820152600c60248201527f436166653a204c4f434b45440000000000000000000000000000000000000000604482015290519081900360640190fd5b6000600c55600654604080516370a0823160e01b81523060048201529051611b1b926001600160a01b0316916370a08231916024808301926020929190829003018186803b158015611a4a57600080fd5b505afa158015611a5e573d6000803e3d6000fd5b505050506040513d6020811015611a7457600080fd5b5051600754604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015611ac157600080fd5b505afa158015611ad5573d6000803e3d6000fd5b505050506040513d6020811015611aeb57600080fd5b50516008546dffffffffffffffffffffffffffff808216916e010000000000000000000000000000900416611dcc565b6001600c55565b604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb000000000000000000000000000000000000000000000000000000001781529251815160009460609489169392918291908083835b60208310611c1b57805182527fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe09092019160209182019101611bde565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114611c7d576040519150601f19603f3d011682016040523d82523d6000602084013e611c82565b606091505b5091509150818015611cb0575080511580611cb05750808060200190516020811015611cad57600080fd5b50515b611d01576040805162461bcd60e51b815260206004820152601560248201527f436166653a205452414e534645525f4641494c45440000000000000000000000604482015290519081900360640190fd5b5050505050565b6000811580611d2357505080820282828281611d2057fe5b04145b610c4c576040805162461bcd60e51b815260206004820152601460248201527f64732d6d6174682d6d756c2d6f766572666c6f77000000000000000000000000604482015290519081900360640190fd5b80820382811115610c4c576040805162461bcd60e51b815260206004820152601560248201527f64732d6d6174682d7375622d756e646572666c6f770000000000000000000000604482015290519081900360640190fd5b6dffffffffffffffffffffffffffff8411801590611df857506dffffffffffffffffffffffffffff8311155b611e49576040805162461bcd60e51b815260206004820152600e60248201527f436166653a204f564552464c4f57000000000000000000000000000000000000604482015290519081900360640190fd5b60085463ffffffff428116917c010000000000000000000000000000000000000000000000000000000090048116820390811615801590611e9957506dffffffffffffffffffffffffffff841615155b8015611eb457506dffffffffffffffffffffffffffff831615155b15611f64578063ffffffff16611ef785611ecd8661248d565b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff169063ffffffff6124b116565b600980547bffffffffffffffffffffffffffffffffffffffffffffffffffffffff929092169290920201905563ffffffff8116611f3784611ecd8761248d565b600a80547bffffffffffffffffffffffffffffffffffffffffffffffffffffffff92909216929092020190555b600880547fffffffffffffffffffffffffffffffffffff0000000000000000000000000000166dffffffffffffffffffffffffffff888116919091177fffffffff0000000000000000000000000000ffffffffffffffffffffffffffff166e0100000000000000000000000000008883168102919091177bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167c010000000000000000000000000000000000000000000000000000000063ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b0383166000908152600160205260409020546120f9908263ffffffff611d7416565b6001600160a01b03808516600090815260016020526040808220939093559084168152205461212e908263ffffffff6124f216565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b600080600560009054906101000a90046001600160a01b03166001600160a01b031663017e7e586040518163ffffffff1660e01b815260040160206040518083038186803b1580156121db57600080fd5b505afa1580156121ef573d6000803e3d6000fd5b505050506040513d602081101561220557600080fd5b5051600b546001600160a01b0382161580159450919250906122db5780156122d657600061224f610fdf6dffffffffffffffffffffffffffff88811690881663ffffffff611d0816565b9050600061225c836122ef565b9050808211156122d357600061228a61227b848463ffffffff611d7416565b6000549063ffffffff611d0816565b905060006122af836122a386600363ffffffff611d0816565b9063ffffffff6124f216565b905060008183816122bc57fe5b04905080156122cf576122cf8782612341565b5050505b50505b6122e7565b80156122e7576000600b555b505092915050565b60006003821115612332575080600160028204015b8181101561232c5780915060028182858161231b57fe5b04018161232457fe5b049050612304565b5061233c565b811561233c575060015b919050565b600054612354908263ffffffff6124f216565b60009081556001600160a01b03831681526001602052604090205461237f908263ffffffff6124f216565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b60008183106123e657816123e8565b825b9392505050565b6001600160a01b038216600090815260016020526040902054612418908263ffffffff611d7416565b6001600160a01b03831660009081526001602052604081209190915554612445908263ffffffff611d7416565b60009081556040805183815290516001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a35050565b6dffffffffffffffffffffffffffff166e0100000000000000000000000000000290565b60006dffffffffffffffffffffffffffff82167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8416816124ea57fe5b049392505050565b80820182811015610c4c576040805162461bcd60e51b815260206004820152601460248201527f64732d6d6174682d6164642d6f766572666c6f77000000000000000000000000604482015290519081900360640190fdfe436166653a20494e53554646494349454e545f4c49515549444954595f4d494e544544436166653a20494e53554646494349454e545f4c49515549444954595f4255524e4544a265627a7a723158201888e45b525aa6bbc41842d37f61e4de083940d3dbca62dfb5f5cc112aff917864736f6c63430005100032454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429

Deployed ByteCode Sourcemap

11044:9607:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;11044:9607:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18204:1854;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;18204:1854:0;;;;;;;;-1:-1:-1;;;;;18204:1854:0;;;;;;;;;;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;18204:1854:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;18204:1854: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;18204:1854:0;;-1:-1:-1;18204:1854:0;-1:-1:-1;18204:1854:0;:::i;:::-;;4503:44;;;:::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;4503:44:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12045:231;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6553:147;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;6553:147:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;11339:21;;;:::i;:::-;;;;-1:-1:-1;;;;;11339:21:0;;;;;;;;;;;;;;4644:24;;;:::i;:::-;;;;;;;;;;;;;;;;6855:301;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;6855:301:0;;;;;;;;;;;;;;;;;:::i;4936:108::-;;;:::i;4602:35::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;4793:31;;;:::i;13100:205::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;13100:205:0;;;;;;;;;;:::i;11690:32::-;;;:::i;11729:::-;;;:::i;15279:1240::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;15279:1240:0;-1:-1:-1;;;;;15279:1240:0;;:::i;4675:41::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;4675:41:0;-1:-1:-1;;;;;4675:41:0;;:::i;11768:17::-;;;:::i;5051:38::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;5051:38:0;-1:-1:-1;;;;;5051:38:0;;:::i;16631:1461::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16631:1461:0;-1:-1:-1;;;;;16631:1461:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;4554:41;;;:::i;6708:139::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;6708:139:0;;;;;;;;:::i;11160:46::-;;;:::i;20107:334::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;20107:334:0;-1:-1:-1;;;;;20107:334:0;;:::i;11310:22::-;;;:::i;11367:21::-;;;:::i;7164:664::-;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;7164:664:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;4723:61::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;4723:61:0;;;;;;;;;;:::i;20490:158::-;;;:::i;18204:1854::-;11941:8;;11953:1;11941:13;11933:38;;;;;-1:-1:-1;;;11933:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11993:1;11982:8;:12;18318:14;;;;:32;;;18349:1;18336:10;:14;18318:32;18310:77;;;;;-1:-1:-1;;;18310:77:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18399:17;18418;18440:13;:11;:13::i;:::-;18398:55;;;;;18500:9;18487:22;;:10;:22;:48;;;;;18526:9;18513:22;;:10;:22;18487:48;18479:89;;;;;-1:-1:-1;;;18479:89:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;18713:6;;18748;;18581:13;;;;-1:-1:-1;;;;;18713:6:0;;;;18748;;;;18773:13;;;;;;;:30;;;18796:7;-1:-1:-1;;;;;18790:13:0;:2;-1:-1:-1;;;;;18790:13:0;;;18773:30;18765:59;;;;;-1:-1:-1;;;18765:59:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;18839:14;;18835:58;;18855:38;18869:7;18878:2;18882:10;18855:13;:38::i;:::-;18942:14;;18938:58;;18958:38;18972:7;18981:2;18985:10;18958:13;:38::i;:::-;19045:15;;19041:87;;19074:2;-1:-1:-1;;;;;19062:24:0;;19087:10;19099;19111;19123:4;;19062:66;;;;;;;;;;;;;-1:-1:-1;;;;;19062:66:0;-1:-1:-1;;;;;19062:66: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;;19062:66:0;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;19062:66:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19062:66:0;;;;19041:87;19150:40;;;-1:-1:-1;;;19150:40:0;;19184:4;19150:40;;;;;;-1:-1:-1;;;;;19150:25:0;;;;;:40;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;19150:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19150:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19150:40:0;19212;;;-1:-1:-1;;;19212:40:0;;19246:4;19212:40;;;;;;19150;;-1:-1:-1;;;;;;19212:25:0;;;;;:40;;;;;19150;;19212;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;19212:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;19212:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19212:40:0;;-1:-1:-1;19274:14:0;;-1:-1:-1;;19302:22:0;;;;;;19291:33;;:75;;19365:1;19291:75;;;19351:10;19339:9;:22;;;19327:8;:35;19291:75;19274:92;;19377:14;19417:10;19405:9;:22;;;19394:8;:33;:75;;19468:1;19394:75;;;19454:10;19442:9;:22;;;19430:8;:35;19394:75;19377:92;;19500:1;19488:9;:13;:30;;;;19517:1;19505:9;:13;19488:30;19480:74;;;;;-1:-1:-1;;;19480:74:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;19640:21;19664:40;19687:16;:9;19701:1;19687:16;:13;:16;:::i;:::-;19664:18;:8;19677:4;19664:18;:12;:18;:::i;:::-;:22;:40;:22;:40;:::i;:::-;19640:64;-1:-1:-1;19715:21:0;19739:40;19762:16;:9;19776:1;19762:16;:13;:16;:::i;19739:40::-;19715:64;-1:-1:-1;19840:43:0;19875:7;19840:30;;:15;;;;:30;;;:19;:30;:::i;:::-;:34;:43;:34;:43;:::i;:::-;19798:38;:16;19819;19798:38;:20;:38;:::i;:::-;:85;;19790:105;;;;;-1:-1:-1;;;19790:105:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;12005:1;;19919:49;19927:8;19937;19947:9;19958;19919:7;:49::i;:::-;19984:66;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19984:66:0;;;19989:10;;19984:66;;;;;;;;;-1:-1:-1;;12028:1:0;12017:8;:12;-1:-1:-1;;;;;;;;;18204:1854:0:o;4503:44::-;;;;;;;;;;;;;;;;;;;:::o;12045:231::-;12178:8;;;;;;;12209;;;;;;;12250:18;;;;;;12045:231::o;6553:147::-;6617:4;6634:36;6643:10;6655:7;6664:5;6634:8;:36::i;:::-;-1:-1:-1;6688:4:0;6553:147;;;;;:::o;11339:21::-;;;-1:-1:-1;;;;;11339:21:0;;:::o;4644:24::-;;;;:::o;6855:301::-;-1:-1:-1;;;;;6954:15:0;;6933:4;6954:15;;;:9;:15;;;;;;;;6970:10;6954:27;;;;;;;;6990:2;6954:39;6950:140;;-1:-1:-1;;;;;7040:15:0;;;;;;:9;:15;;;;;;;;7056:10;7040:27;;;;;;;;:38;;7072:5;7040:38;:31;:38;:::i;:::-;-1:-1:-1;;;;;7010:15:0;;;;;;:9;:15;;;;;;;;7026:10;7010:27;;;;;;;:68;6950:140;7100:26;7110:4;7116:2;7120:5;7100:9;:26::i;:::-;-1:-1:-1;7144:4:0;6855:301;;;;;:::o;4936:108::-;4978:66;4936:108;:::o;4602:35::-;4635:2;4602:35;:::o;4793:31::-;;;;:::o;13100:205::-;13196:7;;-1:-1:-1;;;;;13196:7:0;13182:10;:21;13174:49;;;;;-1:-1:-1;;;13174:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;13254:6;:16;;-1:-1:-1;;;;;13254:16:0;;;;;;;;;;;13281:6;:16;;;;;;;;;;;13100:205::o;11690:32::-;;;;:::o;11729:::-;;;;:::o;15279:1240::-;15328:14;11941:8;;11953:1;11941:13;11933:38;;;;;-1:-1:-1;;;11933:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11993:1;11982:8;:12;;;11993:1;15397:13;:11;:13::i;:::-;-1:-1:-1;15459:6:0;;15452:39;;;-1:-1:-1;;;15452:39:0;;15485:4;15452:39;;;;;;15355:55;;-1:-1:-1;15355:55:0;;-1:-1:-1;15436:13:0;;-1:-1:-1;;;;;15459:6:0;;;;15452:24;;:39;;;;;;;;;;;;;;15459:6;15452:39;;;5:2:-1;;;;30:1;27;20:12;5:2;15452:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;15452:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;15452:39:0;15525:6;;15518:39;;;-1:-1:-1;;;15518:39:0;;15551:4;15518:39;;;;;;15452;;-1:-1:-1;15502:13:0;;-1:-1:-1;;;;;15525:6:0;;;;15518:24;;:39;;;;;15452;;15518;;;;;;;;15525:6;15518:39;;;5:2:-1;;;;30:1;27;20:12;5:2;15518:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;15518:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;15518:39:0;;-1:-1:-1;15568:12:0;15583:23;:8;:23;;;;:12;:23;:::i;:::-;15568:38;-1:-1:-1;15617:12:0;15632:23;:8;:23;;;;:12;:23;:::i;:::-;15617:38;;15668:10;15681:30;15690:9;15701;15681:8;:30::i;:::-;15722:17;15742:11;15668:43;;-1:-1:-1;15846:17:0;15842:357;;15898:54;11201:5;15898:31;15908:20;:7;15920;15908:20;:11;:20;:::i;:::-;15898:9;:31::i;:54::-;15886:66;;15965:36;15979:1;11201:5;15965;:36::i;:::-;15842:357;;;16101:86;16110:37;;;:25;:7;16122:12;16110:25;:11;:25;:::i;:::-;:37;;;;;;16149;;;:25;:7;16161:12;16149:25;:11;:25;:::i;:::-;:37;;;;;;16101:8;:86::i;:::-;16089:98;;15842:357;16229:1;16217:9;:13;16209:61;;;;-1:-1:-1;;;16209:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16281:20;16287:2;16291:9;16281:5;:20::i;:::-;16314:49;16322:8;16332;16342:9;16353;16314:7;:49::i;:::-;16378:5;16374:47;;;16412:8;;16393:28;;16412:8;16398;;;;16412;;;;16393:28;:18;:28;:::i;:::-;16385:5;:36;16374:47;16477:34;;;;;;;;;;;;;;16482:10;;16477:34;;;;;;;;-1:-1:-1;;12028:1:0;12017:8;:12;-1:-1:-1;15279:1240:0;;;-1:-1:-1;;;;;;15279:1240:0:o;4675:41::-;;;;;;;;;;;;;:::o;11768:17::-;;;;:::o;5051:38::-;;;;;;;;;;;;;:::o;16631:1461::-;16680:12;16694;11941:8;;11953:1;11941:13;11933:38;;;;;-1:-1:-1;;;11933:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11993:1;11982:8;:12;;;11993:1;16761:13;:11;:13::i;:::-;-1:-1:-1;16818:6:0;;16899;;16978:40;;;-1:-1:-1;;;16978:40:0;;17012:4;16978:40;;;;;;16719:55;;-1:-1:-1;16719:55:0;;-1:-1:-1;;;;;;16818:6:0;;;;16899;;;16800:15;;16818:6;;16978:25;;:40;;;;;;;;;;;;;;16818:6;16978:40;;;5:2:-1;;;;30:1;27;20:12;5:2;16978:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;16978:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16978:40:0;17045;;;-1:-1:-1;;;17045:40:0;;17079:4;17045:40;;;;;;16978;;-1:-1:-1;17029:13:0;;-1:-1:-1;;;;;17045:25:0;;;;;:40;;;;;16978;;17045;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;17045:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;17045:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17045:40:0;17131:4;17096:14;17113:24;;;:9;17045:40;17113:24;;;;;17045:40;;-1:-1:-1;17163:30:0;17172:9;17183;17163:8;:30::i;:::-;17204:17;17224:11;17150:43;;-1:-1:-1;17224:11:0;17334:23;:9;17348:8;17334:23;:13;:23;:::i;:::-;:38;;;;;;;-1:-1:-1;17467:12:0;17441:23;:9;17455:8;17441:23;:13;:23;:::i;:::-;:38;;;;;;17431:48;;17556:1;17546:7;:11;:26;;;;;17571:1;17561:7;:11;17546:26;17538:74;;;;-1:-1:-1;;;17538:74:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17623:31;17637:4;17644:9;17623:5;:31::i;:::-;17665:35;17679:7;17688:2;17692:7;17665:13;:35::i;:::-;17711;17725:7;17734:2;17738:7;17711:13;:35::i;:::-;17768:40;;;-1:-1:-1;;;17768:40:0;;17802:4;17768:40;;;;;;-1:-1:-1;;;;;17768:25:0;;;;;:40;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;17768:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;17768:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17768:40:0;17830;;;-1:-1:-1;;;17830:40:0;;17864:4;17830:40;;;;;;17768;;-1:-1:-1;;;;;;17830:25:0;;;;;:40;;;;;17768;;17830;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;5:2;17830:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;17830:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17830:40:0;;-1:-1:-1;17883:49:0;17891:8;17830:40;17911:9;17922;17883:7;:49::i;:::-;17947:5;17943:47;;;17981:8;;17962:28;;17981:8;17967;;;;17981;;;;17962:28;:18;:28;:::i;:::-;17954:5;:36;17943:47;18046:38;;;;;;;;;;;;;;-1:-1:-1;;;;;18046:38:0;;;18051:10;;18046:38;;;;;;;;;;;12005:1;;;;;;;;;12028;12017:8;:12;;;;16631:1461;;;:::o;4554:41::-;;;;;;;;;;;;;;;;;;;:::o;6708:139::-;6768:4;6785:32;6795:10;6807:2;6811:5;6785:9;:32::i;11160:46::-;11201:5;11160:46;:::o;20107:334::-;11941:8;;11953:1;11941:13;11933:38;;;;;-1:-1:-1;;;11933:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11993:1;11982:8;:12;20176:6;;20226;;20330:8;;20285:40;;;-1:-1:-1;;;20285:40:0;;20319:4;20285:40;;;;;;-1:-1:-1;;;;;20176:6:0;;;;20226;;;;20258:82;;20176:6;;20281:2;;20285:54;;20330:8;;;20176:6;;20285:25;;:40;;;;;;;;;;;;;;;20176:6;20285:40;;;5:2:-1;;;;30:1;27;20:12;5:2;20285:40:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;20285:40:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;20285:40:0;;:54;:44;:54;:::i;:::-;20258:13;:82::i;:::-;20423:8;;20378:40;;;-1:-1:-1;;;20378:40:0;;20412:4;20378:40;;;;;;20351:82;;20365:7;;20374:2;;20378:54;;20423:8;;;;;;-1:-1:-1;;;;;20378:25:0;;;;;:40;;;;;;;;;;;;;;;:25;:40;;;5:2:-1;;;;30:1;27;20:12;20351:82:0;-1:-1:-1;;12028:1:0;12017:8;:12;-1:-1:-1;20107:334:0:o;11310:22::-;;;-1:-1:-1;;;;;11310:22:0;;:::o;11367:21::-;;;-1:-1:-1;;;;;11367:21:0;;:::o;7164:664::-;7310:15;7298:8;:27;;7290:53;;;;;-1:-1:-1;;;7290:53:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;7459:16;;-1:-1:-1;;;;;7555:13:0;;;7354:14;7555:13;;;:6;:13;;;;;;;;:15;;;;;;;;;7504:77;;4978:66;7504:77;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;7504:77:0;;;;;7494:88;;;;;;7395:202;;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;7395:202:0;;;;;;7371:237;;;;;;;;;7646:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7354:14;;7555:15;7646:26;;;;;-1:-1:-1;7646:26:0;;;;;;;;;;7555:15;7646:26;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;7646:26:0;;;;;;-1:-1:-1;;;;;;;7691:30:0;;;;;;:59;;;7745:5;-1:-1:-1;;;;;7725:25:0;:16;-1:-1:-1;;;;;7725:25:0;;7691:59;7683:95;;;;;-1:-1:-1;;;7683:95:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;7789:31;7798:5;7805:7;7814:5;7789:8;:31::i;:::-;7164:664;;;;;;;;;:::o;4723:61::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;20490:158::-;11941:8;;11953:1;11941:13;11933:38;;;;;-1:-1:-1;;;11933:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;11993:1;11982:8;:12;20546:6;;20539:39;;;-1:-1:-1;;;20539:39:0;;20572:4;20539:39;;;;;;20531:109;;-1:-1:-1;;;;;20546:6:0;;20539:24;;:39;;;;;;;;;;;;;;20546:6;20539:39;;;5:2:-1;;;;30:1;27;20:12;5:2;20539:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;20539:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;20539:39:0;20587:6;;20580:39;;;-1:-1:-1;;;20580:39:0;;20613:4;20580:39;;;;;;-1:-1:-1;;;;;20587:6:0;;;;20580:24;;:39;;;;;20539;;20580;;;;;;;;20587:6;20580:39;;;5:2:-1;;;;30:1;27;20:12;5:2;20580:39:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;20580:39:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;20580:39:0;20621:8;;;;;;;20631;;;;20531:7;:109::i;:::-;12028:1;12017:8;:12;20490:158::o;12284:282::-;11265:34;;;;;;;;;;;;;;;;;12412:43;;-1:-1:-1;;;;;12412:43:0;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;12412:43:0;;;;;;25:18:-1;;;61:17;;12412:43:0;182:15:-1;12412:43:0;179:29:-1;160:49;;12401:55:0;;;;12366:12;;12380:17;;12401:10;;;12412:43;12401:55;;;25:18:-1;12401:55:0;;25:18:-1;36:153;66:2;61:3;58:11;36:153;;176:10;;164:23;;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;;;12401: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;;12365:91:0;;;;12475:7;:57;;;;-1:-1:-1;12487:11:0;;:16;;:44;;;12518:4;12507:24;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12507:24:0;12487:44;12467:91;;;;;-1:-1:-1;;;12467:91:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;12284:282;;;;;:::o;4214:142::-;4266:6;4293;;;:30;;-1:-1:-1;;4308:5:0;;;4322:1;4317;4308:5;4317:1;4303:15;;;;;:20;4293:30;4285:63;;;;;-1:-1:-1;;;4285:63:0;;;;;;;;;;;;;;;;;;;;;;;;;;;4077:129;4161:5;;;4156:16;;;;4148:50;;;;;-1:-1:-1;;;4148:50:0;;;;;;;;;;;;;;;;;;;;;;;;;;;13390:855;13502:23;;;;;;:50;;-1:-1:-1;13529:23:0;;;;13502:50;13494:77;;;;;-1:-1:-1;;;13494:77:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;13686:18;;13613:23;:15;:23;;;13686:18;;;;;13669:35;;;13742:15;;;;;;:33;;-1:-1:-1;13761:14:0;;;;;13742:33;:51;;;;-1:-1:-1;13779:14:0;;;;;13742:51;13738:336;;;13948:11;13895:64;;13900:44;13934:9;13900:27;13917:9;13900:16;:27::i;:::-;:33;;;:44;:33;:44;:::i;:::-;13871:20;:88;;13895:50;;;;;:64;;;;13871:88;;;13998:64;;;14003:44;14037:9;14003:27;14020:9;14003:16;:27::i;:44::-;13974:20;:88;;13998:50;;;;;:64;;;;13974:88;;;13738:336;14084:8;:28;;;;;;;;;;;;14123;;;;;;;;;;;;14162:35;;;;;;;;;;;;14213:24;;;14218:8;;;14213:24;;14228:8;;;;;;;14213:24;;;;;;;;;;;;;;;;;13390:855;;;;;;:::o;6148:169::-;-1:-1:-1;;;;;6229:16:0;;;;;;;:9;:16;;;;;;;;:25;;;;;;;;;;;;;:33;;;6278:31;;;;;;;;;;;;;;;;;6148:169;;;:::o;6325:220::-;-1:-1:-1;;;;;6419:15:0;;;;;;:9;:15;;;;;;:26;;6439:5;6419:26;:19;:26;:::i;:::-;-1:-1:-1;;;;;6401:15:0;;;;;;;:9;:15;;;;;;:44;;;;6472:13;;;;;;;:24;;6490:5;6472:24;:17;:24;:::i;:::-;-1:-1:-1;;;;;6456:13:0;;;;;;;:9;:13;;;;;;;;;:40;;;;6512:25;;;;;;;6456:13;;6512:25;;;;;;;;;;;;;6325:220;;;:::o;14335:832::-;14408:10;14431:13;14460:7;;;;;;;;;-1:-1:-1;;;;;14460:7:0;-1:-1:-1;;;;;14447:27:0;;:29;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;14447:29:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;14447:29:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;14447:29:0;14539:5;;-1:-1:-1;;;;;14495:19:0;;;;;;-1:-1:-1;14447:29:0;;-1:-1:-1;14539:5:0;14570:590;;14600:11;;14596:494;;14632:10;14645:41;14655:30;;:15;;;;:30;;;:19;:30;:::i;14645:41::-;14632:54;;14705:14;14722:17;14732:6;14722:9;:17::i;:::-;14705:34;;14770:9;14762:5;:17;14758:317;;;14804:14;14821:37;14837:20;:5;14847:9;14837:20;:9;:20;:::i;:::-;14821:11;;;:37;:15;:37;:::i;:::-;14804:54;-1:-1:-1;14881:16:0;14900:27;14917:9;14900:12;:5;14910:1;14900:12;:9;:12;:::i;:::-;:16;:27;:16;:27;:::i;:::-;14881:46;;14950:14;14979:11;14967:9;:23;;;;;;;-1:-1:-1;15017:13:0;;15013:42;;15032:23;15038:5;15045:9;15032:5;:23::i;:::-;14758:317;;;;14596:494;;;14570:590;;;15111:11;;15107:53;;15147:1;15139:5;:9;15107:53;14335:832;;;;;;:::o;8193:303::-;8238:6;8265:1;8261;:5;8257:232;;;-1:-1:-1;8287:1:0;8320;8316;8312:5;;:9;8336:92;8347:1;8343;:5;8336:92;;;8373:1;8369:5;;8411:1;8406;8402;8398;:5;;;;;;:9;8397:15;;;;;;8393:19;;8336:92;;;8257:232;;;;8449:6;;8445:44;;-1:-1:-1;8476:1:0;8445:44;8193:303;;;:::o;5722:201::-;5795:11;;:22;;5811:5;5795:22;:15;:22;:::i;:::-;5781:11;:36;;;-1:-1:-1;;;;;5844:13:0;;;;:9;:13;;;;;;:24;;5862:5;5844:24;:17;:24;:::i;:::-;-1:-1:-1;;;;;5828:13:0;;;;;;:9;:13;;;;;;;;:40;;;;5884:31;;;;;;;5828:13;;;;5884:31;;;;;;;;;;5722:201;;:::o;7979:96::-;8031:6;8058:1;8054;:5;:13;;8066:1;8054:13;;;8062:1;8054:13;8050:17;7979:96;-1:-1:-1;;;7979:96:0:o;5931:209::-;-1:-1:-1;;;;;6010:15:0;;;;;;:9;:15;;;;;;:26;;6030:5;6010:26;:19;:26;:::i;:::-;-1:-1:-1;;;;;5992:15:0;;;;;;:9;:15;;;;;:44;;;;6061:11;:22;;6077:5;6061:22;:15;:22;:::i;:::-;6047:11;:36;;;6099:33;;;;;;;;-1:-1:-1;;;;;6099:33:0;;;;;;;;;;;;;5931:209;;:::o;8843:120::-;8919:10;;8788:6;8919:17;;8843:120::o;9034:108::-;9094:9;9124:10;;;9120:14;;;9124:10;9120:14;;;;;;9034:108;-1:-1:-1;;;9034:108:0:o;3941:128::-;4025:5;;;4020:16;;;;4012:49;;;;;-1:-1:-1;;;4012:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;

Swarm Source

bzzr://1888e45b525aa6bbc41842d37f61e4de083940d3dbca62dfb5f5cc112aff9178
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.