ETH Price: $3,307.44 (-0.05%)

Contract

0xA42ecABB4ADEd01600d6e84A3Ee7785e3A506D37
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Create Vault194630442024-03-18 17:04:59280 days ago1710781499IN
0xA42ecABB...e3A506D37
0 ETH0.0597038845.88963326
Create Vault190808932024-01-25 3:16:59333 days ago1706152619IN
0xA42ecABB...e3A506D37
0.0828 ETH0.0756627110.80332451
Create Vault190635062024-01-22 16:39:47336 days ago1705941587IN
0xA42ecABB...e3A506D37
1.05 ETH0.1344011822.10282898
Create Vault190587172024-01-22 0:27:23336 days ago1705883243IN
0xA42ecABB...e3A506D37
0.06 ETH0.0594867111.80685831
Create Vault190175942024-01-16 6:15:23342 days ago1705385723IN
0xA42ecABB...e3A506D37
0.053 ETH0.0877550721.13086274
Create Vault189285162024-01-03 18:08:35355 days ago1704305315IN
0xA42ecABB...e3A506D37
0.008 ETH0.1119200927.8379934
Create Vault188699152023-12-26 12:37:23363 days ago1703594243IN
0xA42ecABB...e3A506D37
0.008 ETH0.1085700722.95662901
Create Vault188666652023-12-26 1:42:11363 days ago1703554931IN
0xA42ecABB...e3A506D37
0.048 ETH0.05147812.52625053
Create Vault188311572023-12-21 2:05:11368 days ago1703124311IN
0xA42ecABB...e3A506D37
0 ETH0.0492546538.36128139
Create Vault188311522023-12-21 2:04:11368 days ago1703124251IN
0xA42ecABB...e3A506D37
0 ETH0.0501487638.54430665
Create Vault186870742023-11-30 21:23:47388 days ago1701379427IN
0xA42ecABB...e3A506D37
0.84 ETH0.3761698963.43595641
Create Vault186868782023-11-30 20:44:35388 days ago1701377075IN
0xA42ecABB...e3A506D37
0 ETH0.0841394564.67310898
Create Vault184728882023-10-31 21:48:11418 days ago1698788891IN
0xA42ecABB...e3A506D37
0.098523 ETH0.1012655522.08424365
Create Vault184387782023-10-27 3:11:23423 days ago1698376283IN
0xA42ecABB...e3A506D37
0.14 ETH0.0599484613.22343129
Create Vault184135452023-10-23 14:24:47427 days ago1698071087IN
0xA42ecABB...e3A506D37
0.16 ETH0.2105314837.37713906
Create Vault184088072023-10-22 22:27:11427 days ago1698013631IN
0xA42ecABB...e3A506D37
0.0048 ETH0.04412968.06372849
Create Vault183999962023-10-21 16:52:47429 days ago1697907167IN
0xA42ecABB...e3A506D37
0.18 ETH0.0503465711.16474288
Create Vault183826072023-10-19 6:29:47431 days ago1697696987IN
0xA42ecABB...e3A506D37
0.032175 ETH0.040582475.71716596
Create Vault183448822023-10-13 23:55:11436 days ago1697241311IN
0xA42ecABB...e3A506D37
0.0024 ETH0.036010825.36217014
Create Vault182278772023-09-27 15:06:23453 days ago1695827183IN
0xA42ecABB...e3A506D37
0.46 ETH0.1331257724.24400543
Create Vault181803702023-09-20 23:25:47459 days ago1695252347IN
0xA42ecABB...e3A506D37
0.067 ETH0.09277999.71585618
Create Vault180751582023-09-06 4:52:47474 days ago1693975967IN
0xA42ecABB...e3A506D37
0.048 ETH0.079927459.98042319
Create Vault179968442023-08-26 5:44:23485 days ago1693028663IN
0xA42ecABB...e3A506D37
0.16065 ETH0.0798592412.21368078
Create Vault179963432023-08-26 4:02:47485 days ago1693022567IN
0xA42ecABB...e3A506D37
0.24 ETH0.063337811.64990717
Create Vault179445382023-08-18 22:05:35492 days ago1692396335IN
0xA42ecABB...e3A506D37
0.0715 ETH0.1038146918.46043816
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Block
From
To
190808932024-01-25 3:16:59333 days ago1706152619
0xA42ecABB...e3A506D37
0.0828 ETH
190635062024-01-22 16:39:47336 days ago1705941587
0xA42ecABB...e3A506D37
1.05 ETH
190587172024-01-22 0:27:23336 days ago1705883243
0xA42ecABB...e3A506D37
0.06 ETH
190175942024-01-16 6:15:23342 days ago1705385723
0xA42ecABB...e3A506D37
0.053 ETH
189285162024-01-03 18:08:35355 days ago1704305315
0xA42ecABB...e3A506D37
0.008 ETH
188699152023-12-26 12:37:23363 days ago1703594243
0xA42ecABB...e3A506D37
0.008 ETH
188666652023-12-26 1:42:11363 days ago1703554931
0xA42ecABB...e3A506D37
0.048 ETH
186870742023-11-30 21:23:47388 days ago1701379427
0xA42ecABB...e3A506D37
0.84 ETH
185006552023-11-04 19:08:23414 days ago1699124903
0xA42ecABB...e3A506D37
0.8 ETH
185006552023-11-04 19:08:23414 days ago1699124903
0xA42ecABB...e3A506D37
0.8 ETH
184728882023-10-31 21:48:11418 days ago1698788891
0xA42ecABB...e3A506D37
0.098523 ETH
184387782023-10-27 3:11:23423 days ago1698376283
0xA42ecABB...e3A506D37
0.14 ETH
184135452023-10-23 14:24:47427 days ago1698071087
0xA42ecABB...e3A506D37
0.16 ETH
184088072023-10-22 22:27:11427 days ago1698013631
0xA42ecABB...e3A506D37
0.0048 ETH
183999962023-10-21 16:52:47429 days ago1697907167
0xA42ecABB...e3A506D37
0.18 ETH
183826072023-10-19 6:29:47431 days ago1697696987
0xA42ecABB...e3A506D37
0.032175 ETH
183448822023-10-13 23:55:11436 days ago1697241311
0xA42ecABB...e3A506D37
0.0024 ETH
182278772023-09-27 15:06:23453 days ago1695827183
0xA42ecABB...e3A506D37
0.46 ETH
181803702023-09-20 23:25:47459 days ago1695252347
0xA42ecABB...e3A506D37
0.067 ETH
180751582023-09-06 4:52:47474 days ago1693975967
0xA42ecABB...e3A506D37
0.048 ETH
179968442023-08-26 5:44:23485 days ago1693028663
0xA42ecABB...e3A506D37
0.16065 ETH
179963432023-08-26 4:02:47485 days ago1693022567
0xA42ecABB...e3A506D37
0.24 ETH
179445382023-08-18 22:05:35492 days ago1692396335
0xA42ecABB...e3A506D37
0.0715 ETH
179195492023-08-15 10:08:35496 days ago1692094115
0xA42ecABB...e3A506D37
0.18 ETH
179070542023-08-13 16:13:11498 days ago1691943191
0xA42ecABB...e3A506D37
0.08 ETH
View All Internal Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
NFTXVaultCreationZap

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 1000 runs

Other Settings:
default evmVersion, MIT license
File 1 of 23 : NFTXVaultCreationZap.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../interface/INFTXInventoryStaking.sol";
import "../interface/INFTXLPStaking.sol";
import "../interface/IUniswapV2Router01.sol";
import "../interface/INFTXVault.sol";
import "../interface/INFTXVaultFactory.sol";
import "../testing/IERC1155.sol";
import "../testing/ERC1155Holder.sol";
import "../util/Ownable.sol";
import "../util/ReentrancyGuard.sol";
import "../util/SafeERC20.sol";
import "../util/SushiHelper.sol";


/**
 * @notice A partial WETH interface.
 */

interface IWETH {
  function deposit() external payable;
  function transfer(address to, uint value) external returns (bool);
  function withdraw(uint) external;
  function balanceOf(address to) external view returns (uint256);
  function approve(address guy, uint wad) external returns (bool);
}


/**
 * @notice An amalgomation of vault creation steps, merged and optimised in
 * a single contract call in an attempt reduce gas costs to the end-user.
 * 
 * @author Twade
 */

contract NFTXVaultCreationZap is Ownable, ReentrancyGuard, ERC1155Holder {

  using SafeERC20 for IERC20;

  /// @notice Allows zap to be paused
  bool public paused = false;

  /// @notice An interface for the NFTX Vault Factory contract
  INFTXVaultFactory public immutable vaultFactory;

  /// @notice Holds the mapping of our sushi router
  IUniswapV2Router01 public immutable sushiRouter;
  SushiHelper internal immutable sushiHelper;

  /// @notice An interface for the WETH contract
  IWETH public immutable WETH;

  /// @notice An interface for the NFTX Vault Factory contract
  INFTXInventoryStaking public immutable inventoryStaking;
  INFTXLPStaking public immutable lpStaking;

  // Set a constant address for specific contracts that need special logic
  address constant CRYPTO_PUNKS = 0xb47e3cd837dDF8e4c57F05d70Ab865de6e193BBB;

  /// @notice Basic information pertaining to the vault
  struct vaultInfo {
    address assetAddress;      // 20/32
    bool is1155;               // 21/32
    bool allowAllItems;        // 22/32
    string name;               // ??/32
    string symbol;             // ??/32
  }

  /// @notice Fee information in 9-decimal format
  struct vaultFeesConfig {
    uint32 mintFee;
    uint32 randomRedeemFee;
    uint32 targetRedeemFee;
    uint32 randomSwapFee;
    uint32 targetSwapFee;
  }

  /// @notice Reference to the vault's eligibility implementation
  struct vaultEligibilityStorage {
    int moduleIndex;
    bytes initData;
  }

  /// @notice Valid tokens to be transferred to the vault on creation
  struct vaultTokens {
    uint[] assetTokenIds;
    uint[] assetTokenAmounts;

    // Sushiswap integration for liquidity
    uint minTokenIn;
    uint minWethIn;
    uint wethIn;
  }


  /**
   * @notice Initialises our zap by setting contract addresses onto their
   * respective interfaces.
   */

  constructor(
    address _vaultFactory,
    address _inventoryStaking,
    address _lpStaking,
    address _sushiRouter,
    address _sushiHelper,
    address _weth
  ) Ownable() ReentrancyGuard() {
    // Set our staking contracts
    inventoryStaking = INFTXInventoryStaking(_inventoryStaking);
    lpStaking = INFTXLPStaking(_lpStaking);

    // Set our NFTX factory contract
    vaultFactory = INFTXVaultFactory(_vaultFactory);

    // Set our Sushi Router used for liquidity
    sushiRouter = IUniswapV2Router01(_sushiRouter);
    sushiHelper = SushiHelper(_sushiHelper);

    // Set our chain's WETH contract
    WETH = IWETH(_weth);
    // setting infinite approval here to save on subsequent gas costs
    IWETH(_weth).approve(_sushiRouter, type(uint256).max);
  }


  /**
   * @notice Creates an NFTX vault, handling any desired settings and tokens.
   * 
   * @dev Tokens are deposited into the vault prior to fees being sent.
   * 
   * @param vaultData Basic information about the vault stored in `vaultInfo` struct
   * @param vaultFeatures A numeric representation of boolean values for features on the vault
   * @param vaultFees Fee definitions stored in a `vaultFeesConfig` struct
   * @param eligibilityStorage Eligibility implementation, stored in a `vaultEligibilityStorage` struct
   * @param assetTokens Tokens to be transferred to the vault in exchange for vault tokens
   * 
   * @return vaultId_ The numeric ID of the NFTX vault
   */

  function createVault(
    vaultInfo calldata vaultData,
    uint vaultFeatures,
    vaultFeesConfig calldata vaultFees,
    vaultEligibilityStorage calldata eligibilityStorage,
    vaultTokens calldata assetTokens
  ) external nonReentrant payable returns (uint vaultId_) {
    // Ensure our zap is not paused
    require(!paused, 'Zap is paused');

    // Get the amount of starting ETH in the contract
    uint startingWeth = WETH.balanceOf(address(this));

    // Create our vault skeleton
    vaultId_ = vaultFactory.createVault(
      vaultData.name,
      vaultData.symbol,
      vaultData.assetAddress,
      vaultData.is1155,
      vaultData.allowAllItems
    );

    // Deploy our vault's xToken
    inventoryStaking.deployXTokenForVault(vaultId_);

    // Build our vault interface
    INFTXVault vault = INFTXVault(vaultFactory.vault(vaultId_));

    // If we have a specified eligibility storage, add that on
    if (eligibilityStorage.moduleIndex >= 0) {
      vault.deployEligibilityStorage(
        uint256(eligibilityStorage.moduleIndex),
        eligibilityStorage.initData
      );
    }

    // Mint and stake liquidity into the vault
    uint length = assetTokens.assetTokenIds.length;

    // If we don't have any tokens to send, we can skip our transfers
    if (length > 0) {
      // Determine the token type to alternate our transfer logic
      if (!vaultData.is1155) {
        // Iterate over our 721 tokens to transfer them all to our vault
        for (uint i; i < length;) {
          _transferFromERC721(vaultData.assetAddress, assetTokens.assetTokenIds[i], address(vault));

          if(vaultData.assetAddress == CRYPTO_PUNKS) {
            bytes memory data = abi.encodeWithSignature(
                "offerPunkForSaleToAddress(uint256,uint256,address)",
                assetTokens.assetTokenIds[i],
                0,
                address(vault)
            );
            (bool success, bytes memory resultData) = vaultData.assetAddress.call(data);
            require(success, string(resultData));
          }

          unchecked { ++i; }
        }
      } else {
        // Transfer all of our 1155 tokens to our zap, as the `mintTo` call on our
        // vault requires the call sender to hold the ERC1155 token.
        IERC1155(vaultData.assetAddress).safeBatchTransferFrom(
          msg.sender,
          address(this),
          assetTokens.assetTokenIds,
          assetTokens.assetTokenAmounts,
          ""
        );

        // Approve our vault to play with our 1155 tokens
        IERC1155(vaultData.assetAddress).setApprovalForAll(address(vault), true);
      }

      // We can now mint our asset tokens, giving the vault our tokens and storing them
      // inside our zap, as we will shortly be staking them. Our zap is excluded from fees,
      // so there should be no loss in the amount returned.
      vault.mintTo(assetTokens.assetTokenIds, assetTokens.assetTokenAmounts, address(this));

      // We now have tokens against our provided NFTs that we can now stake through either
      // inventory or liquidity.

      // Get our vaults base staking token. This is used to calculate the xToken
      address baseToken = address(vault);

      // We first want to set up our liquidity, as the returned values will be variable
      if (assetTokens.minTokenIn > 0) {
        require(msg.value >= assetTokens.wethIn, 'Insufficient msg.value sent for liquidity');

        // Wrap ETH into WETH for our contract from the sender
        WETH.deposit{value: msg.value}();

        // Convert WETH to vault token
        require(IERC20(baseToken).balanceOf(address(this)) >= assetTokens.minTokenIn, 'Insufficient tokens acquired for liquidity');

        // Provide liquidity to sushiswap, using the vault tokens and pairing it with the
        // liquidity amount specified in the call.
        IERC20(baseToken).safeApprove(address(sushiRouter), assetTokens.minTokenIn);
        (,, uint256 liquidity) = sushiRouter.addLiquidity(
          baseToken,
          address(WETH),
          assetTokens.minTokenIn,
          assetTokens.wethIn,
          assetTokens.minTokenIn,
          assetTokens.minWethIn,
          address(this),
          block.timestamp
        );
        IERC20(baseToken).safeApprove(address(sushiRouter), 0);

        // Stake in LP rewards contract 
        address lpToken = sushiHelper.pairFor(sushiRouter.factory(), baseToken, address(WETH));
        IERC20(lpToken).safeApprove(address(lpStaking), liquidity);
        lpStaking.timelockDepositFor(vaultId_, msg.sender, liquidity, 48 hours);
      }

      // Return any token dust to the caller
      uint256 remainingTokens = IERC20(baseToken).balanceOf(address(this));

      // Any tokens that we have remaining after our liquidity staking are thrown into
      // inventory to ensure what we don't have any token dust remaining.
      if (remainingTokens > 0) {
        // Make a direct timelock mint using the default timelock duration. This sends directly
        // to our user, rather than via the zap, to avoid the timelock locking the tx.
        IERC20(baseToken).transfer(inventoryStaking.vaultXToken(vaultId_), remainingTokens);
        inventoryStaking.timelockMintFor(vaultId_, remainingTokens, msg.sender, 2);
      }
    }

    // If we have specified vault features that aren't the default (all enabled)
    // then update them
    if (vaultFeatures < 31) {
      vault.setVaultFeatures(
        _getBoolean(vaultFeatures, 4),
        _getBoolean(vaultFeatures, 3),
        _getBoolean(vaultFeatures, 2),
        _getBoolean(vaultFeatures, 1),
        _getBoolean(vaultFeatures, 0)
      );
    }

    // Set our vault fees, converting our 9-decimal to 18-decimal
    vault.setFees(
      uint256(vaultFees.mintFee) * 10e9,
      uint256(vaultFees.randomRedeemFee) * 10e9,
      uint256(vaultFees.targetRedeemFee) * 10e9,
      uint256(vaultFees.randomSwapFee) * 10e9,
      uint256(vaultFees.targetSwapFee) * 10e9
    );

    // Finalise our vault, preventing further edits
    vault.finalizeVault();

    // Now that all transactions are finished we can return any ETH dust left over
    // from our liquidity staking.
    uint remainingWEth = WETH.balanceOf(address(this)) - startingWeth;
    if (remainingWEth > 0) {
      WETH.withdraw(remainingWEth);
      bool sent = payable(msg.sender).send(remainingWEth);
      require(sent, "Failed to send Ether");
    }
  }


  /**
   * @notice Transfers our ERC721 tokens to a specified recipient.
   * 
   * @param assetAddr Address of the asset being transferred
   * @param tokenId The ID of the token being transferred
   * @param to The address the token is being transferred to
   */

  function _transferFromERC721(address assetAddr, uint256 tokenId, address to) internal virtual {
    bytes memory data;

    if (assetAddr == CRYPTO_PUNKS) {
      // Fix here for frontrun attack.
      bytes memory punkIndexToAddress = abi.encodeWithSignature("punkIndexToAddress(uint256)", tokenId);
      (bool checkSuccess, bytes memory result) = address(assetAddr).staticcall(punkIndexToAddress);
      (address nftOwner) = abi.decode(result, (address));
      require(checkSuccess && nftOwner == msg.sender, "Not the NFT owner");
      data = abi.encodeWithSignature("buyPunk(uint256)", tokenId);
    } else {
      // We push to the vault to avoid an unneeded transfer.
      data = abi.encodeWithSignature("safeTransferFrom(address,address,uint256)", msg.sender, to, tokenId);
    }

    (bool success, bytes memory resultData) = address(assetAddr).call(data);
    require(success, string(resultData));
  }


  /**
   * @notice Reads a boolean at a set character index of a uint.
   * 
   * @dev 0 and 1 define false and true respectively.
   * 
   * @param _packedBools A numeric representation of a series of boolean values
   * @param _boolNumber The character index of the boolean we are looking up
   *
   * @return bool The representation of the boolean value
   */

  function _getBoolean(uint256 _packedBools, uint256 _boolNumber) internal pure returns(bool) {
    uint256 flag = (_packedBools >> _boolNumber) & uint256(1);
    return (flag == 1 ? true : false);
  }


  /**
   * @notice Allows our zap to be paused to prevent any processing.
   * 
   * @param _paused New pause state
   */

  function pause(bool _paused) external onlyOwner {
    paused = _paused;
  }

  receive() external payable {
    require(msg.sender == address(WETH), "Only WETH");
  }

}

File 2 of 23 : INFTXEligibility.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

interface INFTXEligibility {
    // Read functions.
    function name() external pure returns (string memory);

    function finalized() external view returns (bool);

    function targetAsset() external pure returns (address);

    function checkAllEligible(uint256[] calldata tokenIds)
        external
        view
        returns (bool);

    function checkEligible(uint256[] calldata tokenIds)
        external
        view
        returns (bool[] memory);

    function checkAllIneligible(uint256[] calldata tokenIds)
        external
        view
        returns (bool);

    function checkIsEligible(uint256 tokenId) external view returns (bool);

    // Write functions.
    function __NFTXEligibility_init_bytes(bytes calldata configData) external;

    function beforeMintHook(uint256[] calldata tokenIds) external;

    function afterMintHook(uint256[] calldata tokenIds) external;

    function beforeRedeemHook(uint256[] calldata tokenIds) external;

    function afterRedeemHook(uint256[] calldata tokenIds) external;
}

File 3 of 23 : INFTXInventoryStaking.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "./INFTXVaultFactory.sol";

interface INFTXInventoryStaking {
    function nftxVaultFactory() external view returns (INFTXVaultFactory);

    function vaultXToken(uint256 vaultId) external view returns (address);

    function xTokenAddr(address baseToken) external view returns (address);

    function xTokenShareValue(uint256 vaultId) external view returns (uint256);

    function __NFTXInventoryStaking_init(address nftxFactory) external;

    function deployXTokenForVault(uint256 vaultId) external;

    function receiveRewards(uint256 vaultId, uint256 amount)
        external
        returns (bool);

    function timelockMintFor(
        uint256 vaultId,
        uint256 amount,
        address to,
        uint256 timelockLength
    ) external returns (uint256);

    function deposit(uint256 vaultId, uint256 _amount) external;

    function withdraw(uint256 vaultId, uint256 _share) external;
}

File 4 of 23 : INFTXLPStaking.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

interface INFTXLPStaking {
    function nftxVaultFactory() external view returns (address);

    function rewardDistTokenImpl() external view returns (address);

    function stakingTokenProvider() external view returns (address);

    function vaultToken(address _stakingToken) external view returns (address);

    function stakingToken(address _vaultToken) external view returns (address);

    function rewardDistributionToken(uint256 vaultId)
        external
        view
        returns (address);

    function newRewardDistributionToken(uint256 vaultId)
        external
        view
        returns (address);

    function oldRewardDistributionToken(uint256 vaultId)
        external
        view
        returns (address);

    function unusedRewardDistributionToken(uint256 vaultId)
        external
        view
        returns (address);

    function rewardDistributionTokenAddr(
        address stakedToken,
        address rewardToken
    ) external view returns (address);

    // Write functions.
    function __NFTXLPStaking__init(address _stakingTokenProvider) external;

    function setNFTXVaultFactory(address newFactory) external;

    function setStakingTokenProvider(address newProvider) external;

    function addPoolForVault(uint256 vaultId) external;

    function updatePoolForVault(uint256 vaultId) external;

    function updatePoolForVaults(uint256[] calldata vaultId) external;

    function receiveRewards(uint256 vaultId, uint256 amount)
        external
        returns (bool);

    function deposit(uint256 vaultId, uint256 amount) external;

    function timelockDepositFor(
        uint256 vaultId,
        address account,
        uint256 amount,
        uint256 timelockLength
    ) external;

    function exit(uint256 vaultId, uint256 amount) external;

    function rescue(uint256 vaultId) external;

    function withdraw(uint256 vaultId, uint256 amount) external;

    function claimRewards(uint256 vaultId) external;
}

File 5 of 23 : INFTXVault.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../token/IERC20Upgradeable.sol";
import "./INFTXVaultFactory.sol";
import "./INFTXEligibility.sol";

interface INFTXVault is IERC20Upgradeable {
    function manager() external view returns (address);

    function assetAddress() external view returns (address);

    function vaultFactory() external view returns (INFTXVaultFactory);

    function eligibilityStorage() external view returns (INFTXEligibility);

    function is1155() external view returns (bool);

    function allowAllItems() external view returns (bool);

    function enableMint() external view returns (bool);

    function enableRandomRedeem() external view returns (bool);

    function enableTargetRedeem() external view returns (bool);

    function enableRandomSwap() external view returns (bool);

    function enableTargetSwap() external view returns (bool);

    function vaultId() external view returns (uint256);

    function nftIdAt(uint256 holdingsIndex) external view returns (uint256);

    function allHoldings() external view returns (uint256[] memory);

    function totalHoldings() external view returns (uint256);

    function mintFee() external view returns (uint256);

    function randomRedeemFee() external view returns (uint256);

    function targetRedeemFee() external view returns (uint256);

    function randomSwapFee() external view returns (uint256);

    function targetSwapFee() external view returns (uint256);

    function vaultFees()
        external
        view
        returns (
            uint256,
            uint256,
            uint256,
            uint256,
            uint256
        );

    event VaultInit(
        uint256 indexed vaultId,
        address assetAddress,
        bool is1155,
        bool allowAllItems
    );

    event ManagerSet(address manager);
    event EligibilityDeployed(uint256 moduleIndex, address eligibilityAddr);
    // event CustomEligibilityDeployed(address eligibilityAddr);

    event EnableMintUpdated(bool enabled);
    event EnableRandomRedeemUpdated(bool enabled);
    event EnableTargetRedeemUpdated(bool enabled);
    event EnableRandomSwapUpdated(bool enabled);
    event EnableTargetSwapUpdated(bool enabled);

    event Minted(uint256[] nftIds, uint256[] amounts, address to);
    event Redeemed(uint256[] nftIds, uint256[] specificIds, address to);
    event Swapped(
        uint256[] nftIds,
        uint256[] amounts,
        uint256[] specificIds,
        uint256[] redeemedIds,
        address to
    );

    function __NFTXVault_init(
        string calldata _name,
        string calldata _symbol,
        address _assetAddress,
        bool _is1155,
        bool _allowAllItems
    ) external;

    function finalizeVault() external;

    function setVaultMetadata(string memory name_, string memory symbol_)
        external;

    function setVaultFeatures(
        bool _enableMint,
        bool _enableRandomRedeem,
        bool _enableTargetRedeem,
        bool _enableRandomSwap,
        bool _enableTargetSwap
    ) external;

    function setFees(
        uint256 _mintFee,
        uint256 _randomRedeemFee,
        uint256 _targetRedeemFee,
        uint256 _randomSwapFee,
        uint256 _targetSwapFee
    ) external;

    function disableVaultFees() external;

    // This function allows for an easy setup of any eligibility module contract from the EligibilityManager.
    // It takes in ABI encoded parameters for the desired module. This is to make sure they can all follow
    // a similar interface.
    function deployEligibilityStorage(
        uint256 moduleIndex,
        bytes calldata initData
    ) external returns (address);

    // The manager has control over options like fees and features
    function setManager(address _manager) external;

    function mint(
        uint256[] calldata tokenIds,
        uint256[] calldata amounts /* ignored for ERC721 vaults */
    ) external returns (uint256);

    function mintTo(
        uint256[] calldata tokenIds,
        uint256[] calldata amounts, /* ignored for ERC721 vaults */
        address to
    ) external returns (uint256);

    function redeem(uint256 amount, uint256[] calldata specificIds)
        external
        returns (uint256[] calldata);

    function redeemTo(
        uint256 amount,
        uint256[] calldata specificIds,
        address to
    ) external returns (uint256[] calldata);

    function swap(
        uint256[] calldata tokenIds,
        uint256[] calldata amounts, /* ignored for ERC721 vaults */
        uint256[] calldata specificIds
    ) external returns (uint256[] calldata);

    function swapTo(
        uint256[] calldata tokenIds,
        uint256[] calldata amounts, /* ignored for ERC721 vaults */
        uint256[] calldata specificIds,
        address to
    ) external returns (uint256[] calldata);

    function allValidNFTs(uint256[] calldata tokenIds)
        external
        view
        returns (bool);
}

File 6 of 23 : INFTXVaultFactory.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../proxy/IBeacon.sol";

interface INFTXVaultFactory is IBeacon {
    // Read functions.
    function numVaults() external view returns (uint256);

    function zapContract() external view returns (address);

    function zapContracts(address addr) external view returns (bool);

    function feeDistributor() external view returns (address);

    function eligibilityManager() external view returns (address);

    function vault(uint256 vaultId) external view returns (address);

    function allVaults() external view returns (address[] memory);

    function vaultsForAsset(address asset)
        external
        view
        returns (address[] memory);

    function isLocked(uint256 id) external view returns (bool);

    function excludedFromFees(address addr) external view returns (bool);

    function factoryMintFee() external view returns (uint64);

    function factoryRandomRedeemFee() external view returns (uint64);

    function factoryTargetRedeemFee() external view returns (uint64);

    function factoryRandomSwapFee() external view returns (uint64);

    function factoryTargetSwapFee() external view returns (uint64);

    function vaultFees(uint256 vaultId)
        external
        view
        returns (
            uint256,
            uint256,
            uint256,
            uint256,
            uint256
        );

    event NewFeeDistributor(address oldDistributor, address newDistributor);
    event NewZapContract(address oldZap, address newZap);
    event UpdatedZapContract(address zap, bool excluded);
    event FeeExclusion(address feeExcluded, bool excluded);
    event NewEligibilityManager(address oldEligManager, address newEligManager);
    event NewVault(
        uint256 indexed vaultId,
        address vaultAddress,
        address assetAddress
    );
    event UpdateVaultFees(
        uint256 vaultId,
        uint256 mintFee,
        uint256 randomRedeemFee,
        uint256 targetRedeemFee,
        uint256 randomSwapFee,
        uint256 targetSwapFee
    );
    event DisableVaultFees(uint256 vaultId);
    event UpdateFactoryFees(
        uint256 mintFee,
        uint256 randomRedeemFee,
        uint256 targetRedeemFee,
        uint256 randomSwapFee,
        uint256 targetSwapFee
    );

    // Write functions.
    function __NFTXVaultFactory_init(
        address _vaultImpl,
        address _feeDistributor
    ) external;

    function createVault(
        string calldata name,
        string calldata symbol,
        address _assetAddress,
        bool is1155,
        bool allowAllItems
    ) external returns (uint256);

    function setFeeDistributor(address _feeDistributor) external;

    function setEligibilityManager(address _eligibilityManager) external;

    function setZapContract(address _zapContract, bool _excluded) external;

    function setFeeExclusion(address _excludedAddr, bool excluded) external;

    function setFactoryFees(
        uint256 mintFee,
        uint256 randomRedeemFee,
        uint256 targetRedeemFee,
        uint256 randomSwapFee,
        uint256 targetSwapFee
    ) external;

    function setVaultFees(
        uint256 vaultId,
        uint256 mintFee,
        uint256 randomRedeemFee,
        uint256 targetRedeemFee,
        uint256 randomSwapFee,
        uint256 targetSwapFee
    ) external;

    function disableVaultFees(uint256 vaultId) external;
}

File 7 of 23 : IUniswapV2Router01.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

interface IUniswapV2Router01 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETH(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountToken, uint256 amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountA, uint256 amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountToken, uint256 amountETH);

    function swapExactTokensForTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapTokensForExactTokens(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactETHForTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function swapTokensForExactETH(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapExactTokensForETH(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);

    function swapETHForExactTokens(
        uint256 amountOut,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);

    function quote(
        uint256 amountA,
        uint256 reserveA,
        uint256 reserveB
    ) external pure returns (uint256 amountB);

    function getAmountOut(
        uint256 amountIn,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountOut);

    function getAmountIn(
        uint256 amountOut,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountIn);

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);

    function getAmountsIn(uint256 amountOut, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

File 8 of 23 : IBeacon.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

/**
 * @dev This is the interface that {BeaconProxy} expects of its beacon.
 */
interface IBeacon {
    /**
     * @dev Must return an address that can be used as a delegate call target.
     *
     * {BeaconProxy} will check that this address is a contract.
     */
    function childImplementation() external view returns (address);

    function upgradeChildTo(address newImplementation) external;
}

File 9 of 23 : Context.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

File 10 of 23 : ERC1155Holder.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC1155/utils/ERC1155Holder.sol)

pragma solidity ^0.8.0;

import "./ERC1155Receiver.sol";

/**
 * Simple implementation of `ERC1155Receiver` that will allow a contract to hold ERC1155 tokens.
 *
 * IMPORTANT: When inheriting this contract, you must include a way to use the received tokens, otherwise they will be
 * stuck.
 *
 * @dev _Available since v3.1._
 */
contract ERC1155Holder is ERC1155Receiver {
    function onERC1155Received(
        address,
        address,
        uint256,
        uint256,
        bytes memory
    ) public virtual override returns (bytes4) {
        return this.onERC1155Received.selector;
    }

    function onERC1155BatchReceived(
        address,
        address,
        uint256[] memory,
        uint256[] memory,
        bytes memory
    ) public virtual override returns (bytes4) {
        return this.onERC1155BatchReceived.selector;
    }
}

File 11 of 23 : ERC1155Receiver.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "./IERC1155Receiver.sol";
import "./ERC165.sol";

/**
 * @dev _Available since v3.1._
 */
abstract contract ERC1155Receiver is ERC165, IERC1155Receiver {
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool) {
        return interfaceId == type(IERC1155Receiver).interfaceId
            || super.supportsInterface(interfaceId);
    }
}

File 12 of 23 : ERC165.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "./IERC165.sol";

/**
 * @dev Implementation of the {IERC165} interface.
 *
 * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check
 * for the additional interface id that will be supported. For example:
 *
 * ```solidity
 * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
 *     return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);
 * }
 * ```
 *
 * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.
 */
abstract contract ERC165 is IERC165 {
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IERC165).interfaceId;
    }
}

File 13 of 23 : IERC1155.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "./IERC165.sol";

/**
 * @dev Required interface of an ERC1155 compliant contract, as defined in the
 * https://eips.ethereum.org/EIPS/eip-1155[EIP].
 *
 * _Available since v3.1._
 */
interface IERC1155 is IERC165 {
    /**
     * @dev Emitted when `value` tokens of token type `id` are transferred from `from` to `to` by `operator`.
     */
    event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value);

    /**
     * @dev Equivalent to multiple {TransferSingle} events, where `operator`, `from` and `to` are the same for all
     * transfers.
     */
    event TransferBatch(address indexed operator, address indexed from, address indexed to, uint256[] ids, uint256[] values);

    /**
     * @dev Emitted when `account` grants or revokes permission to `operator` to transfer their tokens, according to
     * `approved`.
     */
    event ApprovalForAll(address indexed account, address indexed operator, bool approved);

    /**
     * @dev Emitted when the URI for token type `id` changes to `value`, if it is a non-programmatic URI.
     *
     * If an {URI} event was emitted for `id`, the standard
     * https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that `value` will equal the value
     * returned by {IERC1155MetadataURI-uri}.
     */
    event URI(string value, uint256 indexed id);

    /**
     * @dev Returns the amount of tokens of token type `id` owned by `account`.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function balanceOf(address account, uint256 id) external view returns (uint256);

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {balanceOf}.
     *
     * Requirements:
     *
     * - `accounts` and `ids` must have the same length.
     */
    function balanceOfBatch(address[] calldata accounts, uint256[] calldata ids) external view returns (uint256[] memory);

    /**
     * @dev Grants or revokes permission to `operator` to transfer the caller's tokens, according to `approved`,
     *
     * Emits an {ApprovalForAll} event.
     *
     * Requirements:
     *
     * - `operator` cannot be the caller.
     */
    function setApprovalForAll(address operator, bool approved) external;

    /**
     * @dev Returns true if `operator` is approved to transfer ``account``'s tokens.
     *
     * See {setApprovalForAll}.
     */
    function isApprovedForAll(address account, address operator) external view returns (bool);

    /**
     * @dev Transfers `amount` tokens of token type `id` from `from` to `to`.
     *
     * Emits a {TransferSingle} event.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - If the caller is not `from`, it must be have been approved to spend ``from``'s tokens via {setApprovalForAll}.
     * - `from` must have a balance of tokens of type `id` of at least `amount`.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the
     * acceptance magic value.
     */
    function safeTransferFrom(address from, address to, uint256 id, uint256 amount, bytes calldata data) external;

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {safeTransferFrom}.
     *
     * Emits a {TransferBatch} event.
     *
     * Requirements:
     *
     * - `ids` and `amounts` must have the same length.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the
     * acceptance magic value.
     */
    function safeBatchTransferFrom(address from, address to, uint256[] calldata ids, uint256[] calldata amounts, bytes calldata data) external;
}

File 14 of 23 : IERC1155Receiver.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "./IERC165.sol";

/**
 * _Available since v3.1._
 */
interface IERC1155Receiver is IERC165 {
    /**
        @dev Handles the receipt of a single ERC1155 token type. This function is
        called at the end of a `safeTransferFrom` after the balance has been updated.
        To accept the transfer, this must return
        `bytes4(keccak256("onERC1155Received(address,address,uint256,uint256,bytes)"))`
        (i.e. 0xf23a6e61, or its own function selector).
        @param operator The address which initiated the transfer (i.e. msg.sender)
        @param from The address which previously owned the token
        @param id The ID of the token being transferred
        @param value The amount of tokens being transferred
        @param data Additional data with no specified format
        @return `bytes4(keccak256("onERC1155Received(address,address,uint256,uint256,bytes)"))` if transfer is allowed
    */
    function onERC1155Received(
        address operator,
        address from,
        uint256 id,
        uint256 value,
        bytes calldata data
    ) external returns (bytes4);

    /**
        @dev Handles the receipt of a multiple ERC1155 token types. This function
        is called at the end of a `safeBatchTransferFrom` after the balances have
        been updated. To accept the transfer(s), this must return
        `bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)"))`
        (i.e. 0xbc197c81, or its own function selector).
        @param operator The address which initiated the batch transfer (i.e. msg.sender)
        @param from The address which previously owned the token
        @param ids An array containing ids of each token being transferred (order and length must match values array)
        @param values An array containing amounts of each token being transferred (order and length must match ids array)
        @param data Additional data with no specified format
        @return `bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)"))` if transfer is allowed
    */
    function onERC1155BatchReceived(
        address operator,
        address from,
        uint256[] calldata ids,
        uint256[] calldata values,
        bytes calldata data
    ) external returns (bytes4);
}

File 15 of 23 : IERC165.sol
// SPDX-License-Identifier: MIT

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

File 16 of 23 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.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.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `from` to `to` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) external returns (bool);
}

File 17 of 23 : IERC20Permit.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (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.
     * - `deadline` must be a timestamp in the future.
     * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner`
     * over the EIP712-formatted function arguments.
     * - the signature must use ``owner``'s current nonce (see {nonces}).
     *
     * For more information on the signature format, see the
     * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP
     * section].
     */
    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    /**
     * @dev Returns the current nonce for `owner`. This value must be
     * included whenever a signature is generated for {permit}.
     *
     * Every successful call to {permit} increases ``owner``'s nonce by one. This
     * prevents a signature from being used multiple times.
     */
    function nonces(address owner) external view returns (uint256);

    /**
     * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}.
     */
    // solhint-disable-next-line func-name-mixedcase
    function DOMAIN_SEPARATOR() external view returns (bytes32);
}

File 18 of 23 : IERC20Upgradeable.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20Upgradeable {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

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

File 19 of 23 : Address.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(
            address(this).balance >= amount,
            "Address: insufficient balance"
        );

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{value: amount}("");
        require(
            success,
            "Address: unable to send value, recipient may have reverted"
        );
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data)
        internal
        returns (bytes memory)
    {
        return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return
            functionCallWithValue(
                target,
                data,
                value,
                "Address: low-level call with value failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(
            address(this).balance >= value,
            "Address: insufficient balance for call"
        );
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data)
        internal
        view
        returns (bytes memory)
    {
        return
            functionStaticCall(
                target,
                data,
                "Address: low-level static call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data)
        internal
        returns (bytes memory)
    {
        return
            functionDelegateCall(
                target,
                data,
                "Address: low-level delegate call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) private pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

File 20 of 23 : Ownable.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../testing/Context.sol";

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

File 21 of 23 : ReentrancyGuard.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
}

File 22 of 23 : SafeERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.8.0) (token/ERC20/utils/SafeERC20.sol)

pragma solidity ^0.8.0;

import "../testing/IERC20.sol";
import "../testing/IERC20Permit.sol";
import "./Address.sol";

/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using Address for address;

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transfer.selector, to, value)
        );
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
        );
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.approve.selector, spender, value)
        );
    }

    function safeIncreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        uint256 newAllowance = token.allowance(address(this), spender) + value;
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(
                token.approve.selector,
                spender,
                newAllowance
            )
        );
    }

    function safeDecreaseAllowance(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        unchecked {
            uint256 oldAllowance = token.allowance(address(this), spender);
            require(
                oldAllowance >= value,
                "SafeERC20: decreased allowance below zero"
            );
            uint256 newAllowance = oldAllowance - value;
            _callOptionalReturn(
                token,
                abi.encodeWithSelector(
                    token.approve.selector,
                    spender,
                    newAllowance
                )
            );
        }
    }

    function safePermit(
        IERC20Permit token,
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal {
        uint256 nonceBefore = token.nonces(owner);
        token.permit(owner, spender, value, deadline, v, r, s);
        uint256 nonceAfter = token.nonces(owner);
        require(
            nonceAfter == nonceBefore + 1,
            "SafeERC20: permit did not succeed"
        );
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address-functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(
            data,
            "SafeERC20: low-level call failed"
        );
        if (returndata.length > 0) {
            // Return data is optional
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }
}

File 23 of 23 : SushiHelper.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;


contract SushiHelper {

  /**
   * @notice Calculates the CREATE2 address for a sushi pair without making any
   * external calls.
   * 
   * @return pair Address of our token pair
   */

  function pairFor(address sushiRouterFactory, address tokenA, address tokenB) external view returns (address pair) {
    (address token0, address token1) = sortTokens(tokenA, tokenB);
    pair = address(uint160(uint256(keccak256(abi.encodePacked(
      hex'ff',
      sushiRouterFactory,
      keccak256(abi.encodePacked(token0, token1)),
      hex'e18a34eb0e04b04f7a0ac29a6e80748dca96319b42c54d679cb821dca90c6303' // init code hash
    )))));
  }


  /**
   * @notice 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, 'UniswapV2Library: IDENTICAL_ADDRESSES');
      (token0, token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
      require(token0 != address(0), 'UniswapV2Library: ZERO_ADDRESS');
  }

}

Settings
{
  "evmVersion": "istanbul",
  "libraries": {},
  "metadata": {
    "bytecodeHash": "ipfs",
    "useLiteralContent": true
  },
  "optimizer": {
    "enabled": true,
    "runs": 1000
  },
  "remappings": [],
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_vaultFactory","type":"address"},{"internalType":"address","name":"_inventoryStaking","type":"address"},{"internalType":"address","name":"_lpStaking","type":"address"},{"internalType":"address","name":"_sushiRouter","type":"address"},{"internalType":"address","name":"_sushiHelper","type":"address"},{"internalType":"address","name":"_weth","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[],"name":"WETH","outputs":[{"internalType":"contract IWETH","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"components":[{"internalType":"address","name":"assetAddress","type":"address"},{"internalType":"bool","name":"is1155","type":"bool"},{"internalType":"bool","name":"allowAllItems","type":"bool"},{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"symbol","type":"string"}],"internalType":"struct NFTXVaultCreationZap.vaultInfo","name":"vaultData","type":"tuple"},{"internalType":"uint256","name":"vaultFeatures","type":"uint256"},{"components":[{"internalType":"uint32","name":"mintFee","type":"uint32"},{"internalType":"uint32","name":"randomRedeemFee","type":"uint32"},{"internalType":"uint32","name":"targetRedeemFee","type":"uint32"},{"internalType":"uint32","name":"randomSwapFee","type":"uint32"},{"internalType":"uint32","name":"targetSwapFee","type":"uint32"}],"internalType":"struct NFTXVaultCreationZap.vaultFeesConfig","name":"vaultFees","type":"tuple"},{"components":[{"internalType":"int256","name":"moduleIndex","type":"int256"},{"internalType":"bytes","name":"initData","type":"bytes"}],"internalType":"struct NFTXVaultCreationZap.vaultEligibilityStorage","name":"eligibilityStorage","type":"tuple"},{"components":[{"internalType":"uint256[]","name":"assetTokenIds","type":"uint256[]"},{"internalType":"uint256[]","name":"assetTokenAmounts","type":"uint256[]"},{"internalType":"uint256","name":"minTokenIn","type":"uint256"},{"internalType":"uint256","name":"minWethIn","type":"uint256"},{"internalType":"uint256","name":"wethIn","type":"uint256"}],"internalType":"struct NFTXVaultCreationZap.vaultTokens","name":"assetTokens","type":"tuple"}],"name":"createVault","outputs":[{"internalType":"uint256","name":"vaultId_","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"inventoryStaking","outputs":[{"internalType":"contract INFTXInventoryStaking","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lpStaking","outputs":[{"internalType":"contract INFTXLPStaking","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"},{"internalType":"uint256[]","name":"","type":"uint256[]"},{"internalType":"uint256[]","name":"","type":"uint256[]"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC1155BatchReceived","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"name":"onERC1155Received","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"_paused","type":"bool"}],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sushiRouter","outputs":[{"internalType":"contract IUniswapV2Router01","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"vaultFactory","outputs":[{"internalType":"contract INFTXVaultFactory","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

6101406040526002805460ff191690553480156200001c57600080fd5b5060405162002bcb38038062002bcb8339810160408190526200003f9162000171565b600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600180556001600160601b0319606086811b82166101005285811b82166101205287811b821660805284811b821660a05283811b821660c05282901b1660e05260405163095ea7b360e01b81526001600160a01b038085166004830152600019602483015282169063095ea7b390604401602060405180830381600087803b1580156200010c57600080fd5b505af115801562000121573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001479190620001f1565b505050505050506200021a565b80516001600160a01b03811681146200016c57600080fd5b919050565b60008060008060008060c087890312156200018a578182fd5b620001958762000154565b9550620001a56020880162000154565b9450620001b56040880162000154565b9350620001c56060880162000154565b9250620001d56080880162000154565b9150620001e560a0880162000154565b90509295509295509295565b60006020828403121562000203578081fd5b8151801515811462000213578182fd5b9392505050565b60805160601c60a05160601c60c05160601c60e05160601c6101005160601c6101205160601c6128d2620002f96000396000818161029e0152818161136d01526113d701526000818161024c0152818161093c01528181611501015261163f01526000818160f1015281816102d20152818161079601528181610f0c015281816110e0015281816112e20152818161192c01526119e7015260006111f60152600081816101eb0152818161107e0152818161113b015281816111cc01526112250152600081816103640152818161082401526109d101526128d26000f3fe6080604052600436106100e15760003560e01c80639bf1401c1161007f578063d8a06f7311610059578063d8a06f7314610352578063f23a6e6114610386578063f2fde38b146103cb578063f3e301cf146103eb57600080fd5b80639bf1401c1461028c578063ad5c4648146102c0578063bc197c81146102f457600080fd5b80636d13582c116100bb5780636d13582c146101d9578063715018a61461022557806374a1b0b01461023a5780638da5cb5b1461026e57600080fd5b806301ffc9a71461016a57806302329a291461019f5780635c975abb146101bf57600080fd5b3661016557336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146101635760405162461bcd60e51b815260206004820152600960248201527f4f6e6c792057455448000000000000000000000000000000000000000000000060448201526064015b60405180910390fd5b005b600080fd5b34801561017657600080fd5b5061018a610185366004612419565b61040c565b60405190151581526020015b60405180910390f35b3480156101ab57600080fd5b506101636101ba3660046123e1565b610475565b3480156101cb57600080fd5b5060025461018a9060ff1681565b3480156101e557600080fd5b5061020d7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610196565b34801561023157600080fd5b506101636104e2565b34801561024657600080fd5b5061020d7f000000000000000000000000000000000000000000000000000000000000000081565b34801561027a57600080fd5b506000546001600160a01b031661020d565b34801561029857600080fd5b5061020d7f000000000000000000000000000000000000000000000000000000000000000081565b3480156102cc57600080fd5b5061020d7f000000000000000000000000000000000000000000000000000000000000000081565b34801561030057600080fd5b5061033961030f3660046122d0565b7fbc197c810000000000000000000000000000000000000000000000000000000095945050505050565b6040516001600160e01b03199091168152602001610196565b34801561035e57600080fd5b5061020d7f000000000000000000000000000000000000000000000000000000000000000081565b34801561039257600080fd5b506103396103a136600461237a565b7ff23a6e610000000000000000000000000000000000000000000000000000000095945050505050565b3480156103d757600080fd5b506101636103e6366004612298565b610593565b6103fe6103f9366004612441565b6106d1565b604051908152602001610196565b60006001600160e01b031982167f4e2312e000000000000000000000000000000000000000000000000000000000148061046f57507f01ffc9a7000000000000000000000000000000000000000000000000000000006001600160e01b03198316145b92915050565b6000546001600160a01b031633146104cf5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b6002805460ff1916911515919091179055565b6000546001600160a01b0316331461053c5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36000805473ffffffffffffffffffffffffffffffffffffffff19169055565b6000546001600160a01b031633146105ed5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b6001600160a01b0381166106695760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f6464726573730000000000000000000000000000000000000000000000000000606482015260840161015a565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a36000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000600260015414156107265760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015260640161015a565b600260018190555460ff161561077e5760405162461bcd60e51b815260206004820152600d60248201527f5a61702069732070617573656400000000000000000000000000000000000000604482015260640161015a565b6040516370a0823160e01b81523060048201526000907f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316906370a082319060240160206040518083038186803b1580156107e057600080fd5b505afa1580156107f4573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061081891906124dd565b90506001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001663ef8658db61085660608a018a61276e565b61086360808c018c61276e565b61087060208e018e612298565b8d602001602081019061088391906123e1565b8e604001602081019061089691906123e1565b6040518863ffffffff1660e01b81526004016108b89796959493929190612677565b602060405180830381600087803b1580156108d257600080fd5b505af11580156108e6573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061090a91906124dd565b6040517ff0f2a4d7000000000000000000000000000000000000000000000000000000008152600481018290529092507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063f0f2a4d790602401600060405180830381600087803b15801561098857600080fd5b505af115801561099c573d6000803e3d6000fd5b50506040517f81a36fb600000000000000000000000000000000000000000000000000000000815260048101859052600092507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031691506381a36fb69060240160206040518083038186803b158015610a1c57600080fd5b505afa158015610a30573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a5491906122b4565b90506000853512610aef576001600160a01b038116635877aee68635610a7d602089018961276e565b6040518463ffffffff1660e01b8152600401610a9b939291906126fc565b602060405180830381600087803b158015610ab557600080fd5b505af1158015610ac9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aed91906122b4565b505b6000610afb858061271f565b91505080156116c857610b1460408a0160208b016123e1565b610cd85760005b81811015610cd257610b68610b3360208c018c612298565b610b3d888061271f565b84818110610b5b57634e487b7160e01b600052603260045260246000fd5b9050602002013585611acc565b73b47e3cd837ddf8e4c57f05d70ab865de6e193bbb610b8a60208c018c612298565b6001600160a01b03161415610cca576000610ba5878061271f565b83818110610bc357634e487b7160e01b600052603260045260246000fd5b60405160209091029290920135602483015250600060448201526001600160a01b038516606482015260840160408051601f19818403018152919052602080820180516001600160e01b03167fbf31196f000000000000000000000000000000000000000000000000000000001790529091506000908190610c47908e018e612298565b6001600160a01b031683604051610c5e91906125bc565b6000604051808303816000865af19150503d8060008114610c9b576040519150601f19603f3d011682016040523d82523d6000602084013e610ca0565b606091505b5091509150818190610cc55760405162461bcd60e51b815260040161015a91906126c9565b505050505b600101610b1b565b50610deb565b610ce560208a018a612298565b6001600160a01b0316632eb2c2d63330610cff898061271f565b610d0c60208c018c61271f565b6040518763ffffffff1660e01b8152600401610d2d969594939291906125d8565b600060405180830381600087803b158015610d4757600080fd5b505af1158015610d5b573d6000803e3d6000fd5b50610d6d9250505060208a018a612298565b6040517fa22cb4650000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015260016024830152919091169063a22cb46590604401600060405180830381600087803b158015610dd257600080fd5b505af1158015610de6573d6000803e3d6000fd5b505050505b6001600160a01b03821663b10402ea610e04878061271f565b610e1160208a018a61271f565b306040518663ffffffff1660e01b8152600401610e32959493929190612634565b602060405180830381600087803b158015610e4c57600080fd5b505af1158015610e60573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e8491906124dd565b508160408601351561143e578560800135341015610f0a5760405162461bcd60e51b815260206004820152602960248201527f496e73756666696369656e74206d73672e76616c75652073656e7420666f722060448201527f6c69717569646974790000000000000000000000000000000000000000000000606482015260840161015a565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663d0e30db0346040518263ffffffff1660e01b81526004016000604051808303818588803b158015610f6557600080fd5b505af1158015610f79573d6000803e3d6000fd5b5050604080516370a0823160e01b8152306004820152908a013593506001600160a01b03851692506370a08231915060240160206040518083038186803b158015610fc357600080fd5b505afa158015610fd7573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ffb91906124dd565b101561106f5760405162461bcd60e51b815260206004820152602a60248201527f496e73756666696369656e7420746f6b656e7320616371756972656420666f7260448201527f206c697175696469747900000000000000000000000000000000000000000000606482015260840161015a565b6110a76001600160a01b0382167f00000000000000000000000000000000000000000000000000000000000000006040890135611d77565b604080517fe8e337000000000000000000000000000000000000000000000000000000000081526001600160a01b0383811660048301527f0000000000000000000000000000000000000000000000000000000000000000811660248301529188013560448201819052608089013560648301526084820152606088013560a48201523060c48201524260e48201526000917f0000000000000000000000000000000000000000000000000000000000000000169063e8e337009061010401606060405180830381600087803b15801561118057600080fd5b505af1158015611194573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b891906124f5565b92506111f29150506001600160a01b0383167f00000000000000000000000000000000000000000000000000000000000000006000611d77565b60007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316636d91c0e27f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b15801561127c57600080fd5b505afa158015611290573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112b491906122b4565b60405160e083901b6001600160e01b03191681526001600160a01b03918216600482015286821660248201527f0000000000000000000000000000000000000000000000000000000000000000909116604482015260640160206040518083038186803b15801561132457600080fd5b505afa158015611338573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061135c91906122b4565b90506113926001600160a01b0382167f000000000000000000000000000000000000000000000000000000000000000084611d77565b6040517f6c9b958800000000000000000000000000000000000000000000000000000000815260048101889052336024820152604481018390526202a30060648201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690636c9b958890608401600060405180830381600087803b15801561142357600080fd5b505af1158015611437573d6000803e3d6000fd5b5050505050505b6040516370a0823160e01b81523060048201526000906001600160a01b038316906370a082319060240160206040518083038186803b15801561148057600080fd5b505afa158015611494573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114b891906124dd565b905080156116c5576040517f034fc83c000000000000000000000000000000000000000000000000000000008152600481018790526001600160a01b038084169163a9059cbb917f0000000000000000000000000000000000000000000000000000000000000000169063034fc83c9060240160206040518083038186803b15801561154357600080fd5b505afa158015611557573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061157b91906122b4565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b1580156115c357600080fd5b505af11580156115d7573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115fb91906123fd565b506040517f2699f55a0000000000000000000000000000000000000000000000000000000081526004810187905260248101829052336044820152600260648201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690632699f55a90608401602060405180830381600087803b15801561168b57600080fd5b505af115801561169f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116c391906124dd565b505b50505b601f88101561178757816001600160a01b0316630d636a096116eb8a6004611efb565b6116f68b6003611efb565b6117018c6002611efb565b61170c8d6001611efb565b6117178e6000611efb565b6040516001600160e01b031960e088901b168152941515600486015292151560248501529015156044840152151560648301521515608482015260a401600060405180830381600087803b15801561176e57600080fd5b505af1158015611782573d6000803e3d6000fd5b505050505b6001600160a01b0382166304a66b486117a360208a018a612522565b6117b89063ffffffff166402540be4006127e4565b6117c860408b0160208c01612522565b6117dd9063ffffffff166402540be4006127e4565b6117ed60608c0160408d01612522565b6118029063ffffffff166402540be4006127e4565b61181260808d0160608e01612522565b6118279063ffffffff166402540be4006127e4565b61183760a08e0160808f01612522565b61184c9063ffffffff166402540be4006127e4565b6040516001600160e01b031960e088901b1681526004810195909552602485019390935260448401919091526064830152608482015260a401600060405180830381600087803b15801561189f57600080fd5b505af11580156118b3573d6000803e3d6000fd5b50505050816001600160a01b031663c3cb8c146040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156118f257600080fd5b505af1158015611906573d6000803e3d6000fd5b50506040516370a0823160e01b8152306004820152600092508591506001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016906370a082319060240160206040518083038186803b15801561196e57600080fd5b505afa158015611982573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119a691906124dd565b6119b09190612803565b90508015611aba576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690632e1a7d4d90602401600060405180830381600087803b158015611a3357600080fd5b505af1158015611a47573d6000803e3d6000fd5b50506040516000925033915083156108fc0290849084818181858888f19350505050905080611ab85760405162461bcd60e51b815260206004820152601460248201527f4661696c656420746f2073656e64204574686572000000000000000000000000604482015260640161015a565b505b50506001805550909695505050505050565b60606001600160a01b03841673b47e3cd837ddf8e4c57f05d70ab865de6e193bbb1415611c8457600083604051602401611b0891815260200190565b60408051601f198184030181529181526020820180516001600160e01b03167f58178168000000000000000000000000000000000000000000000000000000001790525190915060009081906001600160a01b03881690611b6a9085906125bc565b600060405180830381855afa9150503d8060008114611ba5576040519150601f19603f3d011682016040523d82523d6000602084013e611baa565b606091505b5091509150600081806020019051810190611bc591906122b4565b9050828015611bdc57506001600160a01b03811633145b611c285760405162461bcd60e51b815260206004820152601160248201527f4e6f7420746865204e4654206f776e6572000000000000000000000000000000604482015260640161015a565b6040516024810188905260440160408051601f198184030181529190526020810180516001600160e01b03167f8264fe98000000000000000000000000000000000000000000000000000000001790529450611cec9350505050565b6040513360248201526001600160a01b03831660448201526064810184905260840160408051601f198184030181529190526020810180516001600160e01b03167f42842e0e0000000000000000000000000000000000000000000000000000000017905290505b600080856001600160a01b031683604051611d0791906125bc565b6000604051808303816000865af19150503d8060008114611d44576040519150601f19603f3d011682016040523d82523d6000602084013e611d49565b606091505b5091509150818190611d6e5760405162461bcd60e51b815260040161015a91906126c9565b50505050505050565b801580611e1957506040517fdd62ed3e0000000000000000000000000000000000000000000000000000000081523060048201526001600160a01b03838116602483015284169063dd62ed3e9060440160206040518083038186803b158015611ddf57600080fd5b505afa158015611df3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e1791906124dd565b155b611e8b5760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e636500000000000000000000606482015260840161015a565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b03167f095ea7b300000000000000000000000000000000000000000000000000000000179052611ef6908490611f1d565b505050565b6000600183831c8116908114611f12576000611f15565b60015b949350505050565b6000611f72826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166120029092919063ffffffff16565b805190915015611ef65780806020019051810190611f9091906123fd565b611ef65760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f74207375636365656400000000000000000000000000000000000000000000606482015260840161015a565b6060612011848460008561201b565b90505b9392505050565b6060824710156120935760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c0000000000000000000000000000000000000000000000000000606482015260840161015a565b843b6120e15760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640161015a565b600080866001600160a01b031685876040516120fd91906125bc565b60006040518083038185875af1925050503d806000811461213a576040519150601f19603f3d011682016040523d82523d6000602084013e61213f565b606091505b509150915061214f82828661215a565b979650505050505050565b60608315612169575081612014565b8251156121795782518084602001fd5b8160405162461bcd60e51b815260040161015a91906126c9565b600082601f8301126121a3578081fd5b8135602067ffffffffffffffff8211156121bf576121bf612860565b8160051b6121ce8282016127b3565b8381528281019086840183880185018910156121e8578687fd5b8693505b8584101561220a5780358352600193909301929184019184016121ec565b50979650505050505050565b600082601f830112612226578081fd5b813567ffffffffffffffff81111561224057612240612860565b612253601f8201601f19166020016127b3565b818152846020838601011115612267578283fd5b816020850160208301379081016020019190915292915050565b600060a08284031215612292578081fd5b50919050565b6000602082840312156122a9578081fd5b813561201481612876565b6000602082840312156122c5578081fd5b815161201481612876565b600080600080600060a086880312156122e7578081fd5b85356122f281612876565b9450602086013561230281612876565b9350604086013567ffffffffffffffff8082111561231e578283fd5b61232a89838a01612193565b9450606088013591508082111561233f578283fd5b61234b89838a01612193565b93506080880135915080821115612360578283fd5b5061236d88828901612216565b9150509295509295909350565b600080600080600060a08688031215612391578081fd5b853561239c81612876565b945060208601356123ac81612876565b93506040860135925060608601359150608086013567ffffffffffffffff8111156123d5578182fd5b61236d88828901612216565b6000602082840312156123f2578081fd5b81356120148161288e565b60006020828403121561240e578081fd5b81516120148161288e565b60006020828403121561242a578081fd5b81356001600160e01b031981168114612014578182fd5b60008060008060006101208688031215612459578081fd5b853567ffffffffffffffff80821115612470578283fd5b61247c89838a01612281565b9650602088013595506124928960408a01612281565b945060e08801359150808211156124a7578283fd5b908701906040828a0312156124ba578283fd5b90925061010087013590808211156124d0578283fd5b5061236d88828901612281565b6000602082840312156124ee578081fd5b5051919050565b600080600060608486031215612509578081fd5b8351925060208401519150604084015190509250925092565b600060208284031215612533578081fd5b813563ffffffff81168114612014578182fd5b81835260007f07ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff831115612577578081fd5b8260051b80836020870137939093016020019283525090919050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b600082516125ce81846020870161281a565b9190910192915050565b60006001600160a01b03808916835280881660208401525060a0604083015261260560a083018688612546565b8281036060840152612618818587612546565b8381036080909401939093525081526020019695505050505050565b606081526000612648606083018789612546565b828103602084015261265b818688612546565b9150506001600160a01b03831660408301529695505050505050565b60a08152600061268b60a08301898b612593565b828103602084015261269e81888a612593565b6001600160a01b03969096166040840152505091151560608301521515608090910152949350505050565b60208152600082518060208401526126e881604085016020870161281a565b601f01601f19169190910160400192915050565b838152604060208201526000612716604083018486612593565b95945050505050565b6000808335601e19843603018112612735578283fd5b83018035915067ffffffffffffffff82111561274f578283fd5b6020019150600581901b360382131561276757600080fd5b9250929050565b6000808335601e19843603018112612784578283fd5b83018035915067ffffffffffffffff82111561279e578283fd5b60200191503681900382131561276757600080fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156127dc576127dc612860565b604052919050565b60008160001904831182151516156127fe576127fe61284a565b500290565b6000828210156128155761281561284a565b500390565b60005b8381101561283557818101518382015260200161281d565b83811115612844576000848401525b50505050565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461288b57600080fd5b50565b801515811461288b57600080fdfea26469706673582212201852bd4c492d50249681174cf82594d12007f6779f2a2857c342f9dd007b67bb64736f6c63430008040033000000000000000000000000be86f647b167567525ccaafcd6f881f1ee5582160000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab893000000000000000000000000688c3e4658b5367da06fd629e41879beab538e37000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f00000000000000000000000012db7df759871061bc62d9fe023dce7c98717b82000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2

Deployed Bytecode

0x6080604052600436106100e15760003560e01c80639bf1401c1161007f578063d8a06f7311610059578063d8a06f7314610352578063f23a6e6114610386578063f2fde38b146103cb578063f3e301cf146103eb57600080fd5b80639bf1401c1461028c578063ad5c4648146102c0578063bc197c81146102f457600080fd5b80636d13582c116100bb5780636d13582c146101d9578063715018a61461022557806374a1b0b01461023a5780638da5cb5b1461026e57600080fd5b806301ffc9a71461016a57806302329a291461019f5780635c975abb146101bf57600080fd5b3661016557336001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc216146101635760405162461bcd60e51b815260206004820152600960248201527f4f6e6c792057455448000000000000000000000000000000000000000000000060448201526064015b60405180910390fd5b005b600080fd5b34801561017657600080fd5b5061018a610185366004612419565b61040c565b60405190151581526020015b60405180910390f35b3480156101ab57600080fd5b506101636101ba3660046123e1565b610475565b3480156101cb57600080fd5b5060025461018a9060ff1681565b3480156101e557600080fd5b5061020d7f000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f81565b6040516001600160a01b039091168152602001610196565b34801561023157600080fd5b506101636104e2565b34801561024657600080fd5b5061020d7f0000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab89381565b34801561027a57600080fd5b506000546001600160a01b031661020d565b34801561029857600080fd5b5061020d7f000000000000000000000000688c3e4658b5367da06fd629e41879beab538e3781565b3480156102cc57600080fd5b5061020d7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b34801561030057600080fd5b5061033961030f3660046122d0565b7fbc197c810000000000000000000000000000000000000000000000000000000095945050505050565b6040516001600160e01b03199091168152602001610196565b34801561035e57600080fd5b5061020d7f000000000000000000000000be86f647b167567525ccaafcd6f881f1ee55821681565b34801561039257600080fd5b506103396103a136600461237a565b7ff23a6e610000000000000000000000000000000000000000000000000000000095945050505050565b3480156103d757600080fd5b506101636103e6366004612298565b610593565b6103fe6103f9366004612441565b6106d1565b604051908152602001610196565b60006001600160e01b031982167f4e2312e000000000000000000000000000000000000000000000000000000000148061046f57507f01ffc9a7000000000000000000000000000000000000000000000000000000006001600160e01b03198316145b92915050565b6000546001600160a01b031633146104cf5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b6002805460ff1916911515919091179055565b6000546001600160a01b0316331461053c5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a36000805473ffffffffffffffffffffffffffffffffffffffff19169055565b6000546001600160a01b031633146105ed5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161015a565b6001600160a01b0381166106695760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f6464726573730000000000000000000000000000000000000000000000000000606482015260840161015a565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a36000805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000600260015414156107265760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015260640161015a565b600260018190555460ff161561077e5760405162461bcd60e51b815260206004820152600d60248201527f5a61702069732070617573656400000000000000000000000000000000000000604482015260640161015a565b6040516370a0823160e01b81523060048201526000907f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b0316906370a082319060240160206040518083038186803b1580156107e057600080fd5b505afa1580156107f4573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061081891906124dd565b90506001600160a01b037f000000000000000000000000be86f647b167567525ccaafcd6f881f1ee5582161663ef8658db61085660608a018a61276e565b61086360808c018c61276e565b61087060208e018e612298565b8d602001602081019061088391906123e1565b8e604001602081019061089691906123e1565b6040518863ffffffff1660e01b81526004016108b89796959493929190612677565b602060405180830381600087803b1580156108d257600080fd5b505af11580156108e6573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061090a91906124dd565b6040517ff0f2a4d7000000000000000000000000000000000000000000000000000000008152600481018290529092507f0000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab8936001600160a01b03169063f0f2a4d790602401600060405180830381600087803b15801561098857600080fd5b505af115801561099c573d6000803e3d6000fd5b50506040517f81a36fb600000000000000000000000000000000000000000000000000000000815260048101859052600092507f000000000000000000000000be86f647b167567525ccaafcd6f881f1ee5582166001600160a01b031691506381a36fb69060240160206040518083038186803b158015610a1c57600080fd5b505afa158015610a30573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a5491906122b4565b90506000853512610aef576001600160a01b038116635877aee68635610a7d602089018961276e565b6040518463ffffffff1660e01b8152600401610a9b939291906126fc565b602060405180830381600087803b158015610ab557600080fd5b505af1158015610ac9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aed91906122b4565b505b6000610afb858061271f565b91505080156116c857610b1460408a0160208b016123e1565b610cd85760005b81811015610cd257610b68610b3360208c018c612298565b610b3d888061271f565b84818110610b5b57634e487b7160e01b600052603260045260246000fd5b9050602002013585611acc565b73b47e3cd837ddf8e4c57f05d70ab865de6e193bbb610b8a60208c018c612298565b6001600160a01b03161415610cca576000610ba5878061271f565b83818110610bc357634e487b7160e01b600052603260045260246000fd5b60405160209091029290920135602483015250600060448201526001600160a01b038516606482015260840160408051601f19818403018152919052602080820180516001600160e01b03167fbf31196f000000000000000000000000000000000000000000000000000000001790529091506000908190610c47908e018e612298565b6001600160a01b031683604051610c5e91906125bc565b6000604051808303816000865af19150503d8060008114610c9b576040519150601f19603f3d011682016040523d82523d6000602084013e610ca0565b606091505b5091509150818190610cc55760405162461bcd60e51b815260040161015a91906126c9565b505050505b600101610b1b565b50610deb565b610ce560208a018a612298565b6001600160a01b0316632eb2c2d63330610cff898061271f565b610d0c60208c018c61271f565b6040518763ffffffff1660e01b8152600401610d2d969594939291906125d8565b600060405180830381600087803b158015610d4757600080fd5b505af1158015610d5b573d6000803e3d6000fd5b50610d6d9250505060208a018a612298565b6040517fa22cb4650000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015260016024830152919091169063a22cb46590604401600060405180830381600087803b158015610dd257600080fd5b505af1158015610de6573d6000803e3d6000fd5b505050505b6001600160a01b03821663b10402ea610e04878061271f565b610e1160208a018a61271f565b306040518663ffffffff1660e01b8152600401610e32959493929190612634565b602060405180830381600087803b158015610e4c57600080fd5b505af1158015610e60573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e8491906124dd565b508160408601351561143e578560800135341015610f0a5760405162461bcd60e51b815260206004820152602960248201527f496e73756666696369656e74206d73672e76616c75652073656e7420666f722060448201527f6c69717569646974790000000000000000000000000000000000000000000000606482015260840161015a565b7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031663d0e30db0346040518263ffffffff1660e01b81526004016000604051808303818588803b158015610f6557600080fd5b505af1158015610f79573d6000803e3d6000fd5b5050604080516370a0823160e01b8152306004820152908a013593506001600160a01b03851692506370a08231915060240160206040518083038186803b158015610fc357600080fd5b505afa158015610fd7573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ffb91906124dd565b101561106f5760405162461bcd60e51b815260206004820152602a60248201527f496e73756666696369656e7420746f6b656e7320616371756972656420666f7260448201527f206c697175696469747900000000000000000000000000000000000000000000606482015260840161015a565b6110a76001600160a01b0382167f000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f6040890135611d77565b604080517fe8e337000000000000000000000000000000000000000000000000000000000081526001600160a01b0383811660048301527f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2811660248301529188013560448201819052608089013560648301526084820152606088013560a48201523060c48201524260e48201526000917f000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f169063e8e337009061010401606060405180830381600087803b15801561118057600080fd5b505af1158015611194573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b891906124f5565b92506111f29150506001600160a01b0383167f000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f6000611d77565b60007f00000000000000000000000012db7df759871061bc62d9fe023dce7c98717b826001600160a01b0316636d91c0e27f000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f6001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b15801561127c57600080fd5b505afa158015611290573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112b491906122b4565b60405160e083901b6001600160e01b03191681526001600160a01b03918216600482015286821660248201527f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2909116604482015260640160206040518083038186803b15801561132457600080fd5b505afa158015611338573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061135c91906122b4565b90506113926001600160a01b0382167f000000000000000000000000688c3e4658b5367da06fd629e41879beab538e3784611d77565b6040517f6c9b958800000000000000000000000000000000000000000000000000000000815260048101889052336024820152604481018390526202a30060648201527f000000000000000000000000688c3e4658b5367da06fd629e41879beab538e376001600160a01b031690636c9b958890608401600060405180830381600087803b15801561142357600080fd5b505af1158015611437573d6000803e3d6000fd5b5050505050505b6040516370a0823160e01b81523060048201526000906001600160a01b038316906370a082319060240160206040518083038186803b15801561148057600080fd5b505afa158015611494573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114b891906124dd565b905080156116c5576040517f034fc83c000000000000000000000000000000000000000000000000000000008152600481018790526001600160a01b038084169163a9059cbb917f0000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab893169063034fc83c9060240160206040518083038186803b15801561154357600080fd5b505afa158015611557573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061157b91906122b4565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b1580156115c357600080fd5b505af11580156115d7573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115fb91906123fd565b506040517f2699f55a0000000000000000000000000000000000000000000000000000000081526004810187905260248101829052336044820152600260648201527f0000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab8936001600160a01b031690632699f55a90608401602060405180830381600087803b15801561168b57600080fd5b505af115801561169f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116c391906124dd565b505b50505b601f88101561178757816001600160a01b0316630d636a096116eb8a6004611efb565b6116f68b6003611efb565b6117018c6002611efb565b61170c8d6001611efb565b6117178e6000611efb565b6040516001600160e01b031960e088901b168152941515600486015292151560248501529015156044840152151560648301521515608482015260a401600060405180830381600087803b15801561176e57600080fd5b505af1158015611782573d6000803e3d6000fd5b505050505b6001600160a01b0382166304a66b486117a360208a018a612522565b6117b89063ffffffff166402540be4006127e4565b6117c860408b0160208c01612522565b6117dd9063ffffffff166402540be4006127e4565b6117ed60608c0160408d01612522565b6118029063ffffffff166402540be4006127e4565b61181260808d0160608e01612522565b6118279063ffffffff166402540be4006127e4565b61183760a08e0160808f01612522565b61184c9063ffffffff166402540be4006127e4565b6040516001600160e01b031960e088901b1681526004810195909552602485019390935260448401919091526064830152608482015260a401600060405180830381600087803b15801561189f57600080fd5b505af11580156118b3573d6000803e3d6000fd5b50505050816001600160a01b031663c3cb8c146040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156118f257600080fd5b505af1158015611906573d6000803e3d6000fd5b50506040516370a0823160e01b8152306004820152600092508591506001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc216906370a082319060240160206040518083038186803b15801561196e57600080fd5b505afa158015611982573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119a691906124dd565b6119b09190612803565b90508015611aba576040517f2e1a7d4d000000000000000000000000000000000000000000000000000000008152600481018290527f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b031690632e1a7d4d90602401600060405180830381600087803b158015611a3357600080fd5b505af1158015611a47573d6000803e3d6000fd5b50506040516000925033915083156108fc0290849084818181858888f19350505050905080611ab85760405162461bcd60e51b815260206004820152601460248201527f4661696c656420746f2073656e64204574686572000000000000000000000000604482015260640161015a565b505b50506001805550909695505050505050565b60606001600160a01b03841673b47e3cd837ddf8e4c57f05d70ab865de6e193bbb1415611c8457600083604051602401611b0891815260200190565b60408051601f198184030181529181526020820180516001600160e01b03167f58178168000000000000000000000000000000000000000000000000000000001790525190915060009081906001600160a01b03881690611b6a9085906125bc565b600060405180830381855afa9150503d8060008114611ba5576040519150601f19603f3d011682016040523d82523d6000602084013e611baa565b606091505b5091509150600081806020019051810190611bc591906122b4565b9050828015611bdc57506001600160a01b03811633145b611c285760405162461bcd60e51b815260206004820152601160248201527f4e6f7420746865204e4654206f776e6572000000000000000000000000000000604482015260640161015a565b6040516024810188905260440160408051601f198184030181529190526020810180516001600160e01b03167f8264fe98000000000000000000000000000000000000000000000000000000001790529450611cec9350505050565b6040513360248201526001600160a01b03831660448201526064810184905260840160408051601f198184030181529190526020810180516001600160e01b03167f42842e0e0000000000000000000000000000000000000000000000000000000017905290505b600080856001600160a01b031683604051611d0791906125bc565b6000604051808303816000865af19150503d8060008114611d44576040519150601f19603f3d011682016040523d82523d6000602084013e611d49565b606091505b5091509150818190611d6e5760405162461bcd60e51b815260040161015a91906126c9565b50505050505050565b801580611e1957506040517fdd62ed3e0000000000000000000000000000000000000000000000000000000081523060048201526001600160a01b03838116602483015284169063dd62ed3e9060440160206040518083038186803b158015611ddf57600080fd5b505afa158015611df3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e1791906124dd565b155b611e8b5760405162461bcd60e51b815260206004820152603660248201527f5361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f60448201527f20746f206e6f6e2d7a65726f20616c6c6f77616e636500000000000000000000606482015260840161015a565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b03167f095ea7b300000000000000000000000000000000000000000000000000000000179052611ef6908490611f1d565b505050565b6000600183831c8116908114611f12576000611f15565b60015b949350505050565b6000611f72826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166120029092919063ffffffff16565b805190915015611ef65780806020019051810190611f9091906123fd565b611ef65760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e60448201527f6f74207375636365656400000000000000000000000000000000000000000000606482015260840161015a565b6060612011848460008561201b565b90505b9392505050565b6060824710156120935760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f60448201527f722063616c6c0000000000000000000000000000000000000000000000000000606482015260840161015a565b843b6120e15760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015260640161015a565b600080866001600160a01b031685876040516120fd91906125bc565b60006040518083038185875af1925050503d806000811461213a576040519150601f19603f3d011682016040523d82523d6000602084013e61213f565b606091505b509150915061214f82828661215a565b979650505050505050565b60608315612169575081612014565b8251156121795782518084602001fd5b8160405162461bcd60e51b815260040161015a91906126c9565b600082601f8301126121a3578081fd5b8135602067ffffffffffffffff8211156121bf576121bf612860565b8160051b6121ce8282016127b3565b8381528281019086840183880185018910156121e8578687fd5b8693505b8584101561220a5780358352600193909301929184019184016121ec565b50979650505050505050565b600082601f830112612226578081fd5b813567ffffffffffffffff81111561224057612240612860565b612253601f8201601f19166020016127b3565b818152846020838601011115612267578283fd5b816020850160208301379081016020019190915292915050565b600060a08284031215612292578081fd5b50919050565b6000602082840312156122a9578081fd5b813561201481612876565b6000602082840312156122c5578081fd5b815161201481612876565b600080600080600060a086880312156122e7578081fd5b85356122f281612876565b9450602086013561230281612876565b9350604086013567ffffffffffffffff8082111561231e578283fd5b61232a89838a01612193565b9450606088013591508082111561233f578283fd5b61234b89838a01612193565b93506080880135915080821115612360578283fd5b5061236d88828901612216565b9150509295509295909350565b600080600080600060a08688031215612391578081fd5b853561239c81612876565b945060208601356123ac81612876565b93506040860135925060608601359150608086013567ffffffffffffffff8111156123d5578182fd5b61236d88828901612216565b6000602082840312156123f2578081fd5b81356120148161288e565b60006020828403121561240e578081fd5b81516120148161288e565b60006020828403121561242a578081fd5b81356001600160e01b031981168114612014578182fd5b60008060008060006101208688031215612459578081fd5b853567ffffffffffffffff80821115612470578283fd5b61247c89838a01612281565b9650602088013595506124928960408a01612281565b945060e08801359150808211156124a7578283fd5b908701906040828a0312156124ba578283fd5b90925061010087013590808211156124d0578283fd5b5061236d88828901612281565b6000602082840312156124ee578081fd5b5051919050565b600080600060608486031215612509578081fd5b8351925060208401519150604084015190509250925092565b600060208284031215612533578081fd5b813563ffffffff81168114612014578182fd5b81835260007f07ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff831115612577578081fd5b8260051b80836020870137939093016020019283525090919050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b600082516125ce81846020870161281a565b9190910192915050565b60006001600160a01b03808916835280881660208401525060a0604083015261260560a083018688612546565b8281036060840152612618818587612546565b8381036080909401939093525081526020019695505050505050565b606081526000612648606083018789612546565b828103602084015261265b818688612546565b9150506001600160a01b03831660408301529695505050505050565b60a08152600061268b60a08301898b612593565b828103602084015261269e81888a612593565b6001600160a01b03969096166040840152505091151560608301521515608090910152949350505050565b60208152600082518060208401526126e881604085016020870161281a565b601f01601f19169190910160400192915050565b838152604060208201526000612716604083018486612593565b95945050505050565b6000808335601e19843603018112612735578283fd5b83018035915067ffffffffffffffff82111561274f578283fd5b6020019150600581901b360382131561276757600080fd5b9250929050565b6000808335601e19843603018112612784578283fd5b83018035915067ffffffffffffffff82111561279e578283fd5b60200191503681900382131561276757600080fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156127dc576127dc612860565b604052919050565b60008160001904831182151516156127fe576127fe61284a565b500290565b6000828210156128155761281561284a565b500390565b60005b8381101561283557818101518382015260200161281d565b83811115612844576000848401525b50505050565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461288b57600080fd5b50565b801515811461288b57600080fdfea26469706673582212201852bd4c492d50249681174cf82594d12007f6779f2a2857c342f9dd007b67bb64736f6c63430008040033

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

000000000000000000000000be86f647b167567525ccaafcd6f881f1ee5582160000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab893000000000000000000000000688c3e4658b5367da06fd629e41879beab538e37000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f00000000000000000000000012db7df759871061bc62d9fe023dce7c98717b82000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2

-----Decoded View---------------
Arg [0] : _vaultFactory (address): 0xBE86f647b167567525cCAAfcd6f881F1Ee558216
Arg [1] : _inventoryStaking (address): 0x3E135c3E981fAe3383A5aE0d323860a34CfAB893
Arg [2] : _lpStaking (address): 0x688c3E4658B5367da06fd629E41879beaB538E37
Arg [3] : _sushiRouter (address): 0xd9e1cE17f2641f24aE83637ab66a2cca9C378B9F
Arg [4] : _sushiHelper (address): 0x12dB7df759871061bC62D9Fe023DCE7C98717B82
Arg [5] : _weth (address): 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2

-----Encoded View---------------
6 Constructor Arguments found :
Arg [0] : 000000000000000000000000be86f647b167567525ccaafcd6f881f1ee558216
Arg [1] : 0000000000000000000000003e135c3e981fae3383a5ae0d323860a34cfab893
Arg [2] : 000000000000000000000000688c3e4658b5367da06fd629e41879beab538e37
Arg [3] : 000000000000000000000000d9e1ce17f2641f24ae83637ab66a2cca9c378b9f
Arg [4] : 00000000000000000000000012db7df759871061bc62d9fe023dce7c98717b82
Arg [5] : 000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2


Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

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

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ 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.