S Price: $0.495717 (+6.48%)
    /

    Contract

    0xA047e2AbF8263FcA7c368F43e2f960A06FD9949f

    Overview

    S Balance

    Sonic LogoSonic LogoSonic Logo0 S

    S Value

    $0.00

    Multichain Info

    No addresses found
    Transaction Hash
    Method
    Block
    Age
    From
    To
    Amount
    Exact Input Sing...213387632025-04-21 8:23:2022 secs ago1745223800IN
    SwapX: Router 2
    0 S0.0130669199
    Multicall213387312025-04-21 8:23:0636 secs ago1745223786IN
    SwapX: Router 2
    0 S0.0202737755.01
    Exact Output Sin...213385182025-04-21 8:21:481 min ago1745223708IN
    SwapX: Router 2
    0 S0.0153851999
    Exact Output Sin...213383582025-04-21 8:20:552 mins ago1745223655IN
    SwapX: Router 2
    0 S0.0315423100
    Exact Output Sin...213383042025-04-21 8:20:373 mins ago1745223637IN
    SwapX: Router 2
    0 S0.0342373100
    Exact Output Sin...213382802025-04-21 8:20:293 mins ago1745223629IN
    SwapX: Router 2
    0 S0.0138614988
    Exact Input Sing...213378702025-04-21 8:16:556 mins ago1745223415IN
    SwapX: Router 2
    0 S0.0322004100
    Exact Input Sing...213378592025-04-21 8:16:486 mins ago1745223408IN
    SwapX: Router 2
    0 S0.0337581100
    Swap Exact Token...213377082025-04-21 8:15:198 mins ago1745223319IN
    SwapX: Router 2
    0 S0.0200682355
    Exact Input Sing...213373922025-04-21 8:12:2811 mins ago1745223148IN
    SwapX: Router 2
    0 S0.0150354299
    Multicall213372652025-04-21 8:11:2912 mins ago1745223089IN
    SwapX: Router 2
    0 S0.0271133288
    Exact Output Sin...213371422025-04-21 8:10:4213 mins ago1745223042IN
    SwapX: Router 2
    0 S0.0156061888
    Exact Output Sin...213371102025-04-21 8:10:3113 mins ago1745223031IN
    SwapX: Router 2
    0 S0.0138603588
    Multicall213370842025-04-21 8:10:2313 mins ago1745223023IN
    SwapX: Router 2
    0 S0.020740855.01
    Exact Output Sin...213370562025-04-21 8:10:1413 mins ago1745223014IN
    SwapX: Router 2
    0 S0.0145981499
    Exact Output Sin...213370562025-04-21 8:10:1413 mins ago1745223014IN
    SwapX: Router 2
    0 S0.0342372100
    Exact Output Sin...213369252025-04-21 8:09:1514 mins ago1745222955IN
    SwapX: Router 2
    0 S0.0165261699
    Swap Exact Token...213368152025-04-21 8:08:2315 mins ago1745222903IN
    SwapX: Router 2
    0.02 S0.0309552255.01
    Exact Input Sing...213367982025-04-21 8:08:1615 mins ago1745222896IN
    SwapX: Router 2
    0 S0.0104504455
    Exact Output Sin...213367962025-04-21 8:08:1515 mins ago1745222895IN
    SwapX: Router 2
    0 S0.0145979499
    Swap Exact Token...213366162025-04-21 8:06:5716 mins ago1745222817IN
    SwapX: Router 2
    0.1 S0.029159755.01
    Exact Input Sing...213362852025-04-21 8:04:4518 mins ago1745222685IN
    SwapX: Router 2
    0 S0.0093580355
    Exact Output Sin...213362852025-04-21 8:04:4518 mins ago1745222685IN
    SwapX: Router 2
    0 S0.014562999
    Exact Output Sin...213361742025-04-21 8:03:5519 mins ago1745222635IN
    SwapX: Router 2
    0 S0.0162082899
    Exact Output Sin...213361742025-04-21 8:03:5519 mins ago1745222635IN
    SwapX: Router 2
    0 S0.0165955699
    View all transactions

    Latest 25 internal transactions (View All)

    Parent Transaction Hash Block Age From To Amount
    213387312025-04-21 8:23:0636 secs ago1745223786
    SwapX: Router 2
    1.39993331 S
    213387312025-04-21 8:23:0636 secs ago1745223786
    SwapX: Router 2
    1.39993331 S
    213372652025-04-21 8:11:2912 mins ago1745223089
    SwapX: Router 2
    87.12478225 S
    213372652025-04-21 8:11:2912 mins ago1745223089
    SwapX: Router 2
    87.12478225 S
    213370842025-04-21 8:10:2313 mins ago1745223023
    SwapX: Router 2
    31.3194835 S
    213370842025-04-21 8:10:2313 mins ago1745223023
    SwapX: Router 2
    31.3194835 S
    213368152025-04-21 8:08:2315 mins ago1745222903
    SwapX: Router 2
    0.02 S
    213366162025-04-21 8:06:5716 mins ago1745222817
    SwapX: Router 2
    0.1 S
    213360942025-04-21 8:03:1920 mins ago1745222599
    SwapX: Router 2
    5.52833976 S
    213360942025-04-21 8:03:1920 mins ago1745222599
    SwapX: Router 2
    5.52833976 S
    213358202025-04-21 8:01:0822 mins ago1745222468
    SwapX: Router 2
    0.022 S
    213356802025-04-21 8:00:0723 mins ago1745222407
    SwapX: Router 2
    0.021 S
    213354992025-04-21 7:58:4025 mins ago1745222320
    SwapX: Router 2
    0.02 S
    213351622025-04-21 7:55:4327 mins ago1745222143
    SwapX: Router 2
    3.16836908 S
    213351622025-04-21 7:55:4327 mins ago1745222143
    SwapX: Router 2
    3.16836908 S
    213345512025-04-21 7:50:2533 mins ago1745221825
    SwapX: Router 2
    318.22382353 S
    213345512025-04-21 7:50:2533 mins ago1745221825
    SwapX: Router 2
    318.22382353 S
    213330682025-04-21 7:37:0246 mins ago1745221022
    SwapX: Router 2
    3.8505004 S
    213330682025-04-21 7:37:0246 mins ago1745221022
    SwapX: Router 2
    3.8505004 S
    213316882025-04-21 7:25:3158 mins ago1745220331
    SwapX: Router 2
    0.99746001 S
    213316882025-04-21 7:25:3158 mins ago1745220331
    SwapX: Router 2
    0.99746001 S
    213315992025-04-21 7:24:5058 mins ago1745220290
    SwapX: Router 2
    1 S
    213309922025-04-21 7:19:381 hr ago1745219978
    SwapX: Router 2
    145.49951794 S
    213309922025-04-21 7:19:381 hr ago1745219978
    SwapX: Router 2
    145.49951794 S
    213293302025-04-21 7:06:491 hr ago1745219209
    SwapX: Router 2
    23.1051802 S
    View All Internal Transactions
    Loading...
    Loading

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

    Contract Name:
    SwapRouter02

    Compiler Version
    v0.8.20+commit.a1b79de6

    Optimization Enabled:
    Yes with 10000 runs

    Other Settings:
    istanbul EvmVersion
    File 1 of 65 : SwapRouter02.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;
    pragma abicoder v2;
    import '@cryptoalgebra/integral-periphery/contracts/base/SelfPermit.sol';
    import '@cryptoalgebra/integral-periphery/contracts/base/PeripheryImmutableState.sol';
    import './interfaces/ISwapRouter02.sol';
    import './V2SwapRouter.sol';
    import './V3SwapRouter.sol';
    import './base/ApproveAndCall.sol';
    import './base/MulticallExtended.sol';
    /// @title Uniswap V2 and V3 Swap Router
    contract SwapRouter02 is ISwapRouter02, V2SwapRouter, V3SwapRouter, ApproveAndCall, MulticallExtended, SelfPermit {
    constructor(
    address _factoryV2,
    address poolDeployer,
    address factoryV3,
    address _positionManager,
    address _WNativeToken
    ) ImmutableState(_factoryV2, _positionManager) PeripheryImmutableState(factoryV3, _WNativeToken, poolDeployer) {}
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 2 of 65 : IVolatilityOracle.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 The interface for the Algebra volatility oracle
    /// @dev This contract stores timepoints and calculates statistical averages
    interface IVolatilityOracle {
    /// @notice Returns data belonging to a certain timepoint
    /// @param index The index of timepoint in the array
    /// @dev There is more convenient function to fetch a timepoint: getTimepoints(). Which requires not an index but seconds
    /// @return initialized Whether the timepoint has been initialized and the values are safe to use
    /// @return blockTimestamp The timestamp of the timepoint
    /// @return tickCumulative The tick multiplied by seconds elapsed for the life of the pool as of the timepoint timestamp
    /// @return volatilityCumulative Cumulative standard deviation for the life of the pool as of the timepoint timestamp
    /// @return tick The tick at blockTimestamp
    /// @return averageTick Time-weighted average tick
    /// @return windowStartIndex Index of closest timepoint >= WINDOW seconds ago
    function timepoints(
    uint256 index
    )
    external
    view
    returns (
    bool initialized,
    uint32 blockTimestamp,
    int56 tickCumulative,
    uint88 volatilityCumulative,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 3 of 65 : 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: GPL-2.0-or-later
    pragma solidity >=0.8.4;
    import '@cryptoalgebra/integral-core/contracts/libraries/FullMath.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/TickMath.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/Plugins.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/PoolAddress.sol';
    import '../../interfaces/plugins/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);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 4 of 65 : IAlgebraSwapCallback.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;
    /// @title Callback for IAlgebraPoolActions#swap
    /// @notice Any contract that calls IAlgebraPoolActions#swap 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 IAlgebraSwapCallback {
    /// @notice Called to `msg.sender` after executing a swap via IAlgebraPool#swap.
    /// @dev In the implementation you must pay the pool tokens owed for the swap.
    /// The caller of this method _must_ be checked to be a AlgebraPool deployed by the canonical AlgebraFactory.
    /// amount0Delta and amount1Delta can both be 0 if no tokens were swapped.
    /// @param amount0Delta The amount of token0 that was sent (negative) or must be received (positive) by the pool by
    /// the end of the swap. If positive, the callback must send that amount of token0 to the pool.
    /// @param amount1Delta The amount of token1 that was sent (negative) or must be received (positive) by the pool by
    /// the end of the swap. If positive, the callback must send that amount of token1 to the pool.
    /// @param data Any data passed through by the caller via the IAlgebraPoolActions#swap call
    function algebraSwapCallback(int256 amount0Delta, int256 amount1Delta, bytes calldata data) external;
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 5 of 65 : 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 6 of 65 : 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 65 : 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 65 : 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 65 : 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 65 : 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 65 : 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 65 : 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 13 of 65 : Plugins.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 Contains logic and constants for interacting with the plugin through hooks
    /// @dev Allows pool to check which hooks are enabled, as well as control the return selector
    library Plugins {
    function hasFlag(uint8 pluginConfig, uint256 flag) internal pure returns (bool res) {
    assembly {
    res := gt(and(pluginConfig, flag), 0)
    }
    }
    function shouldReturn(bytes4 selector, bytes4 expectedSelector) internal pure {
    if (selector != expectedSelector) revert IAlgebraPoolErrors.invalidHookResponse(expectedSelector);
    }
    uint256 internal constant BEFORE_SWAP_FLAG = 1;
    uint256 internal constant AFTER_SWAP_FLAG = 1 << 1;
    uint256 internal constant BEFORE_POSITION_MODIFY_FLAG = 1 << 2;
    uint256 internal constant AFTER_POSITION_MODIFY_FLAG = 1 << 3;
    uint256 internal constant BEFORE_FLASH_FLAG = 1 << 4;
    uint256 internal constant AFTER_FLASH_FLAG = 1 << 5;
    uint256 internal constant AFTER_INIT_FLAG = 1 << 6;
    uint256 internal constant DYNAMIC_FEE = 1 << 7;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 14 of 65 : SafeCast.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 Safe casting methods
    /// @notice Contains methods for safely casting between types
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-core/blob/main/contracts/libraries
    library SafeCast {
    /// @notice Cast a uint256 to a uint160, revert on overflow
    /// @param y The uint256 to be downcasted
    /// @return z The downcasted integer, now type uint160
    function toUint160(uint256 y) internal pure returns (uint160 z) {
    require((z = uint160(y)) == y);
    }
    /// @notice Cast a uint256 to a uint128, revert on overflow
    /// @param y The uint256 to be downcasted
    /// @return z The downcasted integer, now type uint128
    function toUint128(uint256 y) internal pure returns (uint128 z) {
    require((z = uint128(y)) == y);
    }
    /// @notice Cast a int256 to a int128, revert on overflow or underflow
    /// @param y The int256 to be downcasted
    /// @return z The downcasted integer, now type int128
    function toInt128(int256 y) internal pure returns (int128 z) {
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 15 of 65 : 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 65 : 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 17 of 65 : 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) public 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 18 of 65 : 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 19 of 65 : 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) public payable override {
    uint256 balanceWNativeToken = _balanceOfToken(WNativeToken);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 20 of 65 : PeripheryPaymentsWithFee.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 './PeripheryPayments.sol';
    import '../interfaces/IPeripheryPaymentsWithFee.sol';
    import '../interfaces/external/IWNativeToken.sol';
    import '../libraries/TransferHelper.sol';
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    abstract contract PeripheryPaymentsWithFee is PeripheryPayments, IPeripheryPaymentsWithFee {
    /// @inheritdoc IPeripheryPaymentsWithFee
    function unwrapWNativeTokenWithFee(
    uint256 amountMinimum,
    address recipient,
    uint256 feeBips,
    address feeRecipient
    ) public payable override {
    require(feeBips > 0 && feeBips <= 100);
    uint256 balanceWNativeToken = IWNativeToken(WNativeToken).balanceOf(address(this));
    require(balanceWNativeToken >= amountMinimum, 'Insufficient WNativeToken');
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 21 of 65 : 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 22 of 65 : 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 23 of 65 : 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 24 of 65 : 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 25 of 65 : 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 26 of 65 : 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 27 of 65 : 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 28 of 65 : 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 29 of 65 : 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 30 of 65 : IPeripheryPaymentsWithFee.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 './IPeripheryPayments.sol';
    /// @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 IPeripheryPaymentsWithFee is IPeripheryPayments {
    /// @notice Unwraps the contract's WNativeToken balance and sends it to recipient as NativeToken, with a percentage between
    /// 0 (exclusive), and 1 (inclusive) going to feeRecipient
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing WNativeToken from users.
    function unwrapWNativeTokenWithFee(
    uint256 amountMinimum,
    address recipient,
    uint256 feeBips,
    address feeRecipient
    ) external payable;
    /// @notice Transfers the full amount of a token held by this contract to recipient, with a percentage between
    /// 0 (exclusive) and 1 (inclusive) going to feeRecipient
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing the token from users
    function sweepTokenWithFee(
    address token,
    uint256 amountMinimum,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 31 of 65 : 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 32 of 65 : 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 33 of 65 : BytesLib.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
    /**
    * @title Solidity Bytes Arrays Utils
    * @author Gonçalo Sá <goncalo.sa@consensys.net>
    *
    * @dev Bytes tightly packed arrays utility library for ethereum contracts written in Solidity.
    * The library lets you concatenate, slice and type cast bytes arrays both in memory and storage.
    */
    pragma solidity >=0.8.0 <0.9.0;
    library BytesLib {
    function slice(bytes memory _bytes, uint256 _start, uint256 _length) internal pure returns (bytes memory) {
    unchecked {
    require(_length + 31 >= _length, 'slice_overflow');
    require(_bytes.length >= _start + _length, 'slice_outOfBounds');
    bytes memory tempBytes;
    assembly {
    switch iszero(_length)
    case 0 {
    // Get a location of some free memory and store it in tempBytes as
    // Solidity does for memory variables.
    tempBytes := mload(0x40)
    // The first word of the slice result is potentially a partial
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 34 of 65 : 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 35 of 65 : Path.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 './BytesLib.sol';
    /// @title Functions for manipulating path data for multihop swaps
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    library Path {
    using BytesLib for bytes;
    /// @dev The length of the bytes encoded address
    uint256 private constant ADDR_SIZE = 20;
    /// @dev The offset of a single token address
    uint256 private constant NEXT_OFFSET = ADDR_SIZE;
    /// @dev The offset of an encoded pool key
    uint256 private constant POP_OFFSET = NEXT_OFFSET + ADDR_SIZE;
    /// @dev The minimum length of an encoding that contains 2 or more pools
    uint256 private constant MULTIPLE_POOLS_MIN_LENGTH = POP_OFFSET + NEXT_OFFSET;
    /// @notice Returns true if the path contains two or more pools
    /// @param path The encoded swap path
    /// @return True if path contains two or more pools, otherwise false
    function hasMultiplePools(bytes memory path) internal pure returns (bool) {
    return path.length >= MULTIPLE_POOLS_MIN_LENGTH;
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 36 of 65 : 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 37 of 65 : 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

    File 38 of 65 : 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 39 of 65 : 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 40 of 65 : 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 41 of 65 : 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 42 of 65 : 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 43 of 65 : 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 44 of 65 : 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 45 of 65 : ApproveAndCall.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;
    pragma abicoder v2;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    import '@cryptoalgebra/integral-periphery/contracts/interfaces/INonfungiblePositionManager.sol';
    import '../interfaces/IApproveAndCall.sol';
    import './ImmutableState.sol';
    /// @title Approve and Call
    /// @notice Allows callers to approve the Uniswap V3 position manager from this contract,
    /// for any token, and then make calls into the position manager
    abstract contract ApproveAndCall is IApproveAndCall, ImmutableState {
    function tryApprove(address token, uint256 amount) private returns (bool) {
    (bool success, bytes memory data) =
    token.call(abi.encodeWithSelector(IERC20.approve.selector, positionManager, amount));
    return success && (data.length == 0 || abi.decode(data, (bool)));
    }
    /// @inheritdoc IApproveAndCall
    function getApprovalType(address token, uint256 amount) external override returns (ApprovalType) {
    // check existing approval
    if (IERC20(token).allowance(address(this), positionManager) >= amount) return ApprovalType.NOT_REQUIRED;
    // try type(uint256).max / type(uint256).max - 1
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 46 of 65 : ImmutableState.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '../interfaces/IImmutableState.sol';
    /// @title Immutable state
    /// @notice Immutable state used by the swap router
    abstract contract ImmutableState is IImmutableState {
    /// @inheritdoc IImmutableState
    address public immutable override factoryV2;
    /// @inheritdoc IImmutableState
    address public immutable override positionManager;
    constructor(address _factoryV2, address _positionManager) {
    factoryV2 = _factoryV2;
    positionManager = _positionManager;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 47 of 65 : MulticallExtended.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;
    pragma abicoder v2;
    import '@cryptoalgebra/integral-periphery/contracts/base/Multicall.sol';
    import '../interfaces/IMulticallExtended.sol';
    import '../base/PeripheryValidationExtended.sol';
    /// @title Multicall
    /// @notice Enables calling multiple methods in a single call to the contract
    abstract contract MulticallExtended is IMulticallExtended, Multicall, PeripheryValidationExtended {
    /// @inheritdoc IMulticallExtended
    function multicall(uint256 deadline, bytes[] calldata data)
    external
    payable
    override
    checkDeadline(deadline)
    returns (bytes[] memory)
    {
    return multicall(data);
    }
    /// @inheritdoc IMulticallExtended
    function multicall(bytes32 previousBlockhash, bytes[] calldata data)
    external
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 48 of 65 : OracleSlippage.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;
    pragma abicoder v2;
    import '../interfaces/IOracleSlippage.sol';
    import '@cryptoalgebra/integral-periphery/contracts/base/PeripheryImmutableState.sol';
    import '@cryptoalgebra/integral-periphery/contracts/base/BlockTimestamp.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/Path.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/PoolAddress.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import '@cryptoalgebra/integral-base-plugin/contracts/libraries/integration/OracleLibrary.sol';
    import '@cryptoalgebra/integral-base-plugin/contracts/interfaces/plugins/IVolatilityOracle.sol';
    abstract contract OracleSlippage is IOracleSlippage, PeripheryImmutableState, BlockTimestamp {
    using Path for bytes;
    /// @dev Returns the tick as of the beginning of the current block, and as of right now, for the given pool.
    function getBlockStartingAndCurrentTick(IAlgebraPool pool)
    internal
    view
    returns (int24 blockStartingTick, int24 currentTick)
    {
    uint16 observationIndex;
    uint32 observationTimestamp;
    (, currentTick, , , , ) = IAlgebraPool(pool).globalState();
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 49 of 65 : PeripheryPaymentsExtended.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 '@cryptoalgebra/integral-periphery/contracts/base/PeripheryPayments.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/TransferHelper.sol';
    import '../interfaces/IPeripheryPaymentsExtended.sol';
    abstract contract PeripheryPaymentsExtended is IPeripheryPaymentsExtended, PeripheryPayments {
    /// @inheritdoc IPeripheryPaymentsExtended
    function unwrapWNativeToken(uint256 amountMinimum) external payable override {
    unwrapWNativeToken(amountMinimum, msg.sender);
    }
    /// @inheritdoc IPeripheryPaymentsExtended
    function wrapETH(uint256 value) external payable override {
    IWNativeToken(WNativeToken).deposit{value: value}();
    }
    /// @inheritdoc IPeripheryPaymentsExtended
    function sweepToken(address token, uint256 amountMinimum) external payable override {
    sweepToken(token, amountMinimum, msg.sender);
    }
    /// @inheritdoc IPeripheryPaymentsExtended
    function pull(address token, uint256 value) external payable override {
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 50 of 65 : PeripheryPaymentsWithFeeExtended.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 '@cryptoalgebra/integral-periphery/contracts/base/PeripheryPaymentsWithFee.sol';
    import '../interfaces/IPeripheryPaymentsWithFeeExtended.sol';
    import './PeripheryPaymentsExtended.sol';
    abstract contract PeripheryPaymentsWithFeeExtended is
    IPeripheryPaymentsWithFeeExtended,
    PeripheryPaymentsExtended,
    PeripheryPaymentsWithFee
    {
    /// @inheritdoc IPeripheryPaymentsWithFeeExtended
    function unwrapWNativeTokenWithFee(
    uint256 amountMinimum,
    uint256 feeBips,
    address feeRecipient
    ) external payable override {
    unwrapWNativeTokenWithFee(amountMinimum, msg.sender, feeBips, feeRecipient);
    }
    /// @inheritdoc IPeripheryPaymentsWithFeeExtended
    function sweepTokenWithFee(
    address token,
    uint256 amountMinimum,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 51 of 65 : PeripheryValidationExtended.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    // SPDX-License-Identifier: GPL-2.0-or-later
    pragma solidity =0.8.20;
    import '@cryptoalgebra/integral-periphery/contracts/base/PeripheryValidation.sol';
    abstract contract PeripheryValidationExtended is PeripheryValidation {
    modifier checkPreviousBlockhash(bytes32 previousBlockhash) {
    require(blockhash(block.number - 1) == previousBlockhash, 'Blockhash');
    _;
    }
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 52 of 65 : IApproveAndCall.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;
    pragma abicoder v2;
    interface IApproveAndCall {
    enum ApprovalType {NOT_REQUIRED, MAX, MAX_MINUS_ONE, ZERO_THEN_MAX, ZERO_THEN_MAX_MINUS_ONE}
    /// @dev Lens to be called off-chain to determine which (if any) of the relevant approval functions should be called
    /// @param token The token to approve
    /// @param amount The amount to approve
    /// @return The required approval type
    function getApprovalType(address token, uint256 amount) external returns (ApprovalType);
    /// @notice Approves a token for the maximum possible amount
    /// @param token The token to approve
    function approveMax(address token) external payable;
    /// @notice Approves a token for the maximum possible amount minus one
    /// @param token The token to approve
    function approveMaxMinusOne(address token) external payable;
    /// @notice Approves a token for zero, then the maximum possible amount
    /// @param token The token to approve
    function approveZeroThenMax(address token) external payable;
    /// @notice Approves a token for zero, then the maximum possible amount minus one
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 53 of 65 : IBaseV1Pair.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    pragma solidity >=0.5.0;
    interface IBaseV1Pair {
    function transferFrom(address src, address dst, uint amount) external returns (bool);
    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function burn(address to) external returns (uint amount0, uint amount1);
    function mint(address to) external returns (uint liquidity);
    function getReserves() external view returns (uint112 _reserve0, uint112 _reserve1, uint32 _blockTimestampLast);
    function getAmountOut(uint, address) external view returns (uint);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 54 of 65 : IImmutableState.sol
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    // 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
    interface IImmutableState {
    /// @return Returns the address of the Uniswap V2 factory
    function factoryV2() external view returns (address);
    /// @return Returns the address of Uniswap V3 NFT position manager
    function positionManager() external view returns (address);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 55 of 65 : IMulticallExtended.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 '@cryptoalgebra/integral-periphery/contracts/interfaces/IMulticall.sol';
    /// @title MulticallExtended interface
    /// @notice Enables calling multiple methods in a single call to the contract with optional validation
    interface IMulticallExtended is 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 deadline The time by which this function must be called before failing
    /// @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(uint256 deadline, bytes[] calldata data) external payable returns (bytes[] memory results);
    /// @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 previousBlockhash The expected parent blockHash
    /// @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(bytes32 previousBlockhash, bytes[] calldata data)
    external
    payable
    returns (bytes[] memory results);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 56 of 65 : IOracleSlippage.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;
    /// @title OracleSlippage interface
    /// @notice Enables slippage checks against oracle prices
    interface IOracleSlippage {
    /// @notice Ensures that the current (synthetic) tick over the path is no worse than
    /// `maximumTickDivergence` ticks away from the average as of `secondsAgo`
    /// @param path The path to fetch prices over
    /// @param maximumTickDivergence The maximum number of ticks that the price can degrade by
    /// @param secondsAgo The number of seconds ago to compute oracle prices against
    function checkOracleSlippage(
    bytes memory path,
    uint24 maximumTickDivergence,
    uint32 secondsAgo
    ) external view;
    /// @notice Ensures that the weighted average current (synthetic) tick over the path is no
    /// worse than `maximumTickDivergence` ticks away from the average as of `secondsAgo`
    /// @param paths The paths to fetch prices over
    /// @param amounts The weights for each entry in `paths`
    /// @param maximumTickDivergence The maximum number of ticks that the price can degrade by
    /// @param secondsAgo The number of seconds ago to compute oracle prices against
    function checkOracleSlippage(
    bytes[] memory paths,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 57 of 65 : IPeripheryPaymentsExtended.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 '@cryptoalgebra/integral-periphery/contracts/interfaces/IPeripheryPayments.sol';
    /// @title Periphery Payments Extended
    /// @notice Functions to ease deposits and withdrawals of ETH and tokens
    interface IPeripheryPaymentsExtended is IPeripheryPayments {
    /// @notice Unwraps the contract's WNativeToken balance and sends it to msg.sender as ETH.
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing WNativeToken from users.
    /// @param amountMinimum The minimum amount of WNativeToken to unwrap
    function unwrapWNativeToken(uint256 amountMinimum) external payable;
    /// @notice Wraps the contract's ETH balance into WNativeToken
    /// @dev The resulting WNativeToken is custodied by the router, thus will require further distribution
    /// @param value The amount of ETH to wrap
    function wrapETH(uint256 value) external payable;
    /// @notice Transfers the full amount of a token held by this contract to msg.sender
    /// @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 msg.sender
    /// @param amountMinimum The minimum amount of token required for a transfer
    function sweepToken(address token, uint256 amountMinimum) external payable;
    /// @notice Transfers the specified amount of a token from the msg.sender to address(this)
    /// @param token The token to pull
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 58 of 65 : IPeripheryPaymentsWithFeeExtended.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 '@cryptoalgebra/integral-periphery/contracts/interfaces/IPeripheryPaymentsWithFee.sol';
    import './IPeripheryPaymentsExtended.sol';
    /// @title Periphery Payments With Fee Extended
    /// @notice Functions to ease deposits and withdrawals of ETH
    interface IPeripheryPaymentsWithFeeExtended is IPeripheryPaymentsExtended, IPeripheryPaymentsWithFee {
    /// @notice Unwraps the contract's WNativeToken balance and sends it to msg.sender as ETH, with a percentage between
    /// 0 (exclusive), and 1 (inclusive) going to feeRecipient
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing WNativeToken from users.
    function unwrapWNativeTokenWithFee(
    uint256 amountMinimum,
    uint256 feeBips,
    address feeRecipient
    ) external payable;
    /// @notice Transfers the full amount of a token held by this contract to msg.sender, with a percentage between
    /// 0 (exclusive) and 1 (inclusive) going to feeRecipient
    /// @dev The amountMinimum parameter prevents malicious contracts from stealing the token from users
    function sweepTokenWithFee(
    address token,
    uint256 amountMinimum,
    uint256 feeBips,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 59 of 65 : ISwapRouter02.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.7.5;
    pragma abicoder v2;
    import '@cryptoalgebra/integral-periphery/contracts/interfaces/ISelfPermit.sol';
    import './IV2SwapRouter.sol';
    import './IV3SwapRouter.sol';
    import './IApproveAndCall.sol';
    import './IMulticallExtended.sol';
    /// @title Router token swapping functionality
    interface ISwapRouter02 is IV2SwapRouter, IV3SwapRouter, IApproveAndCall, IMulticallExtended, ISelfPermit {
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 60 of 65 : IV2SwapRouter.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;
    /// @title Router token swapping functionality
    /// @notice Functions for swapping tokens via Uniswap V2
    interface IV2SwapRouter {
    struct Route {
    address from;
    address to;
    bool stable;
    }
    /// @notice Swaps `amountIn` of one token for as much as possible of another token
    /// @dev Setting `amountIn` to 0 will cause the contract to look up its own balance,
    /// and swap the entire amount, enabling contracts to send tokens before calling this function.
    /// @param amountIn The amount of token to swap
    /// @param amountOutMin The minimum amount of output that must be received
    /// @param path The ordered list of tokens to swap through
    /// @param to The recipient address
    /// @return amountOut The amount of the received token
    function swapExactTokensForTokens(
    uint256 amountIn,
    uint256 amountOutMin,
    Route[] calldata path,
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 61 of 65 : IV3SwapRouter.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 '@cryptoalgebra/integral-core/contracts/interfaces/callback/IAlgebraSwapCallback.sol';
    /// @title Router token swapping functionality
    /// @notice Functions for swapping tokens via Algebra
    /// @dev Credit to Uniswap Labs under GPL-2.0-or-later license:
    /// https://github.com/Uniswap/v3-periphery
    interface IV3SwapRouter is IAlgebraSwapCallback {
    struct ExactInputSingleParams {
    address tokenIn;
    address tokenOut;
    address recipient;
    uint256 amountIn;
    uint256 amountOutMinimum;
    uint160 limitSqrtPrice;
    }
    /// @notice Swaps `amountIn` of one token for as much as possible of another token
    /// @dev Setting `amountIn` to 0 will cause the contract to look up its own balance,
    /// and swap the entire amount, enabling contracts to send tokens before calling this function.
    /// @param params The parameters necessary for the swap, encoded as `ExactInputSingleParams` in calldata
    /// @return amountOut The amount of the received token
    function exactInputSingle(ExactInputSingleParams calldata params) external payable returns (uint256 amountOut);
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 62 of 65 : Constants.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.8.20;
    /// @title Constant state
    /// @notice Constant state used by the swap router
    library Constants {
    /// @dev Used for identifying cases when this contract's balance of a token is to be used
    uint256 internal constant CONTRACT_BALANCE = 0;
    /// @dev Used as a flag for identifying msg.sender, saves gas by sending more 0 bytes
    address internal constant MSG_SENDER = address(1);
    /// @dev Used as a flag for identifying address(this), saves gas by sending more 0 bytes
    address internal constant ADDRESS_THIS = address(2);
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 63 of 65 : UniswapV2Library.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/IBaseV1Pair.sol';
    library UniswapV2Library {
    // returns sorted token addresses, used to handle return values from pairs sorted in this order
    function sortTokens(address tokenA, address tokenB) internal pure returns (address token0, address token1) {
    require(tokenA != tokenB);
    (token0, token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
    require(token0 != address(0));
    }
    // calculates the CREATE2 address for a pair without making any external calls
    function pairFor(
    address factory,
    address tokenA,
    address tokenB,
    bool stable
    ) internal pure returns (address pair) {
    (address token0, address token1) = sortTokens(tokenA, tokenB);
    pair = address(
    uint160(
    uint256(
    keccak256(
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 64 of 65 : V2SwapRouter.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;
    pragma abicoder v2;
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    import './interfaces/IV2SwapRouter.sol';
    import './base/ImmutableState.sol';
    import './base/PeripheryPaymentsWithFeeExtended.sol';
    import './libraries/Constants.sol';
    import './libraries/UniswapV2Library.sol';
    /// @title Uniswap V2 Swap Router
    /// @notice Router for stateless execution of swaps against Uniswap V2
    abstract contract V2SwapRouter is IV2SwapRouter, ImmutableState, PeripheryPaymentsWithFeeExtended {
    // supports fee-on-transfer tokens
    // requires the initial amount to have already been sent to the first pair
    function _swap(Route[] memory routes, address _to) private {
    for (uint256 i; i < routes.length; i++) {
    (address input, address output) = (routes[i].from, routes[i].to);
    (address token0, ) = UniswapV2Library.sortTokens(input, output);
    IBaseV1Pair pair = IBaseV1Pair(UniswapV2Library.pairFor(factoryV2, routes[i].from, routes[i].to, routes[i].stable));
    uint256 amountInput;
    uint256 amountOutput;
    // scope to avoid stack too deep errors
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    File 65 of 65 : V3SwapRouter.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;
    pragma abicoder v2;
    import '@cryptoalgebra/integral-core/contracts/libraries/SafeCast.sol';
    import '@cryptoalgebra/integral-core/contracts/libraries/TickMath.sol';
    import '@cryptoalgebra/integral-core/contracts/interfaces/IAlgebraPool.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/Path.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/PoolAddress.sol';
    import '@cryptoalgebra/integral-periphery/contracts/libraries/CallbackValidation.sol';
    import '@openzeppelin/contracts/token/ERC20/IERC20.sol';
    import './interfaces/IV3SwapRouter.sol';
    import './base/PeripheryPaymentsWithFeeExtended.sol';
    import './base/OracleSlippage.sol';
    import './libraries/Constants.sol';
    /// @title Uniswap V3 Swap Router
    /// @notice Router for stateless execution of swaps against Uniswap V3
    abstract contract V3SwapRouter is IV3SwapRouter, PeripheryPaymentsWithFeeExtended, OracleSlippage {
    using Path for bytes;
    using SafeCast for uint256;
    /// @dev Used as the placeholder value for amountInCached, because the computed amount in for an exact output swap
    /// can never actually be this value
    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
    {
    "evmVersion": "istanbul",
    "optimizer": {
    "enabled": true,
    "runs": 10000
    },
    "metadata": {
    "bytecodeHash": "none"
    },
    "outputSelection": {
    "*": {
    "*": [
    "evm.bytecode",
    "evm.deployedBytecode",
    "devdoc",
    "userdoc",
    "metadata",
    "abi"
    ]
    }
    },
    "libraries": {}
    }
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Contract Security Audit

    Contract ABI

    API
    [{"inputs":[{"internalType":"address","name":"_factoryV2","type":"address"},{"internalType":"address","name":"poolDeployer","type":"address"},{"internalType":"address","name":"factoryV3","type":"address"},{"internalType":"address","name":"_positionManager","type":"address"},{"internalType":"address","name":"_WNativeToken","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"WNativeToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"int256","name":"amount0Delta","type":"int256"},{"internalType":"int256","name":"amount1Delta","type":"int256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"algebraSwapCallback","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"approveMax","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"approveMaxMinusOne","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"approveZeroThenMax","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"approveZeroThenMaxMinusOne","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"bytes","name":"data","type":"bytes"}],"name":"callPositionManager","outputs":[{"internalType":"bytes","name":"result","type":"bytes"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"bytes[]","name":"paths","type":"bytes[]"},{"internalType":"uint128[]","name":"amounts","type":"uint128[]"},{"internalType":"uint24","name":"maximumTickDivergence","type":"uint24"},{"internalType":"uint32","name":"secondsAgo","type":"uint32"}],"name":"checkOracleSlippage","outputs":[],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes","name":"path","type":"bytes"},{"internalType":"uint24","name":"maximumTickDivergence","type":"uint24"},{"internalType":"uint32","name":"secondsAgo","type":"uint32"}],"name":"checkOracleSlippage","outputs":[],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"bytes","name":"path","type":"bytes"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amountIn","type":"uint256"},{"internalType":"uint256","name":"amountOutMinimum","type":"uint256"}],"internalType":"struct IV3SwapRouter.ExactInputParams","name":"params","type":"tuple"}],"name":"exactInput","outputs":[{"internalType":"uint256","name":"amountOut","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"tokenIn","type":"address"},{"internalType":"address","name":"tokenOut","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amountIn","type":"uint256"},{"internalType":"uint256","name":"amountOutMinimum","type":"uint256"},{"internalType":"uint160","name":"limitSqrtPrice","type":"uint160"}],"internalType":"struct IV3SwapRouter.ExactInputSingleParams","name":"params","type":"tuple"}],"name":"exactInputSingle","outputs":[{"internalType":"uint256","name":"amountOut","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"tokenIn","type":"address"},{"internalType":"address","name":"tokenOut","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amountIn","type":"uint256"},{"internalType":"uint256","name":"amountOutMinimum","type":"uint256"},{"internalType":"uint160","name":"limitSqrtPrice","type":"uint160"}],"internalType":"struct IV3SwapRouter.ExactInputSingleParams","name":"params","type":"tuple"}],"name":"exactInputSingleSupportingFeeOnTransferTokens","outputs":[{"internalType":"uint256","name":"amountOut","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"bytes","name":"path","type":"bytes"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amountOut","type":"uint256"},{"internalType":"uint256","name":"amountInMaximum","type":"uint256"}],"internalType":"struct IV3SwapRouter.ExactOutputParams","name":"params","type":"tuple"}],"name":"exactOutput","outputs":[{"internalType":"uint256","name":"amountIn","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"tokenIn","type":"address"},{"internalType":"address","name":"tokenOut","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amountOut","type":"uint256"},{"internalType":"uint256","name":"amountInMaximum","type":"uint256"},{"internalType":"uint160","name":"limitSqrtPrice","type":"uint160"}],"internalType":"struct IV3SwapRouter.ExactOutputSingleParams","name":"params","type":"tuple"}],"name":"exactOutputSingle","outputs":[{"internalType":"uint256","name":"amountIn","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"factoryV2","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"getApprovalType","outputs":[{"internalType":"enum IApproveAndCall.ApprovalType","name":"","type":"uint8"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"token0","type":"address"},{"internalType":"address","name":"token1","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"amount0Min","type":"uint256"},{"internalType":"uint256","name":"amount1Min","type":"uint256"}],"internalType":"struct IApproveAndCall.IncreaseLiquidityParams","name":"params","type":"tuple"}],"name":"increaseLiquidity","outputs":[{"internalType":"bytes","name":"result","type":"bytes"}],"stateMutability":"payable","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":"amount0Min","type":"uint256"},{"internalType":"uint256","name":"amount1Min","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"}],"internalType":"struct IApproveAndCall.MintParams","name":"params","type":"tuple"}],"name":"mint","outputs":[{"internalType":"bytes","name":"result","type":"bytes"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"previousBlockhash","type":"bytes32"},{"internalType":"bytes[]","name":"data","type":"bytes[]"}],"name":"multicall","outputs":[{"internalType":"bytes[]","name":"","type":"bytes[]"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"bytes[]","name":"data","type":"bytes[]"}],"name":"multicall","outputs":[{"internalType":"bytes[]","name":"","type":"bytes[]"}],"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":"poolDeployer","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"positionManager","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"pull","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"refundNativeToken","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":"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":"uint256","name":"amountIn","type":"uint256"},{"internalType":"uint256","name":"amountOutMin","type":"uint256"},{"components":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"bool","name":"stable","type":"bool"}],"internalType":"struct IV2SwapRouter.Route[]","name":"routes","type":"tuple[]"},{"internalType":"address","name":"to","type":"address"}],"name":"swapExactTokensForTokens","outputs":[{"internalType":"uint256","name":"amountOut","type":"uint256"}],"stateMutability":"payable","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":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amountMinimum","type":"uint256"}],"name":"sweepToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"uint256","name":"feeBips","type":"uint256"},{"internalType":"address","name":"feeRecipient","type":"address"}],"name":"sweepTokenWithFee","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"feeBips","type":"uint256"},{"internalType":"address","name":"feeRecipient","type":"address"}],"name":"sweepTokenWithFee","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"}],"name":"unwrapWNativeToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountMinimum","type":"uint256"}],"name":"unwrapWNativeToken","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"feeBips","type":"uint256"},{"internalType":"address","name":"feeRecipient","type":"address"}],"name":"unwrapWNativeTokenWithFee","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountMinimum","type":"uint256"},{"internalType":"uint256","name":"feeBips","type":"uint256"},{"internalType":"address","name":"feeRecipient","type":"address"}],"name":"unwrapWNativeTokenWithFee","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"wrapETH","outputs":[],"stateMutability":"payable","type":"function"},{"stateMutability":"payable","type":"receive"}]

    Deployed Bytecode

    0x6080604052600436106102bf5760003560e01c8063ab3fdd501161016e578063d9da7f91116100cb578063efdeed8e1161007f578063f25801a711610064578063f25801a71461071a578063f2d5d56b1461073a578063f3995c671461074d57600080fd5b8063efdeed8e146106e7578063f100b2051461070757600080fd5b8063df2ab5bb116100b0578063df2ab5bb146106ae578063e0e189a0146106c1578063e90a182f146106d457600080fd5b8063d9da7f911461066e578063dee00f351461068157600080fd5b8063c2e3140a11610122578063c60696ec11610107578063c60696ec14610635578063cab372ce14610648578063d67d920a1461065b57600080fd5b8063c2e3140a146105ee578063c45a01551461060157600080fd5b8063b3a2af1311610153578063b3a2af13146105b5578063b858183f146105c8578063bab2140e146105db57600080fd5b8063ab3fdd501461058f578063ac9650d8146105a257600080fd5b8063571ac8b01161021c57806369bc35b2116101d057806389b73b3e116101b557806389b73b3e146105355780638af3ac8514610548578063a4a78f0c1461057c57600080fd5b806369bc35b2146104ee578063791b98bc1461050157600080fd5b80635b0bd144116102015780635b0bd14414610487578063639d71a9146104a757806368e0d4e1146104ba57600080fd5b8063571ac8b0146104615780635ae401dc1461047457600080fd5b80632fdb2239116102735780633119049a116102585780633119049a146103fa57806341865270146104465780634659a4941461044e57600080fd5b80632fdb2239146103d45780633068c554146103e757600080fd5b80631c58db4f116102a45780631c58db4f146103815780631f0464d1146103945780632c8958f6146103b457600080fd5b806309b81346146103485780630ed91c5a1461036e57600080fd5b3661034357336001600160a01b037f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad3816146103415760405162461bcd60e51b815260206004820152601060248201527f4e6f7420574e6174697665546f6b656e0000000000000000000000000000000060448201526064015b60405180910390fd5b005b600080fd5b61035b610356366004614338565b610760565b6040519081526020015b60405180910390f35b61035b61037c3660046143e8565b610838565b61034161038f366004614483565b610b33565b6103a76103a23660046144e1565b610baa565b604051610365919061457d565b3480156103c057600080fd5b506103416103cf3660046145fd565b610c1a565b61035b6103e236600461467d565b610d33565b6103416103f536600461471b565b61115a565b34801561040657600080fd5b5061042e7f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a918881565b6040516001600160a01b039091168152602001610365565b61034161116d565b61034161045c366004614774565b61117f565b61034161046f3660046147d0565b61122d565b6103a76104823660046144e1565b611245565b61049a6104953660046147ed565b611251565b60405161036591906147ff565b6103416104b53660046147d0565b6113dd565b3480156104c657600080fd5b5061042e7f00000000000000000000000005c1be79d3ac21cc4b727eed58c9b2ff757f566381565b6103416104fc366004614812565b6113f1565b34801561050d57600080fd5b5061042e7f000000000000000000000000d82fe82244ad01aad671576202f9b46b76fadfe281565b61035b610543366004614842565b611516565b34801561055457600080fd5b5061042e7f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad3881565b61034161058a366004614774565b611623565b61034161059d3660046147d0565b611643565b6103a76105b0366004614854565b61166d565b61049a6105c3366004614914565b61178e565b61035b6105d6366004614949565b61185e565b61035b6105e93660046143e8565b611a07565b6103416105fc366004614774565b611b89565b34801561060d57600080fd5b5061042e7f0000000000000000000000008121a3f8c4176e9765deea0b95fa2bdfd301679481565b6103416106433660046149f9565b611ba7565b6103416106563660046147d0565b611657565b610341610669366004614a38565b611d97565b61034161067c366004614483565b611da3565b34801561068d57600080fd5b506106a161069c366004614a71565b611dad565b6040516103659190614a9d565b6103416106bc366004614ade565b611eeb565b6103416106cf366004614b15565b611f59565b6103416106e2366004614a71565b612098565b3480156106f357600080fd5b50610341610702366004614c3f565b6120a7565b61049a610715366004614d34565b612116565b34801561072657600080fd5b50610341610735366004614d46565b6121d7565b610341610748366004614a71565b612245565b61034161075b366004614774565b612251565b60006107d46040830180359061077990602086016147d0565b60408051808201909152600090806107918880614d9d565b8080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250505090825250336020909101526122c1565b5050600054606082013581111561082d5760405162461bcd60e51b815260206004820152601260248201527f546f6f206d7563682072657175657374656400000000000000000000000000006044820152606401610338565b600019600055919050565b60008060008360600151036108d3575081516040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526001916001600160a01b0316906370a0823190602401602060405180830381865afa1580156108a9573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108cd9190614e02565b60608401525b60408051808201909152835160208501517fffffffffffffffffffffffffffffffffffffffff000000000000000000000000606092831b811683850152911b166074820152600090806088810160405160208183030381529060405281526020018361093f5733610941565b305b6001600160a01b03908116909152604086015191925081166000190161096857503361099b565b7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe6001600160a01b0382160161099b5750305b602085015185516001600160a01b03808316908216109160009182916109c19190612488565b6001600160a01b0316639e4e02273386866109df8d606001516124c4565b60a08e01516001600160a01b0316156109fc578d60a00151610a35565b88610a2557610a20600173fffd8963efd1fc6a506488495d951d5263988d26614e4a565b610a35565b610a356401000276a36001614e6a565b8b604051602001610a469190614e8a565b6040516020818303038152906040526040518763ffffffff1660e01b8152600401610a7696959493929190614ec5565b60408051808303816000875af1158015610a94573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ab89190614f13565b9150915082610ac75781610ac9565b805b610ad290614f37565b96508760800151871015610b285760405162461bcd60e51b815260206004820152601360248201527f546f6f206c6974746c65207265636569766564000000000000000000000000006044820152606401610338565b505050505050919050565b7f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b158015610b8e57600080fd5b505af1158015610ba2573d6000803e3d6000fd5b505050505050565b60608380610bb9600143614f6f565b4014610c075760405162461bcd60e51b815260206004820152600960248201527f426c6f636b6861736800000000000000000000000000000000000000000000006044820152606401610338565b610c11848461166d565b95945050505050565b6000841380610c295750600083135b610c3257600080fd5b6000610c4082840184614f82565b9050600080610c5283600001516124d8565b91509150610c817f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a918883836124f9565b5060008060008913610ca857836001600160a01b0316836001600160a01b03161088610cbf565b826001600160a01b0316846001600160a01b031610895b915091508115610cde57610cd98486602001513384612516565b610d28565b8451610ce9906126af565b15610d0e578451610cf9906126d2565b8552610d0881336000886122c1565b50610d28565b80600081905550829350610d288486602001513384612516565b505050505050505050565b60008086610deb575060018484600081610d4f57610d4f61501c565b610d6592602060609092020190810191506147d0565b6040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526001600160a01b0391909116906370a0823190602401602060405180830381865afa158015610dc4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de89190614e02565b96505b610ed285856000818110610e0157610e0161501c565b610e1792602060609092020190810191506147d0565b82610e225733610e24565b305b610ecc7f00000000000000000000000005c1be79d3ac21cc4b727eed58c9b2ff757f566389896000818110610e5b57610e5b61501c565b610e7192602060609092020190810191506147d0565b8a8a6000818110610e8457610e8461501c565b9050606002016020016020810190610e9c91906147d0565b8b8b6000818110610eaf57610eaf61501c565b9050606002016040016020810190610ec79190615059565b6126ee565b8a612516565b6000196001600160a01b03841601610eec57339250610f20565b7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe6001600160a01b03841601610f20573092505b60008585610f2f600182614f6f565b818110610f3e57610f3e61501c565b9050606002016020016020810190610f5691906147d0565b6040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b03868116600483015291909116906370a0823190602401602060405180830381865afa158015610fb7573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610fdb9190614e02565b90506110398686808060200260200160405190810160405280939291908181526020016000905b8282101561102e5761101f60608302860136819003810190615076565b81526020019060010190611002565b505050505085612811565b808686611047600182614f6f565b8181106110565761105661501c565b905060600201602001602081019061106e91906147d0565b6040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b03878116600483015291909116906370a0823190602401602060405180830381865afa1580156110cf573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110f39190614e02565b6110fd9190614f6f565b92508683101561114f5760405162461bcd60e51b815260206004820152601360248201527f546f6f206c6974746c65207265636569766564000000000000000000000000006044820152606401610338565b505095945050505050565b6111678484338585611f59565b50505050565b471561117d5761117d3347612c1a565b565b6040517f8fcbaf0c00000000000000000000000000000000000000000000000000000000815233600482015230602482015260448101869052606481018590526001608482015260ff841660a482015260c4810183905260e481018290526001600160a01b03871690638fcbaf0c90610104015b600060405180830381600087803b15801561120d57600080fd5b505af1158015611221573d6000803e3d6000fd5b50505050505050505050565b61123981600019612cd7565b61124257600080fd5b50565b606083610c0781612df0565b6040805161014081019091526060906113d7907f9cc1a28300000000000000000000000000000000000000000000000000000000908061129460208701876147d0565b6001600160a01b031681526020018560200160208101906112b591906147d0565b6001600160a01b031681526020016112d360608701604088016150f7565b60020b81526020016112eb60808701606088016150f7565b60020b815260209081019061130b90611306908801886147d0565b612e40565b815260200161132686602001602081019061130691906147d0565b81526080860135602082015260a0860135604082015260600161134f60e0870160c088016147d0565b6001600160a01b031681526020016000198152506040516024016113739190615114565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fffffffff000000000000000000000000000000000000000000000000000000009093169290921790915261178e565b92915050565b6113e8816000612cd7565b61122d57600080fd5b600061141c7f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad38612e40565b90508281101561146e5760405162461bcd60e51b815260206004820152601960248201527f496e73756666696369656e7420574e6174697665546f6b656e000000000000006044820152606401610338565b8015611511576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b031690632e1a7d4d90602401600060405180830381600087803b1580156114ef57600080fd5b505af1158015611503573d6000803e3d6000fd5b505050506115118282612c1a565b505050565b60006115cd6060830180359061152f90604086016147d0565b61153f60c0860160a087016147d0565b604051806040016040528087602001602081019061155d91906147d0565b61156a60208a018a6147d0565b6040517fffffffffffffffffffffffffffffffffffffffff000000000000000000000000606093841b811660208301529190921b1660348201526048016040516020818303038152906040528152602001336001600160a01b03168152506122c1565b9050816080013581111561082d5760405162461bcd60e51b815260206004820152601260248201527f546f6f206d7563682072657175657374656400000000000000000000000000006044820152606401610338565b60001961162f87612ec5565b1015610ba257610ba286868686868661117f565b61164e816000612cd7565b61165757600080fd5b611239816116686001600019614f6f565b612cd7565b60608167ffffffffffffffff81111561168857611688614373565b6040519080825280602002602001820160405280156116bb57816020015b60608152602001906001900390816116a65790505b50905060005b8281101561178757600080308686858181106116df576116df61501c565b90506020028101906116f19190614d9d565b6040516116ff9291906151bf565b600060405180830381855af49150503d806000811461173a576040519150601f19603f3d011682016040523d82523d6000602084013e61173f565b606091505b50915091508161175f57600081511161175757600080fd5b805181602001fd5b808484815181106117725761177261501c565b602090810291909101015250506001016116c1565b5092915050565b606060007f000000000000000000000000d82fe82244ad01aad671576202f9b46b76fadfe26001600160a01b0316836040516117ca91906151cf565b6000604051808303816000865af19150503d8060008114611807576040519150601f19603f3d011682016040523d82523d6000602084013e61180c565b606091505b5092509050806118585760448251101561182557600080fd5b6004820191508180602001905181019061183f91906151eb565b60405162461bcd60e51b815260040161033891906147ff565b50919050565b600080600083604001510361190c5760019050600061188084600001516124d8565b506040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201529091506001600160a01b038216906370a0823190602401602060405180830381865afa1580156118e1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119059190614e02565b6040850152505b600081611919573361191b565b305b90505b600061192d85600001516126af565b9050611979856040015182611946578660200151611948565b305b600060405180604001604052806119628b60000151612f13565b8152602001876001600160a01b0316815250612f25565b60408601528015611999578451309250611992906126d2565b85526119a6565b84604001519350506119ac565b5061191e565b8360600151831015611a005760405162461bcd60e51b815260206004820152601360248201527f546f6f206c6974746c65207265636569766564000000000000000000000000006044820152606401610338565b5050919050565b6000806000836060015103611aa2575081516040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526001916001600160a01b0316906370a0823190602401602060405180830381865afa158015611a78573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a9c9190614e02565b60608401525b60608084015160408086015160a08701518251808401909352875160208901517fffffffffffffffffffffffffffffffffffffffff00000000000000000000000091871b82168588015290951b9094166074830152611b339390918060888101604051602081830303815290604052815260200186611b215733611b23565b305b6001600160a01b03169052612f25565b915082608001518210156118585760405162461bcd60e51b815260206004820152601360248201527f546f6f206c6974746c65207265636569766564000000000000000000000000006044820152606401610338565b84611b9387612ec5565b1015610ba257610ba2868686868686612251565b600082118015611bb8575060648211155b611bc157600080fd5b6040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526000907f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b0316906370a0823190602401602060405180830381865afa158015611c41573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c659190614e02565b905084811015611cb75760405162461bcd60e51b815260206004820152601960248201527f496e73756666696369656e7420574e6174697665546f6b656e000000000000006044820152606401610338565b8015611d90576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b031690632e1a7d4d90602401600060405180830381600087803b158015611d3857600080fd5b505af1158015611d4c573d6000803e3d6000fd5b5050505060006127108483611d619190615259565b611d6b919061529f565b90508015611d7d57611d7d8382612c1a565b610ba285611d8b8385614f6f565b612c1a565b5050505050565b61151183338484611ba7565b61124281336113f1565b6040517fdd62ed3e0000000000000000000000000000000000000000000000000000000081523060048201526001600160a01b037f000000000000000000000000d82fe82244ad01aad671576202f9b46b76fadfe281166024830152600091839185169063dd62ed3e90604401602060405180830381865afa158015611e37573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e5b9190614e02565b10611e68575060006113d7565b611e7483600019612cd7565b15611e81575060016113d7565b611e92836116686001600019614f6f565b15611e9f575060026113d7565b611eaa836000612cd7565b611eb357600080fd5b611ebf83600019612cd7565b15611ecc575060036113d7565b611edd836116686001600019614f6f565b156103435750600492915050565b6000611ef684612e40565b905082811015611f485760405162461bcd60e51b815260206004820152601260248201527f496e73756666696369656e7420746f6b656e00000000000000000000000000006044820152606401610338565b8015611167576111678483836130b7565b600082118015611f6a575060648211155b611f7357600080fd5b6040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526000906001600160a01b038716906370a0823190602401602060405180830381865afa158015611fd3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ff79190614e02565b9050848110156120495760405162461bcd60e51b815260206004820152601260248201527f496e73756666696369656e7420746f6b656e00000000000000000000000000006044820152606401610338565b8015610ba257600061271061205e8584615259565b612068919061529f565b9050801561207b5761207b8784836130b7565b61208f878661208a8486614f6f565b6130b7565b50505050505050565b6120a3828233611eeb565b5050565b6000806120b58686856131f9565b915091508360020b81836120c991906152b3565b12610ba25760405162461bcd60e51b815260206004820152600260248201527f54440000000000000000000000000000000000000000000000000000000000006044820152606401610338565b60606113d763219f5d1760e01b6040518060c001604052808560400135815260200161214e86600001602081019061130691906147d0565b815260200161216986602001602081019061130691906147d0565b815260200185606001358152602001856080013581526020016000198152506040516024016113739190600060c082019050825182526020830151602083015260408301516040830152606083015160608301526080830151608083015260a083015160a083015292915050565b6000806121e4858461344b565b915091508360020b81836121f891906152b3565b12611d905760405162461bcd60e51b815260206004820152600260248201527f54440000000000000000000000000000000000000000000000000000000000006044820152606401610338565b6120a3823330846136a3565b6040517fd505accf000000000000000000000000000000000000000000000000000000008152336004820152306024820152604481018690526064810185905260ff8416608482015260a4810183905260c481018290526001600160a01b0387169063d505accf9060e4016111f3565b60006000196001600160a01b038516016122dd57339350612311565b7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe6001600160a01b03851601612311573093505b60008061232184600001516124d8565b90925090506001600160a01b03808316908216106000806123428486612488565b6001600160a01b031663128acb088a8561235b8e6124c4565b61236490614f37565b6001600160a01b038d1615612379578c6123b2565b876123a25761239d600173fffd8963efd1fc6a506488495d951d5263988d26614e4a565b6123b2565b6123b26401000276a36001614e6a565b8c6040516020016123c39190614e8a565b6040516020818303038152906040526040518663ffffffff1660e01b81526004016123f29594939291906152d3565b60408051808303816000875af1158015612410573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906124349190614f13565b9150915060008361244e578161244984614f37565b612458565b8261245883614f37565b90975090506001600160a01b03891660000361247a578a811461247a57600080fd5b505050505050949350505050565b60006124bd7f000000000000000000000000885229e48987ea4c68f0aa1bcbff5184198a91886124b885856137ed565b613841565b9392505050565b8060008112156124d357600080fd5b919050565b6000806124e583826139a2565b91506124f28360146139a2565b9050915091565b600061250e8461250985856137ed565b613a11565b949350505050565b7f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b0316846001600160a01b03161480156125575750804710155b15612683577f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad386001600160a01b031663d0e30db0826040518263ffffffff1660e01b81526004016000604051808303818588803b1580156125b757600080fd5b505af11580156125cb573d6000803e3d6000fd5b50506040517fa9059cbb0000000000000000000000000000000000000000000000000000000081526001600160a01b038681166004830152602482018690527f000000000000000000000000039e2fb66102314ce7b64ce5ce3e5183bc94ad3816935063a9059cbb925060440190506020604051808303816000875af1158015612659573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061267d9190615318565b50611167565b306001600160a01b038416036126a35761269e8483836130b7565b611167565b611167848484846136a3565b600060146126bd8180615335565b6126c79190615335565b825110159050919050565b60606113d760148084516126e69190614f6f565b849190613a77565b60008060006126fd8686613b91565b6040517fffffffffffffffffffffffffffffffffffffffff000000000000000000000000606084811b8216602084015283901b16603482015286151560f81b604882015291935091508790604901604051602081830303815290604052805190602001206040516020016127ee9291907fff00000000000000000000000000000000000000000000000000000000000000815260609290921b7fffffffffffffffffffffffffffffffffffffffff00000000000000000000000016600183015260158201527f6c45999f36731ff6ab43e943fca4b5a700786bbb202116cf6633b32039161e05603582015260550190565b60408051601f198184030181529190528051602090910120979650505050505050565b60005b8251811015611511576000808483815181106128325761283261501c565b6020026020010151600001518584815181106128505761285061501c565b60200260200101516020015191509150600061286c8383613b91565b50905060006128f47f00000000000000000000000005c1be79d3ac21cc4b727eed58c9b2ff757f56638887815181106128a7576128a761501c565b6020026020010151600001518988815181106128c5576128c561501c565b6020026020010151602001518a89815181106128e3576128e361501c565b6020026020010151604001516126ee565b9050600080600089888151811061290d5761290d61501c565b6020026020010151604001519050600080856001600160a01b0316630902f1ac6040518163ffffffff1660e01b8152600401606060405180830381865afa15801561295c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129809190615366565b506dffffffffffffffffffffffffffff1691506dffffffffffffffffffffffffffff1691506000876001600160a01b03168a6001600160a01b0316146129c75781836129ca565b82825b506040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b03898116600483015291925082918c16906370a0823190602401602060405180830381865afa158015612a2f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a539190614e02565b612a5d9190614f6f565b9550612a8c7f00000000000000000000000005c1be79d3ac21cc4b727eed58c9b2ff757f5663878c8c88613bf4565b508095505050505050600080856001600160a01b0316886001600160a01b031614612ab957826000612abd565b6000835b91509150600060018c51612ad19190614f6f565b8a10612add578a612b71565b612b717f00000000000000000000000005c1be79d3ac21cc4b727eed58c9b2ff757f56638d612b0d8d6001615335565b81518110612b1d57612b1d61501c565b6020026020010151600001518e8d6001612b379190615335565b81518110612b4757612b4761501c565b6020026020010151602001518f8e6001612b619190615335565b815181106128e3576128e361501c565b604080516000815260208101918290527f022c0d9f000000000000000000000000000000000000000000000000000000009091529091506001600160a01b0387169063022c0d9f90612bcc90869086908690602481016153a2565b600060405180830381600087803b158015612be657600080fd5b505af1158015612bfa573d6000803e3d6000fd5b505050505050505050505050508080612c12906153da565b915050612814565b604080516000808252602082019092526001600160a01b038416908390604051612c4491906151cf565b60006040518083038185875af1925050503d8060008114612c81576040519150601f19603f3d011682016040523d82523d6000602084013e612c86565b606091505b50509050806115115760405162461bcd60e51b815260206004820152600360248201527f53544500000000000000000000000000000000000000000000000000000000006044820152606401610338565b604080517f000000000000000000000000d82fe82244ad01aad671576202f9b46b76fadfe26001600160a01b039081166024830152604480830185905283518084039091018152606490920183526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f095ea7b30000000000000000000000000000000000000000000000000000000017905291516000928392839291871691612d8491906151cf565b6000604051808303816000865af19150503d8060008114612dc1576040519150601f19603f3d011682016040523d82523d6000602084013e612dc6565b606091505b5091509150818015610c11575080511580610c11575080806020019051810190610c119190615318565b804211156112425760405162461bcd60e51b815260206004820152601360248201527f5472616e73616374696f6e20746f6f206f6c64000000000000000000000000006044820152606401610338565b6040517f70a082310000000000000000000000000000000000000000000000000000000081523060048201526000906001600160a01b038316906370a08231906024015b602060405180830381865afa158015612ea1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113d79190614e02565b6040517fdd62ed3e0000000000000000000000000000000000000000000000000000000081523360048201523060248201526000906001600160a01b0383169063dd62ed3e90604401612e84565b60606113d760006126e6601480615335565b60006000196001600160a01b03851601612f4157339350612f75565b7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe6001600160a01b03851601612f75573093505b600080612f8584600001516124d8565b90925090506001600160a01b0380821690831610600080612fa68585612488565b6001600160a01b031663128acb088a85612fbf8e6124c4565b6001600160a01b038d1615612fd4578c61300d565b87612ffd57612ff8600173fffd8963efd1fc6a506488495d951d5263988d26614e4a565b61300d565b61300d6401000276a36001614e6a565b8c60405160200161301e9190614e8a565b6040516020818303038152906040526040518663ffffffff1660e01b815260040161304d9594939291906152d3565b60408051808303816000875af115801561306b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061308f9190614f13565b915091508261309e57816130a0565b805b6130a990614f37565b9a9950505050505050505050565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb00000000000000000000000000000000000000000000000000000000179052915160009283929087169161314191906151cf565b6000604051808303816000865af19150503d806000811461317e576040519150601f19603f3d011682016040523d82523d6000602084013e613183565b606091505b50915091508180156131ad5750805115806131ad5750808060200190518101906131ad9190615318565b611d905760405162461bcd60e51b815260206004820152600260248201527f53540000000000000000000000000000000000000000000000000000000000006044820152606401610338565b600080835185511461320a57600080fd5b6000855167ffffffffffffffff81111561322657613226614373565b60405190808252806020026020018201604052801561326b57816020015b60408051808201909152600080825260208201528152602001906001900390816132445790505b5090506000865167ffffffffffffffff81111561328a5761328a614373565b6040519080825280602002602001820160405280156132cf57816020015b60408051808201909152600080825260208201528152602001906001900390816132a85790505b50905060005b8751811015613424576000806133048a84815181106132f6576132f661501c565b60200260200101518961344b565b915091508185848151811061331b5761331b61501c565b60200260200101516000019060020b908160020b81525050808484815181106133465761334661501c565b60200260200101516000019060020b908160020b815250508883815181106133705761337061501c565b602002602001015185848151811061338a5761338a61501c565b6020026020010151602001906fffffffffffffffffffffffffffffffff1690816fffffffffffffffffffffffffffffffff16815250508883815181106133d2576133d261501c565b60200260200101518484815181106133ec576133ec61501c565b6020908102919091018101516fffffffffffffffffffffffffffffffff9092169101525081905061341c816153da565b9150506132d5565b5061342e82613ca4565b60020b935061343c81613ca4565b60020b92505050935093915050565b60008060008061345a86613d8f565b90506000805b82811015613676576000806134748a6124d8565b9150915060006134848383612488565b90506000808b63ffffffff166000036134b0576134a083613daa565b600291820b9350900b9050613590565b61351b836001600160a01b031663ef01df4f6040518163ffffffff1660e01b8152600401602060405180830381865afa1580156134f1573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061351591906153f4565b8d61406a565b60020b9150826001600160a01b031663e76c01e46040518163ffffffff1660e01b815260040160c060405180830381865afa15801561355e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906135829190615423565b50505060029190910b925050505b61359b600189614f6f565b86036135bd57836001600160a01b0316856001600160a01b03161098506135cc565b6135c68d6126d2565b9c508496505b600086158061361f5750856001600160a01b0316886001600160a01b03161061360957856001600160a01b0316856001600160a01b03161061361f565b846001600160a01b0316866001600160a01b0316105b9050801561364457613631838d6154a2565b9b5061363d828c6154a2565b9a5061365d565b61364e838d6152b3565b9b5061365a828c6152b3565b9a505b505050505050808061366e906153da565b915050613460565b508261369957613688600019866154ca565b9450613696600019856154ca565b93505b5050509250929050565b604080516001600160a01b0385811660248301528481166044830152606480830185905283518084039091018152608490920183526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f23b872dd00000000000000000000000000000000000000000000000000000000179052915160009283929088169161373591906151cf565b6000604051808303816000865af19150503d8060008114613772576040519150601f19603f3d011682016040523d82523d6000602084013e613777565b606091505b50915091508180156137a15750805115806137a15750808060200190518101906137a19190615318565b610ba25760405162461bcd60e51b815260206004820152600360248201527f53544600000000000000000000000000000000000000000000000000000000006044820152606401610338565b6040805180820190915260008082526020820152816001600160a01b0316836001600160a01b0316111561381f579091905b50604080518082019091526001600160a01b0392831681529116602082015290565b600081602001516001600160a01b031682600001516001600160a01b0316106138ac5760405162461bcd60e51b815260206004820152601760248201527f496e76616c6964206f72646572206f6620746f6b656e730000000000000000006044820152606401610338565b82826000015183602001516040516020016138dd9291906001600160a01b0392831681529116602082015260400190565b60408051601f19818403018152908290528051602091820120613983939290917ff96d2474815c32e070cd63233f06af5413efc5dcb430aee4ff18cc29007c562d91017fff00000000000000000000000000000000000000000000000000000000000000815260609390931b7fffffffffffffffffffffffffffffffffffffffff0000000000000000000000001660018401526015830191909152603582015260550190565b60408051601f1981840301815291905280516020909101209392505050565b600081601401835110156139f85760405162461bcd60e51b815260206004820152601560248201527f746f416464726573735f6f75744f66426f756e647300000000000000000000006044820152606401610338565b5001602001516c01000000000000000000000000900490565b6000613a1d8383613841565b9050336001600160a01b038216146113d75760405162461bcd60e51b815260206004820152601a60248201527f496e76616c69642063616c6c6572206f662063616c6c6261636b0000000000006044820152606401610338565b60608182601f011015613acc5760405162461bcd60e51b815260206004820152600e60248201527f736c6963655f6f766572666c6f770000000000000000000000000000000000006044820152606401610338565b81830184511015613b1f5760405162461bcd60e51b815260206004820152601160248201527f736c6963655f6f75744f66426f756e64730000000000000000000000000000006044820152606401610338565b606082158015613b3e5760405191506000825260208201604052613b88565b6040519150601f8416801560200281840101858101878315602002848b0101015b81831015613b77578051835260209283019201613b5f565b5050858452601f01601f1916604052505b50949350505050565b600080826001600160a01b0316846001600160a01b031603613bb257600080fd5b826001600160a01b0316846001600160a01b031610613bd2578284613bd5565b83835b90925090506001600160a01b038216613bed57600080fd5b9250929050565b6000806000613c05888787876126ee565b6040517ff140a35a000000000000000000000000000000000000000000000000000000008152600481018990526001600160a01b03888116602483015291925060009183169063f140a35a90604401602060405180830381865afa158015613c71573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613c959190614e02565b99949850939650505050505050565b6000806000805b8451811015613d5b57848181518110613cc657613cc661501c565b602002602001015160200151600f0b858281518110613ce757613ce761501c565b60200260200101516000015160020b613d0091906154ca565b613d0a90846154a2565b9250848181518110613d1e57613d1e61501c565b6020026020010151602001516fffffffffffffffffffffffffffffffff1682613d479190615335565b915080613d53816153da565b915050613cab565b50613d668183615516565b9250600082128015613d805750613d7d8183615560565b15155b15611a005782610c1181615574565b60006014808351613da09190614f6f565b6113d7919061529f565b600080600080846001600160a01b031663e76c01e46040518163ffffffff1660e01b815260040160c060405180830381865afa158015613dee573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613e129190615423565b5050604080517fef01df4f0000000000000000000000000000000000000000000000000000000081529051939750600094506001600160a01b038a169363ef01df4f9350600480830193506020928290030181865afa158015613e79573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613e9d91906153f4565b9050613ea881614264565b9093509150428263ffffffff1614613ec257839450614062565b6040517f74eceae600000000000000000000000000000000000000000000000000000000815261ffff841660048201526000906001600160a01b038316906374eceae69060240160e060405180830381865afa158015613f26573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f4a91906155e0565b50506040517f74eceae60000000000000000000000000000000000000000000000000000000081526000198a0161ffff811660048301529396509294506000935083928392506001600160a01b03881691506374eceae69060240160e060405180830381865afa158015613fc2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613fe691906155e0565b505050509250925092508261403d5760405162461bcd60e51b815260206004820152600360248201527f544e4900000000000000000000000000000000000000000000000000000000006044820152606401610338565b818703600381900b82870360060b8161405857614058615270565b059a505050505050505b505050915091565b60008163ffffffff166000036140c25760405162461bcd60e51b815260206004820152600e60248201527f506572696f64206973207a65726f0000000000000000000000000000000000006044820152606401610338565b60408051600280825260608201835260009260208301908036833701905050905082816000815181106140f7576140f761501c565b602002602001019063ffffffff16908163ffffffff16815250506000816001815181106141265761412661501c565b63ffffffff909216602092830291909101909101526040517f9d3a524100000000000000000000000000000000000000000000000000000000815284906000906001600160a01b03831690639d3a524190614185908690600401615670565b600060405180830381865afa1580156141a2573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526141ca919081019061571c565b5090506000816000815181106141e2576141e261501c565b6020026020010151826001815181106141fd576141fd61501c565b602002602001015161420f91906157df565b905061422163ffffffff871682615824565b945060008160060b128015614247575061424163ffffffff87168261587a565b60060b15155b1561425a578461425681615574565b9550505b5050505092915050565b600080614270836142d4565b9150826001600160a01b031663f5985d356040518163ffffffff1660e01b8152600401602060405180830381865afa1580156142b0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906124f2919061589c565b6000816001600160a01b0316630786feb66040518163ffffffff1660e01b8152600401602060405180830381865afa158015614314573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113d791906158b9565b60006020828403121561434a57600080fd5b813567ffffffffffffffff81111561436157600080fd5b8201608081850312156124bd57600080fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156143cb576143cb614373565b604052919050565b6001600160a01b038116811461124257600080fd5b600060c082840312156143fa57600080fd5b60405160c0810181811067ffffffffffffffff8211171561441d5761441d614373565b604052823561442b816143d3565b8152602083013561443b816143d3565b6020820152604083013561444e816143d3565b80604083015250606083013560608201526080830135608082015260a0830135614477816143d3565b60a08201529392505050565b60006020828403121561449557600080fd5b5035919050565b60008083601f8401126144ae57600080fd5b50813567ffffffffffffffff8111156144c657600080fd5b6020830191508360208260051b8501011115613bed57600080fd5b6000806000604084860312156144f657600080fd5b83359250602084013567ffffffffffffffff81111561451457600080fd5b6145208682870161449c565b9497909650939450505050565b60005b83811015614548578181015183820152602001614530565b50506000910152565b6000815180845261456981602086016020860161452d565b601f01601f19169290920160200192915050565b6000602080830181845280855180835260408601915060408160051b870101925083870160005b828110156145f0577fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffc08886030184526145de858351614551565b945092850192908501906001016145a4565b5092979650505050505050565b6000806000806060858703121561461357600080fd5b8435935060208501359250604085013567ffffffffffffffff8082111561463957600080fd5b818701915087601f83011261464d57600080fd5b81358181111561465c57600080fd5b88602082850101111561466e57600080fd5b95989497505060200194505050565b60008060008060006080868803121561469557600080fd5b8535945060208601359350604086013567ffffffffffffffff808211156146bb57600080fd5b818801915088601f8301126146cf57600080fd5b8135818111156146de57600080fd5b8960206060830285010111156146f357600080fd5b602083019550809450505050606086013561470d816143d3565b809150509295509295909350565b6000806000806080858703121561473157600080fd5b843561473c816143d3565b93506020850135925060408501359150606085013561475a816143d3565b939692955090935050565b60ff8116811461124257600080fd5b60008060008060008060c0878903121561478d57600080fd5b8635614798816143d3565b9550602087013594506040870135935060608701356147b681614765565b9598949750929560808101359460a0909101359350915050565b6000602082840312156147e257600080fd5b81356124bd816143d3565b600060e0828403121561185857600080fd5b6020815260006124bd6020830184614551565b6000806040838503121561482557600080fd5b823591506020830135614837816143d3565b809150509250929050565b600060c0828403121561185857600080fd5b6000806020838503121561486757600080fd5b823567ffffffffffffffff81111561487e57600080fd5b61488a8582860161449c565b90969095509350505050565b600067ffffffffffffffff8211156148b0576148b0614373565b50601f01601f191660200190565b600082601f8301126148cf57600080fd5b81356148e26148dd82614896565b6143a2565b8181528460208386010111156148f757600080fd5b816020850160208301376000918101602001919091529392505050565b60006020828403121561492657600080fd5b813567ffffffffffffffff81111561493d57600080fd5b61250e848285016148be565b60006020828403121561495b57600080fd5b813567ffffffffffffffff8082111561497357600080fd5b908301906080828603121561498757600080fd5b6040516080810181811083821117156149a2576149a2614373565b6040528235828111156149b457600080fd5b6149c0878286016148be565b825250602083013591506149d3826143d3565b816020820152604083013560408201526060830135606082015280935050505092915050565b60008060008060808587031215614a0f57600080fd5b843593506020850135614a21816143d3565b925060408501359150606085013561475a816143d3565b600080600060608486031215614a4d57600080fd5b83359250602084013591506040840135614a66816143d3565b809150509250925092565b60008060408385031215614a8457600080fd5b8235614a8f816143d3565b946020939093013593505050565b6020810160058310614ad8577f4e487b7100000000000000000000000000000000000000000000000000000000600052602160045260246000fd5b91905290565b600080600060608486031215614af357600080fd5b8335614afe816143d3565b9250602084013591506040840135614a66816143d3565b600080600080600060a08688031215614b2d57600080fd5b8535614b38816143d3565b9450602086013593506040860135614b4f816143d3565b925060608601359150608086013561470d816143d3565b600067ffffffffffffffff821115614b8057614b80614373565b5060051b60200190565b600082601f830112614b9b57600080fd5b81356020614bab6148dd83614b66565b82815260059290921b84018101918181019086841115614bca57600080fd5b8286015b84811015614c045780356fffffffffffffffffffffffffffffffff81168114614bf75760008081fd5b8352918301918301614bce565b509695505050505050565b803562ffffff811681146124d357600080fd5b63ffffffff8116811461124257600080fd5b80356124d381614c22565b60008060008060808587031215614c5557600080fd5b843567ffffffffffffffff80821115614c6d57600080fd5b818701915087601f830112614c8157600080fd5b81356020614c916148dd83614b66565b82815260059290921b8401810191818101908b841115614cb057600080fd5b8286015b84811015614ce857803586811115614ccc5760008081fd5b614cda8e86838b01016148be565b845250918301918301614cb4565b5098505088013592505080821115614cff57600080fd5b50614d0c87828801614b8a565b935050614d1b60408601614c0f565b9150614d2960608601614c34565b905092959194509250565b600060a0828403121561185857600080fd5b600080600060608486031215614d5b57600080fd5b833567ffffffffffffffff811115614d7257600080fd5b614d7e868287016148be565b935050614d8d60208501614c0f565b91506040840135614a6681614c22565b60008083357fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe1843603018112614dd257600080fd5b83018035915067ffffffffffffffff821115614ded57600080fd5b602001915036819003821315613bed57600080fd5b600060208284031215614e1457600080fd5b5051919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6001600160a01b0382811682821603908082111561178757611787614e1b565b6001600160a01b0381811683821601908082111561178757611787614e1b565b602081526000825160406020840152614ea66060840182614551565b90506001600160a01b0360208501511660408401528091505092915050565b60006001600160a01b0380891683528088166020840152861515604084015285606084015280851660808401525060c060a0830152614f0760c0830184614551565b98975050505050505050565b60008060408385031215614f2657600080fd5b505080516020909101519092909150565b60007f80000000000000000000000000000000000000000000000000000000000000008203614f6857614f68614e1b565b5060000390565b818103818111156113d7576113d7614e1b565b600060208284031215614f9457600080fd5b813567ffffffffffffffff80821115614fac57600080fd5b9083019060408286031215614fc057600080fd5b604051604081018181108382111715614fdb57614fdb614373565b604052823582811115614fed57600080fd5b614ff9878286016148be565b8252506020830135925061500c836143d3565b6020810192909252509392505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b801515811461124257600080fd5b60006020828403121561506b57600080fd5b81356124bd8161504b565b60006060828403121561508857600080fd5b6040516060810181811067ffffffffffffffff821117156150ab576150ab614373565b60405282356150b9816143d3565b815260208301356150c9816143d3565b602082015260408301356150dc8161504b565b60408201529392505050565b8060020b811461124257600080fd5b60006020828403121561510957600080fd5b81356124bd816150e8565b81516001600160a01b031681526101408101602083015161514060208401826001600160a01b03169052565b506040830151615155604084018260020b9052565b50606083015161516a606084018260020b9052565b506080830151608083015260a083015160a083015260c083015160c083015260e083015160e0830152610100808401516151ae828501826001600160a01b03169052565b505061012092830151919092015290565b8183823760009101908152919050565b600082516151e181846020870161452d565b9190910192915050565b6000602082840312156151fd57600080fd5b815167ffffffffffffffff81111561521457600080fd5b8201601f8101841361522557600080fd5b80516152336148dd82614896565b81815285602083850101111561524857600080fd5b610c1182602083016020860161452d565b80820281158282048414176113d7576113d7614e1b565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000826152ae576152ae615270565b500490565b818103600083128015838313168383128216171561178757611787614e1b565b60006001600160a01b038088168352861515602084015285604084015280851660608401525060a0608083015261530d60a0830184614551565b979650505050505050565b60006020828403121561532a57600080fd5b81516124bd8161504b565b808201808211156113d7576113d7614e1b565b80516dffffffffffffffffffffffffffff811681146124d357600080fd5b60008060006060848603121561537b57600080fd5b61538484615348565b925061539260208501615348565b91506040840151614a6681614c22565b8481528360208201526001600160a01b03831660408201526080606082015260006153d06080830184614551565b9695505050505050565b600060001982036153ed576153ed614e1b565b5060010190565b60006020828403121561540657600080fd5b81516124bd816143d3565b805161ffff811681146124d357600080fd5b60008060008060008060c0878903121561543c57600080fd5b8651615447816143d3565b6020880151909650615458816150e8565b945061546660408801615411565b9350606087015161547681614765565b925061548460808801615411565b915060a08701516154948161504b565b809150509295509295509295565b80820182811260008312801582168215821617156154c2576154c2614e1b565b505092915050565b808202600082127f80000000000000000000000000000000000000000000000000000000000000008414161561550257615502614e1b565b81810583148215176113d7576113d7614e1b565b60008261552557615525615270565b60001983147f80000000000000000000000000000000000000000000000000000000000000008314161561555b5761555b614e1b565b500590565b60008261556f5761556f615270565b500790565b60008160020b7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffff80000081036155a9576155a9614e1b565b6000190192915050565b8051600681900b81146124d357600080fd5b80516affffffffffffffffffffff811681146124d357600080fd5b600080600080600080600060e0888a0312156155fb57600080fd5b87516156068161504b565b602089015190975061561781614c22565b9550615625604089016155b3565b9450615633606089016155c5565b93506080880151615643816150e8565b60a0890151909350615654816150e8565b915061566260c08901615411565b905092959891949750929550565b6020808252825182820181905260009190848201906040850190845b818110156156ae57835163ffffffff168352928401929184019160010161568c565b50909695505050505050565b600082601f8301126156cb57600080fd5b815160206156db6148dd83614b66565b82815260059290921b840181019181810190868411156156fa57600080fd5b8286015b84811015614c045761570f816155c5565b83529183019183016156fe565b6000806040838503121561572f57600080fd5b825167ffffffffffffffff8082111561574757600080fd5b818501915085601f83011261575b57600080fd5b8151602061576b6148dd83614b66565b82815260059290921b8401810191818101908984111561578a57600080fd5b948201945b838610156157af576157a0866155b3565b8252948201949082019061578f565b918801519196509093505050808211156157c857600080fd5b506157d5858286016156ba565b9150509250929050565b600682810b9082900b037fffffffffffffffffffffffffffffffffffffffffffffffffff800000000000008112667fffffffffffff821317156113d7576113d7614e1b565b60008160060b8360060b8061583b5761583b615270565b60001981147fffffffffffffffffffffffffffffffffffffffffffffffffff800000000000008314161561587157615871614e1b565b90059392505050565b60008260060b8061588d5761588d615270565b808360060b0791505092915050565b6000602082840312156158ae57600080fd5b81516124bd81614c22565b6000602082840312156158cb57600080fd5b6124bd8261541156fea164736f6c6343000814000a

    Block Age Transaction Gas Used Reward
    view all blocks ##produced##

    Block Age Uncle Number Difficulty Gas Used Reward
    View All Uncles
    Loading...
    Loading
    Loading...
    Loading

    Validator Index Block Age Amount
    View All Withdrawals

    Transaction Hash Block Age Value Eth2 PubKey Valid
    View All Deposits
    [ Download: CSV Export  ]
    [ Download: CSV Export  ]

    A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.