Contract 0x04580ce6dee076354e96fed53cb839de9efb5f3f

 

Contract Overview

Balance:
0 BNB

BNB Value:
$0.00

Token:
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xd305b2c88f1af7295896f29c0cea63aab0544b02835043a652beb2c553faceb8Approve109975242021-09-17 16:15:126 hrs 1 min ago0x758b48c01bd851e2fa9dff4001ca63a8f760a8ee IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0xf4a2ce18d16aa26626d13c5d9d23bd45c194a17b8b11c729b89ae937455c56a3Approve109975192021-09-17 16:14:576 hrs 1 min ago0xadb8e60b7bf0841680e3034590beb15d797a1b7a IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0xf19ea08a64c5639d3e2a7e7e8c5e9e8ad3c258a23b9f7d6fc787556eb24129f0Approve109957482021-09-17 14:46:057 hrs 30 mins ago0x83f0f9a4d1a5a5c9c240ede88744b07e98cfa5a4 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x4d6253e08049265ba0938bacfd2031001b13406c0a7b2eca4a7ac1ec925932daApprove109830832021-09-17 4:12:0018 hrs 4 mins ago0x4913461f16d1170df14a5420be1e3afe1e5f0207 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x1f3d6422781992dd5117c26957cf7c5c7c26e35beedd7ccaad3d1c18b5c370b5Approve109694652021-09-16 16:50:151 day 5 hrs ago0x9e4856ccfc9c00390af34ac44bc70d28591af1b9 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x53a45110a811a4c2e75c926aa4e25be0df5db9da29f289722f601a0edf09d39bApprove109683272021-09-16 15:53:211 day 6 hrs ago0xcd50833ad457b22b34a8ecb9ed2378745399ddef IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x896b0ad1b54d1532b338368f3d603827d75e3cc7cd729799b36fc04125c4844fApprove109649032021-09-16 13:01:461 day 9 hrs ago0x09997acdd96657f80437525771dcf65059b7d31d IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0000738735
0xf18f2bdf5deaa39727db4c6829e2307ca1cf9b9ead1bad7431ed6d88234cb0bfApprove109396672021-09-15 15:57:552 days 6 hrs ago0x3c439948c4967c3057ac8ac5c330c714b76ae788 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x1f7aac8bfbfc8fa9bbfdbb84c0f07c10a9c698f07bc9f39d75d1b30d5819b608Approve109384082021-09-15 14:54:582 days 7 hrs ago0xefcbcef04c52d643e9db6521745957a025aff954 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x2c8211b30130425b304273613e451efbe19431c782fa9125da29d963243cbf33Approve109344622021-09-15 11:37:222 days 10 hrs ago0xdf7640b03e905ff8d244b73d380f62aeb17077a6 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022027
0xa710b8403b4e1613c2e7da4f92343bbba6c236b9ddb145647c98f68800e6fd25Approve109340932021-09-15 11:18:342 days 10 hrs ago0x3d2f507b80ad554931f51dd37a42f0eb30f8fc66 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x3e67d7c7144dbd914839ab99798d8306d0ee195db90fe44bbe3968fbfc1a19ddApprove109328432021-09-15 10:15:442 days 12 hrs ago0xb3f976193fb52b97854060224df40cb8bda180bd IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x91cff8ea10343389700cb01556baa0825751c8f0295ae570b27b1a072dde20c3Approve109222372021-09-15 1:20:022 days 20 hrs ago0xf6567dc39a0d6dff8e92233f7a53305cce63f855 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.000266124
0xdd35e515c36a482eb00f7fa44e4954d5e332eb7645702525afc4bd516e088163Approve109153382021-09-14 19:34:443 days 2 hrs ago0x1493681bf329626e2fc0641d92e1df3f7449c03b IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00012577
0xbd0dc1f8a0d9c418019fab97c475473f3faa61b3f1f60daf5471ce0eb188efd5Approve109152852021-09-14 19:32:053 days 2 hrs ago0x1493681bf329626e2fc0641d92e1df3f7449c03b IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0xa0fe3ea1749e1de5f0b751e803fe4d3aaf2baf49f812c6bd151cad3be1392fc8Transfer109078642021-09-14 13:19:083 days 8 hrs ago0xc8ceae49e41332a1913e4726c86c07074dbbf7ea IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0001807
0x84bc826771514adaa3290b5a43f626e00f935fa8cec474c78df8cc3382554f5bApprove109022282021-09-14 8:36:333 days 13 hrs ago0xa68504aff087203bc987d575947c77b67cdae204 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0xffd02d19bcf39a33f74a9d16e526a27483fe44d4d8b7dd5a7fd50fa9dea284d9Approve109021372021-09-14 8:31:563 days 13 hrs ago0x7632d4b88a4215d96cfd2c0947572a0826a16eaa IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0xe7027f9b2d171d2de7632cd7ed667cd490bc1407520664949014530b3b274eceApprove109016422021-09-14 8:07:113 days 14 hrs ago0x069e54ac23c71328266b2f9df089c42f4be1e600 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x321409b450f16ebc432d1bf3a10967fb33474c028cdadabd0e610238ae6ec28bApprove109002502021-09-14 6:57:353 days 15 hrs ago0x17df756d1b64006ed147a4eba44e3a55f1718624 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x76893824d996f88981d6e9a0d9996298fd1e74763accd541186c1f617c00c17aTransfer108968552021-09-14 4:07:303 days 18 hrs ago0xc8ceae49e41332a1913e4726c86c07074dbbf7ea IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0001807
0x8b50194ac8bb0f02634a3fd2b24242fc9334b483ed24b56182468a523b56f194Approve108954872021-09-14 2:59:023 days 19 hrs ago0x6311ea130fb3dbcb02928e0a835d3bdb3cc895d1 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.00022177
0x317fee4f62258797274a3eab5c9b55236f011c5b720db749d5231ad14fca9ccbTransfer108885932021-09-13 21:14:204 days 1 hr ago0xc8ceae49e41332a1913e4726c86c07074dbbf7ea IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0001807
0x8bd03ee36475013dc74b7b72ce16f27bb048c50bc6d3fce6c2d5496a12cd3ed5Transfer108841812021-09-13 17:33:414 days 4 hrs ago0xc8ceae49e41332a1913e4726c86c07074dbbf7ea IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0001807
0x91cb990bc2d309c2c48aff240584e25b2ef30bb63bf0d21539f0c51bc107b7f4Transfer108833592021-09-13 16:52:304 days 5 hrs ago0x514de7ba2cc60af1065d269fd9716b5bd3433b10 IN  0x04580ce6dee076354e96fed53cb839de9efb5f3f0 BNB0.0001807
[ Download CSV Export 
Latest 1 internal transaction
Parent Txn Hash Block From To Value
0x09720c1b26a7ccaf097249fc22e8d23ea2142b7ebbd54b5c8c8f44c1d944534c79183632021-06-01 13:40:22108 days 8 hrs ago 0x86407bea2078ea5f5eb5a52b2caa963bc1f889da  Contract Creation0 BNB
[ Download CSV Export 
Loading

Contract Source Code Verified (Similar Match)
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0x6dd9c088b674d0e379c0fdc141e0e4be1954c1bf

Contract Name:
BabyPair

Compiler Version
v0.7.4+commit.3f05b770

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-07-22
*/

// SPDX-License-Identifier: MIT

//Donate to me: 0x09EB2C1cf2884973AfA53907532b2db0996C55Bf

pragma solidity >=0.5.0;


library BabyLibrary {
    using SafeMath for uint;

    // returns sorted token addresses, used to handle return values from pairs sorted in this order
    function sortTokens(address tokenA, address tokenB) internal pure returns (address token0, address token1) {
        require(tokenA != tokenB, 'PancakeLibrary: IDENTICAL_ADDRESSES');
        (token0, token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
        require(token0 != address(0), 'PancakeLibrary: ZERO_ADDRESS');
    }

    // calculates the CREATE2 address for a pair without making any external calls
    function pairFor(address factory, address tokenA, address tokenB) internal pure returns (address pair) {
        (address token0, address token1) = sortTokens(tokenA, tokenB);
        pair = address(uint(keccak256(abi.encodePacked(
                hex'ff',
                factory,
                keccak256(abi.encodePacked(token0, token1)),
                hex'48c8bec5512d397a5d512fbb7d83d515e7b6d91e9838730bd1aa1b16575da7f5'
            ))));
    }

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

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

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

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

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

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

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

pragma solidity >=0.4.0;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, 'SafeMath: addition overflow');

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, 'SafeMath: subtraction overflow');
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, 'SafeMath: multiplication overflow');

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, 'SafeMath: division by zero');
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, 'SafeMath: modulo by zero');
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }

    function min(uint256 x, uint256 y) internal pure returns (uint256 z) {
        z = x < y ? x : y;
    }

    // babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method)
    function sqrt(uint256 y) internal pure returns (uint256 z) {
        if (y > 3) {
            z = y;
            uint256 x = y / 2 + 1;
            while (x < z) {
                z = x;
                x = (y / x + x) / 2;
            }
        } else if (y != 0) {
            z = 1;
        }
    }
}

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

pragma solidity >=0.5.0;

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

pragma solidity >=0.5.0;

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

pragma solidity >=0.5.0;

interface IBabyFactory {
    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 expectPairFor(address token0, address token1) external view returns (address);
    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;
}

pragma solidity >=0.5.0;

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

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

pragma solidity >=0.5.16;

contract BabyERC20 is IBabyERC20 {
    using SafeMath for uint256;

    string public override constant name = 'Baby LPs';
    string public override constant symbol = 'Baby-LP';
    uint8 public override constant decimals = 18;
    uint  public override totalSupply;
    mapping(address => uint) public override balanceOf;
    mapping(address => mapping(address => uint)) public override allowance;

    bytes32 public override DOMAIN_SEPARATOR;
    // keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
    bytes32 public override constant PERMIT_TYPEHASH = 0x6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9;
    mapping(address => uint) public override nonces;

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

    constructor() {
        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 override returns (bool) {
        _approve(msg.sender, spender, value);
        return true;
    }

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

    function transferFrom(address from, address to, uint value) external override 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 override {
        require(deadline >= block.timestamp, 'Baby: 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, 'Baby: INVALID_SIGNATURE');
        _approve(owner, spender, value);
    }
}

pragma solidity >=0.5.16;


contract BabyPair is BabyERC20 {
    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, 'Baby: 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))), 'Baby: 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() {
        factory = msg.sender;
    }

    // called once by the factory at time of deployment
    function initialize(address _token0, address _token1) external {
        require(msg.sender == factory, 'Baby: 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), 'Baby: 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 = IBabyFactory(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, 'Baby: 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
        require(_totalSupply != 0, "influence balance");
        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, 'Baby: 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, 'Baby: INSUFFICIENT_OUTPUT_AMOUNT');
        (uint112 _reserve0, uint112 _reserve1,) = getReserves(); // gas savings
        require(amount0Out < _reserve0 && amount1Out < _reserve1, 'Baby: 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, 'Baby: 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) IBabyCallee(to).babyCall(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, 'Baby: 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), 'Baby: 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":[],"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"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINIMUM_LIQUIDITY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PERMIT_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"burn","outputs":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getReserves","outputs":[{"internalType":"uint112","name":"_reserve0","type":"uint112"},{"internalType":"uint112","name":"_reserve1","type":"uint112"},{"internalType":"uint32","name":"_blockTimestampLast","type":"uint32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token0","type":"address"},{"internalType":"address","name":"_token1","type":"address"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"kLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"mint","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"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":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"price0CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"price1CumulativeLast","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"skim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"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":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sync","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"token0","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token1","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"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"}],"stateMutability":"nonpayable","type":"function"}]

60806040526001600c5534801561001557600080fd5b50604080518082018252600881526742616279204c507360c01b6020918201528151808301835260018152603160f81b9082015281517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f818301527ff2af0fab7d1e24a43eb09fbcee8483ea7a053194f6a00a9b241b717441ba0019818401527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a0808301919091528351808303909101815260c09091019092528151910120600355600580546001600160a01b0319163317905561225b806101066000396000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c80636a627842116100f9578063ba9a7a5611610097578063d21220a711610071578063d21220a714610534578063d505accf1461053c578063dd62ed3e1461058d578063fff6cae9146105bb576101a9565b8063ba9a7a56146104fe578063bc25cf7714610506578063c45a01551461052c576101a9565b80637ecebe00116100d35780637ecebe001461046557806389afcb441461048b57806395d89b41146104ca578063a9059cbb146104d2576101a9565b80636a6278421461041157806370a08231146104375780637464fc3d1461045d576101a9565b806323b872dd116101665780633644e515116101405780633644e515146103cb578063485cc955146103d35780635909c0d5146104015780635a3d549314610409576101a9565b806323b872dd1461036f57806330adf81f146103a5578063313ce567146103ad576101a9565b8063022c0d9f146101ae57806306fdde031461023c5780630902f1ac146102b9578063095ea7b3146102f15780630dfe16811461033157806318160ddd14610355575b600080fd5b61023a600480360360808110156101c457600080fd5b8135916020810135916001600160a01b0360408301351691908101906080810160608201356401000000008111156101fb57600080fd5b82018360208201111561020d57600080fd5b8035906020019184600183028401116401000000008311171561022f57600080fd5b5090925090506105c3565b005b610244610afe565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561027e578181015183820152602001610266565b50505050905090810190601f1680156102ab5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102c1610b22565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b61031d6004803603604081101561030757600080fd5b506001600160a01b038135169060200135610b4c565b604080519115158252519081900360200190f35b610339610b63565b604080516001600160a01b039092168252519081900360200190f35b61035d610b72565b60408051918252519081900360200190f35b61031d6004803603606081101561038557600080fd5b506001600160a01b03813581169160208101359091169060400135610b78565b61035d610c0c565b6103b5610c30565b6040805160ff9092168252519081900360200190f35b61035d610c35565b61023a600480360360408110156103e957600080fd5b506001600160a01b0381358116916020013516610c3b565b61035d610cba565b61035d610cc0565b61035d6004803603602081101561042757600080fd5b50356001600160a01b0316610cc6565b61035d6004803603602081101561044d57600080fd5b50356001600160a01b0316610f9d565b61035d610faf565b61035d6004803603602081101561047b57600080fd5b50356001600160a01b0316610fb5565b6104b1600480360360208110156104a157600080fd5b50356001600160a01b0316610fc7565b6040805192835260208301919091528051918290030190f35b61024461139c565b61031d600480360360408110156104e857600080fd5b506001600160a01b0381351690602001356113bf565b61035d6113cc565b61023a6004803603602081101561051c57600080fd5b50356001600160a01b03166113d2565b61033961153f565b61033961154e565b61023a600480360360e081101561055257600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c0013561155d565b61035d600480360360408110156105a357600080fd5b506001600160a01b038135811691602001351661175a565b61023a611777565b600c54600114610609576040805162461bcd60e51b815260206004820152600c60248201526b1098589e4e881313d0d2d15160a21b604482015290519081900360640190fd5b6000600c558415158061061c5750600084115b61066d576040805162461bcd60e51b815260206004820181905260248201527f426162793a20494e53554646494349454e545f4f55545055545f414d4f554e54604482015290519081900360640190fd5b600080610678610b22565b5091509150816001600160701b03168710801561069d5750806001600160701b031686105b6106ee576040805162461bcd60e51b815260206004820152601c60248201527f426162793a20494e53554646494349454e545f4c495155494449545900000000604482015290519081900360640190fd5b60065460075460009182916001600160a01b0391821691908116908916821480159061072c5750806001600160a01b0316896001600160a01b031614155b610770576040805162461bcd60e51b815260206004820152601060248201526f426162793a20494e56414c49445f544f60801b604482015290519081900360640190fd5b8a1561078157610781828a8d6118d4565b891561079257610792818a8c6118d4565b861561084457886001600160a01b031663110c03de338d8d8c8c6040518663ffffffff1660e01b815260040180866001600160a01b03168152602001858152602001848152602001806020018281038252848482818152602001925080828437600081840152601f19601f8201169050808301925050509650505050505050600060405180830381600087803b15801561082b57600080fd5b505af115801561083f573d6000803e3d6000fd5b505050505b604080516370a0823160e01b815230600482015290516001600160a01b038416916370a08231916024808301926020929190829003018186803b15801561088a57600080fd5b505afa15801561089e573d6000803e3d6000fd5b505050506040513d60208110156108b457600080fd5b5051604080516370a0823160e01b815230600482015290519195506001600160a01b038316916370a0823191602480820192602092909190829003018186803b15801561090057600080fd5b505afa158015610914573d6000803e3d6000fd5b505050506040513d602081101561092a57600080fd5b5051925060009150506001600160701b0385168a9003831161094d57600061095c565b89856001600160701b03160383035b9050600089856001600160701b0316038311610979576000610988565b89856001600160701b03160383035b905060008211806109995750600081115b6109ea576040805162461bcd60e51b815260206004820152601f60248201527f426162793a20494e53554646494349454e545f494e5055545f414d4f554e5400604482015290519081900360640190fd5b6000610a0c6109fa846002611a66565b610a06876103e8611a66565b90611ac6565b90506000610a1e6109fa846002611a66565b9050610a43620f4240610a3d6001600160701b038b8116908b16611a66565b90611a66565b610a4d8383611a66565b1015610a8a576040805162461bcd60e51b8152602060048201526007602482015266426162793a204b60c81b604482015290519081900360640190fd5b5050610a9884848888611b08565b60408051838152602081018390528082018d9052606081018c905290516001600160a01b038b169133917fd78ad95fa46c994b6551d0da85fc275fe613ce37657fb8d5e3d130840159d8229181900360800190a350506001600c55505050505050505050565b6040518060400160405280600881526020016742616279204c507360c01b81525081565b6008546001600160701b0380821692600160701b830490911691600160e01b900463ffffffff1690565b6000610b59338484611cc2565b5060015b92915050565b6006546001600160a01b031681565b60005481565b6001600160a01b038316600090815260026020908152604080832033845290915281205460001914610bf7576001600160a01b0384166000908152600260209081526040808320338452909152902054610bd29083611ac6565b6001600160a01b03851660009081526002602090815260408083203384529091529020555b610c02848484611d24565b5060019392505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b601281565b60035481565b6005546001600160a01b03163314610c8c576040805162461bcd60e51b815260206004820152600f60248201526e2130b13c9d102327a92124a22222a760891b604482015290519081900360640190fd5b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b60095481565b600a5481565b6000600c54600114610d0e576040805162461bcd60e51b815260206004820152600c60248201526b1098589e4e881313d0d2d15160a21b604482015290519081900360640190fd5b6000600c81905580610d1e610b22565b50600654604080516370a0823160e01b815230600482015290519395509193506000926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015610d7257600080fd5b505afa158015610d86573d6000803e3d6000fd5b505050506040513d6020811015610d9c57600080fd5b5051600754604080516370a0823160e01b815230600482015290519293506000926001600160a01b03909216916370a0823191602480820192602092909190829003018186803b158015610def57600080fd5b505afa158015610e03573d6000803e3d6000fd5b505050506040513d6020811015610e1957600080fd5b505190506000610e32836001600160701b038716611ac6565b90506000610e49836001600160701b038716611ac6565b90506000610e578787611dd2565b60005490915080610e8e57610e7a6103e8610a06610e758787611a66565b611f12565b9850610e8960006103e8611f64565b610ed1565b610ece6001600160701b038916610ea58684611a66565b81610eac57fe5b046001600160701b038916610ec18685611a66565b81610ec857fe5b04611fee565b98505b60008911610f105760405162461bcd60e51b81526004018080602001828103825260238152602001806122036023913960400191505060405180910390fd5b610f1a8a8a611f64565b610f2686868a8a611b08565b8115610f5057600854610f4c906001600160701b0380821691600160701b900416611a66565b600b555b6040805185815260208101859052815133927f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f928290030190a250506001600c5550949695505050505050565b60016020526000908152604090205481565b600b5481565b60046020526000908152604090205481565b600080600c54600114611010576040805162461bcd60e51b815260206004820152600c60248201526b1098589e4e881313d0d2d15160a21b604482015290519081900360640190fd5b6000600c81905580611020610b22565b50600654600754604080516370a0823160e01b815230600482015290519496509294506001600160a01b039182169391169160009184916370a08231916024808301926020929190829003018186803b15801561107c57600080fd5b505afa158015611090573d6000803e3d6000fd5b505050506040513d60208110156110a657600080fd5b5051604080516370a0823160e01b815230600482015290519192506000916001600160a01b038516916370a08231916024808301926020929190829003018186803b1580156110f457600080fd5b505afa158015611108573d6000803e3d6000fd5b505050506040513d602081101561111e57600080fd5b50513060009081526001602052604081205491925061113d8888611dd2565b60005490915080611189576040805162461bcd60e51b8152602060048201526011602482015270696e666c75656e63652062616c616e636560781b604482015290519081900360640190fd5b806111948487611a66565b8161119b57fe5b049a50806111a98486611a66565b816111b057fe5b04995060008b1180156111c3575060008a115b6111fe5760405162461bcd60e51b81526004018080602001828103825260238152602001806121bf6023913960400191505060405180910390fd5b6112083084612004565b611213878d8d6118d4565b61121e868d8c6118d4565b604080516370a0823160e01b815230600482015290516001600160a01b038916916370a08231916024808301926020929190829003018186803b15801561126457600080fd5b505afa158015611278573d6000803e3d6000fd5b505050506040513d602081101561128e57600080fd5b5051604080516370a0823160e01b815230600482015290519196506001600160a01b038816916370a0823191602480820192602092909190829003018186803b1580156112da57600080fd5b505afa1580156112ee573d6000803e3d6000fd5b505050506040513d602081101561130457600080fd5b5051935061131485858b8b611b08565b811561133e5760085461133a906001600160701b0380821691600160701b900416611a66565b600b555b604080518c8152602081018c905281516001600160a01b038f169233927fdccd412f0b1252819cb1fd330b93224ca42612892bb3f4f789976e6d81936496929081900390910190a35050505050505050506001600c81905550915091565b604051806040016040528060078152602001660426162792d4c560cc1b81525081565b6000610b59338484611d24565b6103e881565b600c54600114611418576040805162461bcd60e51b815260206004820152600c60248201526b1098589e4e881313d0d2d15160a21b604482015290519081900360640190fd5b6000600c55600654600754600854604080516370a0823160e01b815230600482015290516001600160a01b0394851694909316926114c192859287926114bc926001600160701b03169185916370a0823191602480820192602092909190829003018186803b15801561148a57600080fd5b505afa15801561149e573d6000803e3d6000fd5b505050506040513d60208110156114b457600080fd5b505190611ac6565b6118d4565b61153581846114bc6008600e9054906101000a90046001600160701b03166001600160701b0316856001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561148a57600080fd5b50506001600c5550565b6005546001600160a01b031681565b6007546001600160a01b031681565b428410156115a2576040805162461bcd60e51b815260206004820152600d60248201526c1098589e4e8811561412549151609a1b604482015290519081900360640190fd5b6003546001600160a01b0380891660008181526004602090815260408083208054600180820190925582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98186015280840196909652958d166060860152608085018c905260a085019590955260c08085018b90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff89166101828501526101a284018890526101c28401879052519193926101e280820193601f1981019281900390910190855afa1580156116bd573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906116f35750886001600160a01b0316816001600160a01b0316145b611744576040805162461bcd60e51b815260206004820152601760248201527f426162793a20494e56414c49445f5349474e4154555245000000000000000000604482015290519081900360640190fd5b61174f898989611cc2565b505050505050505050565b600260209081526000928352604080842090915290825290205481565b600c546001146117bd576040805162461bcd60e51b815260206004820152600c60248201526b1098589e4e881313d0d2d15160a21b604482015290519081900360640190fd5b6000600c55600654604080516370a0823160e01b815230600482015290516118cd926001600160a01b0316916370a08231916024808301926020929190829003018186803b15801561180e57600080fd5b505afa158015611822573d6000803e3d6000fd5b505050506040513d602081101561183857600080fd5b5051600754604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b15801561188557600080fd5b505afa158015611899573d6000803e3d6000fd5b505050506040513d60208110156118af57600080fd5b50516008546001600160701b0380821691600160701b900416611b08565b6001600c55565b604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0385811660248301526044808301869052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009460609489169392918291908083835b602083106119815780518252601f199092019160209182019101611962565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d80600081146119e3576040519150601f19603f3d011682016040523d82523d6000602084013e6119e8565b606091505b5091509150818015611a16575080511580611a165750808060200190516020811015611a1357600080fd5b50515b611a5f576040805162461bcd60e51b81526020600482015260156024820152741098589e4e881514905394d1915497d19052531151605a1b604482015290519081900360640190fd5b5050505050565b600082611a7557506000610b5d565b82820282848281611a8257fe5b0414611abf5760405162461bcd60e51b81526004018080602001828103825260218152602001806121e26021913960400191505060405180910390fd5b9392505050565b6000611abf83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250612096565b6001600160701b038411801590611b2657506001600160701b038311155b611b68576040805162461bcd60e51b815260206004820152600e60248201526d426162793a204f564552464c4f5760901b604482015290519081900360640190fd5b60085463ffffffff42811691600160e01b90048116820390811615801590611b9857506001600160701b03841615155b8015611bac57506001600160701b03831615155b15611c17578063ffffffff16611bd485611bc58661212d565b6001600160e01b03169061213f565b600980546001600160e01b03929092169290920201905563ffffffff8116611bff84611bc58761212d565b600a80546001600160e01b0392909216929092020190555b600880546dffffffffffffffffffffffffffff19166001600160701b03888116919091176dffffffffffffffffffffffffffff60701b1916600160701b8883168102919091176001600160e01b0316600160e01b63ffffffff871602179283905560408051848416815291909304909116602082015281517f1c411e9a96e071241c2f21f7726b17ae89e3cab4c78be50e062b03a9fffbbad1929181900390910190a1505050505050565b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b038316600090815260016020526040902054611d479082611ac6565b6001600160a01b038085166000908152600160205260408082209390935590841681522054611d769082612164565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b600080600560009054906101000a90046001600160a01b03166001600160a01b031663017e7e586040518163ffffffff1660e01b815260040160206040518083038186803b158015611e2357600080fd5b505afa158015611e37573d6000803e3d6000fd5b505050506040513d6020811015611e4d57600080fd5b5051600b546001600160a01b038216158015945091925090611efe578015611ef9576000611e8a610e756001600160701b03888116908816611a66565b90506000611e9783611f12565b905080821115611ef6576000611eb9611eb08484611ac6565b60005490611a66565b90506000611ed283611ecc866003611a66565b90612164565b90506000818381611edf57fe5b0490508015611ef257611ef28782611f64565b5050505b50505b611f0a565b8015611f0a576000600b555b505092915050565b60006003821115611f55575080600160028204015b81811015611f4f57809150600281828581611f3e57fe5b040181611f4757fe5b049050611f27565b50611f5f565b8115611f5f575060015b919050565b600054611f719082612164565b60009081556001600160a01b038316815260016020526040902054611f969082612164565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b6000818310611ffd5781611abf565b5090919050565b6001600160a01b0382166000908152600160205260409020546120279082611ac6565b6001600160a01b0383166000908152600160205260408120919091555461204e9082611ac6565b60009081556040805183815290516001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a35050565b600081848411156121255760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156120ea5781810151838201526020016120d2565b50505050905090810190601f1680156121175780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b0384168161215c57fe5b049392505050565b600082820183811015611abf576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fdfe426162793a20494e53554646494349454e545f4c49515549444954595f4255524e4544536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77426162793a20494e53554646494349454e545f4c49515549444954595f4d494e544544a2646970667358221220d62a16710db5d5c1c2b9e5d18733ac66aae6371399c94c4aafaa2d10e4a60cac64736f6c63430007040033

Deployed ByteCode Sourcemap

20722:9642:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27917:1854;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;27917:1854:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27917:1854:0;;-1:-1:-1;27917:1854:0;-1:-1:-1;27917:1854:0;:::i;:::-;;17247:49;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21712:231;;;:::i;:::-;;;;-1:-1:-1;;;;;21712:231:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;19373:156;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19373:156:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;21006:21;;;:::i;:::-;;;;-1:-1:-1;;;;;21006:21:0;;;;;;;;;;;;;;17411:33;;;:::i;:::-;;;;;;;;;;;;;;;;19693:310;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19693:310:0;;;;;;;;;;;;;;;;;:::i;17739:117::-;;;:::i;17360:44::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;17587:40;;;:::i;22760:205::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;22760:205:0;;;;;;;;;;:::i;21357:32::-;;;:::i;21396:::-;;;:::i;24939:1235::-;;;;;;;;;;;;;;;;-1:-1:-1;24939:1235:0;-1:-1:-1;;;;;24939:1235:0;;:::i;17451:50::-;;;;;;;;;;;;;;;;-1:-1:-1;17451:50:0;-1:-1:-1;;;;;17451:50:0;;:::i;21435:17::-;;;:::i;17863:47::-;;;;;;;;;;;;;;;;-1:-1:-1;17863:47:0;-1:-1:-1;;;;;17863:47:0;;:::i;26286:1519::-;;;;;;;;;;;;;;;;-1:-1:-1;26286:1519:0;-1:-1:-1;;;;;26286:1519:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;17303:50;;;:::i;19537:148::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19537:148:0;;;;;;;;:::i;20827:46::-;;;:::i;29820:334::-;;;;;;;;;;;;;;;;-1:-1:-1;29820:334:0;-1:-1:-1;;;;;29820:334:0;;:::i;20977:22::-;;;:::i;21034:21::-;;;:::i;20011:673::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;20011:673:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;17508:70::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;17508:70:0;;;;;;;;;;:::i;30203:158::-;;;:::i;27917:1854::-;21608:8;;21620:1;21608:13;21600:38;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;;;;21660:1;21649:8;:12;28031:14;;;;:32:::1;;;28062:1;28049:10;:14;28031:32;28023:77;;;::::0;;-1:-1:-1;;;28023:77:0;;::::1;;::::0;::::1;::::0;;;;;;;::::1;::::0;;;;;;;;;;;;;::::1;;28112:17;28131::::0;28153:13:::1;:11;:13::i;:::-;28111:55;;;;;28213:9;-1:-1:-1::0;;;;;28200:22:0::1;:10;:22;:48;;;;;28239:9;-1:-1:-1::0;;;;;28226:22:0::1;:10;:22;28200:48;28192:89;;;::::0;;-1:-1:-1;;;28192:89:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;28426:6;::::0;28461::::1;::::0;28294:13:::1;::::0;;;-1:-1:-1;;;;;28426:6:0;;::::1;::::0;28461;;::::1;::::0;28486:13;::::1;::::0;::::1;::::0;::::1;::::0;:30:::1;;;28509:7;-1:-1:-1::0;;;;;28503:13:0::1;:2;-1:-1:-1::0;;;;;28503:13:0::1;;;28486:30;28478:59;;;::::0;;-1:-1:-1;;;28478:59:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;28478:59:0;;;;;;;;;;;;;::::1;;28552:14:::0;;28548:58:::1;;28568:38;28582:7;28591:2;28595:10;28568:13;:38::i;:::-;28655:14:::0;;28651:58:::1;;28671:38;28685:7;28694:2;28698:10;28671:13;:38::i;:::-;28758:15:::0;;28754:87:::1;;28787:2;-1:-1:-1::0;;;;;28775:24:0::1;;28800:10;28812;28824;28836:4;;28775:66;;;;;;;;;;;;;-1:-1:-1::0;;;;;28775:66:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;28754:87;28863:40;::::0;;-1:-1:-1;;;28863:40:0;;28897:4:::1;28863:40;::::0;::::1;::::0;;;-1:-1:-1;;;;;28863:25:0;::::1;::::0;::::1;::::0;:40;;;;;::::1;::::0;;;;;;;;:25;:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;28863:40:0;28925::::1;::::0;;-1:-1:-1;;;28925:40:0;;28959:4:::1;28925:40;::::0;::::1;::::0;;;28863;;-1:-1:-1;;;;;;28925:25:0;::::1;::::0;::::1;::::0;:40;;;;;28863::::1;::::0;28925;;;;;;;;:25;:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;28925:40:0;;-1:-1:-1;28987:14:0::1;::::0;-1:-1:-1;;;;;;;29015:22:0;::::1;::::0;;::::1;29004:33:::0;::::1;:75;;29078:1;29004:75;;;29064:10;29052:9;-1:-1:-1::0;;;;;29052:22:0::1;;29040:8;:35;29004:75;28987:92;;29090:14;29130:10;29118:9;-1:-1:-1::0;;;;;29118:22:0::1;;29107:8;:33;:75;;29181:1;29107:75;;;29167:10;29155:9;-1:-1:-1::0;;;;;29155:22:0::1;;29143:8;:35;29107:75;29090:92;;29213:1;29201:9;:13;:30;;;;29230:1;29218:9;:13;29201:30;29193:74;;;::::0;;-1:-1:-1;;;29193:74:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;29353:21;29377:40;29400:16;:9:::0;29414:1:::1;29400:13;:16::i;:::-;29377:18;:8:::0;29390:4:::1;29377:12;:18::i;:::-;:22:::0;::::1;:40::i;:::-;29353:64:::0;-1:-1:-1;29428:21:0::1;29452:40;29475:16;:9:::0;29489:1:::1;29475:13;:16::i;29452:40::-;29428:64:::0;-1:-1:-1;29553:43:0::1;29588:7;29553:30;-1:-1:-1::0;;;;;29553:15:0;;::::1;::::0;:30;::::1;:19;:30::i;:::-;:34:::0;::::1;:43::i;:::-;29511:38;:16:::0;29532;29511:20:::1;:38::i;:::-;:85;;29503:105;;;::::0;;-1:-1:-1;;;29503:105:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;29503:105:0;;;;;;;;;;;;;::::1;;21672:1;;29632:49;29640:8;29650;29660:9;29671;29632:7;:49::i;:::-;29697:66;::::0;;;;;::::1;::::0;::::1;::::0;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29697:66:0;::::1;::::0;29702:10:::1;::::0;29697:66:::1;::::0;;;;;;;::::1;-1:-1:-1::0;;21695:1:0;21684:8;:12;-1:-1:-1;;;;;;;;;27917:1854:0:o;17247:49::-;;;;;;;;;;;;;;-1:-1:-1;;;17247:49:0;;;;:::o;21712:231::-;21845:8;;-1:-1:-1;;;;;21845:8:0;;;;-1:-1:-1;;;21876:8:0;;;;;;-1:-1:-1;;;21917:18:0;;;;;21712:231::o;19373:156::-;19446:4;19463:36;19472:10;19484:7;19493:5;19463:8;:36::i;:::-;-1:-1:-1;19517:4:0;19373:156;;;;;:::o;21006:21::-;;;-1:-1:-1;;;;;21006:21:0;;:::o;17411:33::-;;;;:::o;19693:310::-;-1:-1:-1;;;;;19801:15:0;;19780:4;19801:15;;;:9;:15;;;;;;;;19817:10;19801:27;;;;;;;;-1:-1:-1;;19801:39:0;19797:140;;-1:-1:-1;;;;;19887:15:0;;;;;;:9;:15;;;;;;;;19903:10;19887:27;;;;;;;;:38;;19919:5;19887:31;:38::i;:::-;-1:-1:-1;;;;;19857:15:0;;;;;;:9;:15;;;;;;;;19873:10;19857:27;;;;;;;:68;19797:140;19947:26;19957:4;19963:2;19967:5;19947:9;:26::i;:::-;-1:-1:-1;19991:4:0;19693:310;;;;;:::o;17739:117::-;17790:66;17739:117;:::o;17360:44::-;17402:2;17360:44;:::o;17587:40::-;;;;:::o;22760:205::-;22856:7;;-1:-1:-1;;;;;22856:7:0;22842:10;:21;22834:49;;;;;-1:-1:-1;;;22834:49:0;;;;;;;;;;;;-1:-1:-1;;;22834:49:0;;;;;;;;;;;;;;;22914:6;:16;;-1:-1:-1;;;;;22914:16:0;;;-1:-1:-1;;;;;;22914:16:0;;;;;;;22941:6;:16;;;;;;;;;;;22760:205::o;21357:32::-;;;;:::o;21396:::-;;;;:::o;24939:1235::-;24988:14;21608:8;;21620:1;21608:13;21600:38;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;;;;21660:1;21649:8;:12;;;21660:1;25057:13:::1;:11;:13::i;:::-;-1:-1:-1::0;25119:6:0::1;::::0;25112:39:::1;::::0;;-1:-1:-1;;;25112:39:0;;25145:4:::1;25112:39;::::0;::::1;::::0;;;25015:55;;-1:-1:-1;25015:55:0;;-1:-1:-1;25096:13:0::1;::::0;-1:-1:-1;;;;;25119:6:0;;::::1;::::0;25112:24:::1;::::0;:39;;;;;::::1;::::0;;;;;;;;25119:6;25112:39;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;25112:39:0;25185:6:::1;::::0;25178:39:::1;::::0;;-1:-1:-1;;;25178:39:0;;25211:4:::1;25178:39;::::0;::::1;::::0;;;25112;;-1:-1:-1;25162:13:0::1;::::0;-1:-1:-1;;;;;25185:6:0;;::::1;::::0;25178:24:::1;::::0;:39;;;;;25112::::1;::::0;25178;;;;;;;;25185:6;25178:39;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;25178:39:0;;-1:-1:-1;25228:12:0::1;25243:23;:8:::0;-1:-1:-1;;;;;25243:23:0;::::1;:12;:23::i;:::-;25228:38:::0;-1:-1:-1;25277:12:0::1;25292:23;:8:::0;-1:-1:-1;;;;;25292:23:0;::::1;:12;:23::i;:::-;25277:38;;25328:10;25341:30;25350:9;25361;25341:8;:30::i;:::-;25382:17;25402:11:::0;25328:43;;-1:-1:-1;25506:17:0;25502:352:::1;;25552:54;20868:5;25552:31;25562:20;:7:::0;25574;25562:11:::1;:20::i;:::-;25552:9;:31::i;:54::-;25540:66;;25620:36;25634:1;20868:5;25620;:36::i;:::-;25502:352;;;25756:86;-1:-1:-1::0;;;;;25765:37:0;::::1;:25;:7:::0;25777:12;25765:11:::1;:25::i;:::-;:37;;;;;;-1:-1:-1::0;;;;;25804:37:0;::::1;:25;:7:::0;25816:12;25804:11:::1;:25::i;:::-;:37;;;;;;25756:8;:86::i;:::-;25744:98;;25502:352;25884:1;25872:9;:13;25864:61;;;;-1:-1:-1::0;;;25864:61:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25936:20;25942:2;25946:9;25936:5;:20::i;:::-;25969:49;25977:8;25987;25997:9;26008;25969:7;:49::i;:::-;26033:5;26029:47;;;26067:8;::::0;26048:28:::1;::::0;-1:-1:-1;;;;;26053:8:0;;::::1;::::0;-1:-1:-1;;;26067:8:0;::::1;;26048:18;:28::i;:::-;26040:5;:36:::0;26029:47:::1;26132:34;::::0;;;;;::::1;::::0;::::1;::::0;;;;;26137:10:::1;::::0;26132:34:::1;::::0;;;;;;::::1;-1:-1:-1::0;;21695:1:0;21684:8;:12;-1:-1:-1;24939:1235:0;;;-1:-1:-1;;;;;;24939:1235:0:o;17451:50::-;;;;;;;;;;;;;:::o;21435:17::-;;;;:::o;17863:47::-;;;;;;;;;;;;;:::o;26286:1519::-;26335:12;26349;21608:8;;21620:1;21608:13;21600:38;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;;;;21660:1;21649:8;:12;;;21660:1;26416:13:::1;:11;:13::i;:::-;-1:-1:-1::0;26473:6:0::1;::::0;26554::::1;::::0;26633:40:::1;::::0;;-1:-1:-1;;;26633:40:0;;26667:4:::1;26633:40;::::0;::::1;::::0;;;26374:55;;-1:-1:-1;26374:55:0;;-1:-1:-1;;;;;;26473:6:0;;::::1;::::0;26554;::::1;::::0;26455:15:::1;::::0;26473:6;;26633:25:::1;::::0;:40;;;;;::::1;::::0;;;;;;;;26473:6;26633:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;26633:40:0;26700::::1;::::0;;-1:-1:-1;;;26700:40:0;;26734:4:::1;26700:40;::::0;::::1;::::0;;;26633;;-1:-1:-1;26684:13:0::1;::::0;-1:-1:-1;;;;;26700:25:0;::::1;::::0;::::1;::::0;:40;;;;;26633::::1;::::0;26700;;;;;;;:25;:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;26700:40:0;26786:4:::1;26751:14;26768:24:::0;;;:9:::1;26700:40;26768:24:::0;;;;;26700:40;;-1:-1:-1;26818:30:0::1;26827:9:::0;26838;26818:8:::1;:30::i;:::-;26859:17;26879:11:::0;26805:43;;-1:-1:-1;26987:17:0;26979:47:::1;;;::::0;;-1:-1:-1;;;26979:47:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;-1:-1:-1;;;26979:47:0;;;;;;;;;;;;;::::1;;27073:12:::0;27047:23:::1;:9:::0;27061:8;27047:13:::1;:23::i;:::-;:38;;;;;;::::0;-1:-1:-1;27180:12:0;27154:23:::1;:9:::0;27168:8;27154:13:::1;:23::i;:::-;:38;;;;;;27144:48;;27269:1;27259:7;:11;:26;;;;;27284:1;27274:7;:11;27259:26;27251:74;;;;-1:-1:-1::0;;;27251:74:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27336:31;27350:4;27357:9;27336:5;:31::i;:::-;27378:35;27392:7;27401:2;27405:7;27378:13;:35::i;:::-;27424;27438:7;27447:2;27451:7;27424:13;:35::i;:::-;27481:40;::::0;;-1:-1:-1;;;27481:40:0;;27515:4:::1;27481:40;::::0;::::1;::::0;;;-1:-1:-1;;;;;27481:25:0;::::1;::::0;::::1;::::0;:40;;;;;::::1;::::0;;;;;;;;:25;:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;27481:40:0;27543::::1;::::0;;-1:-1:-1;;;27543:40:0;;27577:4:::1;27543:40;::::0;::::1;::::0;;;27481;;-1:-1:-1;;;;;;27543:25:0;::::1;::::0;::::1;::::0;:40;;;;;27481::::1;::::0;27543;;;;;;;;:25;:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;27543:40:0;;-1:-1:-1;27596:49:0::1;27604:8:::0;27543:40;27624:9;27635;27596:7:::1;:49::i;:::-;27660:5;27656:47;;;27694:8;::::0;27675:28:::1;::::0;-1:-1:-1;;;;;27680:8:0;;::::1;::::0;-1:-1:-1;;;27694:8:0;::::1;;27675:18;:28::i;:::-;27667:5;:36:::0;27656:47:::1;27759:38;::::0;;;;;::::1;::::0;::::1;::::0;;;;;-1:-1:-1;;;;;27759:38:0;::::1;::::0;27764:10:::1;::::0;27759:38:::1;::::0;;;;;;;;;::::1;21672:1;;;;;;;;;21695::::0;21684:8;:12;;;;26286:1519;;;:::o;17303:50::-;;;;;;;;;;;;;;-1:-1:-1;;;17303:50:0;;;;:::o;19537:148::-;19606:4;19623:32;19633:10;19645:2;19649:5;19623:9;:32::i;20827:46::-;20868:5;20827:46;:::o;29820:334::-;21608:8;;21620:1;21608:13;21600:38;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;;;;21660:1;21649:8;:12;29889:6:::1;::::0;29939::::1;::::0;30043:8:::1;::::0;29998:40:::1;::::0;;-1:-1:-1;;;29998:40:0;;30032:4:::1;29998:40;::::0;::::1;::::0;;;-1:-1:-1;;;;;29889:6:0;;::::1;::::0;29939;;::::1;::::0;29971:82:::1;::::0;29889:6;;29994:2;;29998:54:::1;::::0;-1:-1:-1;;;;;30043:8:0::1;::::0;29889:6;;29998:25:::1;::::0;:40;;;;;::::1;::::0;;;;;;;;;29889:6;29998:40;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;29998:40:0;;:44:::1;:54::i;:::-;29971:13;:82::i;:::-;30064;30078:7;30087:2;30091:54;30136:8;;;;;;;;;-1:-1:-1::0;;;;;30136:8:0::1;-1:-1:-1::0;;;;;30091:54:0::1;30098:7;-1:-1:-1::0;;;;;30091:25:0::1;;30125:4;30091:40;;;;;;;;;;;;;-1:-1:-1::0;;;;;30091:40:0::1;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;30064:82;-1:-1:-1::0;;21695:1:0;21684:8;:12;-1:-1:-1;29820:334:0:o;20977:22::-;;;-1:-1:-1;;;;;20977:22:0;;:::o;21034:21::-;;;-1:-1:-1;;;;;21034:21:0;;:::o;20011:673::-;20166:15;20154:8;:27;;20146:53;;;;;-1:-1:-1;;;20146:53:0;;;;;;;;;;;;-1:-1:-1;;;20146:53:0;;;;;;;;;;;;;;;20315:16;;-1:-1:-1;;;;;20411:13:0;;;20210:14;20411:13;;;:6;:13;;;;;;;;:15;;;;;;;;;20360:77;;17790:66;20360:77;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20350:88;;;;;;-1:-1:-1;;;20251:202:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20227:237;;;;;;;;;20502:26;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20210:14;;20411:15;20502:26;;;;;-1:-1:-1;;20502:26:0;;;;;;;;;;20411:15;20502:26;;;;;;;;;;;;;;;-1:-1:-1;;20502:26:0;;-1:-1:-1;;20502:26:0;;;-1:-1:-1;;;;;;;20547:30:0;;;;;;:59;;;20601:5;-1:-1:-1;;;;;20581:25:0;:16;-1:-1:-1;;;;;20581:25:0;;20547:59;20539:95;;;;;-1:-1:-1;;;20539:95:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;20645:31;20654:5;20661:7;20670:5;20645:8;:31::i;:::-;20011:673;;;;;;;;;:::o;17508:70::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;30203:158::-;21608:8;;21620:1;21608:13;21600:38;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;-1:-1:-1;;;21600:38:0;;;;;;;;;;;;;;;21660:1;21649:8;:12;30259:6:::1;::::0;30252:39:::1;::::0;;-1:-1:-1;;;30252:39:0;;30285:4:::1;30252:39;::::0;::::1;::::0;;;30244:109:::1;::::0;-1:-1:-1;;;;;30259:6:0::1;::::0;30252:24:::1;::::0;:39;;;;;::::1;::::0;;;;;;;;30259:6;30252:39;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;30252:39:0;30300:6:::1;::::0;30293:39:::1;::::0;;-1:-1:-1;;;30293:39:0;;30326:4:::1;30293:39;::::0;::::1;::::0;;;-1:-1:-1;;;;;30300:6:0;;::::1;::::0;30293:24:::1;::::0;:39;;;;;30252::::1;::::0;30293;;;;;;;;30300:6;30293:39;::::1;;::::0;::::1;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;::::0;::::1;;-1:-1:-1::0;30293:39:0;30334:8:::1;::::0;-1:-1:-1;;;;;30334:8:0;;::::1;::::0;-1:-1:-1;;;30344:8:0;::::1;;30244:7;:109::i;:::-;21695:1:::0;21684:8;:12;30203:158::o;21951:282::-;20932:34;;;;;;;;;;;;;;;;;22079:43;;-1:-1:-1;;;;;22079:43:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22079:43:0;-1:-1:-1;;;22079:43:0;;;22068:55;;;;22033:12;;22047:17;;22068:10;;;22079:43;22068:55;;;22079:43;22068:55;;22079:43;22068:55;;;;;;;;;;-1:-1:-1;;22068:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22032:91;;;;22142:7;:57;;;;-1:-1:-1;22154:11:0;;:16;;:44;;;22185:4;22174:24;;;;;;;;;;;;;;;-1:-1:-1;22174:24:0;22154:44;22134:91;;;;;-1:-1:-1;;;22134:91:0;;;;;;;;;;;;-1:-1:-1;;;22134:91:0;;;;;;;;;;;;;;;21951:282;;;;;:::o;7418:471::-;7476:7;7721:6;7717:47;;-1:-1:-1;7751:1:0;7744:8;;7717:47;7788:5;;;7792:1;7788;:5;:1;7812:5;;;;;:10;7804:56;;;;-1:-1:-1;;;7804:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7880:1;7418:471;-1:-1:-1;;;7418:471:0:o;6494:136::-;6552:7;6579:43;6583:1;6586;6579:43;;;;;;;;;;;;;;;;;:3;:43::i;23050:855::-;-1:-1:-1;;;;;23162:23:0;;;;;:50;;-1:-1:-1;;;;;;23189:23:0;;;23162:50;23154:77;;;;;-1:-1:-1;;;23154:77:0;;;;;;;;;;;;-1:-1:-1;;;23154:77:0;;;;;;;;;;;;;;;23346:18;;23273:23;:15;:23;;;-1:-1:-1;;;23346:18:0;;;;23329:35;;;23402:15;;;;;;:33;;-1:-1:-1;;;;;;23421:14:0;;;;23402:33;:51;;;;-1:-1:-1;;;;;;23439:14:0;;;;23402:51;23398:336;;;23608:11;23555:64;;23560:44;23594:9;23560:27;23577:9;23560:16;:27::i;:::-;-1:-1:-1;;;;;23560:33:0;;;:44::i;:::-;23531:20;:88;;-1:-1:-1;;;;;23555:50:0;;;;:64;;;;23531:88;;;23658:64;;;23663:44;23697:9;23663:27;23680:9;23663:16;:27::i;:44::-;23634:20;:88;;-1:-1:-1;;;;;23658:50:0;;;;:64;;;;23634:88;;;23398:336;23744:8;:28;;-1:-1:-1;;23744:28:0;-1:-1:-1;;;;;23744:28:0;;;;;;;-1:-1:-1;;;;23783:28:0;-1:-1:-1;;;23783:28:0;;;;;;;;;-1:-1:-1;;;;;23822:35:0;-1:-1:-1;;;23822:35:0;;;;;;;;;23873:24;;;23878:8;;;23873:24;;23888:8;;;;;;;23873:24;;;;;;;;;;;;;;;;;23050:855;;;;;;:::o;18968:169::-;-1:-1:-1;;;;;19049:16:0;;;;;;;:9;:16;;;;;;;;:25;;;;;;;;;;;;;:33;;;19098:31;;;;;;;;;;;;;;;;;18968:169;;;:::o;19145:220::-;-1:-1:-1;;;;;19239:15:0;;;;;;:9;:15;;;;;;:26;;19259:5;19239:19;:26::i;:::-;-1:-1:-1;;;;;19221:15:0;;;;;;;:9;:15;;;;;;:44;;;;19292:13;;;;;;;:24;;19310:5;19292:17;:24::i;:::-;-1:-1:-1;;;;;19276:13:0;;;;;;;:9;:13;;;;;;;;;:40;;;;19332:25;;;;;;;19276:13;;19332:25;;;;;;;;;;;;;19145:220;;;:::o;23995:832::-;24068:10;24091:13;24120:7;;;;;;;;;-1:-1:-1;;;;;24120:7:0;-1:-1:-1;;;;;24107:27:0;;:29;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;24107:29:0;24199:5;;-1:-1:-1;;;;;24155:19:0;;;;;;-1:-1:-1;24107:29:0;;-1:-1:-1;24199:5:0;24230:590;;24260:11;;24256:494;;24292:10;24305:41;24315:30;-1:-1:-1;;;;;24315:15:0;;;;:30;;:19;:30::i;24305:41::-;24292:54;;24365:14;24382:17;24392:6;24382:9;:17::i;:::-;24365:34;;24430:9;24422:5;:17;24418:317;;;24464:14;24481:37;24497:20;:5;24507:9;24497;:20::i;:::-;24481:11;;;:15;:37::i;:::-;24464:54;-1:-1:-1;24541:16:0;24560:27;24577:9;24560:12;:5;24570:1;24560:9;:12::i;:::-;:16;;:27::i;:::-;24541:46;;24610:14;24639:11;24627:9;:23;;;;;;;-1:-1:-1;24677:13:0;;24673:42;;24692:23;24698:5;24705:9;24692:5;:23::i;:::-;24418:317;;;;24256:494;;;24230:590;;;24771:11;;24767:53;;24807:1;24799:5;:9;24767:53;23995:832;;;;;;:::o;4852:303::-;4897:6;4924:1;4920;:5;4916:232;;;-1:-1:-1;4946:1:0;4979;4975;4971:5;;:9;4995:92;5006:1;5002;:5;4995:92;;;5032:1;5028:5;;5070:1;5065;5061;5057;:5;;;;;;:9;5056:15;;;;;;5052:19;;4995:92;;;4916:232;;;;5108:6;;5104:44;;-1:-1:-1;5135:1:0;5104:44;4852:303;;;:::o;18542:201::-;18615:11;;:22;;18631:5;18615:15;:22::i;:::-;18601:11;:36;;;-1:-1:-1;;;;;18664:13:0;;;;:9;:13;;;;;;:24;;18682:5;18664:17;:24::i;:::-;-1:-1:-1;;;;;18648:13:0;;;;;;:9;:13;;;;;;;;:40;;;;18704:31;;;;;;;18648:13;;;;18704:31;;;;;;;;;;18542:201;;:::o;4638:96::-;4690:6;4717:1;4713;:5;:13;;4725:1;4713:13;;;-1:-1:-1;4721:1:0;;4709:17;-1:-1:-1;4638:96:0:o;18751:209::-;-1:-1:-1;;;;;18830:15:0;;;;;;:9;:15;;;;;;:26;;18850:5;18830:19;:26::i;:::-;-1:-1:-1;;;;;18812:15:0;;;;;;:9;:15;;;;;:44;;;;18881:11;:22;;18897:5;18881:15;:22::i;:::-;18867:11;:36;;;18919:33;;;;;;;;-1:-1:-1;;;;;18919:33:0;;;;;;;;;;;;;18751:209;;:::o;6933:226::-;7053:7;7089:12;7081:6;;;;7073:29;;;;-1:-1:-1;;;7073:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;7125:5:0;;;6933:226::o;11430:120::-;-1:-1:-1;;;;;11506:10:0;-1:-1:-1;;;11506:17:0;;11430:120::o;11621:108::-;11681:9;-1:-1:-1;;;;;11711:10:0;;-1:-1:-1;;;;;11707:14:0;;11711:10;11707:14;;;;;;11621:108;-1:-1:-1;;;11621:108:0:o;6030:181::-;6088:7;6120:5;;;6144:6;;;;6136:46;;;;;-1:-1:-1;;;6136:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;

Swarm Source

ipfs://d62a16710db5d5c1c2b9e5d18733ac66aae6371399c94c4aafaa2d10e4a60cac
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.