ETH Price: $3,880.36 (+5.89%)

Token

ERC-20: MYD_Dividend_Tracker (MYD_Dividend_Tracker)
 

Overview

Max Total Supply

325,051,323,028,657.46148387240312952 MYD_Dividend_Tracker

Holders

172

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
2,707,734,492,916.776194506228670024 MYD_Dividend_Tracker

Value
$0.00
0x407b7c8c425d3dc0f19fb89564a33614c158869f
Loading...
Loading
Loading...
Loading
Loading...
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
MYDTokenDividendTracker

Compiler Version
v0.8.15+commit.e14f2714

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-01-05
*/

/*

Earn up to 60-300% APR

Website, dApp : https://www.multiplyyield.com/

**/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.15;

interface IERC20 {
    function totalSupply() external view returns (uint256);

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

    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

interface IFactory {
    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);

    function getPair(address tokenA, address tokenB)
        external
        view
        returns (address pair);
}

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

    function WETH() external pure returns (address);

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

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);
}

interface DividendPayingTokenInterface {
    function dividendOf(address _owner) external view returns (uint256);

    function withdrawDividend() external;

    event DividendsDistributed(address indexed from, uint256 weiAmount);
    event DividendWithdrawn(address indexed to, uint256 weiAmount);
}

interface DividendPayingTokenOptionalInterface {
    function withdrawableDividendOf(address _owner)
        external
        view
        returns (uint256);

    function withdrawnDividendOf(address _owner)
        external
        view
        returns (uint256);

    function accumulativeDividendOf(address _owner)
        external
        view
        returns (uint256);
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

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

        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;
    int256 private constant MAX_INT256 = ~(int256(1) << 255);

    function mul(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a * b;

        // Detect overflow when multiplying MIN_INT256 with -1
        require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256));
        require((b == 0) || (c / b == a));
        return c;
    }

    function div(int256 a, int256 b) internal pure returns (int256) {
        // Prevent overflow when dividing MIN_INT256 by -1
        require(b != -1 || a != MIN_INT256);

        // Solidity already throws when dividing by 0.
        return a / b;
    }

    function sub(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a - b;
        require((b >= 0 && c <= a) || (b < 0 && c > a));
        return c;
    }

    function add(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a + b;
        require((b >= 0 && c >= a) || (b < 0 && c < a));
        return c;
    }

    function abs(int256 a) internal pure returns (int256) {
        require(a != MIN_INT256);
        return a < 0 ? -a : a;
    }

    function toUint256Safe(int256 a) internal pure returns (uint256) {
        require(a >= 0);
        return uint256(a);
    }
}

library SafeMathUint {
    function toInt256Safe(uint256 a) internal pure returns (int256) {
        int256 b = int256(a);
        require(b >= 0);
        return b;
    }
}

library IterableMapping {
    struct Map {
        address[] keys;
        mapping(address => uint256) values;
        mapping(address => uint256) indexOf;
        mapping(address => bool) inserted;
    }

    function get(Map storage map, address key) public view returns (uint256) {
        return map.values[key];
    }

    function getIndexOfKey(Map storage map, address key)
        public
        view
        returns (int256)
    {
        if (!map.inserted[key]) {
            return -1;
        }
        return int256(map.indexOf[key]);
    }

    function getKeyAtIndex(Map storage map, uint256 index)
        public
        view
        returns (address)
    {
        return map.keys[index];
    }

    function size(Map storage map) public view returns (uint256) {
        return map.keys.length;
    }

    function set(
        Map storage map,
        address key,
        uint256 val
    ) public {
        if (map.inserted[key]) {
            map.values[key] = val;
        } else {
            map.inserted[key] = true;
            map.values[key] = val;
            map.indexOf[key] = map.keys.length;
            map.keys.push(key);
        }
    }

    function remove(Map storage map, address key) public {
        if (!map.inserted[key]) {
            return;
        }

        delete map.inserted[key];
        delete map.values[key];

        uint256 index = map.indexOf[key];
        uint256 lastIndex = map.keys.length - 1;
        address lastKey = map.keys[lastIndex];

        map.indexOf[lastKey] = index;
        delete map.indexOf[key];

        map.keys[index] = lastKey;
        map.keys.pop();
    }
}

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

contract Ownable is Context {
    address private _owner;

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

    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;
    string private _name;
    string private _symbol;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    function name() public view virtual override returns (string memory) {
        return _name;
    }

    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _balances[account];
    }

    function transfer(address recipient, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(address owner, address spender)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    function increaseAllowance(address spender, uint256 addedValue)
        public
        virtual
        returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].add(addedValue)
        );
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue)
        public
        virtual
        returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender].sub(
                subtractedValue,
                "ERC20: decreased allowance below zero"
            )
        );
        return true;
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        _beforeTokenTransfer(sender, recipient, amount);
        _balances[sender] = _balances[sender].sub(
            amount,
            "ERC20: transfer amount exceeds balance"
        );
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");
        _beforeTokenTransfer(address(0), account, amount);
        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");
        _beforeTokenTransfer(account, address(0), amount);
        _balances[account] = _balances[account].sub(
            amount,
            "ERC20: burn amount exceeds balance"
        );
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }

    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

contract DividendPayingToken is
    ERC20,
    Ownable,
    DividendPayingTokenInterface,
    DividendPayingTokenOptionalInterface
{
    using SafeMath for uint256;
    using SafeMathUint for uint256;
    using SafeMathInt for int256;

    uint256 internal constant magnitude = 2**128;
    uint256 internal magnifiedDividendPerShare;
    uint256 public totalDividendsDistributed;
    address public rewardToken;
    IRouter public uniswapV2Router;

    mapping(address => int256) internal magnifiedDividendCorrections;
    mapping(address => uint256) internal withdrawnDividends;

    constructor(string memory _name, string memory _symbol)
        ERC20(_name, _symbol)
    {}

    receive() external payable {}

    function distributeDividendsUsingAmount(uint256 amount) public onlyOwner {
        require(totalSupply() > 0);
        if (amount > 0) {
            magnifiedDividendPerShare = magnifiedDividendPerShare.add(
                (amount).mul(magnitude) / totalSupply()
            );
            emit DividendsDistributed(msg.sender, amount);
            totalDividendsDistributed = totalDividendsDistributed.add(amount);
        }
    }

    function withdrawDividend() public virtual override onlyOwner {
        _withdrawDividendOfUser(payable(msg.sender));
    }

    function _withdrawDividendOfUser(address payable user)
        internal
        returns (uint256)
    {
        uint256 _withdrawableDividend = withdrawableDividendOf(user);
        if (_withdrawableDividend > 0) {
            withdrawnDividends[user] = withdrawnDividends[user].add(
                _withdrawableDividend
            );
            emit DividendWithdrawn(user, _withdrawableDividend);
            bool success = IERC20(rewardToken).transfer(
                user,
                _withdrawableDividend
            );
            if (!success) {
                withdrawnDividends[user] = withdrawnDividends[user].sub(
                    _withdrawableDividend
                );
                return 0;
            }
            return _withdrawableDividend;
        }
        return 0;
    }

    function dividendOf(address _owner) public view override returns (uint256) {
        return withdrawableDividendOf(_owner);
    }

    function withdrawableDividendOf(address _owner)
        public
        view
        override
        returns (uint256)
    {
        return accumulativeDividendOf(_owner).sub(withdrawnDividends[_owner]);
    }

    function withdrawnDividendOf(address _owner)
        public
        view
        override
        returns (uint256)
    {
        return withdrawnDividends[_owner];
    }

    function accumulativeDividendOf(address _owner)
        public
        view
        override
        returns (uint256)
    {
        return
            magnifiedDividendPerShare
                .mul(balanceOf(_owner))
                .toInt256Safe()
                .add(magnifiedDividendCorrections[_owner])
                .toUint256Safe() / magnitude;
    }

    function _transfer(
        address from,
        address to,
        uint256 value
    ) internal virtual override {
        require(false);
        int256 _magCorrection = magnifiedDividendPerShare
            .mul(value)
            .toInt256Safe();
        magnifiedDividendCorrections[from] = magnifiedDividendCorrections[from]
            .add(_magCorrection);
        magnifiedDividendCorrections[to] = magnifiedDividendCorrections[to].sub(
            _magCorrection
        );
    }

    function _mint(address account, uint256 value) internal override {
        super._mint(account, value);
        magnifiedDividendCorrections[account] = magnifiedDividendCorrections[
            account
        ].sub((magnifiedDividendPerShare.mul(value)).toInt256Safe());
    }

    function _burn(address account, uint256 value) internal override {
        super._burn(account, value);
        magnifiedDividendCorrections[account] = magnifiedDividendCorrections[
            account
        ].add((magnifiedDividendPerShare.mul(value)).toInt256Safe());
    }

    function _setBalance(address account, uint256 newBalance) internal {
        uint256 currentBalance = balanceOf(account);
        if (newBalance > currentBalance) {
            uint256 mintAmount = newBalance.sub(currentBalance);
            _mint(account, mintAmount);
        } else if (newBalance < currentBalance) {
            uint256 burnAmount = currentBalance.sub(newBalance);
            _burn(account, burnAmount);
        }
    }

    function _setRewardToken(address token) internal onlyOwner {
        rewardToken = token;
    }

    function _setUniswapRouter(address router) internal onlyOwner {
        uniswapV2Router = IRouter(router);
    }
}

contract MultiplyYield is Ownable, ERC20 {
    IRouter public uniswapV2Router;
    address public immutable uniswapV2Pair;

    string private constant _name = "Multiply Yield";
    string private constant _symbol = "MYD";
    uint8 private constant _decimals = 18;

    MYDTokenDividendTracker public dividendTracker;

    bool public isTradingEnabled;

    // initialSupply
    uint256 constant initialSupply = 5000000000000000 * (10**18);

    uint256 public maxWalletAmount = (initialSupply * 200) / 10000;

    uint256 public maxTxAmount = (initialSupply * 200) / 10000;

    bool private _swapping;
    bool public limitsInEffect = true;
    uint256 public minimumTokensBeforeSwap = 150000000 * (10**18);

    address public liquidityWallet;
    address public marketingWallet;
    address public buyBackWallet;

    struct CustomTaxPeriod {
        bytes23 periodName;
        uint8 blocksInPeriod;
        uint256 timeInPeriod;
        uint8 liquidityFeeOnBuy;
        uint8 liquidityFeeOnSell;
        uint8 marketingFeeOnBuy;
        uint8 marketingFeeOnSell;
        uint8 buyBackFeeOnBuy;
        uint8 buyBackFeeOnSell;
        uint8 burnFeeOnBuy;
        uint8 burnFeeOnSell;
        uint8 holdersFeeOnBuy;
        uint8 holdersFeeOnSell;
    }

    // Base taxes
    CustomTaxPeriod private _base =
        CustomTaxPeriod("base", 0, 0, 1, 1, 3, 9, 0, 1, 0, 0, 0, 1);

    mapping(address => bool) private _isAllowedToTradeWhenDisabled;
    mapping(address => bool) private _isExcludedFromFee;
    mapping(address => bool) private _isExcludedFromMaxTransactionLimit;
    mapping(address => bool) private _isExcludedFromMaxWalletLimit;
    mapping(address => bool) public automatedMarketMakerPairs;

    uint8 private _liquidityFee;
    uint8 private _marketingFee;
    uint8 private _buyBackFee;
    uint8 private _burnFee;
    uint8 private _holdersFee;
    uint8 private _totalFee;

    event AutomatedMarketMakerPairChange(
        address indexed pair,
        bool indexed value
    );
    event UniswapV2RouterChange(
        address indexed newAddress,
        address indexed oldAddress
    );
    event WalletChange(
        string indexed indentifier,
        address indexed newWallet,
        address indexed oldWallet
    );
    event FeeChange(
        string indexed identifier,
        uint8 liquidityFee,
        uint8 marketingFee,
        uint8 buyBackFee,
        uint8 burnFee,
        uint8 holdersFee
    );
    event CustomTaxPeriodChange(
        uint256 indexed newValue,
        uint256 indexed oldValue,
        string indexed taxType,
        bytes23 period
    );
    event MaxTransactionAmountChange(
        uint256 indexed newValue,
        uint256 indexed oldValue
    );
    event MaxWalletAmountChange(
        uint256 indexed newValue,
        uint256 indexed oldValue
    );
    event ExcludeFromFeesChange(address indexed account, bool isExcluded);
    event ExcludeFromMaxTransferChange(
        address indexed account,
        bool isExcluded
    );
    event ExcludeFromMaxWalletChange(address indexed account, bool isExcluded);
    event AllowedWhenTradingDisabledChange(
        address indexed account,
        bool isExcluded
    );
    event MinTokenAmountBeforeSwapChange(
        uint256 indexed newValue,
        uint256 indexed oldValue
    );
    event MinTokenAmountForDividendsChange(
        uint256 indexed newValue,
        uint256 indexed oldValue
    );
    event DividendsSent(uint256 tokensSwapped);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    event ClaimETHOverflow(uint256 amount);
    event TokenBurn(uint8 _burnFee, uint256 burnAmount);
    event FeesApplied(
        uint8 liquidityFee,
        uint8 marketingFee,
        uint8 buyBackFee,
        uint8 burnFee,
        uint8 holdersFee,
        uint8 totalFee
    );

    constructor() ERC20(_name, _symbol) {
        dividendTracker = new MYDTokenDividendTracker();
        dividendTracker.setUniswapRouter(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        dividendTracker.setRewardToken(address(this));

        liquidityWallet = owner();
        marketingWallet = address(0xEC13cb4c0e61d7146cCd644F9279c6aD6728F18E);
        buyBackWallet = address(0xe8a8736e2601a35f14579aEe165b0742AD7983d2);

        IRouter _uniswapV2Router = IRouter(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        address _uniswapV2Pair = IFactory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());
        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;
        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);

        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[marketingWallet] = true;
        _isExcludedFromFee[buyBackWallet] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[address(dividendTracker)] = true;

        dividendTracker.excludeFromDividends(address(dividendTracker));
        dividendTracker.excludeFromDividends(address(this));
        dividendTracker.excludeFromDividends(
            address(0x000000000000000000000000000000000000dEaD)
        );
        dividendTracker.excludeFromDividends(owner());
        dividendTracker.excludeFromDividends(address(_uniswapV2Router));

        _isAllowedToTradeWhenDisabled[owner()] = true;

        _isExcludedFromMaxTransactionLimit[address(dividendTracker)] = true;
        _isExcludedFromMaxTransactionLimit[address(this)] = true;
        _isExcludedFromMaxTransactionLimit[owner()] = true;
        _isExcludedFromMaxTransactionLimit[marketingWallet] = true;
        _isExcludedFromMaxTransactionLimit[buyBackWallet] = true;

        _isExcludedFromMaxWalletLimit[_uniswapV2Pair] = true;
        _isExcludedFromMaxWalletLimit[address(dividendTracker)] = true;
        _isExcludedFromMaxWalletLimit[address(uniswapV2Router)] = true;
        _isExcludedFromMaxWalletLimit[address(this)] = true;
        _isExcludedFromMaxWalletLimit[owner()] = true;
        _isExcludedFromMaxWalletLimit[marketingWallet] = true;
        _isExcludedFromMaxWalletLimit[buyBackWallet] = true;
        _isExcludedFromMaxWalletLimit[
            address(0x000000000000000000000000000000000000dEaD)
        ] = true;

        _mint(owner(), initialSupply);
    }

    receive() external payable {}

    // Setters
    function openTrading() external onlyOwner {
        isTradingEnabled = true;
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        require(
            automatedMarketMakerPairs[pair] != value,
            "MYDToken: Automated market maker pair is already set to that value"
        );
        automatedMarketMakerPairs[pair] = value;
        if (value) {
            dividendTracker.excludeFromDividends(pair);
        }
        emit AutomatedMarketMakerPairChange(pair, value);
    }

    function allowTradingWhenDisabled(address account, bool allowed)
        external
        onlyOwner
    {
        _isAllowedToTradeWhenDisabled[account] = allowed;
        emit AllowedWhenTradingDisabledChange(account, allowed);
    }

    function excludeFromFees(address account, bool excluded)
        external
        onlyOwner
    {
        require(
            _isExcludedFromFee[account] != excluded,
            "MYDToken: Account is already the value of 'excluded'"
        );
        _isExcludedFromFee[account] = excluded;
        emit ExcludeFromFeesChange(account, excluded);
    }

    function excludeFromDividends(address account) external onlyOwner {
        dividendTracker.excludeFromDividends(account);
    }

    function removeLimits() external onlyOwner returns (bool) {
        limitsInEffect = false;
        return true;
    }

    function excludeFromMaxTransactionLimit(address account, bool excluded)
        external
        onlyOwner
    {
        require(
            _isExcludedFromMaxTransactionLimit[account] != excluded,
            "MYDToken: Account is already the value of 'excluded'"
        );
        _isExcludedFromMaxTransactionLimit[account] = excluded;
        emit ExcludeFromMaxTransferChange(account, excluded);
    }

    function excludeFromMaxWalletLimit(address account, bool excluded)
        external
        onlyOwner
    {
        require(
            _isExcludedFromMaxWalletLimit[account] != excluded,
            "MYDToken: Account is already the value of 'excluded'"
        );
        _isExcludedFromMaxWalletLimit[account] = excluded;
        emit ExcludeFromMaxWalletChange(account, excluded);
    }

    function setWallets(
        address newLiquidityWallet,
        address newMarketingWallet,
        address newBuyBackWallet
    ) external onlyOwner {
        if (liquidityWallet != newLiquidityWallet) {
            require(
                newLiquidityWallet != address(0),
                "MYDToken: The liquidityWallet cannot be 0"
            );
            emit WalletChange(
                "liquidityWallet",
                newLiquidityWallet,
                liquidityWallet
            );
            liquidityWallet = newLiquidityWallet;
        }
        if (marketingWallet != newMarketingWallet) {
            require(
                newMarketingWallet != address(0),
                "MYDToken: The marketingWallet cannot be 0"
            );
            emit WalletChange(
                "marketingWallet",
                newMarketingWallet,
                marketingWallet
            );
            marketingWallet = newMarketingWallet;
        }
        if (buyBackWallet != newBuyBackWallet) {
            require(
                newBuyBackWallet != address(0),
                "MYDToken: The buyBackWallet cannot be 0"
            );
            emit WalletChange("buyBackWallet", newBuyBackWallet, buyBackWallet);
            buyBackWallet = newBuyBackWallet;
        }
    }

    // Base fees
    function setBaseFeesOnBuy(
        uint8 _liquidityFeeOnBuy,
        uint8 _marketingFeeOnBuy,
        uint8 _buyBackFeeOnBuy,
        uint8 _burnFeeOnBuy,
        uint8 _holdersFeeOnBuy
    ) external onlyOwner {
        _setCustomBuyTaxPeriod(
            _base,
            _liquidityFeeOnBuy,
            _marketingFeeOnBuy,
            _buyBackFeeOnBuy,
            _burnFeeOnBuy,
            _holdersFeeOnBuy
        );
        emit FeeChange(
            "baseFees-Buy",
            _liquidityFeeOnBuy,
            _marketingFeeOnBuy,
            _buyBackFeeOnBuy,
            _burnFeeOnBuy,
            _holdersFeeOnBuy
        );
    }

    function setBaseFeesOnSell(
        uint8 _liquidityFeeOnSell,
        uint8 _marketingFeeOnSell,
        uint8 _buyBackFeeOnSell,
        uint8 _burnFeeOnSell,
        uint8 _holdersFeeOnSell
    ) external onlyOwner {
        _setCustomSellTaxPeriod(
            _base,
            _liquidityFeeOnSell,
            _marketingFeeOnSell,
            _buyBackFeeOnSell,
            _burnFeeOnSell,
            _holdersFeeOnSell
        );
        emit FeeChange(
            "baseFees-Sell",
            _liquidityFeeOnSell,
            _marketingFeeOnSell,
            _buyBackFeeOnSell,
            _burnFeeOnSell,
            _holdersFeeOnSell
        );
    }

    function setUniswapRouter(address newAddress) external onlyOwner {
        require(
            newAddress != address(uniswapV2Router),
            "MYDToken: The router already has that address"
        );
        emit UniswapV2RouterChange(newAddress, address(uniswapV2Router));
        uniswapV2Router = IRouter(newAddress);
        dividendTracker.setUniswapRouter(newAddress);
    }

    function setMaxTransactionAmount(uint256 newValue) external onlyOwner {
        require(
            newValue >= ((totalSupply() * 1) / 1000) / 1e18,
            "Cannot set maxTransactionAmount lower than 0.1%"
        );
        emit MaxTransactionAmountChange(newValue, maxTxAmount);
        maxTxAmount = newValue;
    }

    function setMaxWalletAmount(uint256 newValue) external onlyOwner {
        require(
            newValue >= ((totalSupply() * 5) / 1000) / 1e18,
            "Cannot set maxWallet lower than 0.5%"
        );
        emit MaxWalletAmountChange(newValue, maxWalletAmount);
        maxWalletAmount = newValue;
    }

    function setMinimumTokensBeforeSwap(uint256 newValue) external onlyOwner {
        require(
            newValue != minimumTokensBeforeSwap,
            "MYDToken: Cannot update minimumTokensBeforeSwap to same value"
        );
        emit MinTokenAmountBeforeSwapChange(newValue, minimumTokensBeforeSwap);
        minimumTokensBeforeSwap = newValue;
    }

    function setMinimumTokenBalanceForDividends(uint256 newValue)
        external
        onlyOwner
    {
        dividendTracker.setTokenBalanceForDividends(newValue);
    }

    function claim() external {
        dividendTracker.processAccount(payable(msg.sender), false);
    }

    function claimETHOverflow(uint256 amount) external onlyOwner {
        require(
            amount < address(this).balance,
            "MYDToken: Cannot send more than contract balance"
        );
        (bool success, ) = address(owner()).call{value: amount}("");
        if (success) {
            emit ClaimETHOverflow(amount);
        }
    }

    function burn(uint256 value) external {
        _burn(msg.sender, value);
    }

    // Getters
    function getTotalDividendsDistributed() external view returns (uint256) {
        return dividendTracker.totalDividendsDistributed();
    }

    function withdrawableDividendOf(address account)
        external
        view
        returns (uint256)
    {
        return dividendTracker.withdrawableDividendOf(account);
    }

    function dividendTokenBalanceOf(address account)
        external
        view
        returns (uint256)
    {
        return dividendTracker.balanceOf(account);
    }

    function getNumberOfDividendTokenHolders() external view returns (uint256) {
        return dividendTracker.getNumberOfTokenHolders();
    }

    function getBaseBuyFees()
        external
        view
        returns (
            uint8,
            uint8,
            uint8,
            uint8,
            uint8
        )
    {
        return (
            _base.liquidityFeeOnBuy,
            _base.marketingFeeOnBuy,
            _base.buyBackFeeOnBuy,
            _base.burnFeeOnBuy,
            _base.holdersFeeOnBuy
        );
    }

    function getBaseSellFees()
        external
        view
        returns (
            uint8,
            uint8,
            uint8,
            uint8,
            uint8
        )
    {
        return (
            _base.liquidityFeeOnSell,
            _base.marketingFeeOnSell,
            _base.buyBackFeeOnSell,
            _base.burnFeeOnSell,
            _base.holdersFeeOnSell
        );
    }

    // Main
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        if (amount == 0) {
            super._transfer(from, to, 0);
            return;
        }

        bool isBuyFromLp = automatedMarketMakerPairs[from];
        bool isSelltoLp = automatedMarketMakerPairs[to];

        if (
            !_isAllowedToTradeWhenDisabled[from] &&
            !_isAllowedToTradeWhenDisabled[to]
        ) {
            require(
                isTradingEnabled,
                "MYDToken: Trading is currently disabled."
            );
            if (limitsInEffect) {
                if (
                    !_isExcludedFromMaxTransactionLimit[to] &&
                    !_isExcludedFromMaxTransactionLimit[from]
                ) {
                    require(
                        amount <= maxTxAmount,
                        "MYDToken: Buy amount exceeds the maxTxBuyAmount."
                    );
                }
                if (!_isExcludedFromMaxWalletLimit[to]) {
                    require(
                        (balanceOf(to) + amount) <= maxWalletAmount,
                        "MYDToken: Expected wallet amount exceeds the maxWalletAmount."
                    );
                }
            }
        }

        _adjustTaxes(isBuyFromLp, isSelltoLp);
        bool canSwap = balanceOf(address(this)) >= minimumTokensBeforeSwap;

        if (
            isTradingEnabled &&
            canSwap &&
            !_swapping &&
            _totalFee > 0 &&
            automatedMarketMakerPairs[to] &&
            !_isExcludedFromFee[from] &&
            !_isExcludedFromFee[to]
        ) {
            _swapping = true;
            _swapAndLiquify();
            _swapping = false;
        }

        bool takeFee = !_swapping && isTradingEnabled;

        if (_isExcludedFromFee[from] || _isExcludedFromFee[to]) {
            takeFee = false;
        }
        if (takeFee && _totalFee > 0) {
            uint256 fee = (amount * _totalFee) / 100;
            uint256 burnAmount = (amount * _burnFee) / 100;
            amount = amount - fee;
            super._transfer(from, address(this), fee);

            if (burnAmount > 0) {
                super._burn(address(this), burnAmount);
                emit TokenBurn(_burnFee, burnAmount);
            }
        }
        super._transfer(from, to, amount);

        try
            dividendTracker.setBalance(payable(from), balanceOf(from))
        {} catch {}
        try dividendTracker.setBalance(payable(to), balanceOf(to)) {} catch {}
    }

    function _adjustTaxes(bool isBuyFromLp, bool isSelltoLp) private {
        _liquidityFee = 0;
        _marketingFee = 0;
        _buyBackFee = 0;
        _burnFee = 0;
        _holdersFee = 0;

        if (isBuyFromLp) {
            _liquidityFee = _base.liquidityFeeOnBuy;
            _marketingFee = _base.marketingFeeOnBuy;
            _buyBackFee = _base.buyBackFeeOnBuy;
            _burnFee = _base.burnFeeOnBuy;
            _holdersFee = _base.holdersFeeOnBuy;
        }
        if (isSelltoLp) {
            _liquidityFee = _base.liquidityFeeOnSell;
            _marketingFee = _base.marketingFeeOnSell;
            _buyBackFee = _base.buyBackFeeOnSell;
            _burnFee = _base.burnFeeOnSell;
            _holdersFee = _base.holdersFeeOnSell;
        }
        if (!isSelltoLp && !isBuyFromLp) {
            _liquidityFee = _base.liquidityFeeOnSell;
            _marketingFee = _base.marketingFeeOnSell;
            _buyBackFee = _base.buyBackFeeOnSell;
            _burnFee = _base.burnFeeOnSell;
            _holdersFee = _base.holdersFeeOnSell;
        }
        _totalFee =
            _liquidityFee +
            _marketingFee +
            _buyBackFee +
            _burnFee +
            _holdersFee;
        emit FeesApplied(
            _liquidityFee,
            _marketingFee,
            _buyBackFee,
            _burnFee,
            _holdersFee,
            _totalFee
        );
    }

    function _setCustomSellTaxPeriod(
        CustomTaxPeriod storage map,
        uint8 _liquidityFeeOnSell,
        uint8 _marketingFeeOnSell,
        uint8 _buyBackFeeOnSell,
        uint8 _burnFeeOnSell,
        uint8 _holdersFeeOnSell
    ) private {
        if (map.liquidityFeeOnSell != _liquidityFeeOnSell) {
            emit CustomTaxPeriodChange(
                _liquidityFeeOnSell,
                map.liquidityFeeOnSell,
                "liquidityFeeOnSell",
                map.periodName
            );
            map.liquidityFeeOnSell = _liquidityFeeOnSell;
        }
        if (map.marketingFeeOnSell != _marketingFeeOnSell) {
            emit CustomTaxPeriodChange(
                _marketingFeeOnSell,
                map.marketingFeeOnSell,
                "marketingFeeOnSell",
                map.periodName
            );
            map.marketingFeeOnSell = _marketingFeeOnSell;
        }
        if (map.buyBackFeeOnSell != _buyBackFeeOnSell) {
            emit CustomTaxPeriodChange(
                _buyBackFeeOnSell,
                map.buyBackFeeOnSell,
                "buyBackFeeOnSell",
                map.periodName
            );
            map.buyBackFeeOnSell = _buyBackFeeOnSell;
        }
        if (map.burnFeeOnSell != _burnFeeOnSell) {
            emit CustomTaxPeriodChange(
                _burnFeeOnSell,
                map.burnFeeOnSell,
                "burnFeeOnSell",
                map.periodName
            );
            map.burnFeeOnSell = _burnFeeOnSell;
        }
        if (map.holdersFeeOnSell != _holdersFeeOnSell) {
            emit CustomTaxPeriodChange(
                _holdersFeeOnSell,
                map.holdersFeeOnSell,
                "holdersFeeOnSell",
                map.periodName
            );
            map.holdersFeeOnSell = _holdersFeeOnSell;
        }
    }

    function _setCustomBuyTaxPeriod(
        CustomTaxPeriod storage map,
        uint8 _liquidityFeeOnBuy,
        uint8 _marketingFeeOnBuy,
        uint8 _buyBackFeeOnBuy,
        uint8 _burnFeeOnBuy,
        uint8 _holdersFeeOnBuy
    ) private {
        if (map.liquidityFeeOnBuy != _liquidityFeeOnBuy) {
            emit CustomTaxPeriodChange(
                _liquidityFeeOnBuy,
                map.liquidityFeeOnBuy,
                "liquidityFeeOnBuy",
                map.periodName
            );
            map.liquidityFeeOnBuy = _liquidityFeeOnBuy;
        }
        if (map.marketingFeeOnBuy != _marketingFeeOnBuy) {
            emit CustomTaxPeriodChange(
                _marketingFeeOnBuy,
                map.marketingFeeOnBuy,
                "marketingFeeOnBuy",
                map.periodName
            );
            map.marketingFeeOnBuy = _marketingFeeOnBuy;
        }
        if (map.buyBackFeeOnBuy != _buyBackFeeOnBuy) {
            emit CustomTaxPeriodChange(
                _buyBackFeeOnBuy,
                map.buyBackFeeOnBuy,
                "buyBackFeeOnBuy",
                map.periodName
            );
            map.buyBackFeeOnBuy = _buyBackFeeOnBuy;
        }
        if (map.burnFeeOnBuy != _burnFeeOnBuy) {
            emit CustomTaxPeriodChange(
                _burnFeeOnBuy,
                map.burnFeeOnBuy,
                "burnFeeOnBuy",
                map.periodName
            );
            map.burnFeeOnBuy = _burnFeeOnBuy;
        }
        if (map.holdersFeeOnBuy != _holdersFeeOnBuy) {
            emit CustomTaxPeriodChange(
                _holdersFeeOnBuy,
                map.holdersFeeOnBuy,
                "holdersFeeOnBuy",
                map.periodName
            );
            map.holdersFeeOnBuy = _holdersFeeOnBuy;
        }
    }

    function _swapAndLiquify() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 initialETHBalance = address(this).balance;

        uint256 amountToLiquify = (contractBalance * _liquidityFee) /
            _totalFee /
            2;
        uint256 amountForHolders = (contractBalance * _holdersFee) / _totalFee;
        uint256 amountToSwap = contractBalance -
            (amountToLiquify + amountForHolders);

        _swapTokensForETH(amountToSwap);

        uint256 ETHBalanceAfterSwap = address(this).balance - initialETHBalance;
        uint256 totalETHFee = _totalFee -
            ((_liquidityFee / 2) + _burnFee + _holdersFee);
        uint256 amountETHLiquidity = (ETHBalanceAfterSwap * _liquidityFee) /
            totalETHFee /
            2;
        uint256 amountETHMarketing = (ETHBalanceAfterSwap * _marketingFee) /
            totalETHFee;
        uint256 amountETHBuyBack = ETHBalanceAfterSwap -
            (amountETHLiquidity + amountETHMarketing);

        payable(buyBackWallet).transfer(amountETHBuyBack);
        payable(marketingWallet).transfer(amountETHMarketing);

        if (amountToLiquify > 0) {
            _addLiquidity(amountToLiquify, amountETHLiquidity);
            emit SwapAndLiquify(
                amountToSwap,
                amountETHLiquidity,
                amountToLiquify
            );
        }

        bool success = IERC20(address(this)).transfer(
            address(dividendTracker),
            amountForHolders
        );
        if (success) {
            dividendTracker.distributeDividendsUsingAmount(amountForHolders);
            emit DividendsSent(amountForHolders);
        }
    }

    function _swapTokensForETH(uint256 tokenAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function _addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            liquidityWallet,
            block.timestamp
        );
    }
}

contract MYDTokenDividendTracker is DividendPayingToken {
    using SafeMath for uint256;
    using SafeMathInt for int256;
    using IterableMapping for IterableMapping.Map;

    IterableMapping.Map private tokenHoldersMap;

    mapping(address => bool) public excludedFromDividends;
    mapping(address => uint256) public lastClaimTimes;
    uint256 public claimWait;
    uint256 public minimumTokenBalanceForDividends;

    event ExcludeFromDividends(address indexed account);
    event ClaimWaitUpdated(uint256 indexed newValue, uint256 indexed oldValue);
    event Claim(
        address indexed account,
        uint256 amount,
        bool indexed automatic
    );

    constructor()
        DividendPayingToken("MYD_Dividend_Tracker", "MYD_Dividend_Tracker")
    {
        claimWait = 3600;
        minimumTokenBalanceForDividends = 0 * (10**18);
    }

    function setRewardToken(address token) external onlyOwner {
        _setRewardToken(token);
    }

    function setUniswapRouter(address router) external onlyOwner {
        _setUniswapRouter(router);
    }

    function _transfer(
        address,
        address,
        uint256
    ) internal pure override {
        require(false, "MYD_Dividend_Tracker: No transfers allowed");
    }

    function excludeFromDividends(address account) external onlyOwner {
        require(!excludedFromDividends[account]);
        excludedFromDividends[account] = true;
        _setBalance(account, 0);
        tokenHoldersMap.remove(account);
        emit ExcludeFromDividends(account);
    }

    function setTokenBalanceForDividends(uint256 newValue) external onlyOwner {
        require(
            minimumTokenBalanceForDividends != newValue,
            "MYD_Dividend_Tracker: minimumTokenBalanceForDividends already the value of 'newValue'."
        );
        minimumTokenBalanceForDividends = newValue;
    }

    function getNumberOfTokenHolders() external view returns (uint256) {
        return tokenHoldersMap.keys.length;
    }

    function setBalance(address payable account, uint256 newBalance)
        external
        onlyOwner
    {
        if (excludedFromDividends[account]) {
            return;
        }
        if (newBalance >= minimumTokenBalanceForDividends) {
            _setBalance(account, newBalance);
            tokenHoldersMap.set(account, newBalance);
        } else {
            _setBalance(account, 0);
            tokenHoldersMap.remove(account);
        }
        processAccount(account, true);
    }

    function processAccount(address payable account, bool automatic)
        public
        onlyOwner
        returns (bool)
    {
        uint256 amount = _withdrawDividendOfUser(account);
        if (amount > 0) {
            lastClaimTimes[account] = block.timestamp;
            emit Claim(account, amount, automatic);
            return true;
        }
        return false;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"},{"indexed":true,"internalType":"bool","name":"automatic","type":"bool"}],"name":"Claim","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"newValue","type":"uint256"},{"indexed":true,"internalType":"uint256","name":"oldValue","type":"uint256"}],"name":"ClaimWaitUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"weiAmount","type":"uint256"}],"name":"DividendWithdrawn","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"weiAmount","type":"uint256"}],"name":"DividendsDistributed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"}],"name":"ExcludeFromDividends","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"accumulativeDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"claimWait","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"distributeDividendsUsingAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"dividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromDividends","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"excludedFromDividends","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getNumberOfTokenHolders","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"lastClaimTimes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumTokenBalanceForDividends","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"},{"internalType":"bool","name":"automatic","type":"bool"}],"name":"processAccount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"rewardToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"},{"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"setBalance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"setRewardToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newValue","type":"uint256"}],"name":"setTokenBalanceForDividends","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"router","type":"address"}],"name":"setUniswapRouter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalDividendsDistributed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IRouter","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawDividend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"withdrawableDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"withdrawnDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60806040523480156200001157600080fd5b5060408051808201825260148082527f4d59445f4469766964656e645f547261636b65720000000000000000000000006020808401829052845180860190955291845290830152908181600362000069838262000197565b50600462000078828262000197565b50505060006200008d620000ee60201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35050610e1060125550600060135562000263565b3390565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200011d57607f821691505b6020821081036200013e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200019257600081815260208120601f850160051c810160208610156200016d5750805b601f850160051c820191505b818110156200018e5782815560010162000179565b5050505b505050565b81516001600160401b03811115620001b357620001b3620000f2565b620001cb81620001c4845462000108565b8462000144565b602080601f831160018114620002035760008415620001ea5750858301515b600019600386901b1c1916600185901b1785556200018e565b600085815260208120601f198616915b82811015620002345788860151825594840194600190910190840162000213565b5085821015620002535787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b611be680620002736000396000f3fe6080604052600436106101fd5760003560e01c8063715018a61161010d578063a9059cbb116100a0578063bea9849e1161006f578063bea9849e146105d6578063dd62ed3e146105f6578063e30443bc1461063c578063f2fde38b1461065c578063f7c618c11461067c57600080fd5b8063a9059cbb1461054a578063aafd847a1461056a578063bc4c4b37146105a0578063be10b614146105c057600080fd5b806391b89fba116100dc57806391b89fba146104d557806395d89b41146104f5578063a457c2d71461050a578063a8b9d2401461052a57600080fd5b8063715018a61461046c57806385a6b3ae146104815780638aee8127146104975780638da5cb5b146104b757600080fd5b806327ce0147116101905780634e7b827f1161015f5780634e7b827f146103bb5780636a474002146103eb5780636bf5ecd5146104005780636f2789ec1461042057806370a082311461043657600080fd5b806327ce01471461033f578063313ce5671461035f57806331e79db01461037b578063395093511461039b57600080fd5b80631694505e116101cc5780631694505e146102a557806318160ddd146102dd578063226cfa3d146102f257806323b872dd1461031f57600080fd5b806306fdde0314610209578063095ea7b31461023457806309bbedde14610264578063163c7cef1461028357600080fd5b3661020457005b600080fd5b34801561021557600080fd5b5061021e61069c565b60405161022b919061182d565b60405180910390f35b34801561024057600080fd5b5061025461024f366004611897565b61072e565b604051901515815260200161022b565b34801561027057600080fd5b50600c545b60405190815260200161022b565b34801561028f57600080fd5b506102a361029e3660046118c3565b610745565b005b3480156102b157600080fd5b506009546102c5906001600160a01b031681565b6040516001600160a01b03909116815260200161022b565b3480156102e957600080fd5b50600254610275565b3480156102fe57600080fd5b5061027561030d3660046118dc565b60116020526000908152604090205481565b34801561032b57600080fd5b5061025461033a3660046118f9565b610813565b34801561034b57600080fd5b5061027561035a3660046118dc565b61087c565b34801561036b57600080fd5b506040516012815260200161022b565b34801561038757600080fd5b506102a36103963660046118dc565b6108d8565b3480156103a757600080fd5b506102546103b6366004611897565b6109ff565b3480156103c757600080fd5b506102546103d63660046118dc565b60106020526000908152604090205460ff1681565b3480156103f757600080fd5b506102a3610a35565b34801561040c57600080fd5b506102a361041b3660046118c3565b610a6b565b34801561042c57600080fd5b5061027560125481565b34801561044257600080fd5b506102756104513660046118dc565b6001600160a01b031660009081526020819052604090205490565b34801561047857600080fd5b506102a3610b28565b34801561048d57600080fd5b5061027560075481565b3480156104a357600080fd5b506102a36104b23660046118dc565b610b9c565b3480156104c357600080fd5b506005546001600160a01b03166102c5565b3480156104e157600080fd5b506102756104f03660046118dc565b610bcf565b34801561050157600080fd5b5061021e610bda565b34801561051657600080fd5b50610254610525366004611897565b610be9565b34801561053657600080fd5b506102756105453660046118dc565b610c38565b34801561055657600080fd5b50610254610565366004611897565b610c64565b34801561057657600080fd5b506102756105853660046118dc565b6001600160a01b03166000908152600b602052604090205490565b3480156105ac57600080fd5b506102546105bb366004611948565b610c71565b3480156105cc57600080fd5b5061027560135481565b3480156105e257600080fd5b506102a36105f13660046118dc565b610d1f565b34801561060257600080fd5b50610275610611366004611981565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561064857600080fd5b506102a3610657366004611897565b610d52565b34801561066857600080fd5b506102a36106773660046118dc565b610ebc565b34801561068857600080fd5b506008546102c5906001600160a01b031681565b6060600380546106ab906119af565b80601f01602080910402602001604051908101604052809291908181526020018280546106d7906119af565b80156107245780601f106106f957610100808354040283529160200191610724565b820191906000526020600020905b81548152906001019060200180831161070757829003601f168201915b5050505050905090565b600061073b338484610fa7565b5060015b92915050565b6005546001600160a01b031633146107785760405162461bcd60e51b815260040161076f906119e9565b60405180910390fd5b806013540361080e5760405162461bcd60e51b815260206004820152605660248201527f4d59445f4469766964656e645f547261636b65723a206d696e696d756d546f6b60448201527f656e42616c616e6365466f724469766964656e647320616c726561647920746860648201527532903b30b63ab29037b31013b732bbab30b63ab2939760511b608482015260a40161076f565b601355565b60006108208484846110cb565b610872843361086d85604051806060016040528060288152602001611b64602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611126565b610fa7565b5060019392505050565b6001600160a01b0381166000908152600a602090815260408083205491839052822054600654600160801b926108ce926108c9926108c3916108be9190611160565b6111e9565b906111f9565b611237565b61073f9190611a34565b6005546001600160a01b031633146109025760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b03811660009081526010602052604090205460ff161561092857600080fd5b6001600160a01b0381166000908152601060205260408120805460ff1916600117905561095690829061124a565b60405163131836e760e21b8152600c60048201526001600160a01b0382166024820152735991cf18c86d85ce263491be9f054c5b3ae5bb6290634c60db9c9060440160006040518083038186803b1580156109b057600080fd5b505af41580156109c4573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161073b91859061086d90866112af565b6005546001600160a01b03163314610a5f5760405162461bcd60e51b815260040161076f906119e9565b610a683361130e565b50565b6005546001600160a01b03163314610a955760405162461bcd60e51b815260040161076f906119e9565b6000610aa060025490565b11610aaa57600080fd5b8015610a6857610add610abc60025490565b610aca83600160801b611160565b610ad49190611a34565b600654906112af565b60065560405181815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600754610b2290826112af565b60075550565b6005546001600160a01b03163314610b525760405162461bcd60e51b815260040161076f906119e9565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610bc65760405162461bcd60e51b815260040161076f906119e9565b610a6881611473565b600061073f82610c38565b6060600480546106ab906119af565b600061073b338461086d85604051806060016040528060258152602001611b8c602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611126565b6001600160a01b0381166000908152600b602052604081205461073f90610c5e8461087c565b906114bf565b600061073b3384846110cb565b6005546000906001600160a01b03163314610c9e5760405162461bcd60e51b815260040161076f906119e9565b6000610ca98461130e565b90508015610d15576001600160a01b038416600081815260116020526040908190204290555184151591907fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09290610d039085815260200190565b60405180910390a3600191505061073f565b5060009392505050565b6005546001600160a01b03163314610d495760405162461bcd60e51b815260040161076f906119e9565b610a6881611501565b6005546001600160a01b03163314610d7c5760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b03821660009081526010602052604090205460ff16610eb8576013548110610e2d57610daf828261124a565b604051632f0ad01760e21b8152600c60048201526001600160a01b038316602482015260448101829052735991cf18c86d85ce263491be9f054c5b3ae5bb629063bc2b405c9060640160006040518083038186803b158015610e1057600080fd5b505af4158015610e24573d6000803e3d6000fd5b50505050610eab565b610e3882600061124a565b60405163131836e760e21b8152600c60048201526001600160a01b0383166024820152735991cf18c86d85ce263491be9f054c5b3ae5bb6290634c60db9c9060440160006040518083038186803b158015610e9257600080fd5b505af4158015610ea6573d6000803e3d6000fd5b505050505b610eb6826001610c71565b505b5050565b6005546001600160a01b03163314610ee65760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b038116610f4b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161076f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166110095760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161076f565b6001600160a01b03821661106a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161076f565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60405162461bcd60e51b815260206004820152602a60248201527f4d59445f4469766964656e645f547261636b65723a204e6f207472616e7366656044820152691c9cc8185b1b1bddd95960b21b606482015260840161076f565b6000818484111561114a5760405162461bcd60e51b815260040161076f919061182d565b5060006111578486611a56565b95945050505050565b6000826000036111725750600061073f565b600061117e8385611a6d565b90508261118b8583611a34565b146111e25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161076f565b9392505050565b6000818181121561073f57600080fd5b6000806112068385611a8c565b9050600083121580156112195750838112155b8061122e575060008312801561122e57508381125b6111e257600080fd5b60008082121561124657600080fd5b5090565b6001600160a01b0382166000908152602081905260409020548082111561128957600061127783836114bf565b9050611283848261154d565b50610eb6565b80821015610eb657600061129d82846114bf565b90506112a984826115b1565b50505050565b6000806112bc8385611acd565b9050838110156111e25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161076f565b60008061131a83610c38565b9050801561146a576001600160a01b0383166000908152600b602052604090205461134590826112af565b6001600160a01b0384166000818152600b6020526040908190209290925590517fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d906113949084815260200190565b60405180910390a260085460405163a9059cbb60e01b81526001600160a01b03858116600483015260248201849052600092169063a9059cbb906044016020604051808303816000875af11580156113f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114149190611ae5565b905080611463576001600160a01b0384166000908152600b602052604090205461143e90836114bf565b6001600160a01b039094166000908152600b6020526040812094909455509192915050565b5092915050565b50600092915050565b6005546001600160a01b0316331461149d5760405162461bcd60e51b815260040161076f906119e9565b600880546001600160a01b0319166001600160a01b0392909216919091179055565b60006111e283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611126565b6005546001600160a01b0316331461152b5760405162461bcd60e51b815260040161076f906119e9565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b61155782826115f5565b6115916115726108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906116e0565b6001600160a01b039092166000908152600a602052604090209190915550565b6115bb828261171d565b6115916115d66108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906111f9565b6001600160a01b03821661164b5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640161076f565b61165760008383610eb6565b60025461166490826112af565b6002556001600160a01b03821660009081526020819052604090205461168a90826112af565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6000806116ed8385611b02565b9050600083121580156117005750838113155b8061122e575060008312801561122e57508381136111e257600080fd5b6001600160a01b03821661177d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161076f565b61178982600083610eb6565b6117c681604051806060016040528060228152602001611b42602291396001600160a01b0385166000908152602081905260409020549190611126565b6001600160a01b0383166000908152602081905260409020556002546117ec90826114bf565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020016116d4565b600060208083528351808285015260005b8181101561185a5785810183015185820160400152820161183e565b8181111561186c576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a6857600080fd5b600080604083850312156118aa57600080fd5b82356118b581611882565b946020939093013593505050565b6000602082840312156118d557600080fd5b5035919050565b6000602082840312156118ee57600080fd5b81356111e281611882565b60008060006060848603121561190e57600080fd5b833561191981611882565b9250602084013561192981611882565b929592945050506040919091013590565b8015158114610a6857600080fd5b6000806040838503121561195b57600080fd5b823561196681611882565b915060208301356119768161193a565b809150509250929050565b6000806040838503121561199457600080fd5b823561199f81611882565b9150602083013561197681611882565b600181811c908216806119c357607f821691505b6020821081036119e357634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082611a5157634e487b7160e01b600052601260045260246000fd5b500490565b600082821015611a6857611a68611a1e565b500390565b6000816000190483118215151615611a8757611a87611a1e565b500290565b600080821280156001600160ff1b0384900385131615611aae57611aae611a1e565b600160ff1b8390038412811615611ac757611ac7611a1e565b50500190565b60008219821115611ae057611ae0611a1e565b500190565b600060208284031215611af757600080fd5b81516111e28161193a565b60008083128015600160ff1b850184121615611b2057611b20611a1e565b6001600160ff1b0384018313811615611b3b57611b3b611a1e565b5050039056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220c95b24dc0a911d5c57aef18f4b86e735ccae2b3f976d624f81a45ab365bee28764736f6c634300080f0033

Deployed Bytecode

0x6080604052600436106101fd5760003560e01c8063715018a61161010d578063a9059cbb116100a0578063bea9849e1161006f578063bea9849e146105d6578063dd62ed3e146105f6578063e30443bc1461063c578063f2fde38b1461065c578063f7c618c11461067c57600080fd5b8063a9059cbb1461054a578063aafd847a1461056a578063bc4c4b37146105a0578063be10b614146105c057600080fd5b806391b89fba116100dc57806391b89fba146104d557806395d89b41146104f5578063a457c2d71461050a578063a8b9d2401461052a57600080fd5b8063715018a61461046c57806385a6b3ae146104815780638aee8127146104975780638da5cb5b146104b757600080fd5b806327ce0147116101905780634e7b827f1161015f5780634e7b827f146103bb5780636a474002146103eb5780636bf5ecd5146104005780636f2789ec1461042057806370a082311461043657600080fd5b806327ce01471461033f578063313ce5671461035f57806331e79db01461037b578063395093511461039b57600080fd5b80631694505e116101cc5780631694505e146102a557806318160ddd146102dd578063226cfa3d146102f257806323b872dd1461031f57600080fd5b806306fdde0314610209578063095ea7b31461023457806309bbedde14610264578063163c7cef1461028357600080fd5b3661020457005b600080fd5b34801561021557600080fd5b5061021e61069c565b60405161022b919061182d565b60405180910390f35b34801561024057600080fd5b5061025461024f366004611897565b61072e565b604051901515815260200161022b565b34801561027057600080fd5b50600c545b60405190815260200161022b565b34801561028f57600080fd5b506102a361029e3660046118c3565b610745565b005b3480156102b157600080fd5b506009546102c5906001600160a01b031681565b6040516001600160a01b03909116815260200161022b565b3480156102e957600080fd5b50600254610275565b3480156102fe57600080fd5b5061027561030d3660046118dc565b60116020526000908152604090205481565b34801561032b57600080fd5b5061025461033a3660046118f9565b610813565b34801561034b57600080fd5b5061027561035a3660046118dc565b61087c565b34801561036b57600080fd5b506040516012815260200161022b565b34801561038757600080fd5b506102a36103963660046118dc565b6108d8565b3480156103a757600080fd5b506102546103b6366004611897565b6109ff565b3480156103c757600080fd5b506102546103d63660046118dc565b60106020526000908152604090205460ff1681565b3480156103f757600080fd5b506102a3610a35565b34801561040c57600080fd5b506102a361041b3660046118c3565b610a6b565b34801561042c57600080fd5b5061027560125481565b34801561044257600080fd5b506102756104513660046118dc565b6001600160a01b031660009081526020819052604090205490565b34801561047857600080fd5b506102a3610b28565b34801561048d57600080fd5b5061027560075481565b3480156104a357600080fd5b506102a36104b23660046118dc565b610b9c565b3480156104c357600080fd5b506005546001600160a01b03166102c5565b3480156104e157600080fd5b506102756104f03660046118dc565b610bcf565b34801561050157600080fd5b5061021e610bda565b34801561051657600080fd5b50610254610525366004611897565b610be9565b34801561053657600080fd5b506102756105453660046118dc565b610c38565b34801561055657600080fd5b50610254610565366004611897565b610c64565b34801561057657600080fd5b506102756105853660046118dc565b6001600160a01b03166000908152600b602052604090205490565b3480156105ac57600080fd5b506102546105bb366004611948565b610c71565b3480156105cc57600080fd5b5061027560135481565b3480156105e257600080fd5b506102a36105f13660046118dc565b610d1f565b34801561060257600080fd5b50610275610611366004611981565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561064857600080fd5b506102a3610657366004611897565b610d52565b34801561066857600080fd5b506102a36106773660046118dc565b610ebc565b34801561068857600080fd5b506008546102c5906001600160a01b031681565b6060600380546106ab906119af565b80601f01602080910402602001604051908101604052809291908181526020018280546106d7906119af565b80156107245780601f106106f957610100808354040283529160200191610724565b820191906000526020600020905b81548152906001019060200180831161070757829003601f168201915b5050505050905090565b600061073b338484610fa7565b5060015b92915050565b6005546001600160a01b031633146107785760405162461bcd60e51b815260040161076f906119e9565b60405180910390fd5b806013540361080e5760405162461bcd60e51b815260206004820152605660248201527f4d59445f4469766964656e645f547261636b65723a206d696e696d756d546f6b60448201527f656e42616c616e6365466f724469766964656e647320616c726561647920746860648201527532903b30b63ab29037b31013b732bbab30b63ab2939760511b608482015260a40161076f565b601355565b60006108208484846110cb565b610872843361086d85604051806060016040528060288152602001611b64602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611126565b610fa7565b5060019392505050565b6001600160a01b0381166000908152600a602090815260408083205491839052822054600654600160801b926108ce926108c9926108c3916108be9190611160565b6111e9565b906111f9565b611237565b61073f9190611a34565b6005546001600160a01b031633146109025760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b03811660009081526010602052604090205460ff161561092857600080fd5b6001600160a01b0381166000908152601060205260408120805460ff1916600117905561095690829061124a565b60405163131836e760e21b8152600c60048201526001600160a01b0382166024820152735991cf18c86d85ce263491be9f054c5b3ae5bb6290634c60db9c9060440160006040518083038186803b1580156109b057600080fd5b505af41580156109c4573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161073b91859061086d90866112af565b6005546001600160a01b03163314610a5f5760405162461bcd60e51b815260040161076f906119e9565b610a683361130e565b50565b6005546001600160a01b03163314610a955760405162461bcd60e51b815260040161076f906119e9565b6000610aa060025490565b11610aaa57600080fd5b8015610a6857610add610abc60025490565b610aca83600160801b611160565b610ad49190611a34565b600654906112af565b60065560405181815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600754610b2290826112af565b60075550565b6005546001600160a01b03163314610b525760405162461bcd60e51b815260040161076f906119e9565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610bc65760405162461bcd60e51b815260040161076f906119e9565b610a6881611473565b600061073f82610c38565b6060600480546106ab906119af565b600061073b338461086d85604051806060016040528060258152602001611b8c602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611126565b6001600160a01b0381166000908152600b602052604081205461073f90610c5e8461087c565b906114bf565b600061073b3384846110cb565b6005546000906001600160a01b03163314610c9e5760405162461bcd60e51b815260040161076f906119e9565b6000610ca98461130e565b90508015610d15576001600160a01b038416600081815260116020526040908190204290555184151591907fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09290610d039085815260200190565b60405180910390a3600191505061073f565b5060009392505050565b6005546001600160a01b03163314610d495760405162461bcd60e51b815260040161076f906119e9565b610a6881611501565b6005546001600160a01b03163314610d7c5760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b03821660009081526010602052604090205460ff16610eb8576013548110610e2d57610daf828261124a565b604051632f0ad01760e21b8152600c60048201526001600160a01b038316602482015260448101829052735991cf18c86d85ce263491be9f054c5b3ae5bb629063bc2b405c9060640160006040518083038186803b158015610e1057600080fd5b505af4158015610e24573d6000803e3d6000fd5b50505050610eab565b610e3882600061124a565b60405163131836e760e21b8152600c60048201526001600160a01b0383166024820152735991cf18c86d85ce263491be9f054c5b3ae5bb6290634c60db9c9060440160006040518083038186803b158015610e9257600080fd5b505af4158015610ea6573d6000803e3d6000fd5b505050505b610eb6826001610c71565b505b5050565b6005546001600160a01b03163314610ee65760405162461bcd60e51b815260040161076f906119e9565b6001600160a01b038116610f4b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161076f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166110095760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161076f565b6001600160a01b03821661106a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161076f565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60405162461bcd60e51b815260206004820152602a60248201527f4d59445f4469766964656e645f547261636b65723a204e6f207472616e7366656044820152691c9cc8185b1b1bddd95960b21b606482015260840161076f565b6000818484111561114a5760405162461bcd60e51b815260040161076f919061182d565b5060006111578486611a56565b95945050505050565b6000826000036111725750600061073f565b600061117e8385611a6d565b90508261118b8583611a34565b146111e25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161076f565b9392505050565b6000818181121561073f57600080fd5b6000806112068385611a8c565b9050600083121580156112195750838112155b8061122e575060008312801561122e57508381125b6111e257600080fd5b60008082121561124657600080fd5b5090565b6001600160a01b0382166000908152602081905260409020548082111561128957600061127783836114bf565b9050611283848261154d565b50610eb6565b80821015610eb657600061129d82846114bf565b90506112a984826115b1565b50505050565b6000806112bc8385611acd565b9050838110156111e25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161076f565b60008061131a83610c38565b9050801561146a576001600160a01b0383166000908152600b602052604090205461134590826112af565b6001600160a01b0384166000818152600b6020526040908190209290925590517fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d906113949084815260200190565b60405180910390a260085460405163a9059cbb60e01b81526001600160a01b03858116600483015260248201849052600092169063a9059cbb906044016020604051808303816000875af11580156113f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114149190611ae5565b905080611463576001600160a01b0384166000908152600b602052604090205461143e90836114bf565b6001600160a01b039094166000908152600b6020526040812094909455509192915050565b5092915050565b50600092915050565b6005546001600160a01b0316331461149d5760405162461bcd60e51b815260040161076f906119e9565b600880546001600160a01b0319166001600160a01b0392909216919091179055565b60006111e283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611126565b6005546001600160a01b0316331461152b5760405162461bcd60e51b815260040161076f906119e9565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b61155782826115f5565b6115916115726108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906116e0565b6001600160a01b039092166000908152600a602052604090209190915550565b6115bb828261171d565b6115916115d66108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906111f9565b6001600160a01b03821661164b5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640161076f565b61165760008383610eb6565b60025461166490826112af565b6002556001600160a01b03821660009081526020819052604090205461168a90826112af565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6000806116ed8385611b02565b9050600083121580156117005750838113155b8061122e575060008312801561122e57508381136111e257600080fd5b6001600160a01b03821661177d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161076f565b61178982600083610eb6565b6117c681604051806060016040528060228152602001611b42602291396001600160a01b0385166000908152602081905260409020549190611126565b6001600160a01b0383166000908152602081905260409020556002546117ec90826114bf565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020016116d4565b600060208083528351808285015260005b8181101561185a5785810183015185820160400152820161183e565b8181111561186c576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610a6857600080fd5b600080604083850312156118aa57600080fd5b82356118b581611882565b946020939093013593505050565b6000602082840312156118d557600080fd5b5035919050565b6000602082840312156118ee57600080fd5b81356111e281611882565b60008060006060848603121561190e57600080fd5b833561191981611882565b9250602084013561192981611882565b929592945050506040919091013590565b8015158114610a6857600080fd5b6000806040838503121561195b57600080fd5b823561196681611882565b915060208301356119768161193a565b809150509250929050565b6000806040838503121561199457600080fd5b823561199f81611882565b9150602083013561197681611882565b600181811c908216806119c357607f821691505b6020821081036119e357634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082611a5157634e487b7160e01b600052601260045260246000fd5b500490565b600082821015611a6857611a68611a1e565b500390565b6000816000190483118215151615611a8757611a87611a1e565b500290565b600080821280156001600160ff1b0384900385131615611aae57611aae611a1e565b600160ff1b8390038412811615611ac757611ac7611a1e565b50500190565b60008219821115611ae057611ae0611a1e565b500190565b600060208284031215611af757600080fd5b81516111e28161193a565b60008083128015600160ff1b850184121615611b2057611b20611a1e565b6001600160ff1b0384018313811615611b3b57611b3b611a1e565b5050039056fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220c95b24dc0a911d5c57aef18f4b86e735ccae2b3f976d624f81a45ab365bee28764736f6c634300080f0033

Libraries Used


Deployed Bytecode Sourcemap

45421:2981:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10045:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;11100:210;;;;;;;;;;-1:-1:-1;11100:210:0;;;;;:::i;:::-;;:::i;:::-;;;1237:14:1;;1230:22;1212:41;;1200:2;1185:18;11100:210:0;1072:187:1;47359:120:0;;;;;;;;;;-1:-1:-1;47444:15:0;:27;47359:120;;;1410:25:1;;;1398:2;1383:18;47359:120:0;1264:177:1;47026:325:0;;;;;;;;;;-1:-1:-1;47026:325:0;;;;;:::i;:::-;;:::i;:::-;;14899:30;;;;;;;;;;-1:-1:-1;14899:30:0;;;;-1:-1:-1;;;;;14899:30:0;;;;;;-1:-1:-1;;;;;1810:32:1;;;1792:51;;1780:2;1765:18;14899:30:0;1631:218:1;10366:108:0;;;;;;;;;;-1:-1:-1;10454:12:0;;10366:108;;45718:49;;;;;;;;;;-1:-1:-1;45718:49:0;;;;;:::i;:::-;;;;;;;;;;;;;;11318:454;;;;;;;;;;-1:-1:-1;11318:454:0;;;;;:::i;:::-;;:::i;17184:372::-;;;;;;;;;;-1:-1:-1;17184:372:0;;;;;:::i;:::-;;:::i;10265:93::-;;;;;;;;;;-1:-1:-1;10265:93:0;;10348:2;2709:36:1;;2697:2;2682:18;10265:93:0;2567:184:1;46724:294:0;;;;;;;;;;-1:-1:-1;46724:294:0;;;;;:::i;:::-;;:::i;11780:300::-;;;;;;;;;;-1:-1:-1;11780:300:0;;;;;:::i;:::-;;:::i;45658:53::-;;;;;;;;;;-1:-1:-1;45658:53:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;15661:125;;;;;;;;;;;;;:::i;15212:441::-;;;;;;;;;;-1:-1:-1;15212:441:0;;;;;:::i;:::-;;:::i;45774:24::-;;;;;;;;;;;;;;;;10482:177;;;;;;;;;;-1:-1:-1;10482:177:0;;;;;:::i;:::-;-1:-1:-1;;;;;10633:18:0;10601:7;10633:18;;;;;;;;;;;;10482:177;9164:148;;;;;;;;;;;;;:::i;14819:40::-;;;;;;;;;;;;;;;;46314:99;;;;;;;;;;-1:-1:-1;46314:99:0;;;;;:::i;:::-;;:::i;8950:79::-;;;;;;;;;;-1:-1:-1;9015:6:0;;-1:-1:-1;;;;;9015:6:0;8950:79;;16636:131;;;;;;;;;;-1:-1:-1;16636:131:0;;;;;:::i;:::-;;:::i;10153:104::-;;;;;;;;;;;;;:::i;12088:400::-;;;;;;;;;;-1:-1:-1;12088:400:0;;;;;:::i;:::-;;:::i;16775:216::-;;;;;;;;;;-1:-1:-1;16775:216:0;;;;;:::i;:::-;;:::i;10667:::-;;;;;;;;;;-1:-1:-1;10667:216:0;;;;;:::i;:::-;;:::i;16999:177::-;;;;;;;;;;-1:-1:-1;16999:177:0;;;;;:::i;:::-;-1:-1:-1;;;;;17142:26:0;17110:7;17142:26;;;:18;:26;;;;;;;16999:177;48006:393;;;;;;;;;;-1:-1:-1;48006:393:0;;;;;:::i;:::-;;:::i;45805:46::-;;;;;;;;;;;;;;;;46421:105;;;;;;;;;;-1:-1:-1;46421:105:0;;;;;:::i;:::-;;:::i;10891:201::-;;;;;;;;;;-1:-1:-1;10891:201:0;;;;;:::i;:::-;-1:-1:-1;;;;;11057:18:0;;;11025:7;11057:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;10891:201;47487:511;;;;;;;;;;-1:-1:-1;47487:511:0;;;;;:::i;:::-;;:::i;9320:281::-;;;;;;;;;;-1:-1:-1;9320:281:0;;;;;:::i;:::-;;:::i;14866:26::-;;;;;;;;;;-1:-1:-1;14866:26:0;;;;-1:-1:-1;;;;;14866:26:0;;;10045:100;10099:13;10132:5;10125:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10045:100;:::o;11100:210::-;11219:4;11241:39;8338:10;11264:7;11273:6;11241:8;:39::i;:::-;-1:-1:-1;11298:4:0;11100:210;;;;;:::o;47026:325::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;;;;;;;;;47168:8:::1;47133:31;;:43:::0;47111:179:::1;;;::::0;-1:-1:-1;;;47111:179:0;;5151:2:1;47111:179:0::1;::::0;::::1;5133:21:1::0;5190:2;5170:18;;;5163:30;5229:34;5209:18;;;5202:62;5300:34;5280:18;;;5273:62;-1:-1:-1;;;5351:19:1;;;5344:53;5414:19;;47111:179:0::1;4949:490:1::0;47111:179:0::1;47301:31;:42:::0;47026:325::o;11318:454::-;11458:4;11475:36;11485:6;11493:9;11504:6;11475:9;:36::i;:::-;11522:220;11545:6;8338:10;11593:138;11649:6;11593:138;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;11593:19:0;;;;;;:11;:19;;;;;;;;8338:10;11593:33;;;;;;;;;;:37;:138::i;:::-;11522:8;:220::i;:::-;-1:-1:-1;11760:4:0;11318:454;;;;;:::o;17184:372::-;-1:-1:-1;;;;;17465:36:0;;17298:7;17465:36;;;:28;:36;;;;;;;;;10633:18;;;;;;;17343:25;;-1:-1:-1;;;14757:6:0;17343:193;;:159;;:99;;:66;;:25;:47;:66::i;:::-;:97;:99::i;:::-;:121;;:159::i;:::-;:191;:193::i;:::-;:205;;;;:::i;46724:294::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;46810:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;46809:31;46801:40;;;::::0;::::1;;-1:-1:-1::0;;;;;46852:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;:37;;-1:-1:-1;;46852:37:0::1;46885:4;46852:37;::::0;;46900:23:::1;::::0;46874:7;;46900:11:::1;:23::i;:::-;46934:31;::::0;-1:-1:-1;;;46934:31:0;;:15:::1;:31;::::0;::::1;6001:25:1::0;-1:-1:-1;;;;;6062:32:1;;6042:18;;;6035:60;46934:22:0::1;::::0;::::1;::::0;5974:18:1;;46934:31:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;46981:29:0::1;::::0;-1:-1:-1;;;;;46981:29:0;::::1;::::0;-1:-1:-1;46981:29:0::1;::::0;-1:-1:-1;46981:29:0;;::::1;46724:294:::0;:::o;11780:300::-;8338:10;11895:4;11989:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11989:34:0;;;;;;;;;;11895:4;;11917:133;;11967:7;;11989:50;;12028:10;11989:38;:50::i;15661:125::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;15734:44:::1;15766:10;15734:23;:44::i;:::-;;15661:125::o:0;15212:441::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;15320:1:::1;15304:13;10454:12:::0;;;10366:108;15304:13:::1;:17;15296:26;;;::::0;::::1;;15337:10:::0;;15333:313:::1;;15392:102;15466:13;10454:12:::0;;;10366:108;15466:13:::1;15440:23;15441:6:::0;-1:-1:-1;;;15440:12:0::1;:23::i;:::-;:39;;;;:::i;:::-;15392:25;::::0;;:29:::1;:102::i;:::-;15364:25;:130:::0;15514:40:::1;::::0;1410:25:1;;;15535:10:0::1;::::0;15514:40:::1;::::0;1398:2:1;1383:18;15514:40:0::1;;;;;;;15597:25;::::0;:37:::1;::::0;15627:6;15597:29:::1;:37::i;:::-;15569:25;:65:::0;15212:441;:::o;9164:148::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;9255:6:::1;::::0;9234:40:::1;::::0;9271:1:::1;::::0;-1:-1:-1;;;;;9255:6:0::1;::::0;9234:40:::1;::::0;9271:1;;9234:40:::1;9285:6;:19:::0;;-1:-1:-1;;;;;;9285:19:0::1;::::0;;9164:148::o;46314:99::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;46383:22:::1;46399:5;46383:15;:22::i;16636:131::-:0;16702:7;16729:30;16752:6;16729:22;:30::i;10153:104::-;10209:13;10242:7;10235:14;;;;;:::i;12088:400::-;12208:4;12230:228;8338:10;12280:7;12302:145;12359:15;12302:145;;;;;;;;;;;;;;;;;8338:10;12302:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12302:34:0;;;;;;;;;;;;:38;:145::i;16775:216::-;-1:-1:-1;;;;;16956:26:0;;16889:7;16956:26;;;:18;:26;;;;;;16921:62;;:30;16975:6;16921:22;:30::i;:::-;:34;;:62::i;10667:216::-;10789:4;10811:42;8338:10;10835:9;10846:6;10811:9;:42::i;48006:393::-;9077:6;;48124:4;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;48146:14:::1;48163:32;48187:7;48163:23;:32::i;:::-;48146:49:::0;-1:-1:-1;48210:10:0;;48206:163:::1;;-1:-1:-1::0;;;;;48237:23:0;::::1;;::::0;;;:14:::1;:23;::::0;;;;;;48263:15:::1;48237:41:::0;;48298:33;;::::1;;::::0;48237:23;48298:33:::1;::::0;::::1;::::0;48313:6;1410:25:1;;1398:2;1383:18;;1264:177;48298:33:0::1;;;;;;;;48353:4;48346:11;;;;;48206:163;-1:-1:-1::0;48386:5:0::1;::::0;48006:393;-1:-1:-1;;;48006:393:0:o;46421:105::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;46493:25:::1;46511:6;46493:17;:25::i;47487:511::-:0;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;47609:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;47656:7;47605:69;47702:31;;47688:10;:45;47684:267;;47750:32;47762:7;47771:10;47750:11;:32::i;:::-;47797:40;::::0;-1:-1:-1;;;47797:40:0;;:15:::1;:40;::::0;::::1;6345:25:1::0;-1:-1:-1;;;;;6406:32:1;;6386:18;;;6379:60;6455:18;;;6448:34;;;47797:19:0::1;::::0;::::1;::::0;6318:18:1;;47797:40:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;47684:267;;;47870:23;47882:7;47891:1;47870:11;:23::i;:::-;47908:31;::::0;-1:-1:-1;;;47908:31:0;;:15:::1;:31;::::0;::::1;6001:25:1::0;-1:-1:-1;;;;;6062:32:1;;6042:18;;;6035:60;47908:22:0::1;::::0;::::1;::::0;5974:18:1;;47908:31:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;47684:267;47961:29;47976:7;47985:4;47961:14;:29::i;:::-;;9147:1;47487:511:::0;;:::o;9320:281::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9423:22:0;::::1;9401:110;;;::::0;-1:-1:-1;;;9401:110:0;;7011:2:1;9401:110:0::1;::::0;::::1;6993:21:1::0;7050:2;7030:18;;;7023:30;7089:34;7069:18;;;7062:62;-1:-1:-1;;;7140:18:1;;;7133:36;7186:19;;9401:110:0::1;6809:402:1::0;9401:110:0::1;9548:6;::::0;9527:38:::1;::::0;-1:-1:-1;;;;;9527:38:0;;::::1;::::0;9548:6:::1;::::0;9527:38:::1;::::0;9548:6:::1;::::0;9527:38:::1;9576:6;:17:::0;;-1:-1:-1;;;;;;9576:17:0::1;-1:-1:-1::0;;;;;9576:17:0;;;::::1;::::0;;;::::1;::::0;;9320:281::o;13951:378::-;-1:-1:-1;;;;;14087:19:0;;14079:68;;;;-1:-1:-1;;;14079:68:0;;7418:2:1;14079:68:0;;;7400:21:1;7457:2;7437:18;;;7430:30;7496:34;7476:18;;;7469:62;-1:-1:-1;;;7547:18:1;;;7540:34;7591:19;;14079:68:0;7216:400:1;14079:68:0;-1:-1:-1;;;;;14166:21:0;;14158:68;;;;-1:-1:-1;;;14158:68:0;;7823:2:1;14158:68:0;;;7805:21:1;7862:2;7842:18;;;7835:30;7901:34;7881:18;;;7874:62;-1:-1:-1;;;7952:18:1;;;7945:32;7994:19;;14158:68:0;7621:398:1;14158:68:0;-1:-1:-1;;;;;14237:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14289:32;;1410:25:1;;;14289:32:0;;1383:18:1;14289:32:0;;;;;;;13951:378;;;:::o;46534:182::-;46648:60;;-1:-1:-1;;;46648:60:0;;8226:2:1;46648:60:0;;;8208:21:1;8265:2;8245:18;;;8238:30;8304:34;8284:18;;;8277:62;-1:-1:-1;;;8355:18:1;;;8348:40;8405:19;;46648:60:0;8024:406:1;3442:226:0;3562:7;3598:12;3590:6;;;;3582:29;;;;-1:-1:-1;;;3582:29:0;;;;;;;;:::i;:::-;-1:-1:-1;3622:9:0;3634:5;3638:1;3634;:5;:::i;:::-;3622:17;3442:226;-1:-1:-1;;;;;3442:226:0:o;3676:471::-;3734:7;3979:1;3984;3979:6;3975:47;;-1:-1:-1;4009:1:0;4002:8;;3975:47;4034:9;4046:5;4050:1;4046;:5;:::i;:::-;4034:17;-1:-1:-1;4079:1:0;4070:5;4074:1;4034:17;4070:5;:::i;:::-;:10;4062:56;;;;-1:-1:-1;;;4062:56:0;;8940:2:1;4062:56:0;;;8922:21:1;8979:2;8959:18;;;8952:30;9018:34;8998:18;;;8991:62;-1:-1:-1;;;9069:18:1;;;9062:31;9110:19;;4062:56:0;8738:397:1;4062:56:0;4138:1;3676:471;-1:-1:-1;;;3676:471:0:o;6357:148::-;6413:6;6450:1;6471:6;;;;6463:15;;;;;5874:176;5930:6;;5960:5;5964:1;5960;:5;:::i;:::-;5949:16;;5990:1;5985;:6;;:16;;;;;6000:1;5995;:6;;5985:16;5984:38;;;;6011:1;6007;:5;:14;;;;;6020:1;6016;:5;6007:14;5976:47;;;;;6195:127;6251:7;6284:1;6279;:6;;6271:15;;;;;;-1:-1:-1;6312:1:0;6195:127::o;18657:449::-;-1:-1:-1;;;;;10633:18:0;;18735:22;10633:18;;;;;;;;;;;18793:27;;;18789:310;;;18837:18;18858:30;:10;18873:14;18858;:30::i;:::-;18837:51;;18903:26;18909:7;18918:10;18903:5;:26::i;:::-;18822:119;18789:310;;;18964:14;18951:10;:27;18947:152;;;18995:18;19016:30;:14;19035:10;19016:18;:30::i;:::-;18995:51;;19061:26;19067:7;19076:10;19061:5;:26::i;:::-;18980:119;18724:382;18657:449;;:::o;3109:181::-;3167:7;;3199:5;3203:1;3199;:5;:::i;:::-;3187:17;;3228:1;3223;:6;;3215:46;;;;-1:-1:-1;;;3215:46:0;;9745:2:1;3215:46:0;;;9727:21:1;9784:2;9764:18;;;9757:30;9823:29;9803:18;;;9796:57;9870:18;;3215:46:0;9543:351:1;15794:834:0;15885:7;15910:29;15942:28;15965:4;15942:22;:28::i;:::-;15910:60;-1:-1:-1;15985:25:0;;15981:621;;-1:-1:-1;;;;;16054:24:0;;;;;;:18;:24;;;;;;:83;;16101:21;16054:28;:83::i;:::-;-1:-1:-1;;;;;16027:24:0;;;;;;:18;:24;;;;;;;:110;;;;16157:46;;;;;;16181:21;1410:25:1;;1398:2;1383:18;;1264:177;16157:46:0;;;;;;;;16240:11;;16233:106;;-1:-1:-1;;;16233:106:0;;-1:-1:-1;;;;;10099:32:1;;;16233:106:0;;;10081:51:1;10148:18;;;10141:34;;;16218:12:0;;16240:11;;16233:28;;10054:18:1;;16233:106:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16218:121;;16359:7;16354:194;;-1:-1:-1;;;;;16414:24:0;;;;;;:18;:24;;;;;;:91;;16465:21;16414:28;:91::i;:::-;-1:-1:-1;;;;;16387:24:0;;;;;;;:18;:24;;;;;:118;;;;-1:-1:-1;16387:24:0;;15794:834;-1:-1:-1;;15794:834:0:o;16354:194::-;-1:-1:-1;16569:21:0;15794:834;-1:-1:-1;;15794:834:0:o;15981:621::-;-1:-1:-1;16619:1:0;;15794:834;-1:-1:-1;;15794:834:0:o;19114:97::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;19184:11:::1;:19:::0;;-1:-1:-1;;;;;;19184:19:0::1;-1:-1:-1::0;;;;;19184:19:0;;;::::1;::::0;;;::::1;::::0;;19114:97::o;3298:136::-;3356:7;3383:43;3387:1;3390;3383:43;;;;;;;;;;;;;;;;;:3;:43::i;19219:114::-;9077:6;;-1:-1:-1;;;;;9077:6:0;8338:10;9077:22;9069:67;;;;-1:-1:-1;;;9069:67:0;;;;;;;:::i;:::-;19292:15:::1;:33:::0;;-1:-1:-1;;;;;;19292:33:0::1;-1:-1:-1::0;;;;;19292:33:0;;;::::1;::::0;;;::::1;::::0;;19219:114::o;18077:282::-;18153:27;18165:7;18174:5;18153:11;:27::i;:::-;18231:120;18297:53;18298:36;18328:5;18298:25;;:29;;:36;;;;:::i;18297:53::-;-1:-1:-1;;;;;18231:61:0;;;;;;:28;:61;;;;;;;:65;:120::i;:::-;-1:-1:-1;;;;;18191:37:0;;;;;;;:28;:37;;;;;:160;;;;-1:-1:-1;18077:282:0:o;18367:::-;18443:27;18455:7;18464:5;18443:11;:27::i;:::-;18521:120;18587:53;18588:36;18618:5;18588:25;;:29;;:36;;;;:::i;18587:53::-;-1:-1:-1;;;;;18521:61:0;;;;;;:28;:61;;;;;;;:65;:120::i;13110:374::-;-1:-1:-1;;;;;13194:21:0;;13186:65;;;;-1:-1:-1;;;13186:65:0;;10638:2:1;13186:65:0;;;10620:21:1;10677:2;10657:18;;;10650:30;10716:33;10696:18;;;10689:61;10767:18;;13186:65:0;10436:355:1;13186:65:0;13262:49;13291:1;13295:7;13304:6;13262:20;:49::i;:::-;13337:12;;:24;;13354:6;13337:16;:24::i;:::-;13322:12;:39;-1:-1:-1;;;;;13393:18:0;;:9;:18;;;;;;;;;;;:30;;13416:6;13393:22;:30::i;:::-;-1:-1:-1;;;;;13372:18:0;;:9;:18;;;;;;;;;;;:51;;;;13439:37;;1410:25:1;;;13372:18:0;;:9;;13439:37;;1383:18:1;13439:37:0;;;;;;;;13110:374;;:::o;5690:176::-;5746:6;;5776:5;5780:1;5776;:5;:::i;:::-;5765:16;;5806:1;5801;:6;;:16;;;;;5816:1;5811;:6;;5801:16;5800:38;;;;5827:1;5823;:5;:14;;;;;5836:1;5832;:5;5792:47;;;;;13492:451;-1:-1:-1;;;;;13576:21:0;;13568:67;;;;-1:-1:-1;;;13568:67:0;;11270:2:1;13568:67:0;;;11252:21:1;11309:2;11289:18;;;11282:30;11348:34;11328:18;;;11321:62;-1:-1:-1;;;11399:18:1;;;11392:31;11440:19;;13568:67:0;11068:397:1;13568:67:0;13646:49;13667:7;13684:1;13688:6;13646:20;:49::i;:::-;13727:105;13764:6;13727:105;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13727:18:0;;:9;:18;;;;;;;;;;;;:105;:22;:105::i;:::-;-1:-1:-1;;;;;13706:18:0;;:9;:18;;;;;;;;;;:126;13858:12;;:24;;13875:6;13858:16;:24::i;:::-;13843:12;:39;13898:37;;1410:25:1;;;13924:1:0;;-1:-1:-1;;;;;13898:37:0;;;;;1398:2:1;1383:18;13898:37:0;1264:177:1;14:597;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:131::-;-1:-1:-1;;;;;691:31:1;;681:42;;671:70;;737:1;734;727:12;752:315;820:6;828;881:2;869:9;860:7;856:23;852:32;849:52;;;897:1;894;887:12;849:52;936:9;923:23;955:31;980:5;955:31;:::i;:::-;1005:5;1057:2;1042:18;;;;1029:32;;-1:-1:-1;;;752:315:1:o;1446:180::-;1505:6;1558:2;1546:9;1537:7;1533:23;1529:32;1526:52;;;1574:1;1571;1564:12;1526:52;-1:-1:-1;1597:23:1;;1446:180;-1:-1:-1;1446:180:1:o;1854:247::-;1913:6;1966:2;1954:9;1945:7;1941:23;1937:32;1934:52;;;1982:1;1979;1972:12;1934:52;2021:9;2008:23;2040:31;2065:5;2040:31;:::i;2106:456::-;2183:6;2191;2199;2252:2;2240:9;2231:7;2227:23;2223:32;2220:52;;;2268:1;2265;2258:12;2220:52;2307:9;2294:23;2326:31;2351:5;2326:31;:::i;:::-;2376:5;-1:-1:-1;2433:2:1;2418:18;;2405:32;2446:33;2405:32;2446:33;:::i;:::-;2106:456;;2498:7;;-1:-1:-1;;;2552:2:1;2537:18;;;;2524:32;;2106:456::o;2964:118::-;3050:5;3043:13;3036:21;3029:5;3026:32;3016:60;;3072:1;3069;3062:12;3087:390;3160:6;3168;3221:2;3209:9;3200:7;3196:23;3192:32;3189:52;;;3237:1;3234;3227:12;3189:52;3276:9;3263:23;3295:31;3320:5;3295:31;:::i;:::-;3345:5;-1:-1:-1;3402:2:1;3387:18;;3374:32;3415:30;3374:32;3415:30;:::i;:::-;3464:7;3454:17;;;3087:390;;;;;:::o;3482:388::-;3550:6;3558;3611:2;3599:9;3590:7;3586:23;3582:32;3579:52;;;3627:1;3624;3617:12;3579:52;3666:9;3653:23;3685:31;3710:5;3685:31;:::i;:::-;3735:5;-1:-1:-1;3792:2:1;3777:18;;3764:32;3805:33;3764:32;3805:33;:::i;4203:380::-;4282:1;4278:12;;;;4325;;;4346:61;;4400:4;4392:6;4388:17;4378:27;;4346:61;4453:2;4445:6;4442:14;4422:18;4419:38;4416:161;;4499:10;4494:3;4490:20;4487:1;4480:31;4534:4;4531:1;4524:15;4562:4;4559:1;4552:15;4416:161;;4203:380;;;:::o;4588:356::-;4790:2;4772:21;;;4809:18;;;4802:30;4868:34;4863:2;4848:18;;4841:62;4935:2;4920:18;;4588:356::o;5444:127::-;5505:10;5500:3;5496:20;5493:1;5486:31;5536:4;5533:1;5526:15;5560:4;5557:1;5550:15;5576:217;5616:1;5642;5632:132;;5686:10;5681:3;5677:20;5674:1;5667:31;5721:4;5718:1;5711:15;5749:4;5746:1;5739:15;5632:132;-1:-1:-1;5778:9:1;;5576:217::o;8435:125::-;8475:4;8503:1;8500;8497:8;8494:34;;;8508:18;;:::i;:::-;-1:-1:-1;8545:9:1;;8435:125::o;8565:168::-;8605:7;8671:1;8667;8663:6;8659:14;8656:1;8653:21;8648:1;8641:9;8634:17;8630:45;8627:71;;;8678:18;;:::i;:::-;-1:-1:-1;8718:9:1;;8565:168::o;9140:265::-;9179:3;9207:9;;;9232:10;;-1:-1:-1;;;;;9251:27:1;;;9244:35;;9228:52;9225:78;;;9283:18;;:::i;:::-;-1:-1:-1;;;9330:19:1;;;9323:27;;9315:36;;9312:62;;;9354:18;;:::i;:::-;-1:-1:-1;;9390:9:1;;9140:265::o;9410:128::-;9450:3;9481:1;9477:6;9474:1;9471:13;9468:39;;;9487:18;;:::i;:::-;-1:-1:-1;9523:9:1;;9410:128::o;10186:245::-;10253:6;10306:2;10294:9;10285:7;10281:23;10277:32;10274:52;;;10322:1;10319;10312:12;10274:52;10354:9;10348:16;10373:28;10395:5;10373:28;:::i;10796:267::-;10835:4;10864:9;;;10889:10;;-1:-1:-1;;;10908:19:1;;10901:27;;10885:44;10882:70;;;10932:18;;:::i;:::-;-1:-1:-1;;;;;10979:27:1;;10972:35;;10964:44;;10961:70;;;11011:18;;:::i;:::-;-1:-1:-1;;11048:9:1;;10796:267::o

Swarm Source

ipfs://c95b24dc0a911d5c57aef18f4b86e735ccae2b3f976d624f81a45ab365bee287
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

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