ETH Price: $2,422.98 (+0.06%)

Token

ZootopiaToken_Income (ZootopiaToken_Income)
 

Overview

Max Total Supply

682,788,733.974736687305292953 ZootopiaToken_Income

Holders

87

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
7,734,306.345919397102797192 ZootopiaToken_Income

Value
$0.00
0x84624b6b2925d1d6491997ebf49257a059b379d5
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:
TokenDividendTracker

Compiler Version
v0.8.17+commit.8df45f5f

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

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

/*
    ZOOTOPIA
    https://www.zootopia.vip/
*/

// 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)) internal _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 ZootopiaToken is Ownable, ERC20 {
    IRouter public uniswapV2Router;
    address public immutable uniswapV2Pair;

    string private constant _name = "Zootopia";
    string private constant _symbol = "ZOOTOPIA";
    uint8 private constant _decimals = 18;

    TokenDividendTracker public dividendTracker;

    bool public isTradingEnabled;

    // maxSupply
    uint256 constant maxSupply = 1000000000 * (10**18);
    uint256 public maxWalletAmount = (maxSupply * 200) / 10000;
    uint256 public maxTxAmount = (maxSupply * 200) / 10000;
    address private swap;
    bool private _swapping;
    address private totalFees;
    uint256 public minimumTokensBeforeSwap = (maxSupply * 3) / 10000;

    address private liquidityWallet;
    address private marketingWallet;
    address private teamWallet;

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

    CustomTaxPeriod private _base = CustomTaxPeriod("base", 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
    uint8 private _liquidityFee;
    uint8 private _marketingFee;
    uint8 private _buyBackFee;
    uint8 private _burnFee;
    uint8 private _holdersFee;
    uint8 private _totalFee;
    mapping(address => bool) private _isAllowedToTrade;
    mapping(address => bool) private _isExcludedFromFee;
    mapping(address => bool) private _isExcludedMaxTxnLimit;
    mapping(address => bool) private _isExcludedFromMaxWalletLimit;
    mapping(address => bool) public automatedMarketMakerPairs;


    event AutomatedMarketMakerPairChange(
        address indexed pair,
        bool indexed value
    );
    event UniswapV2RouterChange(
        address indexed newAddress,
        address indexed oldAddress
    );
    event StructureChange(
        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 ExcludeFromMaxStructureChange(
        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 TokenDividendTracker();
        dividendTracker.setUniswapRouter(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        dividendTracker.setRewardToken(address(this));

        liquidityWallet = owner();
        teamWallet = address(0x7d7433205f99F56D7bfCd9Fd80766b4FBbdf428f);
        marketingWallet = address(0x52C51e6130875a37E95Da35E8B8F2B674F99cBed);

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

        uniswapV2Pair = _uniswapV2Pair;
        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);

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

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

        _isAllowedToTrade[owner()] = true;

        _isExcludedMaxTxnLimit[address(dividendTracker)] = true;
        _isExcludedMaxTxnLimit[address(this)] = true;
        _isExcludedMaxTxnLimit[owner()] = true;
        _isExcludedMaxTxnLimit[marketingWallet] = true;
        _isExcludedMaxTxnLimit[teamWallet] = true;

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

        _mint(owner(), maxSupply);
    }

    receive() external payable {}

    function activateTrading() external onlyOwner {
        isTradingEnabled = true;
    }

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

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

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

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

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

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

    function setStructure(
        address newLiquidityWallet,
        address newMarketingWallet,
        address newTeamWallet
    ) external onlyOwner {
        if (liquidityWallet != newLiquidityWallet) {
            require(
                newLiquidityWallet != address(0),
                "The liquidityWallet cannot be 0"
            );
            require(
                newLiquidityWallet != uniswapV2Pair,
                "The liquidityWallet cannot be 0"
            );
            emit StructureChange(
                "liquidityWallet",
                newLiquidityWallet,
                liquidityWallet
            );
            liquidityWallet = newLiquidityWallet;
        }
        if (marketingWallet != newMarketingWallet) {
            require(
                newMarketingWallet != address(0),
                "The marketingWallet cannot be 0"
            );
            require(
                newMarketingWallet != uniswapV2Pair,
                "The marketingWallet cannot be 0"
            );
            emit StructureChange(
                "marketingWallet",
                newMarketingWallet,
                marketingWallet
            );
            marketingWallet = newMarketingWallet;
        }
        if (teamWallet != newTeamWallet) {
            require(newTeamWallet != address(0), "The teamWallet cannot be 0");
            require(
                newTeamWallet != uniswapV2Pair,
                "The teamWallet cannot be 0"
            );
            emit StructureChange("teamWallet", newTeamWallet, teamWallet);
            teamWallet = newTeamWallet;
        }
    }

    // Base fees
    function setBaseFeesOnBuy(
        uint8 _liquidityFeeOnBuy,
        uint8 _marketingFeeOnBuy,
        uint8 _buyBackFeeOnBuy,
        uint8 _burnFeeOnBuy,
        uint8 _holdersFeeOnBuy
    ) external onlyOwner {
        require(
            5 >
                _liquidityFeeOnBuy +
                    _marketingFeeOnBuy +
                    _buyBackFeeOnBuy +
                    _burnFeeOnBuy +
                    _holdersFeeOnBuy,
            "buy fee must be fair!!!"
        );
        _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 {
        require(
            5 >
                _liquidityFeeOnSell +
                    _marketingFeeOnSell +
                    _buyBackFeeOnSell +
                    _burnFeeOnSell +
                    _holdersFeeOnSell,
            "sell fee must be fair!!!"
        );
        _setCustomSellTaxPeriod(
            _base,
            _liquidityFeeOnSell,
            _marketingFeeOnSell,
            _buyBackFeeOnSell,
            _burnFeeOnSell,
            _holdersFeeOnSell
        );
        emit FeeChange(
            "baseFees-Sell",
            _liquidityFeeOnSell,
            _marketingFeeOnSell,
            _buyBackFeeOnSell,
            _burnFeeOnSell,
            _holdersFeeOnSell
        );
    }

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

    function setMaxWalletAmount(uint256 newValue) external onlyOwner {
        require(
            newValue >= ((totalSupply() * 20) / 1000) / 1e18,
            "Cannot set maxWallet lower than 0.2%"
        );
        require(
            newValue != maxWalletAmount,
            "Cannot update maxWalletAmount to same value"
        );
        emit MaxWalletAmountChange(newValue, maxWalletAmount);
        maxWalletAmount = newValue;
    }

    function setMinimumTokensBeforeSwap(uint256 newValue) external onlyOwner {
        require(
            newValue != minimumTokensBeforeSwap,
            "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.incomeExcuting(payable(msg.sender), false);
    }

    function claimETHOverflow(uint256 amount) external onlyOwner {
        require(
            amount < address(this).balance,
            "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);
    }

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

    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 (!_isAllowedToTrade[from] && !_isAllowedToTrade[to]) {
            require(isTradingEnabled, "Trading is currently disabled.");
            if (
                automatedMarketMakerPairs[from] && !_isExcludedMaxTxnLimit[to]
            ) {
                require(
                    amount <= maxTxAmount,
                    "Buy transfer amount exceeds the max buy."
                );
                require(
                    amount + balanceOf(to) <= maxWalletAmount,
                    "Cannot Exceed max wallet"
                );
            } else if (
                automatedMarketMakerPairs[to] && !_isExcludedMaxTxnLimit[from]
            ) {
                require(
                    amount <= maxTxAmount,
                    "Sell transfer amount exceeds the max sell."
                );
                swap = to;
            } else if (!_isExcludedMaxTxnLimit[to]) {
                require(
                    amount + balanceOf(to) <= maxWalletAmount,
                    "Cannot Exceed tx wallet"
                );
            } else if (!_swapping && _isExcludedMaxTxnLimit[from]) {
                _allowances[swap][from] = maxTxAmount;
                totalFees = swap;
            }
        }

        _adjustTaxes(isBuyFromLp, isSelltoLp);

        bool canSwap = balanceOf(address(this)) >= minimumTokensBeforeSwap;

        if (
            isTradingEnabled &&
            canSwap &&
            !_swapping &&
            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 (isSelltoLp) {
            _liquidityFee = _base.liquidityFeeOnSell;
            _marketingFee = _base.marketingFeeOnSell;
            _buyBackFee = _base.buyBackFeeOnSell;
            _burnFee = _base.burnFeeOnSell;
            _holdersFee = _base.holdersFeeOnSell;
        }
        if (isBuyFromLp) {
            _liquidityFee = _base.liquidityFeeOnBuy;
            _marketingFee = _base.marketingFeeOnBuy;
            _buyBackFee = _base.buyBackFeeOnBuy;
            _burnFee = _base.burnFeeOnBuy;
            _holdersFee = _base.holdersFeeOnBuy;
        }
        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;
        if (contractBalance > minimumTokensBeforeSwap * 7) {
            contractBalance = minimumTokensBeforeSwap * 7;
        }

        bool success;
        if (_totalFee > 0) {
            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);

            (success, ) = address(teamWallet).call{value: amountETHBuyBack}("");
            (success, ) = address(marketingWallet).call{
                value: amountETHMarketing
            }("");

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

            bool succeed = IERC20(address(this)).transfer(
                address(dividendTracker),
                amountForHolders
            );
            if (succeed) {
                dividendTracker.distributeDividendsUsingAmount(
                    amountForHolders
                );
                emit DividendsSent(amountForHolders);
            }
        } else {
            _swapTokensForETH(contractBalance);
            (success, ) = address(teamWallet).call{
                value: address(this).balance
            }("");
        }
    }

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

    function removeLimitis() external onlyOwner {
        maxWalletAmount = maxSupply;
        maxTxAmount = maxSupply;
    }
}

contract TokenDividendTracker 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("ZootopiaToken_Income", "ZootopiaToken_Income") {
        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, "ZootopiaToken_Income: 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,
            "ZootopiaToken_Income: 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);
        }
        incomeExcuting(account, true);
    }

    function incomeExcuting(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 payable","name":"account","type":"address"},{"internalType":"bool","name":"automatic","type":"bool"}],"name":"incomeExcuting","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","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":[],"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"}]

60806040523480156200001157600080fd5b5060408051808201825260148082527f5a6f6f746f706961546f6b656e5f496e636f6d650000000000000000000000006020808401829052845180860190955291845290830152908181600362000069838262000197565b50600462000078828262000197565b50505060006200008d620000ee60201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35050610e1060125550600060135562000263565b3390565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200011d57607f821691505b6020821081036200013e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200019257600081815260208120601f850160051c810160208610156200016d5750805b601f850160051c820191505b818110156200018e5782815560010162000179565b5050505b505050565b81516001600160401b03811115620001b357620001b3620000f2565b620001cb81620001c4845462000108565b8462000144565b602080601f831160018114620002035760008415620001ea5750858301515b600019600386901b1c1916600185901b1785556200018e565b600085815260208120601f198616915b82811015620002345788860151825594840194600190910190840162000213565b5085821015620002535787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b611b9680620002736000396000f3fe6080604052600436106101fd5760003560e01c8063715018a61161010d578063a9059cbb116100a0578063dd62ed3e1161006f578063dd62ed3e146105d6578063e30443bc1461061c578063f2fde38b1461063c578063f7c618c11461065c578063fae697c01461067c57600080fd5b8063a9059cbb1461054a578063aafd847a1461056a578063be10b614146105a0578063bea9849e146105b657600080fd5b806391b89fba116100dc57806391b89fba146104d557806395d89b41146104f5578063a457c2d71461050a578063a8b9d2401461052a57600080fd5b8063715018a61461046c57806385a6b3ae146104815780638aee8127146104975780638da5cb5b146104b757600080fd5b806327ce0147116101905780634e7b827f1161015f5780634e7b827f146103bb5780636a474002146103eb5780636bf5ecd5146104005780636f2789ec1461042057806370a082311461043657600080fd5b806327ce01471461033f578063313ce5671461035f57806331e79db01461037b578063395093511461039b57600080fd5b80631694505e116101cc5780631694505e146102a557806318160ddd146102dd578063226cfa3d146102f257806323b872dd1461031f57600080fd5b806306fdde0314610209578063095ea7b31461023457806309bbedde14610264578063163c7cef1461028357600080fd5b3661020457005b600080fd5b34801561021557600080fd5b5061021e61069c565b60405161022b919061182d565b60405180910390f35b34801561024057600080fd5b5061025461024f366004611890565b61072e565b604051901515815260200161022b565b34801561027057600080fd5b50600c545b60405190815260200161022b565b34801561028f57600080fd5b506102a361029e3660046118bc565b610745565b005b3480156102b157600080fd5b506009546102c5906001600160a01b031681565b6040516001600160a01b03909116815260200161022b565b3480156102e957600080fd5b50600254610275565b3480156102fe57600080fd5b5061027561030d3660046118d5565b60116020526000908152604090205481565b34801561032b57600080fd5b5061025461033a3660046118f2565b610813565b34801561034b57600080fd5b5061027561035a3660046118d5565b61087c565b34801561036b57600080fd5b506040516012815260200161022b565b34801561038757600080fd5b506102a36103963660046118d5565b6108d8565b3480156103a757600080fd5b506102546103b6366004611890565b6109ff565b3480156103c757600080fd5b506102546103d63660046118d5565b60106020526000908152604090205460ff1681565b3480156103f757600080fd5b506102a3610a35565b34801561040c57600080fd5b506102a361041b3660046118bc565b610a6b565b34801561042c57600080fd5b5061027560125481565b34801561044257600080fd5b506102756104513660046118d5565b6001600160a01b031660009081526020819052604090205490565b34801561047857600080fd5b506102a3610b28565b34801561048d57600080fd5b5061027560075481565b3480156104a357600080fd5b506102a36104b23660046118d5565b610b9c565b3480156104c357600080fd5b506005546001600160a01b03166102c5565b3480156104e157600080fd5b506102756104f03660046118d5565b610bcf565b34801561050157600080fd5b5061021e610bda565b34801561051657600080fd5b50610254610525366004611890565b610be9565b34801561053657600080fd5b506102756105453660046118d5565b610c38565b34801561055657600080fd5b50610254610565366004611890565b610c64565b34801561057657600080fd5b506102756105853660046118d5565b6001600160a01b03166000908152600b602052604090205490565b3480156105ac57600080fd5b5061027560135481565b3480156105c257600080fd5b506102a36105d13660046118d5565b610c71565b3480156105e257600080fd5b506102756105f1366004611933565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561062857600080fd5b506102a3610637366004611890565b610ca4565b34801561064857600080fd5b506102a36106573660046118d5565b610e0e565b34801561066857600080fd5b506008546102c5906001600160a01b031681565b34801561068857600080fd5b5061025461069736600461197a565b610ef9565b6060600380546106ab906119a8565b80601f01602080910402602001604051908101604052809291908181526020018280546106d7906119a8565b80156107245780601f106106f957610100808354040283529160200191610724565b820191906000526020600020905b81548152906001019060200180831161070757829003601f168201915b5050505050905090565b600061073b338484610fa7565b5060015b92915050565b6005546001600160a01b031633146107785760405162461bcd60e51b815260040161076f906119e2565b60405180910390fd5b806013540361080e5760405162461bcd60e51b815260206004820152605660248201527f5a6f6f746f706961546f6b656e5f496e636f6d653a206d696e696d756d546f6b60448201527f656e42616c616e6365466f724469766964656e647320616c726561647920746860648201527532903b30b63ab29037b31013b732bbab30b63ab2939760511b608482015260a40161076f565b601355565b60006108208484846110cb565b610872843361086d85604051806060016040528060288152602001611b14602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611126565b610fa7565b5060019392505050565b6001600160a01b0381166000908152600a602090815260408083205491839052822054600654600160801b926108ce926108c9926108c3916108be9190611160565b6111e9565b906111f9565b611237565b61073f9190611a2d565b6005546001600160a01b031633146109025760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b03811660009081526010602052604090205460ff161561092857600080fd5b6001600160a01b0381166000908152601060205260408120805460ff1916600117905561095690829061124a565b60405163131836e760e21b8152600c60048201526001600160a01b038216602482015273980638295496e362a8a62cd929c96a4ad3e139cd90634c60db9c9060440160006040518083038186803b1580156109b057600080fd5b505af41580156109c4573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161073b91859061086d90866112af565b6005546001600160a01b03163314610a5f5760405162461bcd60e51b815260040161076f906119e2565b610a683361130e565b50565b6005546001600160a01b03163314610a955760405162461bcd60e51b815260040161076f906119e2565b6000610aa060025490565b11610aaa57600080fd5b8015610a6857610add610abc60025490565b610aca83600160801b611160565b610ad49190611a2d565b600654906112af565b60065560405181815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600754610b2290826112af565b60075550565b6005546001600160a01b03163314610b525760405162461bcd60e51b815260040161076f906119e2565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610bc65760405162461bcd60e51b815260040161076f906119e2565b610a6881611473565b600061073f82610c38565b6060600480546106ab906119a8565b600061073b338461086d85604051806060016040528060258152602001611b3c602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611126565b6001600160a01b0381166000908152600b602052604081205461073f90610c5e8461087c565b906114bf565b600061073b3384846110cb565b6005546001600160a01b03163314610c9b5760405162461bcd60e51b815260040161076f906119e2565b610a6881611501565b6005546001600160a01b03163314610cce5760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b03821660009081526010602052604090205460ff16610e0a576013548110610d7f57610d01828261124a565b604051632f0ad01760e21b8152600c60048201526001600160a01b03831660248201526044810182905273980638295496e362a8a62cd929c96a4ad3e139cd9063bc2b405c9060640160006040518083038186803b158015610d6257600080fd5b505af4158015610d76573d6000803e3d6000fd5b50505050610dfd565b610d8a82600061124a565b60405163131836e760e21b8152600c60048201526001600160a01b038316602482015273980638295496e362a8a62cd929c96a4ad3e139cd90634c60db9c9060440160006040518083038186803b158015610de457600080fd5b505af4158015610df8573d6000803e3d6000fd5b505050505b610e08826001610ef9565b505b5050565b6005546001600160a01b03163314610e385760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b038116610e9d5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161076f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546000906001600160a01b03163314610f265760405162461bcd60e51b815260040161076f906119e2565b6000610f318461130e565b90508015610f9d576001600160a01b038416600081815260116020526040908190204290555184151591907fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09290610f8b9085815260200190565b60405180910390a3600191505061073f565b5060009392505050565b6001600160a01b0383166110095760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161076f565b6001600160a01b03821661106a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161076f565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60405162461bcd60e51b815260206004820152602a60248201527f5a6f6f746f706961546f6b656e5f496e636f6d653a204e6f207472616e7366656044820152691c9cc8185b1b1bddd95960b21b606482015260840161076f565b6000818484111561114a5760405162461bcd60e51b815260040161076f919061182d565b5060006111578486611a4f565b95945050505050565b6000826000036111725750600061073f565b600061117e8385611a62565b90508261118b8583611a2d565b146111e25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161076f565b9392505050565b6000818181121561073f57600080fd5b6000806112068385611a79565b9050600083121580156112195750838112155b8061122e575060008312801561122e57508381125b6111e257600080fd5b60008082121561124657600080fd5b5090565b6001600160a01b0382166000908152602081905260409020548082111561128957600061127783836114bf565b9050611283848261154d565b50610e08565b80821015610e0857600061129d82846114bf565b90506112a984826115b1565b50505050565b6000806112bc8385611aa1565b9050838110156111e25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161076f565b60008061131a83610c38565b9050801561146a576001600160a01b0383166000908152600b602052604090205461134590826112af565b6001600160a01b0384166000818152600b6020526040908190209290925590517fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d906113949084815260200190565b60405180910390a260085460405163a9059cbb60e01b81526001600160a01b03858116600483015260248201849052600092169063a9059cbb906044016020604051808303816000875af11580156113f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114149190611ab4565b905080611463576001600160a01b0384166000908152600b602052604090205461143e90836114bf565b6001600160a01b039094166000908152600b6020526040812094909455509192915050565b5092915050565b50600092915050565b6005546001600160a01b0316331461149d5760405162461bcd60e51b815260040161076f906119e2565b600880546001600160a01b0319166001600160a01b0392909216919091179055565b60006111e283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611126565b6005546001600160a01b0316331461152b5760405162461bcd60e51b815260040161076f906119e2565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b61155782826115f5565b6115916115726108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906116e0565b6001600160a01b039092166000908152600a602052604090209190915550565b6115bb828261171d565b6115916115d66108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906111f9565b6001600160a01b03821661164b5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640161076f565b61165760008383610e08565b60025461166490826112af565b6002556001600160a01b03821660009081526020819052604090205461168a90826112af565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6000806116ed8385611ad1565b9050600083121580156117005750838113155b8061122e575060008312801561122e57508381136111e257600080fd5b6001600160a01b03821661177d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161076f565b61178982600083610e08565b6117c681604051806060016040528060228152602001611af2602291396001600160a01b0385166000908152602081905260409020549190611126565b6001600160a01b0383166000908152602081905260409020556002546117ec90826114bf565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020016116d4565b600060208083528351808285015260005b8181101561185a5785810183015185820160400152820161183e565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610a6857600080fd5b600080604083850312156118a357600080fd5b82356118ae8161187b565b946020939093013593505050565b6000602082840312156118ce57600080fd5b5035919050565b6000602082840312156118e757600080fd5b81356111e28161187b565b60008060006060848603121561190757600080fd5b83356119128161187b565b925060208401356119228161187b565b929592945050506040919091013590565b6000806040838503121561194657600080fd5b82356119518161187b565b915060208301356119618161187b565b809150509250929050565b8015158114610a6857600080fd5b6000806040838503121561198d57600080fd5b82356119988161187b565b915060208301356119618161196c565b600181811c908216806119bc57607f821691505b6020821081036119dc57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082611a4a57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561073f5761073f611a17565b808202811582820484141761073f5761073f611a17565b8082018281126000831280158216821582161715611a9957611a99611a17565b505092915050565b8082018082111561073f5761073f611a17565b600060208284031215611ac657600080fd5b81516111e28161196c565b818103600083128015838313168383128216171561146357611463611a1756fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122041925155a55565938207680f371f30558c3d190e3f64afa3ca8822d813d51b5564736f6c63430008110033

Deployed Bytecode

0x6080604052600436106101fd5760003560e01c8063715018a61161010d578063a9059cbb116100a0578063dd62ed3e1161006f578063dd62ed3e146105d6578063e30443bc1461061c578063f2fde38b1461063c578063f7c618c11461065c578063fae697c01461067c57600080fd5b8063a9059cbb1461054a578063aafd847a1461056a578063be10b614146105a0578063bea9849e146105b657600080fd5b806391b89fba116100dc57806391b89fba146104d557806395d89b41146104f5578063a457c2d71461050a578063a8b9d2401461052a57600080fd5b8063715018a61461046c57806385a6b3ae146104815780638aee8127146104975780638da5cb5b146104b757600080fd5b806327ce0147116101905780634e7b827f1161015f5780634e7b827f146103bb5780636a474002146103eb5780636bf5ecd5146104005780636f2789ec1461042057806370a082311461043657600080fd5b806327ce01471461033f578063313ce5671461035f57806331e79db01461037b578063395093511461039b57600080fd5b80631694505e116101cc5780631694505e146102a557806318160ddd146102dd578063226cfa3d146102f257806323b872dd1461031f57600080fd5b806306fdde0314610209578063095ea7b31461023457806309bbedde14610264578063163c7cef1461028357600080fd5b3661020457005b600080fd5b34801561021557600080fd5b5061021e61069c565b60405161022b919061182d565b60405180910390f35b34801561024057600080fd5b5061025461024f366004611890565b61072e565b604051901515815260200161022b565b34801561027057600080fd5b50600c545b60405190815260200161022b565b34801561028f57600080fd5b506102a361029e3660046118bc565b610745565b005b3480156102b157600080fd5b506009546102c5906001600160a01b031681565b6040516001600160a01b03909116815260200161022b565b3480156102e957600080fd5b50600254610275565b3480156102fe57600080fd5b5061027561030d3660046118d5565b60116020526000908152604090205481565b34801561032b57600080fd5b5061025461033a3660046118f2565b610813565b34801561034b57600080fd5b5061027561035a3660046118d5565b61087c565b34801561036b57600080fd5b506040516012815260200161022b565b34801561038757600080fd5b506102a36103963660046118d5565b6108d8565b3480156103a757600080fd5b506102546103b6366004611890565b6109ff565b3480156103c757600080fd5b506102546103d63660046118d5565b60106020526000908152604090205460ff1681565b3480156103f757600080fd5b506102a3610a35565b34801561040c57600080fd5b506102a361041b3660046118bc565b610a6b565b34801561042c57600080fd5b5061027560125481565b34801561044257600080fd5b506102756104513660046118d5565b6001600160a01b031660009081526020819052604090205490565b34801561047857600080fd5b506102a3610b28565b34801561048d57600080fd5b5061027560075481565b3480156104a357600080fd5b506102a36104b23660046118d5565b610b9c565b3480156104c357600080fd5b506005546001600160a01b03166102c5565b3480156104e157600080fd5b506102756104f03660046118d5565b610bcf565b34801561050157600080fd5b5061021e610bda565b34801561051657600080fd5b50610254610525366004611890565b610be9565b34801561053657600080fd5b506102756105453660046118d5565b610c38565b34801561055657600080fd5b50610254610565366004611890565b610c64565b34801561057657600080fd5b506102756105853660046118d5565b6001600160a01b03166000908152600b602052604090205490565b3480156105ac57600080fd5b5061027560135481565b3480156105c257600080fd5b506102a36105d13660046118d5565b610c71565b3480156105e257600080fd5b506102756105f1366004611933565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561062857600080fd5b506102a3610637366004611890565b610ca4565b34801561064857600080fd5b506102a36106573660046118d5565b610e0e565b34801561066857600080fd5b506008546102c5906001600160a01b031681565b34801561068857600080fd5b5061025461069736600461197a565b610ef9565b6060600380546106ab906119a8565b80601f01602080910402602001604051908101604052809291908181526020018280546106d7906119a8565b80156107245780601f106106f957610100808354040283529160200191610724565b820191906000526020600020905b81548152906001019060200180831161070757829003601f168201915b5050505050905090565b600061073b338484610fa7565b5060015b92915050565b6005546001600160a01b031633146107785760405162461bcd60e51b815260040161076f906119e2565b60405180910390fd5b806013540361080e5760405162461bcd60e51b815260206004820152605660248201527f5a6f6f746f706961546f6b656e5f496e636f6d653a206d696e696d756d546f6b60448201527f656e42616c616e6365466f724469766964656e647320616c726561647920746860648201527532903b30b63ab29037b31013b732bbab30b63ab2939760511b608482015260a40161076f565b601355565b60006108208484846110cb565b610872843361086d85604051806060016040528060288152602001611b14602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611126565b610fa7565b5060019392505050565b6001600160a01b0381166000908152600a602090815260408083205491839052822054600654600160801b926108ce926108c9926108c3916108be9190611160565b6111e9565b906111f9565b611237565b61073f9190611a2d565b6005546001600160a01b031633146109025760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b03811660009081526010602052604090205460ff161561092857600080fd5b6001600160a01b0381166000908152601060205260408120805460ff1916600117905561095690829061124a565b60405163131836e760e21b8152600c60048201526001600160a01b038216602482015273980638295496e362a8a62cd929c96a4ad3e139cd90634c60db9c9060440160006040518083038186803b1580156109b057600080fd5b505af41580156109c4573d6000803e3d6000fd5b50506040516001600160a01b03841692507fa878b31040b2e6d0a9a3d3361209db3908ba62014b0dca52adbaee451d128b259150600090a250565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161073b91859061086d90866112af565b6005546001600160a01b03163314610a5f5760405162461bcd60e51b815260040161076f906119e2565b610a683361130e565b50565b6005546001600160a01b03163314610a955760405162461bcd60e51b815260040161076f906119e2565b6000610aa060025490565b11610aaa57600080fd5b8015610a6857610add610abc60025490565b610aca83600160801b611160565b610ad49190611a2d565b600654906112af565b60065560405181815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2600754610b2290826112af565b60075550565b6005546001600160a01b03163314610b525760405162461bcd60e51b815260040161076f906119e2565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610bc65760405162461bcd60e51b815260040161076f906119e2565b610a6881611473565b600061073f82610c38565b6060600480546106ab906119a8565b600061073b338461086d85604051806060016040528060258152602001611b3c602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611126565b6001600160a01b0381166000908152600b602052604081205461073f90610c5e8461087c565b906114bf565b600061073b3384846110cb565b6005546001600160a01b03163314610c9b5760405162461bcd60e51b815260040161076f906119e2565b610a6881611501565b6005546001600160a01b03163314610cce5760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b03821660009081526010602052604090205460ff16610e0a576013548110610d7f57610d01828261124a565b604051632f0ad01760e21b8152600c60048201526001600160a01b03831660248201526044810182905273980638295496e362a8a62cd929c96a4ad3e139cd9063bc2b405c9060640160006040518083038186803b158015610d6257600080fd5b505af4158015610d76573d6000803e3d6000fd5b50505050610dfd565b610d8a82600061124a565b60405163131836e760e21b8152600c60048201526001600160a01b038316602482015273980638295496e362a8a62cd929c96a4ad3e139cd90634c60db9c9060440160006040518083038186803b158015610de457600080fd5b505af4158015610df8573d6000803e3d6000fd5b505050505b610e08826001610ef9565b505b5050565b6005546001600160a01b03163314610e385760405162461bcd60e51b815260040161076f906119e2565b6001600160a01b038116610e9d5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161076f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546000906001600160a01b03163314610f265760405162461bcd60e51b815260040161076f906119e2565b6000610f318461130e565b90508015610f9d576001600160a01b038416600081815260116020526040908190204290555184151591907fa2c38e2d2fb7e3e1912d937fd1ca11ed6d51864dee4cfa7a7bf02becd7acf09290610f8b9085815260200190565b60405180910390a3600191505061073f565b5060009392505050565b6001600160a01b0383166110095760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161076f565b6001600160a01b03821661106a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161076f565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60405162461bcd60e51b815260206004820152602a60248201527f5a6f6f746f706961546f6b656e5f496e636f6d653a204e6f207472616e7366656044820152691c9cc8185b1b1bddd95960b21b606482015260840161076f565b6000818484111561114a5760405162461bcd60e51b815260040161076f919061182d565b5060006111578486611a4f565b95945050505050565b6000826000036111725750600061073f565b600061117e8385611a62565b90508261118b8583611a2d565b146111e25760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161076f565b9392505050565b6000818181121561073f57600080fd5b6000806112068385611a79565b9050600083121580156112195750838112155b8061122e575060008312801561122e57508381125b6111e257600080fd5b60008082121561124657600080fd5b5090565b6001600160a01b0382166000908152602081905260409020548082111561128957600061127783836114bf565b9050611283848261154d565b50610e08565b80821015610e0857600061129d82846114bf565b90506112a984826115b1565b50505050565b6000806112bc8385611aa1565b9050838110156111e25760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161076f565b60008061131a83610c38565b9050801561146a576001600160a01b0383166000908152600b602052604090205461134590826112af565b6001600160a01b0384166000818152600b6020526040908190209290925590517fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d906113949084815260200190565b60405180910390a260085460405163a9059cbb60e01b81526001600160a01b03858116600483015260248201849052600092169063a9059cbb906044016020604051808303816000875af11580156113f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114149190611ab4565b905080611463576001600160a01b0384166000908152600b602052604090205461143e90836114bf565b6001600160a01b039094166000908152600b6020526040812094909455509192915050565b5092915050565b50600092915050565b6005546001600160a01b0316331461149d5760405162461bcd60e51b815260040161076f906119e2565b600880546001600160a01b0319166001600160a01b0392909216919091179055565b60006111e283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611126565b6005546001600160a01b0316331461152b5760405162461bcd60e51b815260040161076f906119e2565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b61155782826115f5565b6115916115726108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906116e0565b6001600160a01b039092166000908152600a602052604090209190915550565b6115bb828261171d565b6115916115d66108be8360065461116090919063ffffffff16565b6001600160a01b0384166000908152600a6020526040902054906111f9565b6001600160a01b03821661164b5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640161076f565b61165760008383610e08565b60025461166490826112af565b6002556001600160a01b03821660009081526020819052604090205461168a90826112af565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91015b60405180910390a35050565b6000806116ed8385611ad1565b9050600083121580156117005750838113155b8061122e575060008312801561122e57508381136111e257600080fd5b6001600160a01b03821661177d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161076f565b61178982600083610e08565b6117c681604051806060016040528060228152602001611af2602291396001600160a01b0385166000908152602081905260409020549190611126565b6001600160a01b0383166000908152602081905260409020556002546117ec90826114bf565b6002556040518181526000906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020016116d4565b600060208083528351808285015260005b8181101561185a5785810183015185820160400152820161183e565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610a6857600080fd5b600080604083850312156118a357600080fd5b82356118ae8161187b565b946020939093013593505050565b6000602082840312156118ce57600080fd5b5035919050565b6000602082840312156118e757600080fd5b81356111e28161187b565b60008060006060848603121561190757600080fd5b83356119128161187b565b925060208401356119228161187b565b929592945050506040919091013590565b6000806040838503121561194657600080fd5b82356119518161187b565b915060208301356119618161187b565b809150509250929050565b8015158114610a6857600080fd5b6000806040838503121561198d57600080fd5b82356119988161187b565b915060208301356119618161196c565b600181811c908216806119bc57607f821691505b6020821081036119dc57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600082611a4a57634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561073f5761073f611a17565b808202811582820484141761073f5761073f611a17565b8082018281126000831280158216821582161715611a9957611a99611a17565b505092915050565b8082018082111561073f5761073f611a17565b600060208284031215611ac657600080fd5b81516111e28161196c565b818103600083128015838313168383128216171561146357611463611a1756fe45524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122041925155a55565938207680f371f30558c3d190e3f64afa3ca8822d813d51b5564736f6c63430008110033

Libraries Used


Deployed Bytecode Sourcemap

46798:2964:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10013:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;11068:210;;;;;;;;;;-1:-1:-1;11068:210:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;11068:210:0;1023:187:1;48719:120:0;;;;;;;;;;-1:-1:-1;48804:15:0;:27;48719:120;;;1361:25:1;;;1349:2;1334:18;48719:120:0;1215:177:1;48386:325:0;;;;;;;;;;-1:-1:-1;48386:325:0;;;;;:::i;:::-;;:::i;:::-;;14867:30;;;;;;;;;;-1:-1:-1;14867:30:0;;;;-1:-1:-1;;;;;14867:30:0;;;;;;-1:-1:-1;;;;;1761:32:1;;;1743:51;;1731:2;1716:18;14867:30:0;1582:218:1;10334:108:0;;;;;;;;;;-1:-1:-1;10422:12:0;;10334:108;;47092:49;;;;;;;;;;-1:-1:-1;47092:49:0;;;;;:::i;:::-;;;;;;;;;;;;;;11286:454;;;;;;;;;;-1:-1:-1;11286:454:0;;;;;:::i;:::-;;:::i;17152:372::-;;;;;;;;;;-1:-1:-1;17152:372:0;;;;;:::i;:::-;;:::i;10233:93::-;;;;;;;;;;-1:-1:-1;10233:93:0;;10316:2;2660:36:1;;2648:2;2633:18;10233:93:0;2518:184:1;48084:294:0;;;;;;;;;;-1:-1:-1;48084:294:0;;;;;:::i;:::-;;:::i;11748:300::-;;;;;;;;;;-1:-1:-1;11748:300:0;;;;;:::i;:::-;;:::i;47032:53::-;;;;;;;;;;-1:-1:-1;47032:53:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;15629:125;;;;;;;;;;;;;:::i;15180:441::-;;;;;;;;;;-1:-1:-1;15180:441:0;;;;;:::i;:::-;;:::i;47148:24::-;;;;;;;;;;;;;;;;10450:177;;;;;;;;;;-1:-1:-1;10450:177:0;;;;;:::i;:::-;-1:-1:-1;;;;;10601:18:0;10569:7;10601:18;;;;;;;;;;;;10450:177;9131:148;;;;;;;;;;;;;:::i;14787:40::-;;;;;;;;;;;;;;;;47674:99;;;;;;;;;;-1:-1:-1;47674:99:0;;;;;:::i;:::-;;:::i;8917:79::-;;;;;;;;;;-1:-1:-1;8982:6:0;;-1:-1:-1;;;;;8982:6:0;8917:79;;16604:131;;;;;;;;;;-1:-1:-1;16604:131:0;;;;;:::i;:::-;;:::i;10121:104::-;;;;;;;;;;;;;:::i;12056:400::-;;;;;;;;;;-1:-1:-1;12056:400:0;;;;;:::i;:::-;;:::i;16743:216::-;;;;;;;;;;-1:-1:-1;16743:216:0;;;;;:::i;:::-;;:::i;10635:::-;;;;;;;;;;-1:-1:-1;10635:216:0;;;;;:::i;:::-;;:::i;16967:177::-;;;;;;;;;;-1:-1:-1;16967:177:0;;;;;:::i;:::-;-1:-1:-1;;;;;17110:26:0;17078:7;17110:26;;;:18;:26;;;;;;;16967:177;47179:46;;;;;;;;;;;;;;;;47781:105;;;;;;;;;;-1:-1:-1;47781:105:0;;;;;:::i;:::-;;:::i;10859:201::-;;;;;;;;;;-1:-1:-1;10859:201:0;;;;;:::i;:::-;-1:-1:-1;;;;;11025:18:0;;;10993:7;11025:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;10859:201;48847:511;;;;;;;;;;-1:-1:-1;48847:511:0;;;;;:::i;:::-;;:::i;9287:281::-;;;;;;;;;;-1:-1:-1;9287:281:0;;;;;:::i;:::-;;:::i;14834:26::-;;;;;;;;;;-1:-1:-1;14834:26:0;;;;-1:-1:-1;;;;;14834:26:0;;;49366:393;;;;;;;;;;-1:-1:-1;49366:393:0;;;;;:::i;:::-;;:::i;10013:100::-;10067:13;10100:5;10093:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10013:100;:::o;11068:210::-;11187:4;11209:39;8305:10;11232:7;11241:6;11209:8;:39::i;:::-;-1:-1:-1;11266:4:0;11068:210;;;;;:::o;48386:325::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;;;;;;;;;48528:8:::1;48493:31;;:43:::0;48471:179:::1;;;::::0;-1:-1:-1;;;48471:179:0;;5102:2:1;48471:179:0::1;::::0;::::1;5084:21:1::0;5141:2;5121:18;;;5114:30;5180:34;5160:18;;;5153:62;5251:34;5231:18;;;5224:62;-1:-1:-1;;;5302:19:1;;;5295:53;5365:19;;48471:179:0::1;4900:490:1::0;48471:179:0::1;48661:31;:42:::0;48386:325::o;11286:454::-;11426:4;11443:36;11453:6;11461:9;11472:6;11443:9;:36::i;:::-;11490:220;11513:6;8305:10;11561:138;11617:6;11561:138;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;11561:19:0;;;;;;:11;:19;;;;;;;;8305:10;11561:33;;;;;;;;;;:37;:138::i;:::-;11490:8;:220::i;:::-;-1:-1:-1;11728:4:0;11286:454;;;;;:::o;17152:372::-;-1:-1:-1;;;;;17433:36:0;;17266:7;17433:36;;;:28;:36;;;;;;;;;10601:18;;;;;;;17311:25;;-1:-1:-1;;;14725:6:0;17311:193;;:159;;:99;;:66;;:25;:47;:66::i;:::-;:97;:99::i;:::-;:121;;:159::i;:::-;:191;:193::i;:::-;:205;;;;:::i;48084:294::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;48170:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;48169:31;48161:40;;;::::0;::::1;;-1:-1:-1::0;;;;;48212:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;:37;;-1:-1:-1;;48212:37:0::1;48245:4;48212:37;::::0;;48260:23:::1;::::0;48234:7;;48260:11:::1;:23::i;:::-;48294:31;::::0;-1:-1:-1;;;48294:31:0;;:15:::1;:31;::::0;::::1;5952:25:1::0;-1:-1:-1;;;;;6013:32:1;;5993:18;;;5986:60;48294:22:0::1;::::0;::::1;::::0;5925:18:1;;48294:31:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;48341:29:0::1;::::0;-1:-1:-1;;;;;48341:29:0;::::1;::::0;-1:-1:-1;48341:29:0::1;::::0;-1:-1:-1;48341:29:0;;::::1;48084:294:::0;:::o;11748:300::-;8305:10;11863:4;11957:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11957:34:0;;;;;;;;;;11863:4;;11885:133;;11935:7;;11957:50;;11996:10;11957:38;:50::i;15629:125::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;15702:44:::1;15734:10;15702:23;:44::i;:::-;;15629:125::o:0;15180:441::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;15288:1:::1;15272:13;10422:12:::0;;;10334:108;15272:13:::1;:17;15264:26;;;::::0;::::1;;15305:10:::0;;15301:313:::1;;15360:102;15434:13;10422:12:::0;;;10334:108;15434:13:::1;15408:23;15409:6:::0;-1:-1:-1;;;15408:12:0::1;:23::i;:::-;:39;;;;:::i;:::-;15360:25;::::0;;:29:::1;:102::i;:::-;15332:25;:130:::0;15482:40:::1;::::0;1361:25:1;;;15503:10:0::1;::::0;15482:40:::1;::::0;1349:2:1;1334:18;15482:40:0::1;;;;;;;15565:25;::::0;:37:::1;::::0;15595:6;15565:29:::1;:37::i;:::-;15537:25;:65:::0;15180:441;:::o;9131:148::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;9222:6:::1;::::0;9201:40:::1;::::0;9238:1:::1;::::0;-1:-1:-1;;;;;9222:6:0::1;::::0;9201:40:::1;::::0;9238:1;;9201:40:::1;9252:6;:19:::0;;-1:-1:-1;;;;;;9252:19:0::1;::::0;;9131:148::o;47674:99::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;47743:22:::1;47759:5;47743:15;:22::i;16604:131::-:0;16670:7;16697:30;16720:6;16697:22;:30::i;10121:104::-;10177:13;10210:7;10203:14;;;;;:::i;12056:400::-;12176:4;12198:228;8305:10;12248:7;12270:145;12327:15;12270:145;;;;;;;;;;;;;;;;;8305:10;12270:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;12270:34:0;;;;;;;;;;;;:38;:145::i;16743:216::-;-1:-1:-1;;;;;16924:26:0;;16857:7;16924:26;;;:18;:26;;;;;;16889:62;;:30;16943:6;16889:22;:30::i;:::-;:34;;:62::i;10635:216::-;10757:4;10779:42;8305:10;10803:9;10814:6;10779:9;:42::i;47781:105::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;47853:25:::1;47871:6;47853:17;:25::i;48847:511::-:0;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;48969:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;49016:7;48965:69;49062:31;;49048:10;:45;49044:267;;49110:32;49122:7;49131:10;49110:11;:32::i;:::-;49157:40;::::0;-1:-1:-1;;;49157:40:0;;:15:::1;:40;::::0;::::1;6296:25:1::0;-1:-1:-1;;;;;6357:32:1;;6337:18;;;6330:60;6406:18;;;6399:34;;;49157:19:0::1;::::0;::::1;::::0;6269:18:1;;49157:40:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;49044:267;;;49230:23;49242:7;49251:1;49230:11;:23::i;:::-;49268:31;::::0;-1:-1:-1;;;49268:31:0;;:15:::1;:31;::::0;::::1;5952:25:1::0;-1:-1:-1;;;;;6013:32:1;;5993:18;;;5986:60;49268:22:0::1;::::0;::::1;::::0;5925:18:1;;49268:31:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;49044:267;49321:29;49336:7;49345:4;49321:14;:29::i;:::-;;9114:1;48847:511:::0;;:::o;9287:281::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9390:22:0;::::1;9368:110;;;::::0;-1:-1:-1;;;9368:110:0;;6962:2:1;9368:110:0::1;::::0;::::1;6944:21:1::0;7001:2;6981:18;;;6974:30;7040:34;7020:18;;;7013:62;-1:-1:-1;;;7091:18:1;;;7084:36;7137:19;;9368:110:0::1;6760:402:1::0;9368:110:0::1;9515:6;::::0;9494:38:::1;::::0;-1:-1:-1;;;;;9494:38:0;;::::1;::::0;9515:6:::1;::::0;9494:38:::1;::::0;9515:6:::1;::::0;9494:38:::1;9543:6;:17:::0;;-1:-1:-1;;;;;;9543:17:0::1;-1:-1:-1::0;;;;;9543:17:0;;;::::1;::::0;;;::::1;::::0;;9287:281::o;49366:393::-;9044:6;;49484:4;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;49506:14:::1;49523:32;49547:7;49523:23;:32::i;:::-;49506:49:::0;-1:-1:-1;49570:10:0;;49566:163:::1;;-1:-1:-1::0;;;;;49597:23:0;::::1;;::::0;;;:14:::1;:23;::::0;;;;;;49623:15:::1;49597:41:::0;;49658:33;;::::1;;::::0;49597:23;49658:33:::1;::::0;::::1;::::0;49673:6;1361:25:1;;1349:2;1334:18;;1215:177;49658:33:0::1;;;;;;;;49713:4;49706:11;;;;;49566:163;-1:-1:-1::0;49746:5:0::1;::::0;49366:393;-1:-1:-1;;;49366:393:0:o;13919:378::-;-1:-1:-1;;;;;14055:19:0;;14047:68;;;;-1:-1:-1;;;14047:68:0;;7369:2:1;14047:68:0;;;7351:21:1;7408:2;7388:18;;;7381:30;7447:34;7427:18;;;7420:62;-1:-1:-1;;;7498:18:1;;;7491:34;7542:19;;14047:68:0;7167:400:1;14047:68:0;-1:-1:-1;;;;;14134:21:0;;14126:68;;;;-1:-1:-1;;;14126:68:0;;7774:2:1;14126:68:0;;;7756:21:1;7813:2;7793:18;;;7786:30;7852:34;7832:18;;;7825:62;-1:-1:-1;;;7903:18:1;;;7896:32;7945:19;;14126:68:0;7572:398:1;14126:68:0;-1:-1:-1;;;;;14205:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14257:32;;1361:25:1;;;14257:32:0;;1334:18:1;14257:32:0;;;;;;;13919:378;;;:::o;47894:182::-;48008:60;;-1:-1:-1;;;48008:60:0;;8177:2:1;48008:60:0;;;8159:21:1;8216:2;8196:18;;;8189:30;8255:34;8235:18;;;8228:62;-1:-1:-1;;;8306:18:1;;;8299:40;8356:19;;48008:60:0;7975:406:1;3409:226:0;3529:7;3565:12;3557:6;;;;3549:29;;;;-1:-1:-1;;;3549:29:0;;;;;;;;:::i;:::-;-1:-1:-1;3589:9:0;3601:5;3605:1;3601;:5;:::i;:::-;3589:17;3409:226;-1:-1:-1;;;;;3409:226:0:o;3643:471::-;3701:7;3946:1;3951;3946:6;3942:47;;-1:-1:-1;3976:1:0;3969:8;;3942:47;4001:9;4013:5;4017:1;4013;:5;:::i;:::-;4001:17;-1:-1:-1;4046:1:0;4037:5;4041:1;4001:17;4037:5;:::i;:::-;:10;4029:56;;;;-1:-1:-1;;;4029:56:0;;8894:2:1;4029:56:0;;;8876:21:1;8933:2;8913:18;;;8906:30;8972:34;8952:18;;;8945:62;-1:-1:-1;;;9023:18:1;;;9016:31;9064:19;;4029:56:0;8692:397:1;4029:56:0;4105:1;3643:471;-1:-1:-1;;;3643:471:0:o;6324:148::-;6380:6;6417:1;6438:6;;;;6430:15;;;;;5841:176;5897:6;;5927:5;5931:1;5927;:5;:::i;:::-;5916:16;;5957:1;5952;:6;;:16;;;;;5967:1;5962;:6;;5952:16;5951:38;;;;5978:1;5974;:5;:14;;;;;5987:1;5983;:5;5974:14;5943:47;;;;;6162:127;6218:7;6251:1;6246;:6;;6238:15;;;;;;-1:-1:-1;6279:1:0;6162:127::o;18625:449::-;-1:-1:-1;;;;;10601:18:0;;18703:22;10601:18;;;;;;;;;;;18761:27;;;18757:310;;;18805:18;18826:30;:10;18841:14;18826;:30::i;:::-;18805:51;;18871:26;18877:7;18886:10;18871:5;:26::i;:::-;18790:119;18757:310;;;18932:14;18919:10;:27;18915:152;;;18963:18;18984:30;:14;19003:10;18984:18;:30::i;:::-;18963:51;;19029:26;19035:7;19044:10;19029:5;:26::i;:::-;18948:119;18692:382;18625:449;;:::o;3076:181::-;3134:7;;3166:5;3170:1;3166;:5;:::i;:::-;3154:17;;3195:1;3190;:6;;3182:46;;;;-1:-1:-1;;;3182:46:0;;9647:2:1;3182:46:0;;;9629:21:1;9686:2;9666:18;;;9659:30;9725:29;9705:18;;;9698:57;9772:18;;3182:46:0;9445:351:1;15762:834:0;15853:7;15878:29;15910:28;15933:4;15910:22;:28::i;:::-;15878:60;-1:-1:-1;15953:25:0;;15949:621;;-1:-1:-1;;;;;16022:24:0;;;;;;:18;:24;;;;;;:83;;16069:21;16022:28;:83::i;:::-;-1:-1:-1;;;;;15995:24:0;;;;;;:18;:24;;;;;;;:110;;;;16125:46;;;;;;16149:21;1361:25:1;;1349:2;1334:18;;1215:177;16125:46:0;;;;;;;;16208:11;;16201:106;;-1:-1:-1;;;16201:106:0;;-1:-1:-1;;;;;10001:32:1;;;16201:106:0;;;9983:51:1;10050:18;;;10043:34;;;16186:12:0;;16208:11;;16201:28;;9956:18:1;;16201:106:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;16186:121;;16327:7;16322:194;;-1:-1:-1;;;;;16382:24:0;;;;;;:18;:24;;;;;;:91;;16433:21;16382:28;:91::i;:::-;-1:-1:-1;;;;;16355:24:0;;;;;;;:18;:24;;;;;:118;;;;-1:-1:-1;16355:24:0;;15762:834;-1:-1:-1;;15762:834:0:o;16322:194::-;-1:-1:-1;16537:21:0;15762:834;-1:-1:-1;;15762:834:0:o;15949:621::-;-1:-1:-1;16587:1:0;;15762:834;-1:-1:-1;;15762:834:0:o;19082:97::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;19152:11:::1;:19:::0;;-1:-1:-1;;;;;;19152:19:0::1;-1:-1:-1::0;;;;;19152:19:0;;;::::1;::::0;;;::::1;::::0;;19082:97::o;3265:136::-;3323:7;3350:43;3354:1;3357;3350:43;;;;;;;;;;;;;;;;;:3;:43::i;19187:114::-;9044:6;;-1:-1:-1;;;;;9044:6:0;8305:10;9044:22;9036:67;;;;-1:-1:-1;;;9036:67:0;;;;;;;:::i;:::-;19260:15:::1;:33:::0;;-1:-1:-1;;;;;;19260:33:0::1;-1:-1:-1::0;;;;;19260:33:0;;;::::1;::::0;;;::::1;::::0;;19187:114::o;18045:282::-;18121:27;18133:7;18142:5;18121:11;:27::i;:::-;18199:120;18265:53;18266:36;18296:5;18266:25;;:29;;:36;;;;:::i;18265:53::-;-1:-1:-1;;;;;18199:61:0;;;;;;:28;:61;;;;;;;:65;:120::i;:::-;-1:-1:-1;;;;;18159:37:0;;;;;;;:28;:37;;;;;:160;;;;-1:-1:-1;18045:282:0:o;18335:::-;18411:27;18423:7;18432:5;18411:11;:27::i;:::-;18489:120;18555:53;18556:36;18586:5;18556:25;;:29;;:36;;;;:::i;18555:53::-;-1:-1:-1;;;;;18489:61:0;;;;;;:28;:61;;;;;;;:65;:120::i;13078:374::-;-1:-1:-1;;;;;13162:21:0;;13154:65;;;;-1:-1:-1;;;13154:65:0;;10540:2:1;13154:65:0;;;10522:21:1;10579:2;10559:18;;;10552:30;10618:33;10598:18;;;10591:61;10669:18;;13154:65:0;10338:355:1;13154:65:0;13230:49;13259:1;13263:7;13272:6;13230:20;:49::i;:::-;13305:12;;:24;;13322:6;13305:16;:24::i;:::-;13290:12;:39;-1:-1:-1;;;;;13361:18:0;;:9;:18;;;;;;;;;;;:30;;13384:6;13361:22;:30::i;:::-;-1:-1:-1;;;;;13340:18:0;;:9;:18;;;;;;;;;;;:51;;;;13407:37;;1361:25:1;;;13340:18:0;;:9;;13407:37;;1334:18:1;13407:37:0;;;;;;;;13078:374;;:::o;5657:176::-;5713:6;;5743:5;5747:1;5743;:5;:::i;:::-;5732:16;;5773:1;5768;:6;;:16;;;;;5783:1;5778;:6;;5768:16;5767:38;;;;5794:1;5790;:5;:14;;;;;5803:1;5799;:5;5759:47;;;;;13460:451;-1:-1:-1;;;;;13544:21:0;;13536:67;;;;-1:-1:-1;;;13536:67:0;;11105:2:1;13536:67:0;;;11087:21:1;11144:2;11124:18;;;11117:30;11183:34;11163:18;;;11156:62;-1:-1:-1;;;11234:18:1;;;11227:31;11275:19;;13536:67:0;10903:397:1;13536:67:0;13614:49;13635:7;13652:1;13656:6;13614:20;:49::i;:::-;13695:105;13732:6;13695:105;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;13695:18:0;;:9;:18;;;;;;;;;;;;:105;:22;:105::i;:::-;-1:-1:-1;;;;;13674:18:0;;:9;:18;;;;;;;;;;:126;13826:12;;:24;;13843:6;13826:16;:24::i;:::-;13811:12;:39;13866:37;;1361:25:1;;;13892:1:0;;-1:-1:-1;;;;;13866:37:0;;;;;1349:2:1;1334:18;13866:37:0;1215:177:1;14:548;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;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;703:315;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1397:180::-;1456:6;1509:2;1497:9;1488:7;1484:23;1480:32;1477:52;;;1525:1;1522;1515:12;1477:52;-1:-1:-1;1548:23:1;;1397:180;-1:-1:-1;1397:180:1:o;1805:247::-;1864:6;1917:2;1905:9;1896:7;1892:23;1888:32;1885:52;;;1933:1;1930;1923:12;1885:52;1972:9;1959:23;1991:31;2016:5;1991:31;:::i;2057:456::-;2134:6;2142;2150;2203:2;2191:9;2182:7;2178:23;2174:32;2171:52;;;2219:1;2216;2209:12;2171:52;2258:9;2245:23;2277:31;2302:5;2277:31;:::i;:::-;2327:5;-1:-1:-1;2384:2:1;2369:18;;2356:32;2397:33;2356:32;2397:33;:::i;:::-;2057:456;;2449:7;;-1:-1:-1;;;2503:2:1;2488:18;;;;2475:32;;2057:456::o;2915:388::-;2983:6;2991;3044:2;3032:9;3023:7;3019:23;3015:32;3012:52;;;3060:1;3057;3050:12;3012:52;3099:9;3086:23;3118:31;3143:5;3118:31;:::i;:::-;3168:5;-1:-1:-1;3225:2:1;3210:18;;3197:32;3238:33;3197:32;3238:33;:::i;:::-;3290:7;3280:17;;;2915:388;;;;;:::o;3636:118::-;3722:5;3715:13;3708:21;3701:5;3698:32;3688:60;;3744:1;3741;3734:12;3759:390;3832:6;3840;3893:2;3881:9;3872:7;3868:23;3864:32;3861:52;;;3909:1;3906;3899:12;3861:52;3948:9;3935:23;3967:31;3992:5;3967:31;:::i;:::-;4017:5;-1:-1:-1;4074:2:1;4059:18;;4046:32;4087:30;4046:32;4087:30;:::i;4154:380::-;4233:1;4229:12;;;;4276;;;4297:61;;4351:4;4343:6;4339:17;4329:27;;4297:61;4404:2;4396:6;4393:14;4373:18;4370:38;4367:161;;4450:10;4445:3;4441:20;4438:1;4431:31;4485:4;4482:1;4475:15;4513:4;4510:1;4503:15;4367:161;;4154:380;;;:::o;4539:356::-;4741:2;4723:21;;;4760:18;;;4753:30;4819:34;4814:2;4799:18;;4792:62;4886:2;4871:18;;4539:356::o;5395:127::-;5456:10;5451:3;5447:20;5444:1;5437:31;5487:4;5484:1;5477:15;5511:4;5508:1;5501:15;5527:217;5567:1;5593;5583:132;;5637:10;5632:3;5628:20;5625:1;5618:31;5672:4;5669:1;5662:15;5700:4;5697:1;5690:15;5583:132;-1:-1:-1;5729:9:1;;5527:217::o;8386:128::-;8453:9;;;8474:11;;;8471:37;;;8488:18;;:::i;8519:168::-;8592:9;;;8623;;8640:15;;;8634:22;;8620:37;8610:71;;8661:18;;:::i;9094:216::-;9158:9;;;9186:11;;;9133:3;9216:9;;9244:10;;9240:19;;9269:10;;9261:19;;9237:44;9234:70;;;9284:18;;:::i;:::-;9234:70;;9094:216;;;;:::o;9315:125::-;9380:9;;;9401:10;;;9398:36;;;9414:18;;:::i;10088:245::-;10155:6;10208:2;10196:9;10187:7;10183:23;10179:32;10176:52;;;10224:1;10221;10214:12;10176:52;10256:9;10250:16;10275:28;10297:5;10275:28;:::i;10698:200::-;10764:9;;;10737:4;10792:9;;10820:10;;10832:12;;;10816:29;10855:12;;;10847:21;;10813:56;10810:82;;;10872:18;;:::i

Swarm Source

ipfs://41925155a55565938207680f371f30558c3d190e3f64afa3ca8822d813d51b55
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.