S Price: $0.533696 (-0.32%)
    /

    Token

    Algebra Positions NFT-V2 (ALGB-POS)

    Overview

    Max Total Supply

    1,215 ALGB-POS

    Holders

    577

    Market

    Onchain Market Cap

    $0.00

    Circulating Supply Market Cap

    -
    Balance
    1 ALGB-POS
    0xc08eb4df0f9EACcf0F13cDEE0B9E3d6F0A9Eb044
    Loading...
    Loading
    Loading...
    Loading
    Loading...
    Loading

    Click here to update the token information / general information
    This contract may be a proxy contract. Click on More Options and select Is this a proxy? to confirm and enable the "Read as Proxy" & "Write as Proxy" tabs.

    Contract Source Code Verified (Exact Match)

    Contract Name:
    NonfungiblePositionManager

    Compiler Version
    v0.8.20+commit.a1b79de6

    Optimization Enabled:
    Yes with 0 runs

    Other Settings:
    paris EvmVersion
    File 1 of 60 : NonfungiblePositionManager.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: BUSL-1.1
    pragma solidity =0.8.20;
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraFactory.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/Constants.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/FullMath.sol';
    import './interfaces/INonfungiblePositionManager.sol';
    import './interfaces/INonfungibleTokenPositionDescriptor.sol';
    import './interfaces/IPositionFollower.sol';
    import './libraries/PoolInteraction.sol';
    import './libraries/OracleLibrary.sol';
    import './libraries/PoolAddress.sol';
    import './base/LiquidityManagement.sol';
    import './base/PeripheryImmutableState.sol';
    import './base/Multicall.sol';
    import './base/ERC721Permit.sol';
    import './base/PeripheryValidation.sol';
    import './base/SelfPermit.sol';
    import './base/PoolInitializer.sol';
    /// @title Algebra Integral 1.0 NFT positions
    /// @notice Wraps Algebra positions in the ERC721 non-fungible token interface
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 2 of 60 : IAlgebraMintCallback.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Callback for IAlgebraPoolActions#mint
    /// @notice Any contract that calls IAlgebraPoolActions#mint must implement this interface
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraMintCallback {
    /// @notice Called to `msg.sender` after minting liquidity to a position from IAlgebraPool#mint.
    /// @dev In the implementation you must pay the pool tokens owed for the minted liquidity.
    /// The caller of this method _must_ be checked to be a AlgebraPool deployed by the canonical AlgebraFactory.
    /// @param amount0Owed The amount of token0 due to the pool for the minted liquidity
    /// @param amount1Owed The amount of token1 due to the pool for the minted liquidity
    /// @param data Any data passed through by the caller via the IAlgebraPoolActions#mint call
    function algebraMintCallback(uint256 amount0Owed, uint256 amount1Owed, bytes calldata data) external;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 3 of 60 : IAlgebraFactory.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    pragma abicoder v2;
    import './plugin/IAlgebraPluginFactory.sol';
    import './vault/IAlgebraVaultFactory.sol';
    /// @title The interface for the Algebra Factory
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraFactory {
    /// @notice Emitted when a process of ownership renounce is started
    /// @param timestamp The timestamp of event
    /// @param finishTimestamp The timestamp when ownership renounce will be possible to finish
    event RenounceOwnershipStart(uint256 timestamp, uint256 finishTimestamp);
    /// @notice Emitted when a process of ownership renounce cancelled
    /// @param timestamp The timestamp of event
    event RenounceOwnershipStop(uint256 timestamp);
    /// @notice Emitted when a process of ownership renounce finished
    /// @param timestamp The timestamp of ownership renouncement
    event RenounceOwnershipFinish(uint256 timestamp);
    /// @notice Emitted when a pool is created
    /// @param token0 The first token of the pool by address sort order
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 4 of 60 : IAlgebraPool.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.8.4;
    import './pool/IAlgebraPoolImmutables.sol';
    import './pool/IAlgebraPoolState.sol';
    import './pool/IAlgebraPoolActions.sol';
    import './pool/IAlgebraPoolPermissionedActions.sol';
    import './pool/IAlgebraPoolEvents.sol';
    import './pool/IAlgebraPoolErrors.sol';
    /// @title The interface for a Algebra Pool
    /// @dev The pool interface is broken up into many smaller pieces.
    /// This interface includes custom error definitions and cannot be used in older versions of Solidity.
    /// For older versions of Solidity use #IAlgebraPoolLegacy
    /// Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPool is
    IAlgebraPoolImmutables,
    IAlgebraPoolState,
    IAlgebraPoolActions,
    IAlgebraPoolPermissionedActions,
    IAlgebraPoolEvents,
    IAlgebraPoolErrors
    {
    // used only for combining interfaces
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 5 of 60 : IAlgebraPluginFactory.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title An interface for a contract that is capable of deploying Algebra plugins
    /// @dev Such a factory is needed if the plugin should be automatically created and connected to each new pool
    interface IAlgebraPluginFactory {
    /// @notice Deploys new plugin contract for pool
    /// @param pool The address of the pool for which the new plugin will be created
    /// @param token0 First token of the pool
    /// @param token1 Second token of the pool
    /// @return New plugin address
    function createPlugin(address pool, address token0, address token1) external returns (address);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 6 of 60 : IAlgebraPoolActions.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Permissionless pool actions
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPoolActions {
    /// @notice Sets the initial price for the pool
    /// @dev Price is represented as a sqrt(amountToken1/amountToken0) Q64.96 value
    /// @dev Initialization should be done in one transaction with pool creation to avoid front-running
    /// @param initialPrice The initial sqrt price of the pool as a Q64.96
    function initialize(uint160 initialPrice) external;
    /// @notice Adds liquidity for the given recipient/bottomTick/topTick position
    /// @dev The caller of this method receives a callback in the form of IAlgebraMintCallback#algebraMintCallback
    /// in which they must pay any token0 or token1 owed for the liquidity. The amount of token0/token1 due depends
    /// on bottomTick, topTick, the amount of liquidity, and the current price.
    /// @param leftoversRecipient The address which will receive potential surplus of paid tokens
    /// @param recipient The address for which the liquidity will be created
    /// @param bottomTick The lower tick of the position in which to add liquidity
    /// @param topTick The upper tick of the position in which to add liquidity
    /// @param liquidityDesired The desired amount of liquidity to mint
    /// @param data Any data that should be passed through to the callback
    /// @return amount0 The amount of token0 that was paid to mint the given amount of liquidity. Matches the value in the callback
    /// @return amount1 The amount of token1 that was paid to mint the given amount of liquidity. Matches the value in the callback
    /// @return liquidityActual The actual minted amount of liquidity
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 7 of 60 : IAlgebraPoolErrors.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.8.4;
    /// @title Errors emitted by a pool
    /// @notice Contains custom errors emitted by the pool
    /// @dev Custom errors are separated from the common pool interface for compatibility with older versions of Solidity
    interface IAlgebraPoolErrors {
    // #### pool errors ####
    /// @notice Emitted by the reentrancy guard
    error locked();
    /// @notice Emitted if arithmetic error occurred
    error arithmeticError();
    /// @notice Emitted if an attempt is made to initialize the pool twice
    error alreadyInitialized();
    /// @notice Emitted if an attempt is made to mint or swap in uninitialized pool
    error notInitialized();
    /// @notice Emitted if 0 is passed as amountRequired to swap function
    error zeroAmountRequired();
    /// @notice Emitted if invalid amount is passed as amountRequired to swap function
    error invalidAmountRequired();
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 8 of 60 : IAlgebraPoolEvents.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Events emitted by a pool
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPoolEvents {
    /// @notice Emitted exactly once by a pool when #initialize is first called on the pool
    /// @dev Mint/Burn/Swaps cannot be emitted by the pool before Initialize
    /// @param price The initial sqrt price of the pool, as a Q64.96
    /// @param tick The initial tick of the pool, i.e. log base 1.0001 of the starting price of the pool
    event Initialize(uint160 price, int24 tick);
    /// @notice Emitted when liquidity is minted for a given position
    /// @param sender The address that minted the liquidity
    /// @param owner The owner of the position and recipient of any minted liquidity
    /// @param bottomTick The lower tick of the position
    /// @param topTick The upper tick of the position
    /// @param liquidityAmount The amount of liquidity minted to the position range
    /// @param amount0 How much token0 was required for the minted liquidity
    /// @param amount1 How much token1 was required for the minted liquidity
    event Mint(
    address sender,
    address indexed owner,
    int24 indexed bottomTick,
    int24 indexed topTick,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 9 of 60 : IAlgebraPoolImmutables.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Pool state that never changes
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPoolImmutables {
    /// @notice The Algebra factory contract, which must adhere to the IAlgebraFactory interface
    /// @return The contract address
    function factory() external view returns (address);
    /// @notice The first of the two tokens of the pool, sorted by address
    /// @return The token contract address
    function token0() external view returns (address);
    /// @notice The second of the two tokens of the pool, sorted by address
    /// @return The token contract address
    function token1() external view returns (address);
    /// @notice The maximum amount of position liquidity that can use any tick in the range
    /// @dev This parameter is enforced per tick to prevent liquidity from overflowing a uint128 at any point, and
    /// also prevents out-of-range liquidity from being used to prevent adding in-range liquidity to a pool
    /// @return The max amount of liquidity per tick
    function maxLiquidityPerTick() external view returns (uint128);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 10 of 60 : IAlgebraPoolPermissionedActions.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Permissioned pool actions
    /// @notice Contains pool methods that may only be called by permissioned addresses
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPoolPermissionedActions {
    /// @notice Set the community's % share of the fees. Only factory owner or POOLS_ADMINISTRATOR_ROLE role
    /// @param newCommunityFee The new community fee percent in thousandths (1e-3)
    function setCommunityFee(uint16 newCommunityFee) external;
    /// @notice Set the new tick spacing values. Only factory owner or POOLS_ADMINISTRATOR_ROLE role
    /// @param newTickSpacing The new tick spacing value
    function setTickSpacing(int24 newTickSpacing) external;
    /// @notice Set the new plugin address. Only factory owner or POOLS_ADMINISTRATOR_ROLE role
    /// @param newPluginAddress The new plugin address
    function setPlugin(address newPluginAddress) external;
    /// @notice Set new plugin config. Only factory owner or POOLS_ADMINISTRATOR_ROLE role
    /// @param newConfig In the new configuration of the plugin,
    /// each bit of which is responsible for a particular hook.
    function setPluginConfig(uint8 newConfig) external;
    /// @notice Set new community fee vault address. Only factory owner or POOLS_ADMINISTRATOR_ROLE role
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 11 of 60 : IAlgebraPoolState.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Pool state that can change
    /// @dev Important security note: when using this data by external contracts, it is necessary to take into account the possibility
    /// of manipulation (including read-only reentrancy).
    /// This interface is based on the UniswapV3 interface, credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/tree/main/contracts/interfaces
    interface IAlgebraPoolState {
    /// @notice Safely get most important state values of Algebra Integral AMM
    /// @dev Several values exposed as a single method to save gas when accessed externally.
    /// **Important security note: this method checks reentrancy lock and should be preferred in most cases**.
    /// @return sqrtPrice The current price of the pool as a sqrt(dToken1/dToken0) Q64.96 value
    /// @return tick The current global tick of the pool. May not always be equal to SqrtTickMath.getTickAtSqrtRatio(price) if the price is on a tick
          boundary
    /// @return lastFee The current (last known) pool fee value in hundredths of a bip, i.e. 1e-6 (so '100' is '0.01%'). May be obsolete if using
          dynamic fee plugin
    /// @return pluginConfig The current plugin config as bitmap. Each bit is responsible for enabling/disabling the hooks, the last bit turns on/off
          dynamic fees logic
    /// @return activeLiquidity The currently in-range liquidity available to the pool
    /// @return nextTick The next initialized tick after current global tick
    /// @return previousTick The previous initialized tick before (or at) current global tick
    function safelyGetStateOfAMM()
    external
    view
    returns (uint160 sqrtPrice, int24 tick, uint16 lastFee, uint8 pluginConfig, uint128 activeLiquidity, int24 nextTick, int24 previousTick);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 12 of 60 : IAlgebraVaultFactory.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title The interface for the Algebra Vault Factory
    /// @notice This contract can be used for automatic vaults creation
    /// @dev Version: Algebra Integral
    interface IAlgebraVaultFactory {
    /// @notice returns address of the community fee vault for the pool
    /// @param pool the address of Algebra Integral pool
    /// @return communityFeeVault the address of community fee vault
    function getVaultForPool(address pool) external view returns (address communityFeeVault);
    /// @notice creates the community fee vault for the pool if needed
    /// @param pool the address of Algebra Integral pool
    /// @return communityFeeVault the address of community fee vault
    function createVaultForPool(address pool) external returns (address communityFeeVault);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 13 of 60 : Constants.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0 <0.9.0;
    /// @title Contains common constants for Algebra contracts
    /// @dev Constants moved to the library, not the base contract, to further emphasize their constant nature
    library Constants {
    uint8 internal constant RESOLUTION = 96;
    uint256 internal constant Q96 = 1 << 96;
    uint256 internal constant Q128 = 1 << 128;
    uint24 internal constant FEE_DENOMINATOR = 1e6;
    uint16 internal constant FLASH_FEE = 0.01e4; // fee for flash loan in hundredths of a bip (0.01%)
    uint16 internal constant INIT_DEFAULT_FEE = 0.05e4; // init default fee value in hundredths of a bip (0.05%)
    uint16 internal constant MAX_DEFAULT_FEE = 5e4; // max default fee value in hundredths of a bip (5%)
    int24 internal constant INIT_DEFAULT_TICK_SPACING = 60;
    int24 internal constant MAX_TICK_SPACING = 500;
    int24 internal constant MIN_TICK_SPACING = 1;
    // the frequency with which the accumulated community fees are sent to the vault
    uint32 internal constant COMMUNITY_FEE_TRANSFER_FREQUENCY = 8 hours;
    // max(uint128) / (MAX_TICK - MIN_TICK)
    uint128 internal constant MAX_LIQUIDITY_PER_TICK = 191757638537527648490752896198553;
    uint16 internal constant MAX_COMMUNITY_FEE = 1e3; // 100%
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 14 of 60 : FullMath.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.0;
    /// @title Contains 512-bit math functions
    /// @notice Facilitates multiplication and division that can have overflow of an intermediate value without any loss of precision
    /// @dev Handles "phantom overflow" i.e., allows multiplication and division where an intermediate value overflows 256 bits
    library FullMath {
    /// @notice Calculates floor(a×b÷denominator) with full precision. Throws if result overflows a uint256 or denominator == 0
    /// @param a The multiplicand
    /// @param b The multiplier
    /// @param denominator The divisor
    /// @return result The 256-bit result
    /// @dev Credit to Remco Bloemen under MIT license https://xn--2-umb.com/21/muldiv
    function mulDiv(uint256 a, uint256 b, uint256 denominator) internal pure returns (uint256 result) {
    unchecked {
    // 512-bit multiply [prod1 prod0] = a * b
    // Compute the product mod 2**256 and mod 2**256 - 1
    // then use the Chinese Remainder Theorem to reconstruct
    // the 512 bit result. The result is stored in two 256
    // variables such that product = prod1 * 2**256 + prod0
    uint256 prod0 = a * b; // Least significant 256 bits of the product
    uint256 prod1; // Most significant 256 bits of the product
    assembly {
    let mm := mulmod(a, b, not(0))
    prod1 := sub(sub(mm, prod0), lt(mm, prod0))
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 15 of 60 : TickMath.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.8.4 <0.9.0;
    import '../interfaces/pool/IAlgebraPoolErrors.sol';
    /// @title Math library for computing sqrt prices from ticks and vice versa
    /// @notice Computes sqrt price for ticks of size 1.0001, i.e. sqrt(1.0001^tick) as fixed point Q64.96 numbers. Supports
    /// prices between 2**-128 and 2**128
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/blob/main/contracts/libraries
    library TickMath {
    /// @dev The minimum tick that may be passed to #getSqrtRatioAtTick computed from log base 1.0001 of 2**-128
    int24 internal constant MIN_TICK = -887272;
    /// @dev The maximum tick that may be passed to #getSqrtRatioAtTick computed from log base 1.0001 of 2**128
    int24 internal constant MAX_TICK = -MIN_TICK;
    /// @dev The minimum value that can be returned from #getSqrtRatioAtTick. Equivalent to getSqrtRatioAtTick(MIN_TICK)
    uint160 internal constant MIN_SQRT_RATIO = 4295128739;
    /// @dev The maximum value that can be returned from #getSqrtRatioAtTick. Equivalent to getSqrtRatioAtTick(MAX_TICK)
    uint160 internal constant MAX_SQRT_RATIO = 1461446703485210103287273052203988822378723970342;
    /// @notice Calculates sqrt(1.0001^tick) * 2^96
    /// @dev Throws if |tick| > max tick
    /// @param tick The input tick for the above formula
    /// @return price A Fixed point Q64.96 number representing the sqrt of the ratio of the two assets (token1/token0)
    /// at the given tick
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 16 of 60 : draft-IERC20Permit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/extensions/draft-IERC20Permit.sol)
    pragma solidity ^0.8.0;
    // EIP-2612 is Final as of 2022-11-01. This file is deprecated.
    import "./IERC20Permit.sol";
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 17 of 60 : IERC20Permit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/extensions/IERC20Permit.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Interface of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in
    * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612].
    *
    * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by
    * presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't
    * need to send a transaction, and thus is not required to hold Ether at all.
    */
    interface IERC20Permit {
    /**
    * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens,
    * given ``owner``'s signed approval.
    *
    * IMPORTANT: The same issues {IERC20-approve} has related to transaction
    * ordering also apply here.
    *
    * Emits an {Approval} event.
    *
    * Requirements:
    *
    * - `spender` cannot be the zero address.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 18 of 60 : IERC20.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Interface of the ERC20 standard as defined in the EIP.
    */
    interface IERC20 {
    /**
    * @dev Emitted when `value` tokens are moved from one account (`from`) to
    * another (`to`).
    *
    * Note that `value` may be zero.
    */
    event Transfer(address indexed from, address indexed to, uint256 value);
    /**
    * @dev Emitted when the allowance of a `spender` for an `owner` is set by
    * a call to {approve}. `value` is the new allowance.
    */
    event Approval(address indexed owner, address indexed spender, uint256 value);
    /**
    * @dev Returns the amount of tokens in existence.
    */
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 19 of 60 : ERC721.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC721/ERC721.sol)
    pragma solidity ^0.8.0;
    import "./IERC721.sol";
    import "./IERC721Receiver.sol";
    import "./extensions/IERC721Metadata.sol";
    import "../../utils/Address.sol";
    import "../../utils/Context.sol";
    import "../../utils/Strings.sol";
    import "../../utils/introspection/ERC165.sol";
    /**
    * @dev Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including
    * the Metadata extension, but not including the Enumerable extension, which is available separately as
    * {ERC721Enumerable}.
    */
    contract ERC721 is Context, ERC165, IERC721, IERC721Metadata {
    using Address for address;
    using Strings for uint256;
    // Token name
    string private _name;
    // Token symbol
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 20 of 60 : ERC721Enumerable.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.8.0) (token/ERC721/extensions/ERC721Enumerable.sol)
    pragma solidity ^0.8.0;
    import "../ERC721.sol";
    import "./IERC721Enumerable.sol";
    /**
    * @dev This implements an optional extension of {ERC721} defined in the EIP that adds
    * enumerability of all the token ids in the contract as well as all token ids owned by each
    * account.
    */
    abstract contract ERC721Enumerable is ERC721, IERC721Enumerable {
    // Mapping from owner to list of owned token IDs
    mapping(address => mapping(uint256 => uint256)) private _ownedTokens;
    // Mapping from token ID to index of the owner tokens list
    mapping(uint256 => uint256) private _ownedTokensIndex;
    // Array with all token ids, used for enumeration
    uint256[] private _allTokens;
    // Mapping from token id to position in the allTokens array
    mapping(uint256 => uint256) private _allTokensIndex;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 21 of 60 : IERC721Enumerable.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.5.0) (token/ERC721/extensions/IERC721Enumerable.sol)
    pragma solidity ^0.8.0;
    import "../IERC721.sol";
    /**
    * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
    * @dev See https://eips.ethereum.org/EIPS/eip-721
    */
    interface IERC721Enumerable is IERC721 {
    /**
    * @dev Returns the total amount of tokens stored by the contract.
    */
    function totalSupply() external view returns (uint256);
    /**
    * @dev Returns a token ID owned by `owner` at a given `index` of its token list.
    * Use along with {balanceOf} to enumerate all of ``owner``'s tokens.
    */
    function tokenOfOwnerByIndex(address owner, uint256 index) external view returns (uint256);
    /**
    * @dev Returns a token ID at a given `index` of all the tokens stored by the contract.
    * Use along with {totalSupply} to enumerate all tokens.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 22 of 60 : IERC721Metadata.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts v4.4.1 (token/ERC721/extensions/IERC721Metadata.sol)
    pragma solidity ^0.8.0;
    import "../IERC721.sol";
    /**
    * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
    * @dev See https://eips.ethereum.org/EIPS/eip-721
    */
    interface IERC721Metadata is IERC721 {
    /**
    * @dev Returns the token collection name.
    */
    function name() external view returns (string memory);
    /**
    * @dev Returns the token collection symbol.
    */
    function symbol() external view returns (string memory);
    /**
    * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
    */
    function tokenURI(uint256 tokenId) external view returns (string memory);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 23 of 60 : IERC721.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC721/IERC721.sol)
    pragma solidity ^0.8.0;
    import "../../utils/introspection/IERC165.sol";
    /**
    * @dev Required interface of an ERC721 compliant contract.
    */
    interface IERC721 is IERC165 {
    /**
    * @dev Emitted when `tokenId` token is transferred from `from` to `to`.
    */
    event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);
    /**
    * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
    */
    event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);
    /**
    * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
    */
    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 24 of 60 : IERC721Receiver.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.6.0) (token/ERC721/IERC721Receiver.sol)
    pragma solidity ^0.8.0;
    /**
    * @title ERC721 token receiver interface
    * @dev Interface for any contract that wants to support safeTransfers
    * from ERC721 asset contracts.
    */
    interface IERC721Receiver {
    /**
    * @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
    * by `operator` from `from`, this function is called.
    *
    * It must return its Solidity selector to confirm the token transfer.
    * If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted.
    *
    * The selector can be obtained in Solidity with `IERC721Receiver.onERC721Received.selector`.
    */
    function onERC721Received(
    address operator,
    address from,
    uint256 tokenId,
    bytes calldata data
    ) external returns (bytes4);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 25 of 60 : Address.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (utils/Address.sol)
    pragma solidity ^0.8.1;
    /**
    * @dev Collection of functions related to the address type
    */
    library Address {
    /**
    * @dev Returns true if `account` is a contract.
    *
    * [IMPORTANT]
    * ====
    * It is unsafe to assume that an address for which this function returns
    * false is an externally-owned account (EOA) and not a contract.
    *
    * Among others, `isContract` will return false for the following
    * types of addresses:
    *
    * - an externally-owned account
    * - a contract in construction
    * - an address where a contract will be created
    * - an address where a contract lived, but was destroyed
    *
    * Furthermore, `isContract` will also return true if the target contract within
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 26 of 60 : Context.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Provides information about the current execution context, including the
    * sender of the transaction and its data. While these are generally available
    * via msg.sender and msg.data, they should not be accessed in such a direct
    * manner, since when dealing with meta-transactions the account sending and
    * paying for execution may not be the actual sender (as far as an application
    * is concerned).
    *
    * This contract is only required for intermediate, library-like contracts.
    */
    abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
    return msg.sender;
    }
    function _msgData() internal view virtual returns (bytes calldata) {
    return msg.data;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 27 of 60 : ERC165.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)
    pragma solidity ^0.8.0;
    import "./IERC165.sol";
    /**
    * @dev Implementation of the {IERC165} interface.
    *
    * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check
    * for the additional interface id that will be supported. For example:
    *
    * ```solidity
    * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
    * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);
    * }
    * ```
    *
    * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.
    */
    abstract contract ERC165 is IERC165 {
    /**
    * @dev See {IERC165-supportsInterface}.
    */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 28 of 60 : IERC165.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Interface of the ERC165 standard, as defined in the
    * https://eips.ethereum.org/EIPS/eip-165[EIP].
    *
    * Implementers can declare support of contract interfaces, which can then be
    * queried by others ({ERC165Checker}).
    *
    * For an implementation, see {ERC165}.
    */
    interface IERC165 {
    /**
    * @dev Returns true if this contract implements the interface defined by
    * `interfaceId`. See the corresponding
    * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
    * to learn more about how these ids are created.
    *
    * This function call must use less than 30 000 gas.
    */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 29 of 60 : Math.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (utils/math/Math.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Standard math utilities missing in the Solidity language.
    */
    library Math {
    enum Rounding {
    Down, // Toward negative infinity
    Up, // Toward infinity
    Zero // Toward zero
    }
    /**
    * @dev Returns the largest of two numbers.
    */
    function max(uint256 a, uint256 b) internal pure returns (uint256) {
    return a > b ? a : b;
    }
    /**
    * @dev Returns the smallest of two numbers.
    */
    function min(uint256 a, uint256 b) internal pure returns (uint256) {
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 30 of 60 : SignedMath.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.8.0) (utils/math/SignedMath.sol)
    pragma solidity ^0.8.0;
    /**
    * @dev Standard signed math utilities missing in the Solidity language.
    */
    library SignedMath {
    /**
    * @dev Returns the largest of two signed numbers.
    */
    function max(int256 a, int256 b) internal pure returns (int256) {
    return a > b ? a : b;
    }
    /**
    * @dev Returns the smallest of two signed numbers.
    */
    function min(int256 a, int256 b) internal pure returns (int256) {
    return a < b ? a : b;
    }
    /**
    * @dev Returns the average of two signed numbers without overflow.
    * The result is rounded towards zero.
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 31 of 60 : Strings.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: MIT
    // OpenZeppelin Contracts (last updated v4.9.0) (utils/Strings.sol)
    pragma solidity ^0.8.0;
    import "./math/Math.sol";
    import "./math/SignedMath.sol";
    /**
    * @dev String operations.
    */
    library Strings {
    bytes16 private constant _SYMBOLS = "0123456789abcdef";
    uint8 private constant _ADDRESS_LENGTH = 20;
    /**
    * @dev Converts a `uint256` to its ASCII `string` decimal representation.
    */
    function toString(uint256 value) internal pure returns (string memory) {
    unchecked {
    uint256 length = Math.log10(value) + 1;
    string memory buffer = new string(length);
    uint256 ptr;
    /// @solidity memory-safe-assembly
    assembly {
    ptr := add(buffer, add(32, length))
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 32 of 60 : BlockTimestamp.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    /// @title Function for getting block timestamp
    /// @dev Base contract that is overridden for tests
    abstract contract BlockTimestamp {
    /// @dev Method that exists purely to be overridden for tests
    /// @return The current block timestamp
    function _blockTimestamp() internal view virtual returns (uint256) {
    return block.timestamp;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 33 of 60 : ERC721Permit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol';
    import '@openzeppelin/contracts/utils/Address.sol';
    import '../interfaces/external/IERC1271.sol';
    import '../interfaces/IERC721Permit.sol';
    import './BlockTimestamp.sol';
    /// @title ERC721 with permit
    /// @notice Nonfungible tokens that support an approve via signature, i.e. permit
    abstract contract ERC721Permit is BlockTimestamp, ERC721Enumerable, IERC721Permit {
    bytes32 private constant _TYPE_HASH =
    keccak256('EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)');
    /// @dev Gets the current nonce for a token ID and then increments it, returning the original value
    function _getAndIncrementNonce(uint256 tokenId) internal virtual returns (uint256);
    /// @dev The hash of the name used in the permit signature verification
    bytes32 private immutable nameHash;
    /// @dev The hash of the version string used in the permit signature verification
    bytes32 private immutable versionHash;
    bytes32 private immutable _cachedDomainSeparator;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 34 of 60 : LiquidityManagement.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraFactory.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/callback/IAlgebraMintCallback.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/TickMath.sol';
    import '../libraries/PoolAddress.sol';
    import '../libraries/CallbackValidation.sol';
    import '../libraries/LiquidityAmounts.sol';
    import '../libraries/PoolInteraction.sol';
    import './PeripheryPayments.sol';
    import './PeripheryImmutableState.sol';
    /// @title Liquidity management functions
    /// @notice Internal functions for safely managing liquidity in Algebra
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract LiquidityManagement is IAlgebraMintCallback, PeripheryImmutableState, PeripheryPayments {
    using PoolInteraction for IAlgebraPool;
    struct MintCallbackData {
    PoolAddress.PoolKey poolKey;
    address payer;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 35 of 60 : Multicall.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '../interfaces/IMulticall.sol';
    /// @title Multicall
    /// @notice Enables calling multiple methods in a single call to the contract
    abstract contract Multicall is IMulticall {
    /// @inheritdoc IMulticall
    function multicall(bytes[] calldata data) external payable override returns (bytes[] memory results) {
    results = new bytes[](data.length);
    unchecked {
    for (uint256 i = 0; i < data.length; i++) {
    (bool success, bytes memory result) = address(this).delegatecall(data[i]);
    if (!success) {
    // Look for revert reason and bubble it up if present
    require(result.length > 0);
    // The easiest way to bubble the revert reason is using memory via assembly
    assembly ('memory-safe') {
    revert(add(32, result), mload(result))
    }
    }
    results[i] = result;
    }
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 36 of 60 : PeripheryImmutableState.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '../interfaces/IPeripheryImmutableState.sol';
    /// @title Immutable state
    /// @notice Immutable state used by periphery contracts
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract PeripheryImmutableState is IPeripheryImmutableState {
    /// @inheritdoc IPeripheryImmutableState
    address public immutable override factory;
    /// @inheritdoc IPeripheryImmutableState
    address public immutable override poolDeployer;
    /// @inheritdoc IPeripheryImmutableState
    address public immutable override WNativeToken;
    constructor(address _factory, address _WNativeToken, address _poolDeployer) {
    factory = _factory;
    poolDeployer = _poolDeployer;
    WNativeToken = _WNativeToken;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 37 of 60 : PeripheryPayments.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    import '../interfaces/IPeripheryPayments.sol';
    import '../interfaces/external/IWNativeToken.sol';
    import '../libraries/TransferHelper.sol';
    import './PeripheryImmutableState.sol';
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract PeripheryPayments is IPeripheryPayments, PeripheryImmutableState {
    receive() external payable {
    require(msg.sender == WNativeToken, 'Not WNativeToken');
    }
    function _balanceOfToken(address token) private view returns (uint256) {
    return (IERC20(token).balanceOf(address(this)));
    }
    /// @inheritdoc IPeripheryPayments
    function unwrapWNativeToken(uint256 amountMinimum, address recipient) external payable override {
    uint256 balanceWNativeToken = _balanceOfToken(WNativeToken);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 38 of 60 : PeripheryValidation.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import './BlockTimestamp.sol';
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract PeripheryValidation is BlockTimestamp {
    modifier checkDeadline(uint256 deadline) {
    _checkDeadline(deadline);
    _;
    }
    function _checkDeadline(uint256 deadline) private view {
    require(_blockTimestamp() <= deadline, 'Transaction too old');
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 39 of 60 : PoolInitializer.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraFactory.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import './PeripheryImmutableState.sol';
    import '../interfaces/IPoolInitializer.sol';
    import '../libraries/PoolInteraction.sol';
    /// @title Creates and initializes Algebra Pools
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract PoolInitializer is IPoolInitializer, PeripheryImmutableState {
    using PoolInteraction for IAlgebraPool;
    /// @inheritdoc IPoolInitializer
    function createAndInitializePoolIfNecessary(
    address token0,
    address token1,
    uint160 sqrtPriceX96
    ) external payable override returns (address pool) {
    require(token0 < token1, 'Invalid order of tokens');
    pool = IAlgebraFactory(factory).poolByPair(token0, token1);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 40 of 60 : SelfPermit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    import '@openzeppelin/contracts/token/ERC20/extensions/draft-IERC20Permit.sol';
    import '../interfaces/ISelfPermit.sol';
    import '../interfaces/external/IERC20PermitAllowed.sol';
    /// @title Self Permit
    /// @notice Functionality to call permit on any EIP-2612-compliant token for use in the route
    /// @dev These functions are expected to be embedded in multicalls to allow EOAs to approve a contract and call a function
    /// that requires an approval in a single transaction.
    abstract contract SelfPermit is ISelfPermit {
    /// @inheritdoc ISelfPermit
    function selfPermit(
    address token,
    uint256 value,
    uint256 deadline,
    uint8 v,
    bytes32 r,
    bytes32 s
    ) public payable override {
    IERC20Permit(token).permit(msg.sender, address(this), value, deadline, v, r, s);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 41 of 60 : IERC1271.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Interface for verifying contract-based account signatures
    /// @notice Interface that verifies provided signature for the data
    /// @dev Interface defined by EIP-1271
    interface IERC1271 {
    /// @notice Returns whether the provided signature is valid for the provided data
    /// @dev MUST return the bytes4 magic value 0x1626ba7e when function passes.
    /// MUST NOT modify state (using STATICCALL for solc < 0.5, view modifier for solc > 0.5).
    /// MUST allow external calls.
    /// @param hash Hash of the data to be signed
    /// @param signature Signature byte array associated with _data
    /// @return magicValue The bytes4 magic value 0x1626ba7e
    function isValidSignature(bytes32 hash, bytes memory signature) external view returns (bytes4 magicValue);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 42 of 60 : IERC20PermitAllowed.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Interface for permit
    /// @notice Interface used by DAI/CHAI for permit
    interface IERC20PermitAllowed {
    /// @notice Approve the spender to spend some tokens via the holder signature
    /// @dev This is the permit interface used by DAI and CHAI
    /// @param holder The address of the token holder, the token owner
    /// @param spender The address of the token spender
    /// @param nonce The holder's nonce, increases at each call to permit
    /// @param expiry The timestamp at which the permit is no longer valid
    /// @param allowed Boolean that sets approval amount, true for type(uint256).max and false for 0
    /// @param v Must produce valid secp256k1 signature from the holder along with `r` and `s`
    /// @param r Must produce valid secp256k1 signature from the holder along with `v` and `s`
    /// @param s Must produce valid secp256k1 signature from the holder along with `r` and `v`
    function permit(
    address holder,
    address spender,
    uint256 nonce,
    uint256 expiry,
    bool allowed,
    uint8 v,
    bytes32 r,
    bytes32 s
    ) external;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 43 of 60 : IVolatilityOracle.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title The interface for the Algebra volatility oracle
    /// @dev This contract stores timepoints and calculates statistical averages
    interface IVolatilityOracle {
    /// @notice Returns the accumulator values as of each time seconds ago from the given time in the array of `secondsAgos`
    /// @dev Reverts if `secondsAgos` > oldest timepoint
    /// @dev `volatilityCumulative` values for timestamps after the last timepoint _should not_ be compared because they may differ due to
            interpolation errors
    /// @param secondsAgos Each amount of time to look back, in seconds, at which point to return a timepoint
    /// @return tickCumulatives The cumulative tick since the pool was first initialized, as of each `secondsAgo`
    /// @return volatilityCumulatives The cumulative volatility values since the pool was first initialized, as of each `secondsAgo`
    function getTimepoints(
    uint32[] memory secondsAgos
    ) external view returns (int56[] memory tickCumulatives, uint88[] memory volatilityCumulatives);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 44 of 60 : IWNativeToken.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity ^0.8.0;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    /// @title Interface for WNativeToken
    interface IWNativeToken is IERC20 {
    /// @notice Deposit ether to get wrapped ether
    function deposit() external payable;
    /// @notice Withdraw wrapped ether to get ether
    function withdraw(uint256) external;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 45 of 60 : IERC721Permit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    import '@openzeppelin/contracts/token/ERC721/IERC721.sol';
    /// @title ERC721 with permit
    /// @notice Extension to ERC721 that includes a permit function for signature based approvals
    interface IERC721Permit is IERC721 {
    /// @notice The permit typehash used in the permit signature
    /// @return The typehash for the permit
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    /// @notice The domain separator used in the permit signature
    /// @return The domain separator used in encoding of permit signature
    function DOMAIN_SEPARATOR() external view returns (bytes32);
    /// @notice Approve of a specific token ID for spending by spender via signature
    /// @param spender The account that is being approved
    /// @param tokenId The ID of the token that is being approved for spending
    /// @param deadline The deadline timestamp by which the call must be mined for the approve to work
    /// @param v Must produce valid secp256k1 signature from the holder along with `r` and `s`
    /// @param r Must produce valid secp256k1 signature from the holder along with `v` and `s`
    /// @param s Must produce valid secp256k1 signature from the holder along with `r` and `v`
    function permit(
    address spender,
    uint256 tokenId,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 46 of 60 : IMulticall.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    pragma abicoder v2;
    /// @title Multicall interface
    /// @notice Enables calling multiple methods in a single call to the contract
    interface IMulticall {
    /// @notice Call multiple functions in the current contract and return the data from all of them if they all succeed
    /// @dev The `msg.value` should not be trusted for any method callable from multicall.
    /// @param data The encoded function data for each of the calls to make to this contract
    /// @return results The results from each of the calls passed in via data
    function multicall(bytes[] calldata data) external payable returns (bytes[] memory results);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 47 of 60 : INonfungiblePositionManager.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    pragma abicoder v2;
    import '@openzeppelin/contracts/token/ERC721/extensions/IERC721Metadata.sol';
    import '@openzeppelin/contracts/token/ERC721/extensions/IERC721Enumerable.sol';
    import './IPoolInitializer.sol';
    import './IERC721Permit.sol';
    import './IPeripheryPayments.sol';
    import './IPeripheryImmutableState.sol';
    /// @title Non-fungible token for positions
    /// @notice Wraps Algebra positions in a non-fungible token interface which allows for them to be transferred
    /// and authorized.
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface INonfungiblePositionManager is
    IPoolInitializer,
    IPeripheryPayments,
    IPeripheryImmutableState,
    IERC721Metadata,
    IERC721Enumerable,
    IERC721Permit
    {
    /// @notice Emitted when liquidity is increased for a position NFT
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 48 of 60 : INonfungibleTokenPositionDescriptor.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    import './INonfungiblePositionManager.sol';
    /// @title Describes position NFT tokens via URI
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface INonfungibleTokenPositionDescriptor {
    /// @notice Produces the URI describing a particular token ID for a position manager
    /// @dev Note this URI may be a data: URI with the JSON contents directly inlined
    /// @param positionManager The position manager for which to describe the token
    /// @param tokenId The ID of the token for which to produce a description, which may not be valid
    /// @return The URI of the ERC721-compliant metadata
    function tokenURI(INonfungiblePositionManager positionManager, uint256 tokenId)
    external
    view
    returns (string memory);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 49 of 60 : IPeripheryImmutableState.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Immutable state
    /// @notice Functions that return immutable state of the router
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface IPeripheryImmutableState {
    /// @return Returns the address of the Algebra factory
    function factory() external view returns (address);
    /// @return Returns the address of the pool Deployer
    function poolDeployer() external view returns (address);
    /// @return Returns the address of WNativeToken
    function WNativeToken() external view returns (address);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 50 of 60 : IPeripheryPayments.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    /// @title Periphery Payments
    /// @notice Functions to ease deposits and withdrawals of NativeToken
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface IPeripheryPayments {
    /// @notice Unwraps the contract's WNativeToken balance and sends it to recipient as NativeToken.
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing WNativeToken from users.
    /// @param amountMinimum The minimum amount of WNativeToken to unwrap
    /// @param recipient The address receiving NativeToken
    function unwrapWNativeToken(uint256 amountMinimum, address recipient) external payable;
    /// @notice Refunds any NativeToken balance held by this contract to the `msg.sender`
    /// @dev Useful for bundling with mint or increase liquidity that uses ether, or exact output swaps
    /// that use ether for the input amount
    function refundNativeToken() external payable;
    /// @notice Transfers the full amount of a token held by this contract to recipient
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing the token from users
    /// @param token The contract address of the token which will be transferred to `recipient`
    /// @param amountMinimum The minimum amount of token required for a transfer
    /// @param recipient The destination address of the token
    function sweepToken(
    address token,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 51 of 60 : IPoolInitializer.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    pragma abicoder v2;
    /// @title Creates and initializes Algebra Pools
    /// @notice Provides a method for creating and initializing a pool, if necessary, for bundling with other methods that
    /// require the pool to exist.
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface IPoolInitializer {
    /// @notice Creates a new pool if it does not exist, then initializes if not initialized
    /// @dev This method can be bundled with others via IMulticall for the first action (e.g. mint) performed against a pool
    /// @param token0 The contract address of token0 of the pool
    /// @param token1 The contract address of token1 of the pool
    /// @param sqrtPriceX96 The initial square root price of the pool as a Q64.96 value
    /// @return pool Returns the pool address based on the pair of tokens and fee, will return the newly created pool address if necessary
    function createAndInitializePoolIfNecessary(
    address token0,
    address token1,
    uint160 sqrtPriceX96
    ) external payable returns (address pool);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 52 of 60 : IPositionFollower.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Contract tracking liquidity position
    /// @notice Using these methods farmingCenter receives information about changes in the positions
    interface IPositionFollower {
    /// @notice Report a change of liquidity in position
    /// @param tokenId The ID of the token for which liquidity is being added
    /// @param liquidityDelta The amount of added liquidity
    function applyLiquidityDelta(uint256 tokenId, int256 liquidityDelta) external;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 53 of 60 : ISelfPermit.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.7.5;
    /// @title Self Permit
    /// @notice Functionality to call permit on any EIP-2612-compliant token for use in the route
    interface ISelfPermit {
    /// @notice Permits this contract to spend a given token from `msg.sender`
    /// @dev The `owner` is always msg.sender and the `spender` is always address(this).
    /// @param token The address of the token spent
    /// @param value The amount that can be spent of token
    /// @param deadline A timestamp, the current blocktime must be less than or equal to this timestamp
    /// @param v Must produce valid secp256k1 signature from the holder along with `r` and `s`
    /// @param r Must produce valid secp256k1 signature from the holder along with `v` and `s`
    /// @param s Must produce valid secp256k1 signature from the holder along with `r` and `v`
    function selfPermit(
    address token,
    uint256 value,
    uint256 deadline,
    uint8 v,
    bytes32 r,
    bytes32 s
    ) external payable;
    /// @notice Permits this contract to spend a given token from `msg.sender`
    /// @dev The `owner` is always msg.sender and the `spender` is always address(this).
    /// Can be used instead of #selfPermit to prevent calls from failing due to a frontrun of a call to #selfPermit
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 54 of 60 : CallbackValidation.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity ^0.8.0;
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import './PoolAddress.sol';
    /// @notice Provides validation for callbacks from Algebra Pools
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    library CallbackValidation {
    /// @notice Returns the address of a valid Algebra Pool
    /// @param poolDeployer The contract address of the Algebra pool deployer
    /// @param tokenA The contract address of either token0 or token1
    /// @param tokenB The contract address of the other token
    /// @return pool The Algebra pool contract address
    function verifyCallback(
    address poolDeployer,
    address tokenA,
    address tokenB
    ) internal view returns (IAlgebraPool pool) {
    return verifyCallback(poolDeployer, PoolAddress.getPoolKey(tokenA, tokenB));
    }
    /// @notice Returns the address of a valid Algebra Pool
    /// @param poolDeployer The contract address of the Algebra pool deployer
    /// @param poolKey The identifying key of the ALgebra pool
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 55 of 60 : LiquidityAmounts.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    import '@cryptoalgebra/integral-core/contracts/libraries/FullMath.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/Constants.sol';
    /// @title Liquidity amount functions
    /// @notice Provides functions for computing liquidity amounts from token amounts and prices
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    library LiquidityAmounts {
    /// @notice Downcasts uint256 to uint128
    /// @param x The uint258 to be downcasted
    /// @return y The passed value, downcasted to uint128
    function toUint128(uint256 x) private pure returns (uint128 y) {
    require((y = uint128(x)) == x);
    }
    /// @notice Computes the amount of liquidity received for a given amount of token0 and price range
    /// @dev Calculates amount0 * (sqrt(upper) * sqrt(lower)) / (sqrt(upper) - sqrt(lower))
    /// @param sqrtRatioAX96 A sqrt price representing the first tick boundary
    /// @param sqrtRatioBX96 A sqrt price representing the second tick boundary
    /// @param amount0 The amount0 being sent in
    /// @return liquidity The amount of returned liquidity
    function getLiquidityForAmount0(
    uint160 sqrtRatioAX96,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 56 of 60 : OracleLibrary.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: BUSL-1.1
    pragma solidity >=0.8.4;
    import '../interfaces/external/IVolatilityOracle.sol';
    /// @title Oracle library
    /// @notice Provides functions to integrate with Algebra pool TWAP VolatilityOracle
    library OracleLibrary {
    /// @notice Fetches time-weighted average tick using Algebra VolatilityOracle
    /// @param oracleAddress The address of oracle
    /// @param period Number of seconds in the past to start calculating time-weighted average
    /// @return timeWeightedAverageTick The time-weighted average tick from (block.timestamp - period) to block.timestamp
    function consult(address oracleAddress, uint32 period) internal view returns (int24 timeWeightedAverageTick) {
    require(period != 0, 'Period is zero');
    uint32[] memory secondAgos = new uint32[](2);
    secondAgos[0] = period;
    secondAgos[1] = 0;
    IVolatilityOracle oracle = IVolatilityOracle(oracleAddress);
    (int56[] memory tickCumulatives, ) = oracle.getTimepoints(secondAgos);
    int56 tickCumulativesDelta = tickCumulatives[1] - tickCumulatives[0];
    timeWeightedAverageTick = int24(tickCumulativesDelta / int56(uint56(period)));
    // Always round to negative infinity
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 57 of 60 : PoolAddress.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    /// @title Provides functions for deriving a pool address from the poolDeployer and tokens
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    library PoolAddress {
    bytes32 internal constant POOL_INIT_CODE_HASH = 0xf96d2474815c32e070cd63233f06af5413efc5dcb430aee4ff18cc29007c562d;
    /// @notice The identifying key of the pool
    struct PoolKey {
    address token0;
    address token1;
    }
    /// @notice Returns PoolKey: the ordered tokens
    /// @param tokenA The first token of a pool, unsorted
    /// @param tokenB The second token of a pool, unsorted
    /// @return Poolkey The pool details with ordered token0 and token1 assignments
    function getPoolKey(address tokenA, address tokenB) internal pure returns (PoolKey memory) {
    if (tokenA > tokenB) (tokenA, tokenB) = (tokenB, tokenA);
    return PoolKey({token0: tokenA, token1: tokenB});
    }
    /// @notice Deterministically computes the pool address given the poolDeployer and PoolKey
    /// @param poolDeployer The Algebra poolDeployer contract address
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 58 of 60 : PoolInteraction.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import './PositionKey.sol';
    /// @title Implements commonly used interactions with Algebra pool
    library PoolInteraction {
    function _getPositionInPool(
    IAlgebraPool pool,
    address owner,
    int24 tickLower,
    int24 tickUpper
    )
    internal
    view
    returns (
    uint256 liquidityAmount,
    uint256 innerFeeGrowth0Token,
    uint256 innerFeeGrowth1Token,
    uint128 fees0,
    uint128 fees1
    )
    {
    return pool.positions(PositionKey.compute(owner, tickLower, tickUpper));
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 59 of 60 : PositionKey.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.5.0;
    library PositionKey {
    /// @dev Returns the key of the position in the core library
    function compute(
    address owner,
    int24 bottomTick,
    int24 topTick
    ) internal pure returns (bytes32 key) {
    assembly {
    key := or(shl(24, or(shl(24, owner), and(bottomTick, 0xFFFFFF))), and(topTick, 0xFFFFFF))
    }
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 60 of 60 : TransferHelper.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity >=0.6.0;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    library TransferHelper {
    /// @notice Transfers tokens from the targeted address to the given destination
    /// @notice Errors with 'STF' if transfer fails
    /// @param token The contract address of the token to be transferred
    /// @param from The originating address from which the tokens will be transferred
    /// @param to The destination address of the transfer
    /// @param value The amount to be transferred
    function safeTransferFrom(
    address token,
    address from,
    address to,
    uint256 value
    ) internal {
    (bool success, bytes memory data) = token.call(
    abi.encodeWithSelector(IERC20.transferFrom.selector, from, to, value)
    );
    require(success && (data.length == 0 || abi.decode(data, (bool))), 'STF');
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Settings
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    {
    "evmVersion": "paris",
    "viaIR": true,
    "optimizer": {
    "enabled": true,
    "runs": 0
    },
    "metadata": {
    "bytecodeHash": "none"
    },
    "outputSelection": {
    "*": {
    "*": [
    "evm.bytecode",
    "evm.deployedBytecode",
    "devdoc",
    "userdoc",
    "metadata",
    "abi"
    ]
    }
    },
    "libraries": {}
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Contract Security Audit

    Contract ABI

    [{"inputs":[{"internalType":"address","name":"_factory","type":"address"},{"internalType":"address","name":"_WNativeToken","type":"address"},{"internalType":"address","name":"_tokenDescriptor_","type":"address"},{"internalType":"address","name":"_poolDeployer","type":"address"},{"internalType":"address","name":"_vault","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"tickOutOfRange","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"address","name":"recipient","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"}],"name":"Collect","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint128","name":"liquidity","type":"uint128"},{"indexed":false,"internalType":"uint128","name":"withdrawalFeeliquidity","type":"uint128"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"}],"name":"DecreaseLiquidity","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"farmingCenterAddress","type":"address"}],"name":"FarmingCenter","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"FarmingFailed","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"pool","type":"address"},{"indexed":false,"internalType":"address","name":"feeVault","type":"address"},{"indexed":false,"internalType":"uint16","name":"fee","type":"uint16"}],"name":"FeeVaultForPool","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint128","name":"liquidityDesired","type":"uint128"},{"indexed":false,"internalType":"uint128","name":"actualLiquidity","type":"uint128"},{"indexed":false,"internalType":"uint256","name":"amount0","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount1","type":"uint256"},{"indexed":false,"internalType":"address","name":"pool","type":"address"}],"name":"IncreaseLiquidity","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"FEE_DENOMINATOR","outputs":[{"internalType":"uint64","name":"","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"NONFUNGIBLE_POSITION_MANAGER_ADMINISTRATOR_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PERMIT_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"WNativeToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount0Owed","type":"uint256"},{"internalType":"uint256","name":"amount1Owed","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"algebraMintCallback","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bool","name":"approve","type":"bool"},{"internalType":"address","name":"farmingAddress","type":"address"}],"name":"approveForFarming","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"calculateLatestWithdrawalFeesLiquidity","outputs":[{"internalType":"uint128","name":"latestWithdrawalFeeLiquidity","type":"uint128"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"calculatePendingWithdrawalFeesLiquidity","outputs":[{"internalType":"uint128","name":"pendingWithdrawalFeeLiquidity","type":"uint128"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint128","name":"amount0Max","type":"uint128"},{"internalType":"uint128","name":"amount1Max","type":"uint128"}],"internalType":"struct INonfungiblePositionManager.CollectParams","name":"params","type":"tuple"}],"name":"collect","outputs":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token0","type":"address"},{"internalType":"address","name":"token1","type":"address"},{"internalType":"uint160","name":"sqrtPriceX96","type":"uint160"}],"name":"createAndInitializePoolIfNecessary","outputs":[{"internalType":"address","name":"pool","type":"address"}],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint128","name":"liquidity","type":"uint128"},{"internalType":"uint256","name":"amount0Min","type":"uint256"},{"internalType":"uint256","name":"amount1Min","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct INonfungiblePositionManager.DecreaseLiquidityParams","name":"params","type":"tuple"}],"name":"decreaseLiquidity","outputs":[{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"defaultWithdrawalFeesVault","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"farmingApprovals","outputs":[{"internalType":"address","name":"farmingCenterAddress","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"farmingCenter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pool","type":"address"}],"name":"getWithdrawalFeePoolParams","outputs":[{"components":[{"internalType":"uint64","name":"apr0","type":"uint64"},{"internalType":"uint64","name":"apr1","type":"uint64"},{"internalType":"uint16","name":"withdrawalFee","type":"uint16"},{"components":[{"internalType":"address","name":"feeVault","type":"address"},{"internalType":"uint16","name":"fee","type":"uint16"}],"internalType":"struct INonfungiblePositionManager.FeesVault[]","name":"feeVaults","type":"tuple[]"}],"internalType":"struct INonfungiblePositionManager.WithdrawalFeePoolParams","name":"params","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"amount0Desired","type":"uint256"},{"internalType":"uint256","name":"amount1Desired","type":"uint256"},{"internalType":"uint256","name":"amount0Min","type":"uint256"},{"internalType":"uint256","name":"amount1Min","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct INonfungiblePositionManager.IncreaseLiquidityParams","name":"params","type":"tuple"}],"name":"increaseLiquidity","outputs":[{"internalType":"uint128","name":"liquidity","type":"uint128"},{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"isApprovedOrOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"token0","type":"address"},{"internalType":"address","name":"token1","type":"address"},{"internalType":"int24","name":"tickLower","type":"int24"},{"internalType":"int24","name":"tickUpper","type":"int24"},{"internalType":"uint256","name":"amount0Desired","type":"uint256"},{"internalType":"uint256","name":"amount1Desired","type":"uint256"},{"internalType":"uint256","name":"amount0Min","type":"uint256"},{"internalType":"uint256","name":"amount1Min","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"deadline","type":"uint256"}],"internalType":"struct INonfungiblePositionManager.MintParams","name":"params","type":"tuple"}],"name":"mint","outputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint128","name":"liquidity","type":"uint128"},{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"bytes[]","name":"data","type":"bytes[]"}],"name":"multicall","outputs":[{"internalType":"bytes[]","name":"results","type":"bytes[]"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"tokenId","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":"payable","type":"function"},{"inputs":[],"name":"poolDeployer","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"positions","outputs":[{"internalType":"uint88","name":"nonce","type":"uint88"},{"internalType":"address","name":"operator","type":"address"},{"internalType":"address","name":"token0","type":"address"},{"internalType":"address","name":"token1","type":"address"},{"internalType":"int24","name":"tickLower","type":"int24"},{"internalType":"int24","name":"tickUpper","type":"int24"},{"internalType":"uint128","name":"liquidity","type":"uint128"},{"internalType":"uint256","name":"feeGrowthInside0LastX128","type":"uint256"},{"internalType":"uint256","name":"feeGrowthInside1LastX128","type":"uint256"},{"internalType":"uint128","name":"tokensOwed0","type":"uint128"},{"internalType":"uint128","name":"tokensOwed1","type":"uint128"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"positionsWithdrawalFee","outputs":[{"internalType":"uint32","name":"lastUpdateTimestamp","type":"uint32"},{"internalType":"uint128","name":"withdrawalFeeLiquidity","type":"uint128"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"refundNativeToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","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":"selfPermit","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"nonce","type":"uint256"},{"internalType":"uint256","name":"expiry","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"selfPermitAllowed","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"nonce","type":"uint256"},{"internalType":"uint256","name":"expiry","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"selfPermitAllowedIfNecessary","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","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":"selfPermitIfNecessary","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newFarmingCenter","type":"address"}],"name":"setFarmingCenter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pool","type":"address"},{"internalType":"uint64","name":"_apr0","type":"uint64"},{"internalType":"uint64","name":"_apr1","type":"uint64"}],"name":"setTokenAPR","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newVault","type":"address"}],"name":"setVaultAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pool","type":"address"},{"internalType":"uint16[]","name":"fees","type":"uint16[]"},{"internalType":"address[]","name":"vaults","type":"address[]"}],"name":"setVaultsForPool","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pool","type":"address"},{"internalType":"uint16","name":"newWithdrawalFee","type":"uint16"}],"name":"setWithdrawalFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"}],"name":"sweepToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bool","name":"toActive","type":"bool"}],"name":"switchFarmingStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenFarmedIn","outputs":[{"internalType":"address","name":"farmingCenterAddress","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"}],"name":"unwrapWNativeToken","outputs":[],"stateMutability":"payable","type":"function"},{"stateMutability":"payable","type":"receive"}]

    6101a0346200033f57601f6200632238819003918201601f19168301916001600160401b03831184841017620003445780849260a0946040528339810103126200033f576200004e8162000563565b6200005c6020830162000563565b6200006a6040840162000563565b906200008760806200007f6060870162000563565b950162000563565b9360405193620000978562000547565b601885527f416c676562726120506f736974696f6e73204e46542d56320000000000000000602086015260405194620000d08662000547565b6008865267414c47422d504f5360c01b602087015260405195620000f48762000547565b60018752601960f91b602088015281516001600160401b0381116200034457600054600181811c911680156200053c575b60208210146200044457601f8111620004e8575b50806020601f8211600114620004715760009162000465575b508160011b916000199060031b1c1916176000555b8051906001600160401b038211620003445760015490600182811c921680156200045a575b6020831014620004445781601f849311620003e0575b50602090601f831160011462000366576000926200035a575b50508160011b916000199060031b1c1916176001555b60208151910120948560805260208151910120948560a0524660e0526040519560208701917f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f8352604088015260608701524660808701523060a087015260a0865260c086019580871060018060401b038811176200034457604087905251902060c05230610100908152610120918252610140928352610160938452760100000000000000000000000000000000000000000001601355610180948552956001600160a01b031680156200033f57600b80546001600160a01b031916919091179055615d69958662000579873960805186615078015260a0518661509e015260c05186615029015260e051866150e401525185614ff301525184818161092401528181611ce80152614d8b0152518381816124190152818161250401528181614bcc0152615143015251828181601d015281816114e401528181611b1e01526154160152518161082c0152f35b600080fd5b634e487b7160e01b600052604160045260246000fd5b015190503880620001bb565b60016000908152600080516020620063028339815191529350601f198516905b818110620003c75750908460019594939210620003ad575b505050811b01600155620001d1565b015160001960f88460031b161c191690553880806200039e565b9293602060018192878601518155019501930162000386565b600160005290915060008051602062006302833981519152601f840160051c8101916020851062000439575b90601f859493920160051c01905b818110620004295750620001a2565b600081558493506001016200041a565b90915081906200040c565b634e487b7160e01b600052602260045260246000fd5b91607f16916200018c565b90508301513862000152565b60008080529250600080516020620062e2833981519152905b601f1983168410620004cf576001935082601f19811610620004b5575b5050811b0160005562000167565b85015160001960f88460031b161c191690553880620004a7565b858101518255602093840193600190920191016200048a565b60008052600080516020620062e2833981519152601f830160051c81016020841062000534575b601f830160051c820181106200052757505062000139565b600081556001016200050f565b50806200050f565b90607f169062000125565b604081019081106001600160401b038211176200034457604052565b51906001600160a01b03821682036200033f5756fe6080806040526004361015610085575b50361561001b57600080fd5b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316330361004d57005b60405162461bcd60e51b815260206004820152601060248201526f2737ba102ba730ba34bb32aa37b5b2b760811b6044820152606490fd5b600090813560e01c90816301ffc9a71461346f5750806306fdde03146133cd578063081812fc146133ae578063095ea7b3146132805780630c49ccbe14612ddf57806312e724ba14612cbd578063135e53e01461288c57806318160ddd1461286e578063219f5d171461266657806323b872dd1461263c5780632d0b22de146126095780632f745c591461255c57806330adf81f146125335780633119049a146124ee5780633644e515146124d35780633dd657c51461235a5780633edc23321461226d578063418652701461224f57806342842e0e1461222757806342966c6814611f7e578063430c208114611f405780634659a49414611f275780634d10862d14611eb95780634f6ccce714611e2757806351246d6e14611ca35780636301727b14611c345780636352211e14611c0357806369bc35b214611b0657806370227515146119f757806370a08231146119cb5780637ac2ff7b146116e2578063832f630a1461166457806385535cc51461161c5780638692bd7d146115135780638af3ac85146114ce57806395d89b41146113e057806399fbab88146112d55780639cc1a28314610d61578063a22cb46514610c93578063a4a78f0c14610c67578063aa7e1abd14610bc8578063ac9650d814610a3d578063b227aa7914610a14578063b88d4fde14610987578063c2e3140a14610953578063c45a01551461090e578063c87b56dd146107e3578063d73792a9146107c6578063dba5281f1461079d578063dd56e5d814610774578063df2ab5bb146106f1578063e7ce18a3146106be578063e985e9c51461066a578063f143536d14610611578063f3995c67146105f55763fc6f78650361000f5760803660031901126105e05761030d600435614d0a565b6001600160801b03908161031f614a51565b16158015906105e3575b156105e0576001600160a01b0361033e613e17565b166105d25730915b60043582526011602052604082206001810154936001600160a01b036103746001600160501b038716614b8a565b16946004830154958487169660801c938260801c8061050b575b50610397614a51565b88871690871611156104fb578788925b6103af614a67565b87891690891611156104eb5786998a955b876040519c8d9384936309e3d67b60e31b85528060681c60020b9060501c60020b60048601946103ef95614af2565b03818b5a94604095f19586156104e057604099899761048f575b50916004888587969461042483809a81990316858701613e76565b9390920180546001600160801b031916929093031617905588516001600160a01b0390951685521660208401521681860152600435907f40d0efd1a53d60ecbf40971b9daf7dc90178c3aadc7aab1765632738fa8b8f0190606090a281845193168352166020820152f35b8599508880969581959399508094610424838f6004966104c4913d6040116104d9575b6104bc818361364b565b810190614ad1565b9f909f9d979950505050945095965050610409565b503d6104b2565b6040513d8a823e3d90fd5b6104f3614a67565b998a956103c0565b610503614a51565b9788926103a7565b90949760405191631d9de38760e11b83528460501c60020b8060048501528560681c60020b908160248601526000604486015260806064860152600360848601526203078360ec1b60a486015260408560c48160008a5af19485156105c6578a9561058e575b509161058191859330888c613f7d565b920116980116933861038e565b60408092939496503d83116105bf575b6105a8818361364b565b810103126105ba579088939138610571565b600080fd5b503d61059e565b6040513d6000823e3d90fd5b6105da613e17565b91610346565b80fd5b50816105ed614a67565b161515610329565b5061060e610602366136ba565b949390939291926156df565b80f35b50346105e05760203660031901126105e0576040809160043581526012602052206020825191610640836135b0565b5463ffffffff811680845290821c6001600160801b03169190920181905282519182526020820152f35b50346105e05760403660031901126105e05761068461353e565b604061068e613554565b9260018060a01b0380931681526005602052209116600052602052602060ff604060002054166040519015158152f35b50346105e05760203660031901126105e0576020906004358152600d8252604060018060a01b0391205416604051908152f35b5060603660031901126105e05761070661353e565b61070e61356a565b61071782615385565b90602435821061073a578161072a578380f35b61073392615be4565b3880808380f35b60405162461bcd60e51b815260206004820152601260248201527124b739bab33334b1b4b2b73a103a37b5b2b760711b6044820152606490fd5b50346105e057806003193601126105e057600a546040516001600160a01b039091168152602090f35b50346105e057806003193601126105e057600b546040516001600160a01b039091168152602090f35b50346105e057806003193601126105e05760206040516103e88152f35b50346105e0576020806003193601126108fa5760043561080a61080582613f47565b61379b565b60405163e9dc637560e01b8152306004820152602481019190915282816044817f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03165afa92831561090257809361087e575b505061087a604051928284938452830190613519565b0390f35b909192503d8082843e610891818461364b565b82019183818403126108fa578051906001600160401b0382116108fe570182601f820112156108fa578051916108c683613709565b936108d4604051958661364b565b8385528584840101116105e05750906108f2918480850191016134f6565b903880610864565b5080fd5b8280fd5b604051903d90823e3d90fd5b50346105e057806003193601126105e0576040517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b5061095d366136ba565b938061096b879593956157b9565b10610974578680f35b61097d956156df565b3880808080808680f35b50346105e05760803660031901126105e0576109a161353e565b6109a9613554565b90606435906001600160401b038211610a105736602383011215610a1057816004013592846109d785613709565b936109e5604051958661364b565b85855236602487830101116108fa578561060e9660246020930183880137850101526044359161386a565b8380fd5b50346105e057806003193601126105e0576020604051600080516020615cdd8339815191528152f35b506020806003193601126108fa576001600160401b0391600435908382116105e057366023830112156105e0578160040135918483116108fa5760059460243685881b8401820111610a1057610a9485939561366e565b94610aa2604051968761364b565b838652601f19610ab18561366e565b0187865b828110610bb857505050368190036042190190855b858110610b31575050505050506040519280840190808552835180925280604083818801981b870101940192955b828710610b055785850386f35b909192938280610b21600193603f198a82030186528851613519565b9601920196019592919092610af8565b83818b1b8301013583811215610bb45782018481013590868211610bb0576044018136038113610bb057818992918392604051928392833781018381520390305af4610b7b613c5f565b9015610ba15790600191610b8f828b614aa9565b52610b9a818a614aa9565b5001610aca565b8051908a8983156105e0575001fd5b8880fd5b8780fd5b6060898201830152899101610ab5565b50346105e05760603660031901126105e057610be261353e565b6001600160401b0360243581811692908390036105ba576044359182168083036105ba57610c0e614d5c565b6103e8808511159182610c5c575b505015610a10576001600160a01b03168352600e602052604080842080546001600160801b03191690931791901b600160401b600160801b031617905580f35b111590503880610c1c565b50610c71366136ba565b93909290600019610c81876157b9565b10610c8a578680f35b61097d95615748565b50346105e05760403660031901126105e057610cad61353e565b610cb56136fa565b6001600160a01b0390911690338214610d20573383526005602052604083208260005260205260406000209015159060ff1981541660ff83161790556040519081527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3160203392a380f35b60405162461bcd60e51b815260206004820152601960248201527822a9219b99189d1030b8383937bb32903a379031b0b63632b960391b6044820152606490fd5b506101403660031901126105e057610d7b610124356155f2565b610dfb610d86613e01565b610d8e613e17565b610d96613e2d565b610d9e613e3d565b9160405193610dac856135cb565b6001600160a01b039081168552166020840152306040840152600290810b60608401520b608082015260843560a082015260a43560c082015260c43560e082015260e43561010082015261510a565b939493909290610104356001600160a01b03811690036105ba57601380546001600160b01b031981166001600160b01b03808316600101161790915594610104356001600160a01b03161561129157610e65610e5f6001600160b01b038816613f47565b15613efc565b6008546001600160b01b038716600090815260096020526040902081905590600160401b82101561127b576080976111a36111cd92610ecc610ebc866001600080516020615cfd8339815191529801600855613d59565b6001600160b01b038d1691614bf0565b610ed861010435613724565b610104356001600160a01b0316600090815260066020908152604080832084845282528083206001600160b01b038f1690819055808452600790925290912091909155610f2890610e5f90613f47565b610104356001600160a01b0316808252600360209081526040808420805460010190556001600160b01b038d168085526002909252832080546001600160a01b031916831790559082600080516020615d3d8339815191528180a461114d610fa1610f91613e2d565b610f99613e3d565b90308a6159b4565b5050909150610fae613e01565b91610fb7613e17565b60405193610fc4856135b0565b6001600160a01b039081168552908116602080860191909152908b168652600f90526040852080546001600160501b03169384156111f6575b5050611007613e2d565b61100f613e3d565b906040519461101d86613594565b87865287602087015260018060501b0316604086015260020b606085015260020b8f84015260018f81901b038b1660a084015260c083015260e0820152826101008201528261012082015260018060b01b038c1683526011602052604083209060018060581b0381511660018060581b03198354161782556110ab60018060a01b0360208301511683613e4d565b6004600183019261110e60018060501b0360408501511694805495606086015160501b96608087015160681b62ffffff60681b16916080600180911b0319809962ffffff60501b16921617171781556080600180911b0360a08601511690613e76565b60c0830151600282015560e08301516003820155019160018f81901b03610100830151169083541617825561012060018f81901b039101511690613e76565b6040519061115a826135b0565b4263ffffffff908116835260208084018381526001600160b01b038e168452601290915260409092209251835463ffffffff191691161782555160001960018d1b011690613e99565b6040516001600160b01b038916949092839290916001600160a01b03169089908990899086613ec2565b0390a26040519360018060b01b03168452600180861b0316602084015260408301526060820152f35b601380546001600160b01b038116600160b092831c81810190931b6001600160b01b0319169190911790925583546001600160501b03191681179093558288526010602090815260408920835181546001600160a01b03199081166001600160a01b039283161783559290940151920180549091169190921617905592503880610ffd565b634e487b7160e01b600052604160045260246000fd5b606460405162461bcd60e51b815260206004820152602060248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152fd5b50346105e05760203660031901126105e057600435815260116020526040812060018101546001600160501b03811680156113a8578360409161016095526010602052209180549260018060a01b0392836001818454169301541660028401549260046003860154950154956040519760018060581b038116895260581c166020880152604087015260608601528060501c60020b60808601528060681c60020b60a086015260801c60c085015260e084015261010083015260018060801b03811661012083015260801c610140820152f35b60405162461bcd60e51b815260206004820152601060248201526f125b9d985b1a59081d1bdad95b88125160821b6044820152606490fd5b50346105e057806003193601126105e057604051908060019182549283811c928185169485156114c4575b60209586861081146114b05785885287949392918790821561148e575050600114611453575b505061143f9250038361364b565b61087a604051928284938452830190613519565b908592508082528282205b85831061147657505061143f93508201013880611431565b8054838901850152879450869390920191810161145e565b925093505061143f94915060ff191682840152151560051b8201013880611431565b634e487b7160e01b83526022600452602483fd5b93607f169361140b565b50346105e057806003193601126105e0576040517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b50346105e057602090816003193601126105e05761152f61353e565b9060608060405161153f816135fa565b8381528386820152836040820152015260018060a01b038092168152600e83526040812090604051611570816135fa565b82549460018060401b0394858716835281830195808860401c168752604084019761ffff9889809260801c1681526115ab6001809901613d8a565b926060870193845260405199868b528160a08c01985116878c0152511660408a015251166060880152519660808088015287518094528260c08801980194915b8483106115f85787890388f35b8551805182168a528401518216848a015260409098019794830194918601916115eb565b50346105e05760203660031901126105e05761163661353e565b61163e614d5c565b6001600160a01b031680156108fa57600b80546001600160a01b03191691909117905580f35b5060603660031901126105e05760043561167c6136fa565b9061168561356a565b61168e82614d0a565b83926116c1575b508252600c6020526040822080546001600160a01b0319166001600160a01b0390921691909117905580f35b600a54919250906001600160a01b03908116908216036108fe579038611695565b506116ec366136ba565b908392969593421161199557611700614ff0565b85875260209760118952604088209182549260018060581b03938481169460018601169060018060581b0319161790556040518a810190600080516020615d1d833981519152825260018060a01b0397888a16958660408401528b6060840152608083015260a082015260a0815261177781613630565b519020604051908b82019261190160f01b845260228301526042820152604281526117a1816135fa565b519020936117ae886137e2565b868116809414611940578a94939291908a903b156118b957506118209596506040519385850152604084015260ff60f81b9060f81b166060830152604182526117f6826135fa565b6040518080958194630b135d3f60e11b988984526004840152604060248401526044830190613519565b03915afa9081156118ae578591611881575b506001600160e01b0319160361184d5761060e929350614f9c565b60405162461bcd60e51b815260048101859052600c60248201526b155b985d5d1a1bdc9a5e995960a21b6044820152606490fd5b6118a19150863d88116118a7575b611899818361364b565b810190613c3f565b38611832565b503d61188f565b6040513d87823e3d90fd5b9360ff60809498979360405194855216868401526040830152606082015282805260015afa156119355784511680156118fc570361184d5761060e929350614f9c565b60405162461bcd60e51b8152600481018790526011602482015270496e76616c6964207369676e617475726560781b6044820152606490fd5b6040513d86823e3d90fd5b60405162461bcd60e51b8152600481018c9052602760248201527f4552433732315065726d69743a20617070726f76616c20746f2063757272656e6044820152663a1037bbb732b960c91b6064820152608490fd5b60405162461bcd60e51b815260206004820152600e60248201526d14195c9b5a5d08195e1c1a5c995960921b6044820152606490fd5b50346105e05760203660031901126105e05760206119ef6119ea61353e565b613724565b604051908152f35b50346105e05760403660031901126105e057600435611a146136fa565b600a546001600160a01b03908116338114939192859015611ae75750818552600c602052808360408720541603611aa757925b15611a6d578352600d6020526040832080546001600160a01b0319169190921617905580f35b60405162461bcd60e51b815260206004820152601260248201527127b7363c902330b936b4b733a1b2b73a32b960711b6044820152606490fd5b60405162461bcd60e51b81526020600482015260186024820152774e6f7420617070726f76656420666f72206661726d696e6760401b6044820152606490fd5b93905080611a475750808452600d602052816040852054163314611a47565b5060403660031901126105e057611b1b613554565b907f0000000000000000000000000000000000000000000000000000000000000000611b4681615385565b906004358210611bc25781611b59578280f35b6001600160a01b0316803b156108fe57828091602460405180948193632e1a7d4d60e01b83528760048401525af18015611bb757611ba4575b50611b9d9192615c8a565b8038808280f35b91611bb1611b9d936135e7565b91611b92565b6040513d85823e3d90fd5b60405162461bcd60e51b815260206004820152601960248201527824b739bab33334b1b4b2b73a102ba730ba34bb32aa37b5b2b760391b6044820152606490fd5b50346105e05760203660031901126105e0576020611c226004356137e2565b6040516001600160a01b039091168152f35b50346105e05760403660031901126105e057611c4e61353e565b6024359061ffff8216808303610a10576103e890611c6a614d5c565b116108fe576001600160a01b03168252600e60205260408220805461ffff60801b191660809290921b61ffff60801b1691909117905580f35b5060603660031901126105e057611cb861353e565b90611cc1613554565b906001600160a01b0360443581811681036108fe57611ce582851683871610615635565b817f000000000000000000000000000000000000000000000000000000000000000016936040519463d9a641e160e01b8652602096878780611d2b86856004840161567b565b0381855afa968715611e1c5790889392918798611dfd575b508786811680611dcc57505086611d74959697985060405180968195829463e343361560e01b84526004840161567b565b03925af19384156109025793611d99575b50611d909083615695565b60405191168152f35b611d90919350611dbe90853d8711611dc5575b611db6818361364b565b810190614150565b9290611d85565b503d611dac565b925095965050859250611ddf9150615a79565b1615611ded575b5050611d90565b611df691615695565b3880611de6565b611e15919850843d8611611dc557611db6818361364b565b9638611d43565b6040513d88823e3d90fd5b50346105e05760203660031901126105e057600435600854811015611e5f57611e51602091613d59565b90546040519160031b1c8152f35b60405162461bcd60e51b815260206004820152602c60248201527f455243373231456e756d657261626c653a20676c6f62616c20696e646578206f60448201526b7574206f6620626f756e647360a01b6064820152608490fd5b50346105e05760203660031901126105e0577f29f9e1ebeee07596f3165f3e42cb9d4d8d22b0481e968d6c74be3dd037c15d9b6020611ef661353e565b611efe614d5c565b600a80546001600160a01b0319166001600160a01b03929092169182179055604051908152a180f35b5061060e611f34366136ba565b94939093929192615748565b50346105e05760403660031901126105e0576020611f74611f5f61353e565b60243590611f6f61080583613f47565b613905565b6040519015158152f35b506020806003193601126108fa5760043590611f9982614d0a565b81835260118152826040812060018101908154916004820192835460018060801b0391828260801c92169060801c171716610a10578382558390556002810183905560030182905555600d81526040832080546001600160a01b0319908116909155612004836137e2565b6001600160a01b039290838116908115801590816121f9575b156121615750505060085484865260098252806040872055600160401b81101561214d578461205582600161205b9401600855613d59565b90614bf0565b60085460001993908481019081116121395785875260098352612082604088205491613d59565b90549060031b1c6120968161205584613d59565b8752600983526040872055848652856040812055600854801561212557916002918588969594016120c681613d59565b8782549160031b1b191690556008556120de876137e2565b8787526004835260408720858154169055169384865260038252604086209081540190558585525260408320908154169055600080516020615d3d8339815191528280a480f35b634e487b7160e01b87526031600452602487fd5b634e487b7160e01b87526011600452602487fd5b634e487b7160e01b86526041600452602486fd5b61216d575b505061205b565b61217690613724565b600019810191908211612139578587526007835260408720548281036121bd575b508587528660408120558652600682526040862090865281528460408120553880612166565b8188526006845260408820838952845260408820548289526006855260408920828a5285528060408a2055885260078452604088205538612197565b878952601185526040808a208054600160581b600160f81b0319169055600c8652892080548716905561201d565b50346105e05761060e61223936613685565b906040519261224784613615565b85845261386a565b50806003193601126105e057476122635780f35b61060e4733615c8a565b50346105e05760203660031901126105e057610120611d90602092600435908181526011855260408120604051916122a483613594565b815460018060581b038116845260018060a01b039060581c168784015260018201549263ffffffff604060018060501b03861693848285015261233d60608501958860501c60020b8752600460808701988a60681c60020b8a5260a088019a60801c8b52600281015460c0890152600381015460e089015201549560018060801b039c878e80991661010084015260801c910152614b8a565b97815260128b52205416915160020b925160020b93511693614182565b50346105e05760603660031901126105e0576004356024356044356001600160401b038082116124cf57366023830112156124cf5781600401359081116124cf5781013660248201116124cf5781900392606084126124cf5760408051946123c1866135b0565b126124cf5761243d906124046064604051946123dc866135b0565b6123e860248201613580565b86526123f660448201613580565b602087015285885201613580565b60208601908152926001600160a01b039283917f0000000000000000000000000000000000000000000000000000000000000000615905565b16330361248d5780612472575b5082612454578480f35b80602061246a9551015116903392511690615409565b388080808480f35b61248790828651511633908486511690615409565b3861244a565b60405162461bcd60e51b815260206004820152601a602482015279496e76616c69642063616c6c6572206f662063616c6c6261636b60301b6044820152606490fd5b8480fd5b50346105e057806003193601126105e05760206119ef614ff0565b50346105e057806003193601126105e0576040517f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03168152602090f35b50346105e057806003193601126105e0576020604051600080516020615d1d8339815191528152f35b50346105e05760403660031901126105e05761257661353e565b6024359161258382613724565b8310156125b05760209260409260018060a01b031682526006845282822090825283522054604051908152f35b60405162461bcd60e51b815260206004820152602b60248201527f455243373231456e756d657261626c653a206f776e657220696e646578206f7560448201526a74206f6620626f756e647360a81b6064820152608490fd5b50346105e05760203660031901126105e0576020906004358152600c8252604060018060a01b0391205416604051908152f35b50346105e05761060e61264e36613685565b9161266161265c8433613905565b613808565b6139cd565b5060c03660031901126105e05761278760609161268460a4356155f2565b6004358152601160205260408120906040600080516020615cfd833981519152612801600185015460018060501b038116855260106020526127ee6127e861273486882060018060a01b03815416906001808060a01b03910154168851916126eb836135cb565b8252602082015230888201528460501c60020b8c8201528460681c60020b608082015260243560a082015260443560c082015260643560e082015260843561010082015261510a565b949399929a919c909b61275a8860801c8960681c60020b8a60501c60020b308a86613f7d565b908082176001600160801b031661282c575b5050608088901c8c016001600160801b031690600101613e76565b60043581526012602052209160018060a01b03169382546127c363ffffffff928060801c908060681c60020b9060501c60020b8585168a614182565b63ffffffff19909116429092169190911780845560201c6001600160801b0316613f64565b90613e99565b6040519182918789886004359886613ec2565b0390a26001600160801b03169161281a83600435614e73565b60405192835260208301526040820152f35b6004830180546001600160801b038082169390930183166001600160801b0319909116178082556128679360809190911c0190911690613e76565b388061276c565b50346105e057806003193601126105e0576020600854604051908152f35b50346105e05760603660031901126105e0576128a661353e565b906024356001600160401b038082116108fe57366023830112156108fe5781600401356128d28161366e565b926128e0604051948561364b565b8184526024602085019260051b82010190368211612c9a57602401915b818310612c9e575050506044359081116108fe57366023820112156108fe5780600401359061292b8261366e565b91612939604051938461364b565b8083526024602084019160051b83010191368311612c9a57602401905b828210612c8257505050612968614d5c565b8260018060a01b0385168152600e60205260016040822001938251845103612c3d57845415801590612c34575b612beb575b81905b8451821015612b4e576001600160a01b036129b88386614aa9565b511615612b0d576001600160a01b036129d18386614aa9565b511661ffff6129e08488614aa9565b5116604051916129ef836135b0565b825260208201528654600160401b811015612af95760018101808955811015612ae5579061ffff6020612a45938a8852818820019260018060a01b0381511660018060a01b031985541617845501511690614c08565b61ffff80612a538488614aa9565b511691160161ffff8111612ad15790612acb907fff5b7ae049a1a9fb20442c9c2abaa248c078a294b476cb51c8951028b775e46e60606001600160a01b03612a9b8489614aa9565b511661ffff612aaa858b614aa9565b51166040519160018060a01b038d16835260208301526040820152a1614a7d565b9061299d565b634e487b7160e01b83526011600452602483fd5b634e487b7160e01b85526032600452602485fd5b634e487b7160e01b85526041600452602485fd5b60405162461bcd60e51b815260206004820152601960248201527805661756c7420616464726573732063616e6e6f74206265203603c1b6044820152606490fd5b868684928751612b5c578380f35b61ffff6103e8911603612b93576001600160a01b039091168252600e60205260408220612b8c9190600101614c27565b8180808380f35b60405162461bcd60e51b815260206004820152602a60248201527f546f74616c20666565206d75737420626520657175616c20746f204645455f4460448201526922a727a6a4a720aa27a960b11b6064820152608490fd5b6001600160a01b0386168252600e6020526040822060010180548382559081612c16575b505061299a565b835260208320908101905b81811015612c0f57838155600101612c21565b50835115612995565b60405162461bcd60e51b815260206004820152601f60248201527f5661756c747320616e642066656573206c656e677468206d69736d61746368006044820152606490fd5b60208091612c8f84613580565b815201910190612956565b8580fd5b823561ffff81168103612cb9578152602092830192016128fd565b8680fd5b50346105e057602090816003193601126105e057611d9082612dd96101209360043590818152601184526040812060405191612cf883613594565b81546001600160581b038116845260581c6001600160a01b03168684015260018201546001600160501b0381166040808601829052605083901c600290810b60608801908152606885901c820b6080808a0191825295861c60a08a019081529288015460c08a0152600388015460e08a01526004909701546001600160801b038082166101008b0152951c9c9097019b909b52919994928a9291612d9b90614b8a565b96815260128952209160405192612db1846135b0565b54928263ffffffff8516948583528a1c1698899101525160020b925160020b93511693614182565b90613f64565b5060a03660031901126105e057612df7600435614d0a565b612e026084356155f2565b6001600160801b03612e12614a3b565b16156105e05760043581526011602052604081206001810154906001600160801b03612e3c614a3b565b168260801c106108fe576001600160a01b03612e606001600160501b038416614b8a565b16916004358452601260205260408420805490612eab612e988460801c8560681c60020b8660501c60020b63ffffffff87168a614182565b602084901c6001600160801b0316613f64565b608084901c6001600160801b038216111561327a57508260801c915b6001600160a01b0319164263ffffffff161790556001600160801b0381166130b4575b61305c90612fff612f8694612efd614a3b565b6001600160801b03612f1385608089901c614b2e565b166001600160801b0390911611156130a4576001612f34848760801c614b2e565b955b612fe1612f51888360681c60020b8460501c60020b8d615b2d565b99909a6044358c101580613098575b612f6990614b47565b8360801c908460681c60020b908560501c60020b90309089613f7d565b60048601918254908d878060801b0391888060801b0391898060801b03160116878060801b038316011690868060801b03191617808355858060801b0391868060801b03908d888060801b031601169060801c011690613e76565b84828060801b039188848060801b039160801c031603169101613e76565b604080516001600160801b0385811682528316602082015290810186905260608101859052600435907f5e41cd741a4f79d713bd0c5670fae681a19f07bb5eca4955e68e322e9e15287290608090a26001600160801b0392613f64565b16600160ff1b8114613084576130789060409403600435614e73565b82519182526020820152f35b634e487b7160e01b84526011600452602484fd5b506064358b1015612f60565b60016130ae614a3b565b95612f36565b6130cc818360681c60020b8460501c60020b87615b2d565b858793929352600e6020526130e660016040892001613d8a565b8781511560001461318b575050600b54604080516309e3d67b60e31b815294909285928392613144926001600160801b039081169291169060688a901c600290810b9160508c901c90910b906001600160a01b031660048701614af2565b038189895af18015611e1c57612f869461305c93612fff9261316d575b505b9450509050612eea565b6131859060403d6040116104d9576104bc818361364b565b50613161565b909394919692815b85518110156132625761ffff60206131ab8389614aa9565b510151169060406001600160a01b036131c4838a614aa9565b515116928b6103e86131f38c826131e28660018060801b039361416f565b0416936001600160801b039361416f565b041693613223835195869384936309e3d67b60e31b85528b60681c60020b908c60501c60020b9060048701614af2565b0381878a5af19182156119355761323f92613244575b50614a7d565b613193565b61325c9060403d6040116104d9576104bc818361364b565b50613239565b5092965050925061305c9150612fff612f8694613163565b91612ec7565b50346105e05760403660031901126105e05761329a61353e565b6024356001600160a01b03806132af836137e2565b16809184161461335f5780331490811561333e575b50156132d35761060e91614f9c565b60405162461bcd60e51b815260206004820152603d60248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f7420746f60448201527f6b656e206f776e6572206f7220617070726f76656420666f7220616c6c0000006064820152608490fd5b9050835260056020526040832033845260205260ff604084205416386132c4565b60405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b6064820152608490fd5b50346105e05760203660031901126105e0576020611c22600435614ce0565b50346105e057806003193601126105e0576040519080805491600183811c92818516948515613465575b60209586861081146114b05785885287949392918790821561148e57505060011461342a57505061143f9250038361364b565b908592508180528282205b85831061344d57505061143f93508201013880611431565b80548389018501528794508693909201918101613435565b93607f16936133f7565b9050346108fa5760203660031901126108fa5760043563ffffffff60e01b81168091036108fe576020925063780e9d6360e01b81149081156134b3575b5015158152f35b6380ac58cd60e01b8114915081156134e5575b81156134d4575b50386134ac565b6301ffc9a760e01b149050386134cd565b635b5e139f60e01b811491506134c6565b60005b8381106135095750506000910152565b81810151838201526020016134f9565b90602091613532815180928185528580860191016134f6565b601f01601f1916010190565b600435906001600160a01b03821682036105ba57565b602435906001600160a01b03821682036105ba57565b604435906001600160a01b03821682036105ba57565b35906001600160a01b03821682036105ba57565b61014081019081106001600160401b0382111761127b57604052565b604081019081106001600160401b0382111761127b57604052565b61012081019081106001600160401b0382111761127b57604052565b6001600160401b03811161127b57604052565b608081019081106001600160401b0382111761127b57604052565b602081019081106001600160401b0382111761127b57604052565b60c081019081106001600160401b0382111761127b57604052565b601f909101601f19168101906001600160401b0382119082101761127b57604052565b6001600160401b03811161127b5760051b60200190565b60609060031901126105ba576001600160a01b039060043582811681036105ba579160243590811681036105ba579060443590565b60c09060031901126105ba576004356001600160a01b03811681036105ba5790602435906044359060643560ff811681036105ba57906084359060a43590565b6024359081151582036105ba57565b6001600160401b03811161127b57601f01601f191660200190565b6001600160a01b0316801561374457600052600360205260406000205490565b60405162461bcd60e51b815260206004820152602960248201527f4552433732313a2061646472657373207a65726f206973206e6f7420612076616044820152683634b21037bbb732b960b91b6064820152608490fd5b156137a257565b60405162461bcd60e51b8152602060048201526018602482015277115490cdcc8c4e881a5b9d985b1a59081d1bdad95b88125160421b6044820152606490fd5b6000908152600260205260409020546001600160a01b031661380581151561379b565b90565b1561380f57565b60405162461bcd60e51b815260206004820152602d60248201527f4552433732313a2063616c6c6572206973206e6f7420746f6b656e206f776e6560448201526c1c881bdc88185c1c1c9bdd9959609a1b6064820152608490fd5b9061388e93929161387e61265c8433613905565b6138898383836139cd565b613c8f565b1561389557565b60405162461bcd60e51b8152806138ae600482016138b2565b0390fd5b60809060208152603260208201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b60608201520190565b906001600160a01b038080613919846137e2565b1693169183831493841561394c575b508315613936575b50505090565b61394291929350614ce0565b1614388080613930565b909350600052600560205260406000208260005260205260ff604060002054169238613928565b1561397a57565b60405162461bcd60e51b815260206004820152602560248201527f4552433732313a207472616e736665722066726f6d20696e636f72726563742060448201526437bbb732b960d91b6064820152608490fd5b6139f1916139da846137e2565b6001600160a01b0393848416939185168414613973565b838216938415613bee57839182158015613bb2575b15613af9575060085460008781526009602052604090208190559150600160401b82101561127b57613a6092613a4787612055856001899701600855613d59565b828603613ac6575b50613a59866137e2565b1614613973565b600080516020615d3d833981519152600084815260046020526040812060018060a01b03199081815416905583825260036020526040822060001981540190558482526040822060018154019055858252600260205284604083209182541617905580a4565b613acf90613724565b60406000878152600660205281812083825260205288828220558881526007602052205538613a4f565b858303613b0b575b50613a6092613a47565b613b16919250613724565b600019810191908211613b9c57613a609284926000908882526020906007825260409182842054828103613b65575b508a84528383812055868452600681528284209184525281205592613b01565b8785526006825283852083865282528385205488865260068352848620828752835280858720558552600782528385205538613b45565b634e487b7160e01b600052601160045260246000fd5b60008881526011602090815260408083208054600160581b600160f81b0319169055600c909152902080546001600160a01b0319169055613a06565b60405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b6064820152608490fd5b908160209103126105ba57516001600160e01b0319811681036105ba5790565b3d15613c8a573d90613c7082613709565b91613c7e604051938461364b565b82523d6000602084013e565b606090565b9192813b15613d5057602091613ce1916000604051958680958194630a85bd0160e11b9a8b845233600485015260018060a01b0380951660248501526044840152608060648401526084830190613519565b0393165af160009181613d30575b50613d2257613cfc613c5f565b80519081613d1d5760405162461bcd60e51b8152806138ae600482016138b2565b602001fd5b6001600160e01b0319161490565b613d4991925060203d81116118a757611899818361364b565b9038613cef565b50505050600190565b600854811015613d7457600860005260206000200190600090565b634e487b7160e01b600052603260045260246000fd5b908154613d968161366e565b92604093613da68551918261364b565b828152809460208092019260005281600020906000935b858510613dcc57505050505050565b60018481928451613ddc816135b0565b61ffff8754858060a01b038116835260a01c1683820152815201930194019391613dbd565b6004356001600160a01b03811681036105ba5790565b6024356001600160a01b03811681036105ba5790565b6044358060020b81036105ba5790565b6064358060020b81036105ba5790565b8054600160581b600160f81b03191660589290921b600160581b600160f81b0316919091179055565b80546001600160801b031660809290921b6001600160801b031916919091179055565b8054600160201b600160a01b03191660209290921b600160201b600160a01b0316919091179055565b6001600160801b03918216815291166020820152604081019190915260608101919091526001600160a01b03909116608082015260a00190565b15613f0357565b60405162461bcd60e51b815260206004820152601c60248201527b115490cdcc8c4e881d1bdad95b88185b1c9958591e481b5a5b9d195960221b6044820152606490fd5b6000908152600260205260409020546001600160a01b0316151590565b6001600160801b039182169082160191908211613b9c57565b959391613f8a93916159b4565b50509150926002850193613fb4613fc16003875484039460018060801b0393848092168097613fc7565b1698019384548603613fc7565b16945555565b8181029190600019828209918380841093039183830393600160801b93858511156105ba5714614004570990828211900360801b910360801c1790565b5050505060801c90565b8181029190600019828209918380841093039183830393600160601b93858511156105ba571461404b570990828211900360a01b910360601c1790565b5050505060601c90565b90606082901b90600160601b600019818509938380861095039480860395868511156105ba57146140d2579082910981806000031680920460028082600302188083028203028083028203028083028203028083028203028083028203028092029003029360018380600003040190848311900302920304170290565b505091500490565b9181830291600019818509938380861095039480860395868511156105ba57146140d2579082910981806000031680920460028082600302188083028203028083028203028083028203028083028203028083028203028092029003029360018380600003040190848311900302920304170290565b908160209103126105ba57516001600160a01b03811681036105ba5790565b81810292918115918404141715613b9c57565b90949291946000946000600160a01b6001900380941690818152602092600e8452604090818320968251936141b6856135fa565b885493600160401b6001900394858116875285808a8901988184861c168a528481019d8e61ffff809660801c1690526001016141f190613d8a565b606082015251169751169a511698861595861580976146db575b806146d2575b614228575b50505050505050505050505050909150565b63ffffffff809216824216038281116146be5782169889156146aa57835163ef01df4f60e01b815260049b9291839082908e9082905afa9081156146a0579087918791614683575b5016801561466e57845193606085018581108482111761465a57918c8e9692899489526002845286840191893684376142a885614a8c565b52846142b385614a99565b528851978894639d3a524160e01b86528860248701928701525180915260448501929186905b8983831061463a57505050505082809103915afa938415614631578594614522575b5050505061431261430b82614a99565b5191614a8c565b5160060b9060060b0396667fffffffffffff19667fffffffffffff8913818a121761450f578760060b9860060b89156144fc576000199181148a8314166144e95789810560020b9984821291826144da575b50506144a7575b505061438561437f61438d9b9c9d9e6146e4565b9b6146e4565b998a976146e4565b8b9188938d8180849c1691161161449c575b8281169084811682116144615750505050906143bb929161586e565b905b614425575b5050836143d9575b808080808080808e9d9c614216565b614411612dd99593640757b12c0061440b6144199a9b9997956144066103e89660018060801b039861416f565b61416f565b0461416f565b041691615845565b903880808080806143ca565b8299916103e861445087640757b12c0061440b612dd9966144066144599a60018060801b039861416f565b041687896157f9565b9638806143c2565b9091929699508493959416116000146144915750926144858261448b94958361586e565b936158d3565b936143bd565b935061448b926158d3565b8d94508c935061439f565b909d97627fffff1981146144c757979d509096019561438561437f61436b565b634e487b7160e01b835260118f52602483fd5b0760060b151590503880614364565b634e487b7160e01b845260118352602484fd5b634e487b7160e01b845260128352602484fd5b634e487b7160e01b835260118252602483fd5b90919293503d8086863e614536818661364b565b8401918185840312612c9a578451818111612cb95785019483601f87011215612cb9578551956145658761366e565b966145728551988961364b565b808852868089019160051b8301019186831161462d578701905b8282106146105750505084810151918211612cb9570182601f82011215612c9a5783808251936145c76145be8661366e565b9151918261364b565b848152019260051b820101928311612c9a578301905b8282106145f15750505050388080806142fb565b81516001600160581b0381168103612cb95781529083019083016145dd565b81518060060b810361462957815290870190870161458c565b8a80fd5b8980fd5b513d86823e3d90fd5b8451821686528d98508b97509485019493909301926001909101906142d9565b50634e487b7160e01b875260418d52602487fd5b50505050509a50505050505050505050915090565b61469a9150843d8611611dc557611db6818361364b565b38614270565b85513d88823e3d90fd5b505050509a50505050505050505050915090565b634e487b7160e01b85526011600452602485fd5b508a1515614211565b508b151561420b565b8060020b908160171d60020b80910160020b189062ffffff8216620d89e88111614a2957600160801b9260018116614a11575b600281166149f5575b600481166149d9575b600881166149bd575b601081166149a1575b60208116614985575b60408116614969575b60809182821661494e575b6101008216614933575b6102008216614918575b61040082166148fd575b61080082166148e2575b61100082166148c7575b61200082166148ac575b6140008216614891575b6180008216614876575b62010000821661485b575b620200008216614841575b62040000809110156147f4575b5050506000126147eb575b63ffffffff0160201c6001600160a01b031690565b600019046147d6565b8116614827575b620800001661480c575b80806147cb565b6b048a170391f7dc42444e8fa26000929302901c9190614805565b6d2216e584f5fa1ea926041bedfe98909302811c926147fb565b936e5d6af8dedb81196699c329225ee60402821c936147be565b936f09aa508b5b7a84e1c677de54f3e99bc902821c936147b3565b936f31be135f97d08fd981231505542fcfa602821c936147a8565b936f70d869a156d2a1b890bb3df62baf32f702821c9361479e565b936fa9f746462d870fdf8a65dc1f90e061e502821c93614794565b936fd097f3bdfd2022b8845ad8f792aa582502821c9361478a565b936fe7159475a2c29b7443b29c7fa6e889d902821c93614780565b936ff3392b0822b70005940c7a398e4b70f302821c93614776565b936ff987a7253ac413176f2b074cf7815e5402821c9361476c565b936ffcbe86c7900a88aedcffc83b479aa3a402821c93614762565b936ffe5dee046a99a2a811c461f1969c305302821c93614758565b926fff2ea16466c96a3843ec78b326b528610260801c9261474d565b926fff973b41fa98c081472e6896dfb254c00260801c92614744565b926fffcb9843d60f6159c9db58835c9266440260801c9261473b565b926fffe5caca7e10e4e61c3624eaa0941cd00260801c92614732565b926ffff2e50f5f656932ef12357cf3c7fdcc0260801c92614729565b926ffff97272373d413259a46990580e213a0260801c92614720565b6ffffcb933bd6fad37aa2d162d1a5940019350614717565b604051633c10250f60e01b8152600490fd5b6024356001600160801b03811681036105ba5790565b6044356001600160801b03811681036105ba5790565b6064356001600160801b03811681036105ba5790565b6000198114613b9c5760010190565b805115613d745760200190565b805160011015613d745760400190565b8051821015613d745760209160051b010190565b51906001600160801b03821682036105ba57565b91908260409103126105ba576138056020614aeb84614abd565b9301614abd565b6001600160a01b039091168152600291820b602082015291900b60408201526001600160801b0391821660608201529116608082015260a00190565b6001600160801b039182169082160391908211613b9c57565b15614b4e57565b60405162461bcd60e51b8152602060048201526014602482015273507269636520736c69707061676520636865636b60601b6044820152606490fd5b60018060501b03166000526010602052613805604060002060405190614baf826135b0565b80546001600160a01b0390811683526001909101541660208201527f0000000000000000000000000000000000000000000000000000000000000000615905565b919082549060031b91821b91600019901b1916179055565b805461ffff60a01b191660a09290921b61ffff60a01b16919091179055565b818114614cdc57815491600160401b831161127b578154838355808410614cb3575b506000526020600020906000526020600020906000905b838210614c6d5750505050565b806001918403614c86575b928101929181019101614c60565b818060a01b03815416828060a01b0319855416178455614cae61ffff825460a01c1685614c08565b614c78565b6000838152846020822092830192015b828110614cd1575050614c49565b818155600101614cc3565b5050565b614cec61080582613f47565b60009081526011602052604090205460581c6001600160a01b031690565b614d149033613905565b15614d1b57565b60405162461bcd60e51b815260206004820152600c60248201526b139bdd08185c1c1c9bdd995960a21b6044820152606490fd5b519081151582036105ba57565b60405163e8ae2b6960e01b8152600080516020615cdd83398151915260048201523360248201526020816044817f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03165afa9081156105c657600091614dcc575b50156105ba57565b906020823d8211614dfd575b81614de56020938361364b565b810103126105e05750614df790614d4f565b38614dc4565b3d9150614dd8565b600060443d1061380557604051600319913d83016004833e81516001600160401b03918282113d602484011117614e6257818401948551938411614e6a573d85010160208487010111614e6257506138059291016020019061364b565b949350505050565b50949350505050565b6000818152600d602052604081205490926001600160a01b03918216918215614f9557600a5416918215614f95578214614eae575b50505050565b813b15610a10578391604483926040519485938492626e65c960e41b845288600485015260248401525af19081614f82575b50614f7b576001908260033d11614f6b575b806308c379a014614f6257634e487b7114614f18575b5061090257505b38808080614ea8565b8260233d11614f54575b15614f08578291507f4f27462fbdc9bce16bb573a06acba6b27394e151da96ce8098d8e29a6dc8d64b8280a238614f08565b5060206004843e6001614f22565b50614f22614e05565b50600483803e825160e01c614ef2565b5050614f0f565b614f8e909391936135e7565b9138614ee0565b5050505050565b816000526011602052614fb3816040600020613e4d565b6001600160a01b0380614fc5846137e2565b169116907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600080a4565b307f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031614806150e1575b1561504b577f000000000000000000000000000000000000000000000000000000000000000090565b60405160208101907f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f82527f000000000000000000000000000000000000000000000000000000000000000060408201527f000000000000000000000000000000000000000000000000000000000000000060608201524660808201523060a082015260a081526150db81613630565b51902090565b507f00000000000000000000000000000000000000000000000000000000000000004614615022565b8051602082015160405193916001600160a01b03918216911661512c856135b0565b8452602084019081526001600160a01b03615167857f0000000000000000000000000000000000000000000000000000000000000000615905565b16606061517382615a79565b818601615286615186825160020b6146e4565b926080890193615199855160020b6146e4565b60a08b015160c08c015190929082826001600160a01b038083169082161161537a575b50506001600160a01b0385811695908316861161531e5750506151df93506157f9565b985b8960018060a01b0360408b015116935160020b945160020b976020604051615208816135b0565b8481523391019081526040805194516001600160a01b0390811660208701529251831690850152511686830152858252615241826135fa565b60405197889586956302abf8a760e61b875233600488015260248701526044860152606485015260018060801b0316608484015260c060a484015260c4830190613519565b03816000855af19283156105c657600093849385916152cf575b506152bd9095848660e0830151111591826152bf575b5050614b47565b565b61010001511115905038806152b6565b94919350506060843d606011615316575b816152ed6060938361364b565b810103126105e057508251916152bd61530d604060208701519601614abd565b939493906152a0565b3d91506152e0565b919490939192906001600160a01b038216111561536e5782916153459161534b95946157f9565b93615845565b6001600160801b03818116908316101561536757505b986151e1565b9050615361565b91505061536192615845565b9350915038806151bc565b6040516370a0823160e01b815230600482015290602090829060249082906001600160a01b03165afa9081156105c6576000916153c0575090565b906020823d82116153e6575b816153d96020938361364b565b810103126105e057505190565b3d91506153cc565b6001600160a01b039091168152602081019190915260400190565b9293926001600160a01b037f00000000000000000000000000000000000000000000000000000000000000008116929091908282168414806155e8575b1561550857505050803b156105ba57604051630d0e30db60e41b815293600091828660048185855af1958615611bb7576154a295966154f6575b50829360209360405180978195829463a9059cbb60e01b8452600484016153ee565b03925af180156154e9576154b4575050565b6020823d82116154e1575b816154cc6020938361364b565b810103126105e057506154de90614d4f565b50565b3d91506154bf565b50604051903d90823e3d90fd5b926155026020946135e7565b92615480565b9495948216949392509030850361552457506152bd9350615be4565b604093919293519360208501956323b872dd60e01b8752602486015216604484015260648301526064825260a082019282841060018060401b0385111761127b576000809493819460405251925af161557b613c5f565b816155b1575b506152bd5760405162461bcd60e51b815260206004820152600360248201526229aa2360e91b6044820152606490fd5b80518015925082156155c6575b505038615581565b81925090602091810103126105ba5760206155e19101614d4f565b38806155be565b5086471015615446565b42116155fa57565b60405162461bcd60e51b8152602060048201526013602482015272151c985b9cd858dd1a5bdb881d1bdbc81bdb19606a1b6044820152606490fd5b1561563c57565b60405162461bcd60e51b8152602060048201526017602482015276496e76616c6964206f72646572206f6620746f6b656e7360481b6044820152606490fd5b6001600160a01b0391821681529116602082015260400190565b6001600160a01b039081169190823b156105ba57602460009283604051958694859363f637731d60e01b85521660048401525af180156105c6576156d65750565b6152bd906135e7565b92946001600160a01b0390931693919291843b156105ba5760009460e493869260ff604051998a98899763d505accf60e01b89523360048a01523060248a01526044890152606488015216608486015260a485015260c48401525af180156105c6576156d65750565b92946001600160a01b0390931693919291843b156105ba5760009461010493869260ff604051998a9889976323f2ebc360e21b89523360048a01523060248a015260448901526064880152600160848801521660a486015260c485015260e48401525af180156105c6576156d65750565b60206040518092636eb1769f60e11b825281806157da30336004840161567b565b03916001600160a01b03165afa9081156105c6576000916153c0575090565b61582b9291906001600160a01b03908183168282161161583f575b61582282841683831661400e565b920316916140da565b6001600160801b0381169081036105ba5790565b91615814565b61582b92916001600160a01b03919082811683831611615868575b031690614055565b90615860565b916001600160a01b039190828216838516116158cb575b6158a891838116919085900384169060601b600160601b600160e01b03166140da565b91169081156158b5570490565b634e487b7160e01b600052601260045260246000fd5b909290615885565b61380592916001600160a01b039190828116838316116158ff575b0316906001600160801b031661400e565b906158ee565b60018060a01b03916159426159508480808551169461592c60208201968388511611615635565b511693511660405192839160208301958661567b565b03601f19810183528261364b565b51902060405190602082019260ff60f81b845260018060601b03199060601b16602183015260358201527ff96d2474815c32e070cd63233f06af5413efc5dcb430aee4ff18cc29007c562d6055820152605581526159ad816135fa565b5190201690565b60a09293602491604051958694859363514ea4bf60e01b855262ffffff80911692169060181b1760181b176004830152600180861b03165afa9081156105c65760009182938380938193615a0b575b509493929190565b9450925093505060a0823d8211615a62575b81615a2a60a0938361364b565b810103126105e0575080516020820151604083015193615a586080615a5160608701614abd565b9501614abd565b9194939238615a03565b3d9150615a1d565b519061ffff821682036105ba57565b6040516339db007960e21b8152906001600160a01b039060c0908390600490829085165afa9182156105c657600092615ab157505090565b909160c0823d8211615b25575b81615acb60c0938361364b565b810103126105e057815192831683036105e05760208201518060020b036105e057615af860408301615a6a565b50606082015160ff8116036105e0575060a081615b1a6080615b219401615a6a565b5001614d4f565b5090565b3d9150615abe565b9392604092835192631d9de38760e11b845260020b600484015260020b602483015260018060801b0316604482015260806064820152600360848201526203078360ec1b60a4820152818160c4816000809860018060a01b03165af1938415615bd95780928195615ba0575b5050509190565b919450915083813d8111615bd2575b615bb9818361364b565b810103126105e057506020825192015191388080615b99565b503d615baf565b8251903d90823e3d90fd5b6000929183615942615c0f8295604051928391602083019663a9059cbb60e01b8852602484016153ee565b51925af1615c1b613c5f565b81615c53575b5015615c2957565b60405162461bcd60e51b815260206004820152600260248201526114d560f21b6044820152606490fd5b8051801592508215615c68575b505038615c21565b81925090602091810103126105ba576020615c839101614d4f565b3880615c60565b6000808093819382604051615c9e81613615565b525af1615ca9613c5f565b5015615cb157565b60405162461bcd60e51b815260206004820152600360248201526253544560e81b6044820152606490fdfeff0e0466f109fcf4f5660899d8847c592e1e8dea30ffbe040704b23ad381d7628a82de7fe9b33e0e6bca0e26f5bd14a74f1164ffe236d50e0a36c3ea70f2b81449ecf333e5b8c95c40fdafc95c1ad136e8914a8fb55e9dc8bb01eaa83a2df9adddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa164736f6c6343000814000a290decd9548b62a8d60345a988386fc84ba6bc95484008f6362f93160ef3e563b10e2d527612073b26eecdfd717e6a320cf44b4afac2b0732d9fcbe2b7fa0cf60000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd3016794000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad380000000000000000000000003e61919eed4fe4754afe390b45b3c1e9c712411a000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188000000000000000000000000f0f62ed4f66572fab5ed4513b99e53bb2660f42a

    Deployed Bytecode

    0x6080806040526004361015610085575b50361561001b57600080fd5b7f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b0316330361004d57005b60405162461bcd60e51b815260206004820152601060248201526f2737ba102ba730ba34bb32aa37b5b2b760811b6044820152606490fd5b600090813560e01c90816301ffc9a71461346f5750806306fdde03146133cd578063081812fc146133ae578063095ea7b3146132805780630c49ccbe14612ddf57806312e724ba14612cbd578063135e53e01461288c57806318160ddd1461286e578063219f5d171461266657806323b872dd1461263c5780632d0b22de146126095780632f745c591461255c57806330adf81f146125335780633119049a146124ee5780633644e515146124d35780633dd657c51461235a5780633edc23321461226d578063418652701461224f57806342842e0e1461222757806342966c6814611f7e578063430c208114611f405780634659a49414611f275780634d10862d14611eb95780634f6ccce714611e2757806351246d6e14611ca35780636301727b14611c345780636352211e14611c0357806369bc35b214611b0657806370227515146119f757806370a08231146119cb5780637ac2ff7b146116e2578063832f630a1461166457806385535cc51461161c5780638692bd7d146115135780638af3ac85146114ce57806395d89b41146113e057806399fbab88146112d55780639cc1a28314610d61578063a22cb46514610c93578063a4a78f0c14610c67578063aa7e1abd14610bc8578063ac9650d814610a3d578063b227aa7914610a14578063b88d4fde14610987578063c2e3140a14610953578063c45a01551461090e578063c87b56dd146107e3578063d73792a9146107c6578063dba5281f1461079d578063dd56e5d814610774578063df2ab5bb146106f1578063e7ce18a3146106be578063e985e9c51461066a578063f143536d14610611578063f3995c67146105f55763fc6f78650361000f5760803660031901126105e05761030d600435614d0a565b6001600160801b03908161031f614a51565b16158015906105e3575b156105e0576001600160a01b0361033e613e17565b166105d25730915b60043582526011602052604082206001810154936001600160a01b036103746001600160501b038716614b8a565b16946004830154958487169660801c938260801c8061050b575b50610397614a51565b88871690871611156104fb578788925b6103af614a67565b87891690891611156104eb5786998a955b876040519c8d9384936309e3d67b60e31b85528060681c60020b9060501c60020b60048601946103ef95614af2565b03818b5a94604095f19586156104e057604099899761048f575b50916004888587969461042483809a81990316858701613e76565b9390920180546001600160801b031916929093031617905588516001600160a01b0390951685521660208401521681860152600435907f40d0efd1a53d60ecbf40971b9daf7dc90178c3aadc7aab1765632738fa8b8f0190606090a281845193168352166020820152f35b8599508880969581959399508094610424838f6004966104c4913d6040116104d9575b6104bc818361364b565b810190614ad1565b9f909f9d979950505050945095965050610409565b503d6104b2565b6040513d8a823e3d90fd5b6104f3614a67565b998a956103c0565b610503614a51565b9788926103a7565b90949760405191631d9de38760e11b83528460501c60020b8060048501528560681c60020b908160248601526000604486015260806064860152600360848601526203078360ec1b60a486015260408560c48160008a5af19485156105c6578a9561058e575b509161058191859330888c613f7d565b920116980116933861038e565b60408092939496503d83116105bf575b6105a8818361364b565b810103126105ba579088939138610571565b600080fd5b503d61059e565b6040513d6000823e3d90fd5b6105da613e17565b91610346565b80fd5b50816105ed614a67565b161515610329565b5061060e610602366136ba565b949390939291926156df565b80f35b50346105e05760203660031901126105e0576040809160043581526012602052206020825191610640836135b0565b5463ffffffff811680845290821c6001600160801b03169190920181905282519182526020820152f35b50346105e05760403660031901126105e05761068461353e565b604061068e613554565b9260018060a01b0380931681526005602052209116600052602052602060ff604060002054166040519015158152f35b50346105e05760203660031901126105e0576020906004358152600d8252604060018060a01b0391205416604051908152f35b5060603660031901126105e05761070661353e565b61070e61356a565b61071782615385565b90602435821061073a578161072a578380f35b61073392615be4565b3880808380f35b60405162461bcd60e51b815260206004820152601260248201527124b739bab33334b1b4b2b73a103a37b5b2b760711b6044820152606490fd5b50346105e057806003193601126105e057600a546040516001600160a01b039091168152602090f35b50346105e057806003193601126105e057600b546040516001600160a01b039091168152602090f35b50346105e057806003193601126105e05760206040516103e88152f35b50346105e0576020806003193601126108fa5760043561080a61080582613f47565b61379b565b60405163e9dc637560e01b8152306004820152602481019190915282816044817f0000000000000000000000003e61919eed4fe4754afe390b45b3c1e9c712411a6001600160a01b03165afa92831561090257809361087e575b505061087a604051928284938452830190613519565b0390f35b909192503d8082843e610891818461364b565b82019183818403126108fa578051906001600160401b0382116108fe570182601f820112156108fa578051916108c683613709565b936108d4604051958661364b565b8385528584840101116105e05750906108f2918480850191016134f6565b903880610864565b5080fd5b8280fd5b604051903d90823e3d90fd5b50346105e057806003193601126105e0576040517f0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd30167946001600160a01b03168152602090f35b5061095d366136ba565b938061096b879593956157b9565b10610974578680f35b61097d956156df565b3880808080808680f35b50346105e05760803660031901126105e0576109a161353e565b6109a9613554565b90606435906001600160401b038211610a105736602383011215610a1057816004013592846109d785613709565b936109e5604051958661364b565b85855236602487830101116108fa578561060e9660246020930183880137850101526044359161386a565b8380fd5b50346105e057806003193601126105e0576020604051600080516020615cdd8339815191528152f35b506020806003193601126108fa576001600160401b0391600435908382116105e057366023830112156105e0578160040135918483116108fa5760059460243685881b8401820111610a1057610a9485939561366e565b94610aa2604051968761364b565b838652601f19610ab18561366e565b0187865b828110610bb857505050368190036042190190855b858110610b31575050505050506040519280840190808552835180925280604083818801981b870101940192955b828710610b055785850386f35b909192938280610b21600193603f198a82030186528851613519565b9601920196019592919092610af8565b83818b1b8301013583811215610bb45782018481013590868211610bb0576044018136038113610bb057818992918392604051928392833781018381520390305af4610b7b613c5f565b9015610ba15790600191610b8f828b614aa9565b52610b9a818a614aa9565b5001610aca565b8051908a8983156105e0575001fd5b8880fd5b8780fd5b6060898201830152899101610ab5565b50346105e05760603660031901126105e057610be261353e565b6001600160401b0360243581811692908390036105ba576044359182168083036105ba57610c0e614d5c565b6103e8808511159182610c5c575b505015610a10576001600160a01b03168352600e602052604080842080546001600160801b03191690931791901b600160401b600160801b031617905580f35b111590503880610c1c565b50610c71366136ba565b93909290600019610c81876157b9565b10610c8a578680f35b61097d95615748565b50346105e05760403660031901126105e057610cad61353e565b610cb56136fa565b6001600160a01b0390911690338214610d20573383526005602052604083208260005260205260406000209015159060ff1981541660ff83161790556040519081527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3160203392a380f35b60405162461bcd60e51b815260206004820152601960248201527822a9219b99189d1030b8383937bb32903a379031b0b63632b960391b6044820152606490fd5b506101403660031901126105e057610d7b610124356155f2565b610dfb610d86613e01565b610d8e613e17565b610d96613e2d565b610d9e613e3d565b9160405193610dac856135cb565b6001600160a01b039081168552166020840152306040840152600290810b60608401520b608082015260843560a082015260a43560c082015260c43560e082015260e43561010082015261510a565b939493909290610104356001600160a01b03811690036105ba57601380546001600160b01b031981166001600160b01b03808316600101161790915594610104356001600160a01b03161561129157610e65610e5f6001600160b01b038816613f47565b15613efc565b6008546001600160b01b038716600090815260096020526040902081905590600160401b82101561127b576080976111a36111cd92610ecc610ebc866001600080516020615cfd8339815191529801600855613d59565b6001600160b01b038d1691614bf0565b610ed861010435613724565b610104356001600160a01b0316600090815260066020908152604080832084845282528083206001600160b01b038f1690819055808452600790925290912091909155610f2890610e5f90613f47565b610104356001600160a01b0316808252600360209081526040808420805460010190556001600160b01b038d168085526002909252832080546001600160a01b031916831790559082600080516020615d3d8339815191528180a461114d610fa1610f91613e2d565b610f99613e3d565b90308a6159b4565b5050909150610fae613e01565b91610fb7613e17565b60405193610fc4856135b0565b6001600160a01b039081168552908116602080860191909152908b168652600f90526040852080546001600160501b03169384156111f6575b5050611007613e2d565b61100f613e3d565b906040519461101d86613594565b87865287602087015260018060501b0316604086015260020b606085015260020b8f84015260018f81901b038b1660a084015260c083015260e0820152826101008201528261012082015260018060b01b038c1683526011602052604083209060018060581b0381511660018060581b03198354161782556110ab60018060a01b0360208301511683613e4d565b6004600183019261110e60018060501b0360408501511694805495606086015160501b96608087015160681b62ffffff60681b16916080600180911b0319809962ffffff60501b16921617171781556080600180911b0360a08601511690613e76565b60c0830151600282015560e08301516003820155019160018f81901b03610100830151169083541617825561012060018f81901b039101511690613e76565b6040519061115a826135b0565b4263ffffffff908116835260208084018381526001600160b01b038e168452601290915260409092209251835463ffffffff191691161782555160001960018d1b011690613e99565b6040516001600160b01b038916949092839290916001600160a01b03169089908990899086613ec2565b0390a26040519360018060b01b03168452600180861b0316602084015260408301526060820152f35b601380546001600160b01b038116600160b092831c81810190931b6001600160b01b0319169190911790925583546001600160501b03191681179093558288526010602090815260408920835181546001600160a01b03199081166001600160a01b039283161783559290940151920180549091169190921617905592503880610ffd565b634e487b7160e01b600052604160045260246000fd5b606460405162461bcd60e51b815260206004820152602060248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152fd5b50346105e05760203660031901126105e057600435815260116020526040812060018101546001600160501b03811680156113a8578360409161016095526010602052209180549260018060a01b0392836001818454169301541660028401549260046003860154950154956040519760018060581b038116895260581c166020880152604087015260608601528060501c60020b60808601528060681c60020b60a086015260801c60c085015260e084015261010083015260018060801b03811661012083015260801c610140820152f35b60405162461bcd60e51b815260206004820152601060248201526f125b9d985b1a59081d1bdad95b88125160821b6044820152606490fd5b50346105e057806003193601126105e057604051908060019182549283811c928185169485156114c4575b60209586861081146114b05785885287949392918790821561148e575050600114611453575b505061143f9250038361364b565b61087a604051928284938452830190613519565b908592508082528282205b85831061147657505061143f93508201013880611431565b8054838901850152879450869390920191810161145e565b925093505061143f94915060ff191682840152151560051b8201013880611431565b634e487b7160e01b83526022600452602483fd5b93607f169361140b565b50346105e057806003193601126105e0576040517f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b03168152602090f35b50346105e057602090816003193601126105e05761152f61353e565b9060608060405161153f816135fa565b8381528386820152836040820152015260018060a01b038092168152600e83526040812090604051611570816135fa565b82549460018060401b0394858716835281830195808860401c168752604084019761ffff9889809260801c1681526115ab6001809901613d8a565b926060870193845260405199868b528160a08c01985116878c0152511660408a015251166060880152519660808088015287518094528260c08801980194915b8483106115f85787890388f35b8551805182168a528401518216848a015260409098019794830194918601916115eb565b50346105e05760203660031901126105e05761163661353e565b61163e614d5c565b6001600160a01b031680156108fa57600b80546001600160a01b03191691909117905580f35b5060603660031901126105e05760043561167c6136fa565b9061168561356a565b61168e82614d0a565b83926116c1575b508252600c6020526040822080546001600160a01b0319166001600160a01b0390921691909117905580f35b600a54919250906001600160a01b03908116908216036108fe579038611695565b506116ec366136ba565b908392969593421161199557611700614ff0565b85875260209760118952604088209182549260018060581b03938481169460018601169060018060581b0319161790556040518a810190600080516020615d1d833981519152825260018060a01b0397888a16958660408401528b6060840152608083015260a082015260a0815261177781613630565b519020604051908b82019261190160f01b845260228301526042820152604281526117a1816135fa565b519020936117ae886137e2565b868116809414611940578a94939291908a903b156118b957506118209596506040519385850152604084015260ff60f81b9060f81b166060830152604182526117f6826135fa565b6040518080958194630b135d3f60e11b988984526004840152604060248401526044830190613519565b03915afa9081156118ae578591611881575b506001600160e01b0319160361184d5761060e929350614f9c565b60405162461bcd60e51b815260048101859052600c60248201526b155b985d5d1a1bdc9a5e995960a21b6044820152606490fd5b6118a19150863d88116118a7575b611899818361364b565b810190613c3f565b38611832565b503d61188f565b6040513d87823e3d90fd5b9360ff60809498979360405194855216868401526040830152606082015282805260015afa156119355784511680156118fc570361184d5761060e929350614f9c565b60405162461bcd60e51b8152600481018790526011602482015270496e76616c6964207369676e617475726560781b6044820152606490fd5b6040513d86823e3d90fd5b60405162461bcd60e51b8152600481018c9052602760248201527f4552433732315065726d69743a20617070726f76616c20746f2063757272656e6044820152663a1037bbb732b960c91b6064820152608490fd5b60405162461bcd60e51b815260206004820152600e60248201526d14195c9b5a5d08195e1c1a5c995960921b6044820152606490fd5b50346105e05760203660031901126105e05760206119ef6119ea61353e565b613724565b604051908152f35b50346105e05760403660031901126105e057600435611a146136fa565b600a546001600160a01b03908116338114939192859015611ae75750818552600c602052808360408720541603611aa757925b15611a6d578352600d6020526040832080546001600160a01b0319169190921617905580f35b60405162461bcd60e51b815260206004820152601260248201527127b7363c902330b936b4b733a1b2b73a32b960711b6044820152606490fd5b60405162461bcd60e51b81526020600482015260186024820152774e6f7420617070726f76656420666f72206661726d696e6760401b6044820152606490fd5b93905080611a475750808452600d602052816040852054163314611a47565b5060403660031901126105e057611b1b613554565b907f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad38611b4681615385565b906004358210611bc25781611b59578280f35b6001600160a01b0316803b156108fe57828091602460405180948193632e1a7d4d60e01b83528760048401525af18015611bb757611ba4575b50611b9d9192615c8a565b8038808280f35b91611bb1611b9d936135e7565b91611b92565b6040513d85823e3d90fd5b60405162461bcd60e51b815260206004820152601960248201527824b739bab33334b1b4b2b73a102ba730ba34bb32aa37b5b2b760391b6044820152606490fd5b50346105e05760203660031901126105e0576020611c226004356137e2565b6040516001600160a01b039091168152f35b50346105e05760403660031901126105e057611c4e61353e565b6024359061ffff8216808303610a10576103e890611c6a614d5c565b116108fe576001600160a01b03168252600e60205260408220805461ffff60801b191660809290921b61ffff60801b1691909117905580f35b5060603660031901126105e057611cb861353e565b90611cc1613554565b906001600160a01b0360443581811681036108fe57611ce582851683871610615635565b817f0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd301679416936040519463d9a641e160e01b8652602096878780611d2b86856004840161567b565b0381855afa968715611e1c5790889392918798611dfd575b508786811680611dcc57505086611d74959697985060405180968195829463e343361560e01b84526004840161567b565b03925af19384156109025793611d99575b50611d909083615695565b60405191168152f35b611d90919350611dbe90853d8711611dc5575b611db6818361364b565b810190614150565b9290611d85565b503d611dac565b925095965050859250611ddf9150615a79565b1615611ded575b5050611d90565b611df691615695565b3880611de6565b611e15919850843d8611611dc557611db6818361364b565b9638611d43565b6040513d88823e3d90fd5b50346105e05760203660031901126105e057600435600854811015611e5f57611e51602091613d59565b90546040519160031b1c8152f35b60405162461bcd60e51b815260206004820152602c60248201527f455243373231456e756d657261626c653a20676c6f62616c20696e646578206f60448201526b7574206f6620626f756e647360a01b6064820152608490fd5b50346105e05760203660031901126105e0577f29f9e1ebeee07596f3165f3e42cb9d4d8d22b0481e968d6c74be3dd037c15d9b6020611ef661353e565b611efe614d5c565b600a80546001600160a01b0319166001600160a01b03929092169182179055604051908152a180f35b5061060e611f34366136ba565b94939093929192615748565b50346105e05760403660031901126105e0576020611f74611f5f61353e565b60243590611f6f61080583613f47565b613905565b6040519015158152f35b506020806003193601126108fa5760043590611f9982614d0a565b81835260118152826040812060018101908154916004820192835460018060801b0391828260801c92169060801c171716610a10578382558390556002810183905560030182905555600d81526040832080546001600160a01b0319908116909155612004836137e2565b6001600160a01b039290838116908115801590816121f9575b156121615750505060085484865260098252806040872055600160401b81101561214d578461205582600161205b9401600855613d59565b90614bf0565b60085460001993908481019081116121395785875260098352612082604088205491613d59565b90549060031b1c6120968161205584613d59565b8752600983526040872055848652856040812055600854801561212557916002918588969594016120c681613d59565b8782549160031b1b191690556008556120de876137e2565b8787526004835260408720858154169055169384865260038252604086209081540190558585525260408320908154169055600080516020615d3d8339815191528280a480f35b634e487b7160e01b87526031600452602487fd5b634e487b7160e01b87526011600452602487fd5b634e487b7160e01b86526041600452602486fd5b61216d575b505061205b565b61217690613724565b600019810191908211612139578587526007835260408720548281036121bd575b508587528660408120558652600682526040862090865281528460408120553880612166565b8188526006845260408820838952845260408820548289526006855260408920828a5285528060408a2055885260078452604088205538612197565b878952601185526040808a208054600160581b600160f81b0319169055600c8652892080548716905561201d565b50346105e05761060e61223936613685565b906040519261224784613615565b85845261386a565b50806003193601126105e057476122635780f35b61060e4733615c8a565b50346105e05760203660031901126105e057610120611d90602092600435908181526011855260408120604051916122a483613594565b815460018060581b038116845260018060a01b039060581c168784015260018201549263ffffffff604060018060501b03861693848285015261233d60608501958860501c60020b8752600460808701988a60681c60020b8a5260a088019a60801c8b52600281015460c0890152600381015460e089015201549560018060801b039c878e80991661010084015260801c910152614b8a565b97815260128b52205416915160020b925160020b93511693614182565b50346105e05760603660031901126105e0576004356024356044356001600160401b038082116124cf57366023830112156124cf5781600401359081116124cf5781013660248201116124cf5781900392606084126124cf5760408051946123c1866135b0565b126124cf5761243d906124046064604051946123dc866135b0565b6123e860248201613580565b86526123f660448201613580565b602087015285885201613580565b60208601908152926001600160a01b039283917f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188615905565b16330361248d5780612472575b5082612454578480f35b80602061246a9551015116903392511690615409565b388080808480f35b61248790828651511633908486511690615409565b3861244a565b60405162461bcd60e51b815260206004820152601a602482015279496e76616c69642063616c6c6572206f662063616c6c6261636b60301b6044820152606490fd5b8480fd5b50346105e057806003193601126105e05760206119ef614ff0565b50346105e057806003193601126105e0576040517f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a91886001600160a01b03168152602090f35b50346105e057806003193601126105e0576020604051600080516020615d1d8339815191528152f35b50346105e05760403660031901126105e05761257661353e565b6024359161258382613724565b8310156125b05760209260409260018060a01b031682526006845282822090825283522054604051908152f35b60405162461bcd60e51b815260206004820152602b60248201527f455243373231456e756d657261626c653a206f776e657220696e646578206f7560448201526a74206f6620626f756e647360a81b6064820152608490fd5b50346105e05760203660031901126105e0576020906004358152600c8252604060018060a01b0391205416604051908152f35b50346105e05761060e61264e36613685565b9161266161265c8433613905565b613808565b6139cd565b5060c03660031901126105e05761278760609161268460a4356155f2565b6004358152601160205260408120906040600080516020615cfd833981519152612801600185015460018060501b038116855260106020526127ee6127e861273486882060018060a01b03815416906001808060a01b03910154168851916126eb836135cb565b8252602082015230888201528460501c60020b8c8201528460681c60020b608082015260243560a082015260443560c082015260643560e082015260843561010082015261510a565b949399929a919c909b61275a8860801c8960681c60020b8a60501c60020b308a86613f7d565b908082176001600160801b031661282c575b5050608088901c8c016001600160801b031690600101613e76565b60043581526012602052209160018060a01b03169382546127c363ffffffff928060801c908060681c60020b9060501c60020b8585168a614182565b63ffffffff19909116429092169190911780845560201c6001600160801b0316613f64565b90613e99565b6040519182918789886004359886613ec2565b0390a26001600160801b03169161281a83600435614e73565b60405192835260208301526040820152f35b6004830180546001600160801b038082169390930183166001600160801b0319909116178082556128679360809190911c0190911690613e76565b388061276c565b50346105e057806003193601126105e0576020600854604051908152f35b50346105e05760603660031901126105e0576128a661353e565b906024356001600160401b038082116108fe57366023830112156108fe5781600401356128d28161366e565b926128e0604051948561364b565b8184526024602085019260051b82010190368211612c9a57602401915b818310612c9e575050506044359081116108fe57366023820112156108fe5780600401359061292b8261366e565b91612939604051938461364b565b8083526024602084019160051b83010191368311612c9a57602401905b828210612c8257505050612968614d5c565b8260018060a01b0385168152600e60205260016040822001938251845103612c3d57845415801590612c34575b612beb575b81905b8451821015612b4e576001600160a01b036129b88386614aa9565b511615612b0d576001600160a01b036129d18386614aa9565b511661ffff6129e08488614aa9565b5116604051916129ef836135b0565b825260208201528654600160401b811015612af95760018101808955811015612ae5579061ffff6020612a45938a8852818820019260018060a01b0381511660018060a01b031985541617845501511690614c08565b61ffff80612a538488614aa9565b511691160161ffff8111612ad15790612acb907fff5b7ae049a1a9fb20442c9c2abaa248c078a294b476cb51c8951028b775e46e60606001600160a01b03612a9b8489614aa9565b511661ffff612aaa858b614aa9565b51166040519160018060a01b038d16835260208301526040820152a1614a7d565b9061299d565b634e487b7160e01b83526011600452602483fd5b634e487b7160e01b85526032600452602485fd5b634e487b7160e01b85526041600452602485fd5b60405162461bcd60e51b815260206004820152601960248201527805661756c7420616464726573732063616e6e6f74206265203603c1b6044820152606490fd5b868684928751612b5c578380f35b61ffff6103e8911603612b93576001600160a01b039091168252600e60205260408220612b8c9190600101614c27565b8180808380f35b60405162461bcd60e51b815260206004820152602a60248201527f546f74616c20666565206d75737420626520657175616c20746f204645455f4460448201526922a727a6a4a720aa27a960b11b6064820152608490fd5b6001600160a01b0386168252600e6020526040822060010180548382559081612c16575b505061299a565b835260208320908101905b81811015612c0f57838155600101612c21565b50835115612995565b60405162461bcd60e51b815260206004820152601f60248201527f5661756c747320616e642066656573206c656e677468206d69736d61746368006044820152606490fd5b60208091612c8f84613580565b815201910190612956565b8580fd5b823561ffff81168103612cb9578152602092830192016128fd565b8680fd5b50346105e057602090816003193601126105e057611d9082612dd96101209360043590818152601184526040812060405191612cf883613594565b81546001600160581b038116845260581c6001600160a01b03168684015260018201546001600160501b0381166040808601829052605083901c600290810b60608801908152606885901c820b6080808a0191825295861c60a08a019081529288015460c08a0152600388015460e08a01526004909701546001600160801b038082166101008b0152951c9c9097019b909b52919994928a9291612d9b90614b8a565b96815260128952209160405192612db1846135b0565b54928263ffffffff8516948583528a1c1698899101525160020b925160020b93511693614182565b90613f64565b5060a03660031901126105e057612df7600435614d0a565b612e026084356155f2565b6001600160801b03612e12614a3b565b16156105e05760043581526011602052604081206001810154906001600160801b03612e3c614a3b565b168260801c106108fe576001600160a01b03612e606001600160501b038416614b8a565b16916004358452601260205260408420805490612eab612e988460801c8560681c60020b8660501c60020b63ffffffff87168a614182565b602084901c6001600160801b0316613f64565b608084901c6001600160801b038216111561327a57508260801c915b6001600160a01b0319164263ffffffff161790556001600160801b0381166130b4575b61305c90612fff612f8694612efd614a3b565b6001600160801b03612f1385608089901c614b2e565b166001600160801b0390911611156130a4576001612f34848760801c614b2e565b955b612fe1612f51888360681c60020b8460501c60020b8d615b2d565b99909a6044358c101580613098575b612f6990614b47565b8360801c908460681c60020b908560501c60020b90309089613f7d565b60048601918254908d878060801b0391888060801b0391898060801b03160116878060801b038316011690868060801b03191617808355858060801b0391868060801b03908d888060801b031601169060801c011690613e76565b84828060801b039188848060801b039160801c031603169101613e76565b604080516001600160801b0385811682528316602082015290810186905260608101859052600435907f5e41cd741a4f79d713bd0c5670fae681a19f07bb5eca4955e68e322e9e15287290608090a26001600160801b0392613f64565b16600160ff1b8114613084576130789060409403600435614e73565b82519182526020820152f35b634e487b7160e01b84526011600452602484fd5b506064358b1015612f60565b60016130ae614a3b565b95612f36565b6130cc818360681c60020b8460501c60020b87615b2d565b858793929352600e6020526130e660016040892001613d8a565b8781511560001461318b575050600b54604080516309e3d67b60e31b815294909285928392613144926001600160801b039081169291169060688a901c600290810b9160508c901c90910b906001600160a01b031660048701614af2565b038189895af18015611e1c57612f869461305c93612fff9261316d575b505b9450509050612eea565b6131859060403d6040116104d9576104bc818361364b565b50613161565b909394919692815b85518110156132625761ffff60206131ab8389614aa9565b510151169060406001600160a01b036131c4838a614aa9565b515116928b6103e86131f38c826131e28660018060801b039361416f565b0416936001600160801b039361416f565b041693613223835195869384936309e3d67b60e31b85528b60681c60020b908c60501c60020b9060048701614af2565b0381878a5af19182156119355761323f92613244575b50614a7d565b613193565b61325c9060403d6040116104d9576104bc818361364b565b50613239565b5092965050925061305c9150612fff612f8694613163565b91612ec7565b50346105e05760403660031901126105e05761329a61353e565b6024356001600160a01b03806132af836137e2565b16809184161461335f5780331490811561333e575b50156132d35761060e91614f9c565b60405162461bcd60e51b815260206004820152603d60248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f7420746f60448201527f6b656e206f776e6572206f7220617070726f76656420666f7220616c6c0000006064820152608490fd5b9050835260056020526040832033845260205260ff604084205416386132c4565b60405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b6064820152608490fd5b50346105e05760203660031901126105e0576020611c22600435614ce0565b50346105e057806003193601126105e0576040519080805491600183811c92818516948515613465575b60209586861081146114b05785885287949392918790821561148e57505060011461342a57505061143f9250038361364b565b908592508180528282205b85831061344d57505061143f93508201013880611431565b80548389018501528794508693909201918101613435565b93607f16936133f7565b9050346108fa5760203660031901126108fa5760043563ffffffff60e01b81168091036108fe576020925063780e9d6360e01b81149081156134b3575b5015158152f35b6380ac58cd60e01b8114915081156134e5575b81156134d4575b50386134ac565b6301ffc9a760e01b149050386134cd565b635b5e139f60e01b811491506134c6565b60005b8381106135095750506000910152565b81810151838201526020016134f9565b90602091613532815180928185528580860191016134f6565b601f01601f1916010190565b600435906001600160a01b03821682036105ba57565b602435906001600160a01b03821682036105ba57565b604435906001600160a01b03821682036105ba57565b35906001600160a01b03821682036105ba57565b61014081019081106001600160401b0382111761127b57604052565b604081019081106001600160401b0382111761127b57604052565b61012081019081106001600160401b0382111761127b57604052565b6001600160401b03811161127b57604052565b608081019081106001600160401b0382111761127b57604052565b602081019081106001600160401b0382111761127b57604052565b60c081019081106001600160401b0382111761127b57604052565b601f909101601f19168101906001600160401b0382119082101761127b57604052565b6001600160401b03811161127b5760051b60200190565b60609060031901126105ba576001600160a01b039060043582811681036105ba579160243590811681036105ba579060443590565b60c09060031901126105ba576004356001600160a01b03811681036105ba5790602435906044359060643560ff811681036105ba57906084359060a43590565b6024359081151582036105ba57565b6001600160401b03811161127b57601f01601f191660200190565b6001600160a01b0316801561374457600052600360205260406000205490565b60405162461bcd60e51b815260206004820152602960248201527f4552433732313a2061646472657373207a65726f206973206e6f7420612076616044820152683634b21037bbb732b960b91b6064820152608490fd5b156137a257565b60405162461bcd60e51b8152602060048201526018602482015277115490cdcc8c4e881a5b9d985b1a59081d1bdad95b88125160421b6044820152606490fd5b6000908152600260205260409020546001600160a01b031661380581151561379b565b90565b1561380f57565b60405162461bcd60e51b815260206004820152602d60248201527f4552433732313a2063616c6c6572206973206e6f7420746f6b656e206f776e6560448201526c1c881bdc88185c1c1c9bdd9959609a1b6064820152608490fd5b9061388e93929161387e61265c8433613905565b6138898383836139cd565b613c8f565b1561389557565b60405162461bcd60e51b8152806138ae600482016138b2565b0390fd5b60809060208152603260208201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b60608201520190565b906001600160a01b038080613919846137e2565b1693169183831493841561394c575b508315613936575b50505090565b61394291929350614ce0565b1614388080613930565b909350600052600560205260406000208260005260205260ff604060002054169238613928565b1561397a57565b60405162461bcd60e51b815260206004820152602560248201527f4552433732313a207472616e736665722066726f6d20696e636f72726563742060448201526437bbb732b960d91b6064820152608490fd5b6139f1916139da846137e2565b6001600160a01b0393848416939185168414613973565b838216938415613bee57839182158015613bb2575b15613af9575060085460008781526009602052604090208190559150600160401b82101561127b57613a6092613a4787612055856001899701600855613d59565b828603613ac6575b50613a59866137e2565b1614613973565b600080516020615d3d833981519152600084815260046020526040812060018060a01b03199081815416905583825260036020526040822060001981540190558482526040822060018154019055858252600260205284604083209182541617905580a4565b613acf90613724565b60406000878152600660205281812083825260205288828220558881526007602052205538613a4f565b858303613b0b575b50613a6092613a47565b613b16919250613724565b600019810191908211613b9c57613a609284926000908882526020906007825260409182842054828103613b65575b508a84528383812055868452600681528284209184525281205592613b01565b8785526006825283852083865282528385205488865260068352848620828752835280858720558552600782528385205538613b45565b634e487b7160e01b600052601160045260246000fd5b60008881526011602090815260408083208054600160581b600160f81b0319169055600c909152902080546001600160a01b0319169055613a06565b60405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b6064820152608490fd5b908160209103126105ba57516001600160e01b0319811681036105ba5790565b3d15613c8a573d90613c7082613709565b91613c7e604051938461364b565b82523d6000602084013e565b606090565b9192813b15613d5057602091613ce1916000604051958680958194630a85bd0160e11b9a8b845233600485015260018060a01b0380951660248501526044840152608060648401526084830190613519565b0393165af160009181613d30575b50613d2257613cfc613c5f565b80519081613d1d5760405162461bcd60e51b8152806138ae600482016138b2565b602001fd5b6001600160e01b0319161490565b613d4991925060203d81116118a757611899818361364b565b9038613cef565b50505050600190565b600854811015613d7457600860005260206000200190600090565b634e487b7160e01b600052603260045260246000fd5b908154613d968161366e565b92604093613da68551918261364b565b828152809460208092019260005281600020906000935b858510613dcc57505050505050565b60018481928451613ddc816135b0565b61ffff8754858060a01b038116835260a01c1683820152815201930194019391613dbd565b6004356001600160a01b03811681036105ba5790565b6024356001600160a01b03811681036105ba5790565b6044358060020b81036105ba5790565b6064358060020b81036105ba5790565b8054600160581b600160f81b03191660589290921b600160581b600160f81b0316919091179055565b80546001600160801b031660809290921b6001600160801b031916919091179055565b8054600160201b600160a01b03191660209290921b600160201b600160a01b0316919091179055565b6001600160801b03918216815291166020820152604081019190915260608101919091526001600160a01b03909116608082015260a00190565b15613f0357565b60405162461bcd60e51b815260206004820152601c60248201527b115490cdcc8c4e881d1bdad95b88185b1c9958591e481b5a5b9d195960221b6044820152606490fd5b6000908152600260205260409020546001600160a01b0316151590565b6001600160801b039182169082160191908211613b9c57565b959391613f8a93916159b4565b50509150926002850193613fb4613fc16003875484039460018060801b0393848092168097613fc7565b1698019384548603613fc7565b16945555565b8181029190600019828209918380841093039183830393600160801b93858511156105ba5714614004570990828211900360801b910360801c1790565b5050505060801c90565b8181029190600019828209918380841093039183830393600160601b93858511156105ba571461404b570990828211900360a01b910360601c1790565b5050505060601c90565b90606082901b90600160601b600019818509938380861095039480860395868511156105ba57146140d2579082910981806000031680920460028082600302188083028203028083028203028083028203028083028203028083028203028092029003029360018380600003040190848311900302920304170290565b505091500490565b9181830291600019818509938380861095039480860395868511156105ba57146140d2579082910981806000031680920460028082600302188083028203028083028203028083028203028083028203028083028203028092029003029360018380600003040190848311900302920304170290565b908160209103126105ba57516001600160a01b03811681036105ba5790565b81810292918115918404141715613b9c57565b90949291946000946000600160a01b6001900380941690818152602092600e8452604090818320968251936141b6856135fa565b885493600160401b6001900394858116875285808a8901988184861c168a528481019d8e61ffff809660801c1690526001016141f190613d8a565b606082015251169751169a511698861595861580976146db575b806146d2575b614228575b50505050505050505050505050909150565b63ffffffff809216824216038281116146be5782169889156146aa57835163ef01df4f60e01b815260049b9291839082908e9082905afa9081156146a0579087918791614683575b5016801561466e57845193606085018581108482111761465a57918c8e9692899489526002845286840191893684376142a885614a8c565b52846142b385614a99565b528851978894639d3a524160e01b86528860248701928701525180915260448501929186905b8983831061463a57505050505082809103915afa938415614631578594614522575b5050505061431261430b82614a99565b5191614a8c565b5160060b9060060b0396667fffffffffffff19667fffffffffffff8913818a121761450f578760060b9860060b89156144fc576000199181148a8314166144e95789810560020b9984821291826144da575b50506144a7575b505061438561437f61438d9b9c9d9e6146e4565b9b6146e4565b998a976146e4565b8b9188938d8180849c1691161161449c575b8281169084811682116144615750505050906143bb929161586e565b905b614425575b5050836143d9575b808080808080808e9d9c614216565b614411612dd99593640757b12c0061440b6144199a9b9997956144066103e89660018060801b039861416f565b61416f565b0461416f565b041691615845565b903880808080806143ca565b8299916103e861445087640757b12c0061440b612dd9966144066144599a60018060801b039861416f565b041687896157f9565b9638806143c2565b9091929699508493959416116000146144915750926144858261448b94958361586e565b936158d3565b936143bd565b935061448b926158d3565b8d94508c935061439f565b909d97627fffff1981146144c757979d509096019561438561437f61436b565b634e487b7160e01b835260118f52602483fd5b0760060b151590503880614364565b634e487b7160e01b845260118352602484fd5b634e487b7160e01b845260128352602484fd5b634e487b7160e01b835260118252602483fd5b90919293503d8086863e614536818661364b565b8401918185840312612c9a578451818111612cb95785019483601f87011215612cb9578551956145658761366e565b966145728551988961364b565b808852868089019160051b8301019186831161462d578701905b8282106146105750505084810151918211612cb9570182601f82011215612c9a5783808251936145c76145be8661366e565b9151918261364b565b848152019260051b820101928311612c9a578301905b8282106145f15750505050388080806142fb565b81516001600160581b0381168103612cb95781529083019083016145dd565b81518060060b810361462957815290870190870161458c565b8a80fd5b8980fd5b513d86823e3d90fd5b8451821686528d98508b97509485019493909301926001909101906142d9565b50634e487b7160e01b875260418d52602487fd5b50505050509a50505050505050505050915090565b61469a9150843d8611611dc557611db6818361364b565b38614270565b85513d88823e3d90fd5b505050509a50505050505050505050915090565b634e487b7160e01b85526011600452602485fd5b508a1515614211565b508b151561420b565b8060020b908160171d60020b80910160020b189062ffffff8216620d89e88111614a2957600160801b9260018116614a11575b600281166149f5575b600481166149d9575b600881166149bd575b601081166149a1575b60208116614985575b60408116614969575b60809182821661494e575b6101008216614933575b6102008216614918575b61040082166148fd575b61080082166148e2575b61100082166148c7575b61200082166148ac575b6140008216614891575b6180008216614876575b62010000821661485b575b620200008216614841575b62040000809110156147f4575b5050506000126147eb575b63ffffffff0160201c6001600160a01b031690565b600019046147d6565b8116614827575b620800001661480c575b80806147cb565b6b048a170391f7dc42444e8fa26000929302901c9190614805565b6d2216e584f5fa1ea926041bedfe98909302811c926147fb565b936e5d6af8dedb81196699c329225ee60402821c936147be565b936f09aa508b5b7a84e1c677de54f3e99bc902821c936147b3565b936f31be135f97d08fd981231505542fcfa602821c936147a8565b936f70d869a156d2a1b890bb3df62baf32f702821c9361479e565b936fa9f746462d870fdf8a65dc1f90e061e502821c93614794565b936fd097f3bdfd2022b8845ad8f792aa582502821c9361478a565b936fe7159475a2c29b7443b29c7fa6e889d902821c93614780565b936ff3392b0822b70005940c7a398e4b70f302821c93614776565b936ff987a7253ac413176f2b074cf7815e5402821c9361476c565b936ffcbe86c7900a88aedcffc83b479aa3a402821c93614762565b936ffe5dee046a99a2a811c461f1969c305302821c93614758565b926fff2ea16466c96a3843ec78b326b528610260801c9261474d565b926fff973b41fa98c081472e6896dfb254c00260801c92614744565b926fffcb9843d60f6159c9db58835c9266440260801c9261473b565b926fffe5caca7e10e4e61c3624eaa0941cd00260801c92614732565b926ffff2e50f5f656932ef12357cf3c7fdcc0260801c92614729565b926ffff97272373d413259a46990580e213a0260801c92614720565b6ffffcb933bd6fad37aa2d162d1a5940019350614717565b604051633c10250f60e01b8152600490fd5b6024356001600160801b03811681036105ba5790565b6044356001600160801b03811681036105ba5790565b6064356001600160801b03811681036105ba5790565b6000198114613b9c5760010190565b805115613d745760200190565b805160011015613d745760400190565b8051821015613d745760209160051b010190565b51906001600160801b03821682036105ba57565b91908260409103126105ba576138056020614aeb84614abd565b9301614abd565b6001600160a01b039091168152600291820b602082015291900b60408201526001600160801b0391821660608201529116608082015260a00190565b6001600160801b039182169082160391908211613b9c57565b15614b4e57565b60405162461bcd60e51b8152602060048201526014602482015273507269636520736c69707061676520636865636b60601b6044820152606490fd5b60018060501b03166000526010602052613805604060002060405190614baf826135b0565b80546001600160a01b0390811683526001909101541660208201527f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188615905565b919082549060031b91821b91600019901b1916179055565b805461ffff60a01b191660a09290921b61ffff60a01b16919091179055565b818114614cdc57815491600160401b831161127b578154838355808410614cb3575b506000526020600020906000526020600020906000905b838210614c6d5750505050565b806001918403614c86575b928101929181019101614c60565b818060a01b03815416828060a01b0319855416178455614cae61ffff825460a01c1685614c08565b614c78565b6000838152846020822092830192015b828110614cd1575050614c49565b818155600101614cc3565b5050565b614cec61080582613f47565b60009081526011602052604090205460581c6001600160a01b031690565b614d149033613905565b15614d1b57565b60405162461bcd60e51b815260206004820152600c60248201526b139bdd08185c1c1c9bdd995960a21b6044820152606490fd5b519081151582036105ba57565b60405163e8ae2b6960e01b8152600080516020615cdd83398151915260048201523360248201526020816044817f0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd30167946001600160a01b03165afa9081156105c657600091614dcc575b50156105ba57565b906020823d8211614dfd575b81614de56020938361364b565b810103126105e05750614df790614d4f565b38614dc4565b3d9150614dd8565b600060443d1061380557604051600319913d83016004833e81516001600160401b03918282113d602484011117614e6257818401948551938411614e6a573d85010160208487010111614e6257506138059291016020019061364b565b949350505050565b50949350505050565b6000818152600d602052604081205490926001600160a01b03918216918215614f9557600a5416918215614f95578214614eae575b50505050565b813b15610a10578391604483926040519485938492626e65c960e41b845288600485015260248401525af19081614f82575b50614f7b576001908260033d11614f6b575b806308c379a014614f6257634e487b7114614f18575b5061090257505b38808080614ea8565b8260233d11614f54575b15614f08578291507f4f27462fbdc9bce16bb573a06acba6b27394e151da96ce8098d8e29a6dc8d64b8280a238614f08565b5060206004843e6001614f22565b50614f22614e05565b50600483803e825160e01c614ef2565b5050614f0f565b614f8e909391936135e7565b9138614ee0565b5050505050565b816000526011602052614fb3816040600020613e4d565b6001600160a01b0380614fc5846137e2565b169116907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925600080a4565b307f000000000000000000000000d82fe82244ad01aad671576202f9b46b76fadfe26001600160a01b031614806150e1575b1561504b577fa2210c8f25528b72d92ef255b950c440d2c25d7f81be59650e4e8104d80ceda090565b60405160208101907f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f82527f17c93d93526d3bfa00a29c0aa0af2abb9197e14a1e5273df18858d2d357d726860408201527fad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a560608201524660808201523060a082015260a081526150db81613630565b51902090565b507f00000000000000000000000000000000000000000000000000000000000000924614615022565b8051602082015160405193916001600160a01b03918216911661512c856135b0565b8452602084019081526001600160a01b03615167857f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188615905565b16606061517382615a79565b818601615286615186825160020b6146e4565b926080890193615199855160020b6146e4565b60a08b015160c08c015190929082826001600160a01b038083169082161161537a575b50506001600160a01b0385811695908316861161531e5750506151df93506157f9565b985b8960018060a01b0360408b015116935160020b945160020b976020604051615208816135b0565b8481523391019081526040805194516001600160a01b0390811660208701529251831690850152511686830152858252615241826135fa565b60405197889586956302abf8a760e61b875233600488015260248701526044860152606485015260018060801b0316608484015260c060a484015260c4830190613519565b03816000855af19283156105c657600093849385916152cf575b506152bd9095848660e0830151111591826152bf575b5050614b47565b565b61010001511115905038806152b6565b94919350506060843d606011615316575b816152ed6060938361364b565b810103126105e057508251916152bd61530d604060208701519601614abd565b939493906152a0565b3d91506152e0565b919490939192906001600160a01b038216111561536e5782916153459161534b95946157f9565b93615845565b6001600160801b03818116908316101561536757505b986151e1565b9050615361565b91505061536192615845565b9350915038806151bc565b6040516370a0823160e01b815230600482015290602090829060249082906001600160a01b03165afa9081156105c6576000916153c0575090565b906020823d82116153e6575b816153d96020938361364b565b810103126105e057505190565b3d91506153cc565b6001600160a01b039091168152602081019190915260400190565b9293926001600160a01b037f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad388116929091908282168414806155e8575b1561550857505050803b156105ba57604051630d0e30db60e41b815293600091828660048185855af1958615611bb7576154a295966154f6575b50829360209360405180978195829463a9059cbb60e01b8452600484016153ee565b03925af180156154e9576154b4575050565b6020823d82116154e1575b816154cc6020938361364b565b810103126105e057506154de90614d4f565b50565b3d91506154bf565b50604051903d90823e3d90fd5b926155026020946135e7565b92615480565b9495948216949392509030850361552457506152bd9350615be4565b604093919293519360208501956323b872dd60e01b8752602486015216604484015260648301526064825260a082019282841060018060401b0385111761127b576000809493819460405251925af161557b613c5f565b816155b1575b506152bd5760405162461bcd60e51b815260206004820152600360248201526229aa2360e91b6044820152606490fd5b80518015925082156155c6575b505038615581565b81925090602091810103126105ba5760206155e19101614d4f565b38806155be565b5086471015615446565b42116155fa57565b60405162461bcd60e51b8152602060048201526013602482015272151c985b9cd858dd1a5bdb881d1bdbc81bdb19606a1b6044820152606490fd5b1561563c57565b60405162461bcd60e51b8152602060048201526017602482015276496e76616c6964206f72646572206f6620746f6b656e7360481b6044820152606490fd5b6001600160a01b0391821681529116602082015260400190565b6001600160a01b039081169190823b156105ba57602460009283604051958694859363f637731d60e01b85521660048401525af180156105c6576156d65750565b6152bd906135e7565b92946001600160a01b0390931693919291843b156105ba5760009460e493869260ff604051998a98899763d505accf60e01b89523360048a01523060248a01526044890152606488015216608486015260a485015260c48401525af180156105c6576156d65750565b92946001600160a01b0390931693919291843b156105ba5760009461010493869260ff604051998a9889976323f2ebc360e21b89523360048a01523060248a015260448901526064880152600160848801521660a486015260c485015260e48401525af180156105c6576156d65750565b60206040518092636eb1769f60e11b825281806157da30336004840161567b565b03916001600160a01b03165afa9081156105c6576000916153c0575090565b61582b9291906001600160a01b03908183168282161161583f575b61582282841683831661400e565b920316916140da565b6001600160801b0381169081036105ba5790565b91615814565b61582b92916001600160a01b03919082811683831611615868575b031690614055565b90615860565b916001600160a01b039190828216838516116158cb575b6158a891838116919085900384169060601b600160601b600160e01b03166140da565b91169081156158b5570490565b634e487b7160e01b600052601260045260246000fd5b909290615885565b61380592916001600160a01b039190828116838316116158ff575b0316906001600160801b031661400e565b906158ee565b60018060a01b03916159426159508480808551169461592c60208201968388511611615635565b511693511660405192839160208301958661567b565b03601f19810183528261364b565b51902060405190602082019260ff60f81b845260018060601b03199060601b16602183015260358201527ff96d2474815c32e070cd63233f06af5413efc5dcb430aee4ff18cc29007c562d6055820152605581526159ad816135fa565b5190201690565b60a09293602491604051958694859363514ea4bf60e01b855262ffffff80911692169060181b1760181b176004830152600180861b03165afa9081156105c65760009182938380938193615a0b575b509493929190565b9450925093505060a0823d8211615a62575b81615a2a60a0938361364b565b810103126105e0575080516020820151604083015193615a586080615a5160608701614abd565b9501614abd565b9194939238615a03565b3d9150615a1d565b519061ffff821682036105ba57565b6040516339db007960e21b8152906001600160a01b039060c0908390600490829085165afa9182156105c657600092615ab157505090565b909160c0823d8211615b25575b81615acb60c0938361364b565b810103126105e057815192831683036105e05760208201518060020b036105e057615af860408301615a6a565b50606082015160ff8116036105e0575060a081615b1a6080615b219401615a6a565b5001614d4f565b5090565b3d9150615abe565b9392604092835192631d9de38760e11b845260020b600484015260020b602483015260018060801b0316604482015260806064820152600360848201526203078360ec1b60a4820152818160c4816000809860018060a01b03165af1938415615bd95780928195615ba0575b5050509190565b919450915083813d8111615bd2575b615bb9818361364b565b810103126105e057506020825192015191388080615b99565b503d615baf565b8251903d90823e3d90fd5b6000929183615942615c0f8295604051928391602083019663a9059cbb60e01b8852602484016153ee565b51925af1615c1b613c5f565b81615c53575b5015615c2957565b60405162461bcd60e51b815260206004820152600260248201526114d560f21b6044820152606490fd5b8051801592508215615c68575b505038615c21565b81925090602091810103126105ba576020615c839101614d4f565b3880615c60565b6000808093819382604051615c9e81613615565b525af1615ca9613c5f565b5015615cb157565b60405162461bcd60e51b815260206004820152600360248201526253544560e81b6044820152606490fdfeff0e0466f109fcf4f5660899d8847c592e1e8dea30ffbe040704b23ad381d7628a82de7fe9b33e0e6bca0e26f5bd14a74f1164ffe236d50e0a36c3ea70f2b81449ecf333e5b8c95c40fdafc95c1ad136e8914a8fb55e9dc8bb01eaa83a2df9adddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa164736f6c6343000814000a

    Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

    0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd3016794000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad380000000000000000000000003e61919eed4fe4754afe390b45b3c1e9c712411a000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188000000000000000000000000f0f62ed4f66572fab5ed4513b99e53bb2660f42a

    -----Decoded View---------------
    Arg [0] : _factory (address): 0x8121a3F8c4176E9765deEa0B95FA2BDfD3016794
    Arg [1] : _WNativeToken (address): 0x039e2fB66102314Ce7b64Ce5Ce3E5183bc94aD38
    Arg [2] : _tokenDescriptor_ (address): 0x3E61919eED4fE4754afe390b45B3c1E9C712411A
    Arg [3] : _poolDeployer (address): 0x885229E48987EA4c68F0aA1bCBff5184198A9188
    Arg [4] : _vault (address): 0xf0F62ED4F66572faB5ED4513B99e53BB2660f42A

    -----Encoded View---------------
    5 Constructor Arguments found :
    Arg [0] : 0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd3016794
    Arg [1] : 000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad38
    Arg [2] : 0000000000000000000000003e61919eed4fe4754afe390b45b3c1e9c712411a
    Arg [3] : 000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a9188
    Arg [4] : 000000000000000000000000f0f62ed4f66572fab5ed4513b99e53bb2660f42a


    [ Download: CSV Export  ]
    [ Download: CSV Export  ]

    A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.