ETH Price: $3,546.30 (-0.77%)
Gas: 22 Gwei

Contract

0xf70FC6b694D911b1F665b754f77EC5e83D340594
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Value
0x60c06040142616642022-02-23 9:56:13765 days ago1645610173IN
 Create: FuseFTokenSilo
0 ETH0.025200440

Latest 12 internal transactions

Advanced mode:
Parent Txn Hash Block From To Value
142623352022-02-23 12:33:27764 days ago1645619607
0xf70FC6b6...83D340594
0 ETH
142623352022-02-23 12:33:27764 days ago1645619607
0xf70FC6b6...83D340594
0 ETH
142623352022-02-23 12:33:27764 days ago1645619607
0xf70FC6b6...83D340594
0 ETH
142623352022-02-23 12:33:27764 days ago1645619607
0xf70FC6b6...83D340594
0 ETH
142623352022-02-23 12:33:27764 days ago1645619607
0xf70FC6b6...83D340594
0 ETH
142619742022-02-23 11:09:50765 days ago1645614590
0xf70FC6b6...83D340594
0 ETH
142619742022-02-23 11:09:50765 days ago1645614590
0xf70FC6b6...83D340594
0 ETH
142619742022-02-23 11:09:50765 days ago1645614590
0xf70FC6b6...83D340594
0 ETH
142619742022-02-23 11:09:50765 days ago1645614590
0xf70FC6b6...83D340594
0 ETH
142616642022-02-23 9:56:13765 days ago1645610173
0xf70FC6b6...83D340594
0 ETH
142616642022-02-23 9:56:13765 days ago1645610173
0xf70FC6b6...83D340594
0 ETH
142616642022-02-23 9:56:13765 days ago1645610173
0xf70FC6b6...83D340594
0 ETH
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
FuseFTokenSilo

Compiler Version
v0.8.10+commit.fc410830

Optimization Enabled:
Yes with 800 runs

Other Settings:
default evmVersion
File 1 of 5 : FuseFTokenSilo.sol
// SPDX-License-Identifier: Unlicense
pragma solidity ^0.8.10;

import "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";

import "contracts/libraries/FullMath.sol";
import "contracts/interfaces/ISilo.sol";

interface IFToken {
    function accrueInterest() external returns (uint256);

    function exchangeRateStored() external view returns (uint256);

    function mint(uint256 mintAmount) external returns (uint256);

    function redeem(uint256 redeemTokens) external returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function underlying() external view returns (address);

    function isCToken() external view returns (bool);
}

contract FuseFTokenSilo is ISilo {
    /// @inheritdoc ISilo
    string public name;

    address public immutable fToken;

    address public immutable uToken;

    constructor(address _fToken) {
        require(IFToken(_fToken).isCToken(), "Aloe: not an fToken");
        fToken = _fToken;
        uToken = IFToken(_fToken).underlying();

        name = string(abi.encodePacked("Rari Fuse ", IERC20Metadata(uToken).symbol(), " Silo"));
    }

    /// @inheritdoc ISilo
    function poke() external override {
        IFToken(fToken).accrueInterest();
    }

    /// @inheritdoc ISilo
    function deposit(uint256 amount) external override {
        if (amount == 0) return;
        _approve(uToken, fToken, amount);
        require(IFToken(fToken).mint(amount) == 0, "Fuse: mint failed");
    }

    /// @inheritdoc ISilo
    function withdraw(uint256 amount) external override {
        if (amount == 0) return;
        uint256 fAmount = 1 + FullMath.mulDiv(amount, 1e18, IFToken(fToken).exchangeRateStored());

        require(IFToken(fToken).redeem(fAmount) == 0, "Fuse: redeem failed");
    }

    /// @inheritdoc ISilo
    function balanceOf(address account) external view override returns (uint256 balance) {
        IFToken _fToken = IFToken(fToken);
        return FullMath.mulDiv(_fToken.balanceOf(account), _fToken.exchangeRateStored(), 1e18);
    }

    /// @inheritdoc ISilo
    function shouldAllowRemovalOf(address token) external view override returns (bool shouldAllow) {
        shouldAllow = token != fToken;
    }

    function _approve(
        address token,
        address spender,
        uint256 amount
    ) private {
        // 200 gas to read uint256
        if (IERC20(token).allowance(address(this), spender) < amount) {
            // 20000 gas to write uint256 if changing from zero to non-zero
            // 5000  gas to write uint256 if changing from non-zero to non-zero
            IERC20(token).approve(spender, type(uint256).max);
        }
    }
}

File 3 of 5 : IERC20Metadata.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../IERC20.sol";

/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

File 4 of 5 : FullMath.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.10;

/// @title Contains 512-bit math functions
/// @notice Facilitates multiplication and division that can have overflow of an intermediate value without any loss of precision
/// @dev Handles "phantom overflow" i.e., allows multiplication and division where an intermediate value overflows 256 bits
library FullMath {
    /// @notice Calculates floor(a×b÷denominator) with full precision. Throws if result overflows a uint256 or denominator == 0
    /// @param a The multiplicand
    /// @param b The multiplier
    /// @param denominator The divisor
    /// @return result The 256-bit result
    /// @dev Credit to Remco Bloemen under MIT license https://xn--2-umb.com/21/muldiv
    function mulDiv(
        uint256 a,
        uint256 b,
        uint256 denominator
    ) internal pure returns (uint256 result) {
        // Handle division by zero
        require(denominator != 0);

        // 512-bit multiply [prod1 prod0] = a * b
        // Compute the product mod 2**256 and mod 2**256 - 1
        // then use the Chinese Remainder Theorem to reconstruct
        // the 512 bit result. The result is stored in two 256
        // variables such that product = prod1 * 2**256 + prod0
        uint256 prod0; // Least significant 256 bits of the product
        uint256 prod1; // Most significant 256 bits of the product
        assembly {
            let mm := mulmod(a, b, not(0))
            prod0 := mul(a, b)
            prod1 := sub(sub(mm, prod0), lt(mm, prod0))
        }

        // Short circuit 256 by 256 division
        // This saves gas when a * b is small, at the cost of making the
        // large case a bit more expensive. Depending on your use case you
        // may want to remove this short circuit and always go through the
        // 512 bit path.
        if (prod1 == 0) {
            assembly {
                result := div(prod0, denominator)
            }
            return result;
        }

        ///////////////////////////////////////////////
        // 512 by 256 division.
        ///////////////////////////////////////////////

        // Handle overflow, the result must be < 2**256
        require(prod1 < denominator);

        // Make division exact by subtracting the remainder from [prod1 prod0]
        // Compute remainder using mulmod
        // Note mulmod(_, _, 0) == 0
        uint256 remainder;
        assembly {
            remainder := mulmod(a, b, denominator)
        }
        // Subtract 256 bit number from 512 bit number
        assembly {
            prod1 := sub(prod1, gt(remainder, prod0))
            prod0 := sub(prod0, remainder)
        }

        // Factor powers of two out of denominator
        // Compute largest power of two divisor of denominator.
        // Always >= 1.
        unchecked {
            // https://ethereum.stackexchange.com/a/96646
            uint256 twos = (type(uint256).max - denominator + 1) & denominator;
            // Divide denominator by power of two
            assembly {
                denominator := div(denominator, twos)
            }

            // Divide [prod1 prod0] by the factors of two
            assembly {
                prod0 := div(prod0, twos)
            }
            // Shift in bits from prod1 into prod0. For this we need
            // to flip `twos` such that it is 2**256 / twos.
            // If twos is zero, then it becomes one
            assembly {
                twos := add(div(sub(0, twos), twos), 1)
            }
            prod0 |= prod1 * twos;

            // Invert denominator mod 2**256
            // Now that denominator is an odd number, it has an inverse
            // modulo 2**256 such that denominator * inv = 1 mod 2**256.
            // Compute the inverse by starting with a seed that is correct
            // correct for four bits. That is, denominator * inv = 1 mod 2**4
            // If denominator is zero the inverse starts with 2
            uint256 inv = (3 * denominator) ^ 2;
            // Now use Newton-Raphson iteration to improve the precision.
            // Thanks to Hensel's lifting lemma, this also works in modular
            // arithmetic, doubling the correct bits in each step.
            inv *= 2 - denominator * inv; // inverse mod 2**8
            inv *= 2 - denominator * inv; // inverse mod 2**16
            inv *= 2 - denominator * inv; // inverse mod 2**32
            inv *= 2 - denominator * inv; // inverse mod 2**64
            inv *= 2 - denominator * inv; // inverse mod 2**128
            inv *= 2 - denominator * inv; // inverse mod 2**256
            // If denominator is zero, inv is now 128

            // Because the division is now exact we can divide by multiplying
            // with the modular inverse of denominator. This will give us the
            // correct result modulo 2**256. Since the precoditions guarantee
            // that the outcome is less than 2**256, this is the final result.
            // We don't need to compute the high bits of the result and prod1
            // is no longer required.
            result = prod0 * inv;
            return result;
        }
    }

    /// @notice Calculates ceil(a×b÷denominator) with full precision. Throws if result overflows a uint256 or denominator == 0
    /// @param a The multiplicand
    /// @param b The multiplier
    /// @param denominator The divisor
    /// @return result The 256-bit result
    function mulDivRoundingUp(
        uint256 a,
        uint256 b,
        uint256 denominator
    ) internal pure returns (uint256 result) {
        result = mulDiv(a, b, denominator);
        if (mulmod(a, b, denominator) > 0) {
            require(result < type(uint256).max);
            result++;
        }
    }
}

File 5 of 5 : ISilo.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.10;

interface ISilo {
    /// @notice A descriptive name for the silo (ex: Compound USDC Silo)
    function name() external view returns (string memory);

    /// @notice A place to update the silo's internal state
    /// @dev After this has been called, balances reported by `balanceOf` MUST be correct
    function poke() external;

    /// @notice Deposits `amount` of the underlying token
    function deposit(uint256 amount) external;

    /// @notice Withdraws EXACTLY `amount` of the underlying token
    function withdraw(uint256 amount) external;

    /// @notice Reports how much of the underlying token `account` has stored
    /// @dev Must never overestimate `balance`. Should give the exact, correct value after `poke` is called
    function balanceOf(address account) external view returns (uint256 balance);

    /**
     * @notice Whether the given token is irrelevant to the silo's strategy (`shouldAllow = true`) or
     * is required for proper management (`shouldAllow = false`). ex: Compound silos shouldn't allow
     * removal of cTokens, but the may allow removal of COMP rewards.
     * @dev Removed tokens are used to help incentivize rebalances for the Blend vault that uses the silo. So
     * if you want something like COMP rewards to go to Blend *users* instead, you'd have to implement a
     * trading function as part of `poke()` to convert COMP to the underlying token.
     */
    function shouldAllowRemovalOf(address token) external view returns (bool shouldAllow);
}

File 6 of 5 : IERC20.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @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);
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 800
  },
  "metadata": {
    "bytecodeHash": "none"
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_fToken","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"balance","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"fToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"poke","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"shouldAllowRemovalOf","outputs":[{"internalType":"bool","name":"shouldAllow","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60c06040523480156200001157600080fd5b5060405162000e5438038062000e548339810160408190526200003491620002b5565b806001600160a01b031663fe9c44ae6040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000073573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620000999190620002e7565b620000ea5760405162461bcd60e51b815260206004820152601360248201527f416c6f653a206e6f7420616e2066546f6b656e00000000000000000000000000604482015260640160405180910390fd5b6001600160a01b038116608081905260408051636f307dc360e01b81529051636f307dc3916004808201926020929091908290030181865afa15801562000135573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200015b9190620002b5565b6001600160a01b031660a0819052604080516395d89b4160e01b815290516395d89b41916004808201926000929091908290030181865afa158015620001a5573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052620001cf919081019062000354565b604051602001620001e191906200040c565b60405160208183030381529060405260009080519060200190620002079291906200020f565b50506200048c565b8280546200021d906200044f565b90600052602060002090601f0160209004810192826200024157600085556200028c565b82601f106200025c57805160ff19168380011785556200028c565b828001600101855582156200028c579182015b828111156200028c5782518255916020019190600101906200026f565b506200029a9291506200029e565b5090565b5b808211156200029a57600081556001016200029f565b600060208284031215620002c857600080fd5b81516001600160a01b0381168114620002e057600080fd5b9392505050565b600060208284031215620002fa57600080fd5b81518015158114620002e057600080fd5b634e487b7160e01b600052604160045260246000fd5b60005b838110156200033e57818101518382015260200162000324565b838111156200034e576000848401525b50505050565b6000602082840312156200036757600080fd5b81516001600160401b03808211156200037f57600080fd5b818401915084601f8301126200039457600080fd5b815181811115620003a957620003a96200030b565b604051601f8201601f19908116603f01168101908382118183101715620003d457620003d46200030b565b81604052828152876020848701011115620003ee57600080fd5b6200040183602083016020880162000321565b979650505050505050565b6902930b93490233ab9b2960b51b8152600082516200043381600a85016020870162000321565b642053696c6f60d81b600a939091019283015250600f01919050565b600181811c908216806200046457607f821691505b602082108114156200048657634e487b7160e01b600052602260045260246000fd5b50919050565b60805160a05161096b620004e96000396000818161011e015261056d01526000818160bb0152818161017e01528181610243015281816102e10152818161038a015281816104770152818161058e01526105c9015261096b6000f3fe608060405234801561001057600080fd5b50600436106100885760003560e01c8063633156371161005b578063633156371461011957806370a0823114610158578063a8694e5714610179578063b6b55f25146101a057600080fd5b806306fdde031461008d5780631363efd8146100ab57806318178358146100fc5780632e1a7d4d14610106575b600080fd5b6100956101b3565b6040516100a2919061082b565b60405180910390f35b6100ec6100b9366004610880565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b039081169116141590565b60405190151581526020016100a2565b610104610241565b005b6101046101143660046108a9565b6102c8565b6101407f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020016100a2565b61016b610166366004610880565b610455565b6040519081526020016100a2565b6101407f000000000000000000000000000000000000000000000000000000000000000081565b6101046101ae3660046108a9565b610560565b600080546101c0906108c2565b80601f01602080910402602001604051908101604052809291908181526020018280546101ec906108c2565b80156102395780601f1061020e57610100808354040283529160200191610239565b820191906000526020600020905b81548152906001019060200180831161021c57829003601f168201915b505050505081565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663a6afed956040518163ffffffff1660e01b81526004016020604051808303816000875af11580156102a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102c591906108fd565b50565b806102d05750565b600061036682670de0b6b3a76400007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663182df0f56040518163ffffffff1660e01b8152600401602060405180830381865afa15801561033d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061036191906108fd565b61068b565b610371906001610916565b60405163db006a7560e01b8152600481018290529091507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063db006a75906024016020604051808303816000875af11580156103db573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103ff91906108fd565b156104515760405162461bcd60e51b815260206004820152601360248201527f467573653a2072656465656d206661696c65640000000000000000000000000060448201526064015b60405180910390fd5b5050565b6040516370a0823160e01b81526001600160a01b0382811660048301526000917f00000000000000000000000000000000000000000000000000000000000000009161055991908316906370a0823190602401602060405180830381865afa1580156104c5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104e991906108fd565b826001600160a01b031663182df0f56040518163ffffffff1660e01b8152600401602060405180830381865afa158015610527573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061054b91906108fd565b670de0b6b3a764000061068b565b9392505050565b806105685750565b6105b37f00000000000000000000000000000000000000000000000000000000000000007f000000000000000000000000000000000000000000000000000000000000000083610737565b60405163140e25ad60e31b8152600481018290527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b03169063a0712d68906024016020604051808303816000875af115801561061a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061063e91906108fd565b156102c55760405162461bcd60e51b815260206004820152601160248201527f467573653a206d696e74206661696c65640000000000000000000000000000006044820152606401610448565b60008161069757600080fd5b60008060001985870985870292508281108382030391505080600014156106c357508290049050610559565b8381106106cf57600080fd5b600084868809600260036001881981018916988990049182028318808302840302808302840302808302840302808302840302808302840302918202909203026000889003889004909101858311909403939093029303949094049190911702949350505050565b604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015282919085169063dd62ed3e90604401602060405180830381865afa158015610786573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107aa91906108fd565b10156108265760405163095ea7b360e01b81526001600160a01b038381166004830152600019602483015284169063095ea7b3906044016020604051808303816000875af1158015610800573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610824919061093c565b505b505050565b600060208083528351808285015260005b818110156108585785810183015185820160400152820161083c565b8181111561086a576000604083870101525b50601f01601f1916929092016040019392505050565b60006020828403121561089257600080fd5b81356001600160a01b038116811461055957600080fd5b6000602082840312156108bb57600080fd5b5035919050565b600181811c908216806108d657607f821691505b602082108114156108f757634e487b7160e01b600052602260045260246000fd5b50919050565b60006020828403121561090f57600080fd5b5051919050565b6000821982111561093757634e487b7160e01b600052601160045260246000fd5b500190565b60006020828403121561094e57600080fd5b8151801515811461055957600080fdfea164736f6c634300080a000a000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100885760003560e01c8063633156371161005b578063633156371461011957806370a0823114610158578063a8694e5714610179578063b6b55f25146101a057600080fd5b806306fdde031461008d5780631363efd8146100ab57806318178358146100fc5780632e1a7d4d14610106575b600080fd5b6100956101b3565b6040516100a2919061082b565b60405180910390f35b6100ec6100b9366004610880565b7f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe6001600160a01b039081169116141590565b60405190151581526020016100a2565b610104610241565b005b6101046101143660046108a9565b6102c8565b6101407f00000000000000000000000003ab458634910aad20ef5f1c8ee96f1d6ac5491981565b6040516001600160a01b0390911681526020016100a2565b61016b610166366004610880565b610455565b6040519081526020016100a2565b6101407f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe81565b6101046101ae3660046108a9565b610560565b600080546101c0906108c2565b80601f01602080910402602001604051908101604052809291908181526020018280546101ec906108c2565b80156102395780601f1061020e57610100808354040283529160200191610239565b820191906000526020600020905b81548152906001019060200180831161021c57829003601f168201915b505050505081565b7f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe6001600160a01b031663a6afed956040518163ffffffff1660e01b81526004016020604051808303816000875af11580156102a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102c591906108fd565b50565b806102d05750565b600061036682670de0b6b3a76400007f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe6001600160a01b031663182df0f56040518163ffffffff1660e01b8152600401602060405180830381865afa15801561033d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061036191906108fd565b61068b565b610371906001610916565b60405163db006a7560e01b8152600481018290529091507f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe6001600160a01b03169063db006a75906024016020604051808303816000875af11580156103db573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103ff91906108fd565b156104515760405162461bcd60e51b815260206004820152601360248201527f467573653a2072656465656d206661696c65640000000000000000000000000060448201526064015b60405180910390fd5b5050565b6040516370a0823160e01b81526001600160a01b0382811660048301526000917f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe9161055991908316906370a0823190602401602060405180830381865afa1580156104c5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104e991906108fd565b826001600160a01b031663182df0f56040518163ffffffff1660e01b8152600401602060405180830381865afa158015610527573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061054b91906108fd565b670de0b6b3a764000061068b565b9392505050565b806105685750565b6105b37f00000000000000000000000003ab458634910aad20ef5f1c8ee96f1d6ac549197f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe83610737565b60405163140e25ad60e31b8152600481018290527f000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe6001600160a01b03169063a0712d68906024016020604051808303816000875af115801561061a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061063e91906108fd565b156102c55760405162461bcd60e51b815260206004820152601160248201527f467573653a206d696e74206661696c65640000000000000000000000000000006044820152606401610448565b60008161069757600080fd5b60008060001985870985870292508281108382030391505080600014156106c357508290049050610559565b8381106106cf57600080fd5b600084868809600260036001881981018916988990049182028318808302840302808302840302808302840302808302840302808302840302918202909203026000889003889004909101858311909403939093029303949094049190911702949350505050565b604051636eb1769f60e11b81523060048201526001600160a01b03838116602483015282919085169063dd62ed3e90604401602060405180830381865afa158015610786573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107aa91906108fd565b10156108265760405163095ea7b360e01b81526001600160a01b038381166004830152600019602483015284169063095ea7b3906044016020604051808303816000875af1158015610800573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610824919061093c565b505b505050565b600060208083528351808285015260005b818110156108585785810183015185820160400152820161083c565b8181111561086a576000604083870101525b50601f01601f1916929092016040019392505050565b60006020828403121561089257600080fd5b81356001600160a01b038116811461055957600080fd5b6000602082840312156108bb57600080fd5b5035919050565b600181811c908216806108d657607f821691505b602082108114156108f757634e487b7160e01b600052602260045260246000fd5b50919050565b60006020828403121561090f57600080fd5b5051919050565b6000821982111561093757634e487b7160e01b600052601160045260246000fd5b500190565b60006020828403121561094e57600080fd5b8151801515811461055957600080fdfea164736f6c634300080a000a

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

000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe

-----Decoded View---------------
Arg [0] : _fToken (address): 0x752F119bD4Ee2342CE35E2351648d21962c7CAfE

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000752f119bd4ee2342ce35e2351648d21962c7cafe


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

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