ETH Price: $3,172.86 (-2.82%)

Token

ACCEL (ACCEL)
 

Overview

Max Total Supply

5,000,000,000 ACCEL

Holders

2,169

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.167832479138623806 ACCEL

Value
$0.00
0xB7d4826D7f5cc9c03B8f3904a93a95F6d6A0a8fF
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

Redefining Web3 and Decentralized Finance through easy-to-use technology.

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Accel

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-01-06
*/

//import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/v3.4.0-solc-0.7/contracts/token/ERC20/ERC20.sol";
// SPDX-License-Identifier: MIT
// 84 71 32 64 84 104 101 71 104 111 115 116 68 101 118 
// ASCII

pragma solidity ^0.8.4;

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

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

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        uint256 c = a + b;
        if (c < a) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b > a) return (false, 0);
        return (true, a - b);
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, 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 (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a / b);
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a % b);
    }

    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) return 0;
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: modulo by zero");
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        return a - b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryDiv}.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a % b;
    }
}


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

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

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

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

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

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

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}


/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of returning `false` on failure. This behavior is nonetheless conventional
 * and does not conflict with the expectations of ERC20 applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20 {
    using SafeMath for uint256;

    mapping (address => uint256) private _balances;

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;
    uint8 private _decimals;

    /**
     * @dev Sets the values for {name} and {symbol}, initializes {decimals} with
     * a default value of 18.
     *
     * To select a different value for {decimals}, use {_setupDecimals}.
     *
     * All three of these values are immutable: they can only be set once during
     * construction.
     */
    constructor (string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        _decimals = 18;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless {_setupDecimals} is
     * called.
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual returns (uint8) {
        return _decimals;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    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;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    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;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    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);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     */
    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);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    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);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    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);
    }

    /**
     * @dev Sets {decimals} to a value other than the default one of 18.
     *
     * WARNING: This function should only be called from the constructor. Most
     * applications that interact with token contracts will not expect
     * {decimals} to ever change, and may work incorrectly if it does.
     */
    function _setupDecimals(uint8 decimals_) internal virtual {
        _decimals = decimals_;
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { }
}


contract Ownable {
    address public _owner;
    event onOwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    constructor() {
        _owner = msg.sender;
    }
    modifier onlyOwner() {
        require(msg.sender == _owner);
        _;
    }

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

    function transferOwnership(address _newOwner) public onlyOwner {
        require(_newOwner != address(0));
        emit onOwnershipTransferred(_owner, _newOwner);
        _owner = _newOwner;
    }
}



interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

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

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}


// pragma solidity >=0.5.0;

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);

    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
    
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);

    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;

    function initialize(address, address) external;
}

// pragma solidity >=0.6.2;

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

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}



// pragma solidity >=0.6.2;

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

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

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

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

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

        _;

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

contract Accel is ERC20, Ownable, ReentrancyGuard {
    using SafeMath for uint256;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;

    uint256 public feeDevelopment = 30;
    uint256 public feeSustainability = 20;
    uint256 public feeStaking = 50;

    mapping (address => bool) public isExcludedFromFees;
    mapping (address => bool) public isInBlacklist;
    mapping (address => bool) public isInWhitelist;
    mapping (address => bool) public isrouterother;

    uint256 private _totalSupply = 5000000000 * (10**18);
    string private _name = "ACCEL";
    string private _symbol = "ACCEL";

    uint256 public _tokenThresholdToSwap = _totalSupply / 100000;
    bool inSwapAndLiquify;
    bool swapping;
    bool public swapAndSendFeesEnabled = true;
    bool public CEX = false;

    address public walletSustainability;
    address public walletDevelopment;
    address public walletStaking;
    address public DAOcontrol;

    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }

    constructor (address _walletSustainability, address _walletDevelopment, address _walletStaking, address _DAOcontrol) ERC20(_name, _symbol) {
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());

        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;

        walletSustainability = _walletSustainability;
        walletDevelopment = _walletDevelopment;
        walletStaking = _walletStaking;
        DAOcontrol = _DAOcontrol;

        // exclude from paying fees
        excludeFromFee(owner());
        excludeFromFee(address(this));

        _mint(owner(), _totalSupply);
    }

    receive() external payable {}

    function updateWalletSustainability(address _walletSustainability) external {
        require(_msgSender() == DAOcontrol);
        walletSustainability = _walletSustainability;
    }

    function updateWalletDevelopment(address _walletDevelopment) external {
        require(_msgSender() == DAOcontrol);
        walletDevelopment = _walletDevelopment;
    }

    function updateWalletStaking(address _walletStaking) external {
        require(_msgSender() == DAOcontrol);
        walletStaking = _walletStaking;
    }
    function updateDAOcontrol(address _DAOcontrol) external {
        require(_msgSender() == DAOcontrol);
        DAOcontrol = _DAOcontrol;
    }

    function excludeFromFee(address account) public {
        require(_msgSender() == DAOcontrol);
        isExcludedFromFees[account] = true;
    }
    
    function includeInFee(address account) public {
        require(_msgSender() == DAOcontrol);
        isExcludedFromFees[account] = false;
    }

    function setSwapAndSendFeesEnabled(bool _enabled) public {
        require(_msgSender() == DAOcontrol);
        swapAndSendFeesEnabled = _enabled;
    }

    function setThresoldToSwap(uint256 amount) public {
        require(_msgSender() == DAOcontrol);
        _tokenThresholdToSwap = amount;
    }

    function setFeesPercent(uint256 devFee, uint256 sustainabilityFee, uint256 stakingFee) public {
        require(_msgSender() == DAOcontrol);
        feeDevelopment = devFee;
        feeSustainability  = sustainabilityFee;
        feeStaking = stakingFee;
        require(devFee + sustainabilityFee + stakingFee <= 490, "Check fee limit");
    }

    function setBlacklistWallet(address account, bool blacklisted) external {
        require(!CEX);
        require(!isInWhitelist[account]);
        require(_msgSender() == DAOcontrol);
        isInBlacklist[account] = blacklisted;
    }

    function setCEXWhitelistWallet(address account) external {
        require(_msgSender() == DAOcontrol);
        isInWhitelist[account] = true;
    }

    function setRouterOther(address account, bool enabled) external {
        require(_msgSender() == DAOcontrol);
        isrouterother[account] = enabled;
    }

    function AddToCEX (bool enabled) external {
        require(_msgSender() == DAOcontrol);
        CEX = enabled;
    }  

    function manualswap() external lockTheSwap {
        require(_msgSender() == DAOcontrol);
        uint256 contractBalance = balanceOf(address(this));
        swapTokensForEth(contractBalance);
    }

    function manualswapcustom(uint256 percentage) external lockTheSwap {
        require(_msgSender() == DAOcontrol);
        uint256 contractBalance = balanceOf(address(this));
        uint256 swapbalance = contractBalance.div(10**5).mul(percentage);
        swapTokensForEth(swapbalance);
    }

    function manualsend() external {
        require(_msgSender() == DAOcontrol);
        uint256 amount = address(this).balance;

        uint256 ethDevelopment = amount.mul(feeDevelopment).div(feeDevelopment.add(feeSustainability).add(feeStaking));
        uint256 ethSustainability = amount.mul(feeSustainability).div(feeDevelopment.add(feeSustainability).add(feeStaking));
        uint256 ethStaking = amount.sub(ethDevelopment).sub(ethSustainability);

        //Send out fees
        if(ethDevelopment > 0)
            payable(walletDevelopment).transfer(ethDevelopment);
        if(ethSustainability > 0)
            payable(walletSustainability).transfer(ethSustainability);
        if(ethStaking > 0)
            payable(walletStaking).transfer(ethStaking);
    }
    
    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");
        require(amount > 0, "Transfer amount must be greater than zero");
        require(isInBlacklist[from] == false, "You're in blacklist");

        bool overMinTokenBalance = balanceOf(address(this)) >= _tokenThresholdToSwap;
        if (
            overMinTokenBalance &&
            !inSwapAndLiquify &&
            from != uniswapV2Pair &&
            swapAndSendFeesEnabled
        ) {
            swapAndSendFees();
        }
    
        bool takeFee = true;
        if(isExcludedFromFees[from] || isExcludedFromFees[to] || (from != uniswapV2Pair && to != uniswapV2Pair && !isrouterother[from] && !isrouterother[to])) {
            takeFee = false;
        }

        uint256 finalTransferAmount = amount;
        if(takeFee) {
            uint256 totalFeesPercent = feeDevelopment.add(feeSustainability).add(feeStaking);
        	uint256 fees = amount.mul(totalFeesPercent).div(1000);
        	finalTransferAmount = amount.sub(fees);
            super._transfer(from, address(this), fees);
        }

        super._transfer(from, to, finalTransferAmount);
    }

    function swapAndSendFees() private lockTheSwap {
        swapTokensForEth(balanceOf(address(this)));
        uint256 amount = address(this).balance;

        uint256 ethDevelopment = amount.mul(feeDevelopment).div(feeDevelopment.add(feeSustainability).add(feeStaking));
        uint256 ethSustainability = amount.mul(feeSustainability).div(feeDevelopment.add(feeSustainability).add(feeStaking));
        uint256 ethStaking = amount.sub(ethDevelopment).sub(ethSustainability);

        //Send out fees
        if(ethDevelopment > 0)
            payable(walletDevelopment).transfer(ethDevelopment);
        if(ethSustainability > 0)
            payable(walletSustainability).transfer(ethSustainability);
        if(ethStaking > 0)
            payable(walletStaking).transfer(ethStaking);
    }

    function swapTokensForEth(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_walletSustainability","type":"address"},{"internalType":"address","name":"_walletDevelopment","type":"address"},{"internalType":"address","name":"_walletStaking","type":"address"},{"internalType":"address","name":"_DAOcontrol","type":"address"}],"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":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"onOwnershipTransferred","type":"event"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"AddToCEX","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"CEX","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"DAOcontrol","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_tokenThresholdToSwap","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":"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":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeDevelopment","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeStaking","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeSustainability","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"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":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isInBlacklist","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isInWhitelist","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isrouterother","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualsend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"manualswap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"percentage","type":"uint256"}],"name":"manualswapcustom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"blacklisted","type":"bool"}],"name":"setBlacklistWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"setCEXWhitelistWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"devFee","type":"uint256"},{"internalType":"uint256","name":"sustainabilityFee","type":"uint256"},{"internalType":"uint256","name":"stakingFee","type":"uint256"}],"name":"setFeesPercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"enabled","type":"bool"}],"name":"setRouterOther","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndSendFeesEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"setThresoldToSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndSendFeesEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"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":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_DAOcontrol","type":"address"}],"name":"updateDAOcontrol","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_walletDevelopment","type":"address"}],"name":"updateWalletDevelopment","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_walletStaking","type":"address"}],"name":"updateWalletStaking","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_walletSustainability","type":"address"}],"name":"updateWalletSustainability","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"walletDevelopment","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"walletStaking","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"walletSustainability","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

601e6009556014600a556032600b556b1027e72f1f1281308800000060105560c060405260056080819052641050d0d15360da1b60a09081526200004791601191906200065a565b50604080518082019091526005808252641050d0d15360da1b602090920191825262000076916012916200065a565b50620186a06010546200008a9190620007bb565b6013556014805463ffff0000191662010000179055348015620000ac57600080fd5b506040516200273f3803806200273f833981016040819052620000cf916200073a565b60118054620000de90620007dc565b80601f01602080910402602001604051908101604052809291908181526020018280546200010c90620007dc565b80156200015d5780601f1062000131576101008083540402835291602001916200015d565b820191906000526020600020905b8154815290600101906020018083116200013f57829003601f168201915b5050505050601280546200017190620007dc565b80601f01602080910402602001604051908101604052809291908181526020018280546200019f90620007dc565b8015620001f05780601f10620001c457610100808354040283529160200191620001f0565b820191906000526020600020905b815481529060010190602001808311620001d257829003601f168201915b505084516200020a9350600392506020860191506200065a565b508051620002209060049060208401906200065a565b50506005805433610100026001600160a81b03199091161760121790555060016006556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d91600091839163c45a0155916004808301926020929190829003018186803b1580156200029457600080fd5b505afa158015620002a9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002cf91906200071d565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200031857600080fd5b505afa1580156200032d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200035391906200071d565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200039c57600080fd5b505af1158015620003b1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620003d791906200071d565b600780546001600160a01b03199081166001600160a01b038681169190911790925560088054821684841617905560148054600160201b600160c01b0319166401000000008b8516021790556015805482168984161790556016805482168884161790556017805490911691861691909117905590506200046f6200046960055461010090046001600160a01b031690565b620004ab565b6200047a30620004ab565b6200049f6200049660055461010090046001600160a01b031690565b601054620004f0565b50505050505062000819565b6017546001600160a01b0316336001600160a01b031614620004cc57600080fd5b6001600160a01b03166000908152600c60205260409020805460ff19166001179055565b6001600160a01b0382166200054c5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b6200056881600254620005f060201b6200113e1790919060201c565b6002556001600160a01b038216600090815260208181526040909120546200059b9183906200113e620005f0821b17901c565b6001600160a01b038316600081815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b600080620005ff838562000796565b905083811015620006535760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640162000543565b9392505050565b8280546200066890620007dc565b90600052602060002090601f0160209004810192826200068c5760008555620006d7565b82601f10620006a757805160ff1916838001178555620006d7565b82800160010185558215620006d7579182015b82811115620006d7578251825591602001919060010190620006ba565b50620006e5929150620006e9565b5090565b5b80821115620006e55760008155600101620006ea565b80516001600160a01b03811681146200071857600080fd5b919050565b6000602082840312156200072f578081fd5b620006538262000700565b6000806000806080858703121562000750578283fd5b6200075b8562000700565b93506200076b6020860162000700565b92506200077b6040860162000700565b91506200078b6060860162000700565b905092959194509250565b60008219821115620007b657634e487b7160e01b81526011600452602481fd5b500190565b600082620007d757634e487b7160e01b81526012600452602481fd5b500490565b600181811c90821680620007f157607f821691505b602082108114156200081357634e487b7160e01b600052602260045260246000fd5b50919050565b611f1680620008296000396000f3fe6080604052600436106102815760003560e01c80636fc3eaec1161014f578063b3d5eee1116100c1578063ea2f0b371161007a578063ea2f0b37146107f7578063ecca3b1614610817578063f2fde38b14610847578063fd45bc9914610867578063ff3914a314610887578063ff768b20146108a757600080fd5b8063b3d5eee11461071b578063b41c9eda1461073c578063c3c8cd801461075c578063da53267914610771578063dd62ed3e14610791578063e4a0f9f5146107d757600080fd5b80638da5cb5b116101135780638da5cb5b1461064e57806395d89b41146106715780639caf9b0014610686578063a457c2d7146106b6578063a9059cbb146106d6578063b2bdfa7b146106f657600080fd5b80636fc3eaec146105ad57806370a08231146105c25780638720111d146105f8578063876c4cc51461061857806389e7b81b1461062e57600080fd5b806339509351116101f357806349bd5a5e116101ac57806349bd5a5e146104e75780634b8fb314146105075780634ce9f13c1461051d5780634fbee1931461053d578063600775c91461056d57806362b9bbb61461058d57600080fd5b806339509351146104295780633af87bcd146104495780633f8d45fc14610469578063400291f81461048957806341fdc581146104b1578063437823ec146104c757600080fd5b806313096a1a1161024557806313096a1a1461035a578063148d21611461037a5780631694505e1461039a57806318160ddd146103d257806323b872dd146103e7578063313ce5671461040757600080fd5b806306dce8dd1461028d57806306fdde03146102b6578063091646a9146102d8578063095ea7b3146102fa57806309fd82121461032a57600080fd5b3661028857005b600080fd5b34801561029957600080fd5b506102a3600b5481565b6040519081526020015b60405180910390f35b3480156102c257600080fd5b506102cb6108c7565b6040516102ad9190611c4b565b3480156102e457600080fd5b506102f86102f3366004611bee565b610959565b005b34801561030657600080fd5b5061031a610315366004611bc3565b610997565b60405190151581526020016102ad565b34801561033657600080fd5b5061031a610345366004611adf565b600e6020526000908152604090205460ff1681565b34801561036657600080fd5b506102f8610375366004611c08565b6109ae565b34801561038657600080fd5b5060145461031a9062010000900460ff1681565b3480156103a657600080fd5b506007546103ba906001600160a01b031681565b6040516001600160a01b0390911681526020016102ad565b3480156103de57600080fd5b506002546102a3565b3480156103f357600080fd5b5061031a610402366004611b4f565b6109d3565b34801561041357600080fd5b5060055460405160ff90911681526020016102ad565b34801561043557600080fd5b5061031a610444366004611bc3565b610a3c565b34801561045557600080fd5b506102f8610464366004611b8f565b610a72565b34801561047557600080fd5b506102f8610484366004611adf565b610abd565b34801561049557600080fd5b506014546103ba9064010000000090046001600160a01b031681565b3480156104bd57600080fd5b506102a360135481565b3480156104d357600080fd5b506102f86104e2366004611adf565b610b0b565b3480156104f357600080fd5b506008546103ba906001600160a01b031681565b34801561051357600080fd5b506102a360095481565b34801561052957600080fd5b506102f8610538366004611adf565b610b4f565b34801561054957600080fd5b5061031a610558366004611adf565b600c6020526000908152604090205460ff1681565b34801561057957600080fd5b506102f8610588366004611adf565b610b91565b34801561059957600080fd5b506015546103ba906001600160a01b031681565b3480156105b957600080fd5b506102f8610bd3565b3480156105ce57600080fd5b506102a36105dd366004611adf565b6001600160a01b031660009081526020819052604090205490565b34801561060457600080fd5b506016546103ba906001600160a01b031681565b34801561062457600080fd5b506102a3600a5481565b34801561063a57600080fd5b506102f8610649366004611c08565b610d53565b34801561065a57600080fd5b5060055461010090046001600160a01b03166103ba565b34801561067d57600080fd5b506102cb610dc8565b34801561069257600080fd5b5061031a6106a1366004611adf565b600d6020526000908152604090205460ff1681565b3480156106c257600080fd5b5061031a6106d1366004611bc3565b610dd7565b3480156106e257600080fd5b5061031a6106f1366004611bc3565b610e26565b34801561070257600080fd5b506005546103ba9061010090046001600160a01b031681565b34801561072757600080fd5b5060145461031a906301000000900460ff1681565b34801561074857600080fd5b506102f8610757366004611b8f565b610e33565b34801561076857600080fd5b506102f8610ebb565b34801561077d57600080fd5b506102f861078c366004611adf565b610f14565b34801561079d57600080fd5b506102a36107ac366004611b17565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156107e357600080fd5b506102f86107f2366004611adf565b610f56565b34801561080357600080fd5b506102f8610812366004611adf565b610f9a565b34801561082357600080fd5b5061031a610832366004611adf565b600f6020526000908152604090205460ff1681565b34801561085357600080fd5b506102f8610862366004611adf565b610fdb565b34801561087357600080fd5b506017546103ba906001600160a01b031681565b34801561089357600080fd5b506102f86108a2366004611bee565b611071565b3480156108b357600080fd5b506102f86108c2366004611c20565b6110ad565b6060600380546108d690611e04565b80601f016020809104026020016040519081016040528092919081815260200182805461090290611e04565b801561094f5780601f106109245761010080835404028352916020019161094f565b820191906000526020600020905b81548152906001019060200180831161093257829003601f168201915b5050505050905090565b6017546001600160a01b0316336001600160a01b03161461097957600080fd5b6014805491151563010000000263ff00000019909216919091179055565b60006109a43384846111a4565b5060015b92915050565b6017546001600160a01b0316336001600160a01b0316146109ce57600080fd5b601355565b60006109e08484846112c9565b610a328433610a2d85604051806060016040528060288152602001611e94602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611567565b6111a4565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109a4918590610a2d908661113e565b6017546001600160a01b0316336001600160a01b031614610a9257600080fd5b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b6017546001600160a01b0316336001600160a01b031614610add57600080fd5b601480546001600160a01b0390921664010000000002640100000000600160c01b0319909216919091179055565b6017546001600160a01b0316336001600160a01b031614610b2b57600080fd5b6001600160a01b03166000908152600c60205260409020805460ff19166001179055565b6017546001600160a01b0316336001600160a01b031614610b6f57600080fd5b601780546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610bb157600080fd5b601680546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610bf357600080fd5b60004790506000610c34610c20600b54610c1a600a5460095461113e90919063ffffffff16565b9061113e565b600954610c2e90859061159e565b9061161d565b90506000610c66610c58600b54610c1a600a5460095461113e90919063ffffffff16565b600a54610c2e90869061159e565b90506000610c7e82610c788686611678565b90611678565b90508215610cc2576015546040516001600160a01b039091169084156108fc029085906000818181858888f19350505050158015610cc0573d6000803e3d6000fd5b505b8115610d0b576014546040516401000000009091046001600160a01b0316906108fc8415029084906000818181858888f19350505050158015610d09573d6000803e3d6000fd5b505b8015610d4d576016546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015610d4b573d6000803e3d6000fd5b505b50505050565b6014805460ff191660011790556017546001600160a01b0316610d733390565b6001600160a01b031614610d8657600080fd5b3060009081526020819052604081205490610dae83610da884620186a061161d565b9061159e565b9050610db9816116d4565b50506014805460ff1916905550565b6060600480546108d690611e04565b60006109a43384610a2d85604051806060016040528060258152602001611ebc602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611567565b60006109a43384846112c9565b6014546301000000900460ff1615610e4a57600080fd5b6001600160a01b0382166000908152600e602052604090205460ff1615610e7057600080fd5b6017546001600160a01b0316336001600160a01b031614610e9057600080fd5b6001600160a01b03919091166000908152600d60205260409020805460ff1916911515919091179055565b6014805460ff191660011790556017546001600160a01b0316610edb3390565b6001600160a01b031614610eee57600080fd5b30600090815260208190526040902054610f07816116d4565b506014805460ff19169055565b6017546001600160a01b0316336001600160a01b031614610f3457600080fd5b601580546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610f7657600080fd5b6001600160a01b03166000908152600e60205260409020805460ff19166001179055565b6017546001600160a01b0316336001600160a01b031614610fba57600080fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b60055461010090046001600160a01b03163314610ff757600080fd5b6001600160a01b03811661100a57600080fd5b6005546040516001600160a01b0380841692610100900416907f2e3feca4334579203cd183fe1ced9524940047e5586fe13e8cc5dd1babaf6e8290600090a3600580546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6017546001600160a01b0316336001600160a01b03161461109157600080fd5b60148054911515620100000262ff000019909216919091179055565b6017546001600160a01b0316336001600160a01b0316146110cd57600080fd5b6009839055600a829055600b8190556101ea816110ea8486611d96565b6110f49190611d96565b11156111395760405162461bcd60e51b815260206004820152600f60248201526e10da1958dac8199959481b1a5b5a5d608a1b60448201526064015b60405180910390fd5b505050565b60008061114b8385611d96565b90508381101561119d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401611130565b9392505050565b6001600160a01b0383166112065760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401611130565b6001600160a01b0382166112675760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401611130565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166112ef5760405162461bcd60e51b815260040161113090611ce1565b6001600160a01b0382166113155760405162461bcd60e51b815260040161113090611c9e565b600081116113775760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401611130565b6001600160a01b0383166000908152600d602052604090205460ff16156113d65760405162461bcd60e51b8152602060048201526013602482015272165bdd49dc99481a5b88189b1858dadb1a5cdd606a1b6044820152606401611130565b601354306000908152602081905260409020541080159081906113fc575060145460ff16155b801561141657506008546001600160a01b03858116911614155b801561142a575060145462010000900460ff165b1561143757611437611851565b6001600160a01b0384166000908152600c602052604090205460019060ff168061147957506001600160a01b0384166000908152600c602052604090205460ff165b806114f557506008546001600160a01b038681169116148015906114ab57506008546001600160a01b03858116911614155b80156114d057506001600160a01b0385166000908152600f602052604090205460ff16155b80156114f557506001600160a01b0384166000908152600f602052604090205460ff16155b156114fe575060005b828115611554576000611524600b54610c1a600a5460095461113e90919063ffffffff16565b905060006115386103e8610c2e888561159e565b90506115448682611678565b92506115518830836119c1565b50505b61155f8686836119c1565b505050505050565b6000818484111561158b5760405162461bcd60e51b81526004016111309190611c4b565b506115968385611ded565b949350505050565b6000826115ad575060006109a8565b60006115b98385611dce565b9050826115c68583611dae565b1461119d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401611130565b600080821161166e5760405162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f0000000000006044820152606401611130565b61119d8284611dae565b6000828211156116ca5760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f7700006044820152606401611130565b61119d8284611ded565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061171757634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201810191909152600754604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b15801561176b57600080fd5b505afa15801561177f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a39190611afb565b816001815181106117c457634e487b7160e01b600052603260045260246000fd5b6001600160a01b0392831660209182029290920101526007546117ea91309116846111a4565b60075460405163791ac94760e01b81526001600160a01b039091169063791ac94790611823908590600090869030904290600401611d26565b600060405180830381600087803b15801561183d57600080fd5b505af115801561155f573d6000803e3d6000fd5b6014805460ff19166001179055611885611880306001600160a01b031660009081526020819052604090205490565b6116d4565b600047905060006118ac610c20600b54610c1a600a5460095461113e90919063ffffffff16565b905060006118d0610c58600b54610c1a600a5460095461113e90919063ffffffff16565b905060006118e282610c788686611678565b90508215611926576015546040516001600160a01b039091169084156108fc029085906000818181858888f19350505050158015611924573d6000803e3d6000fd5b505b811561196f576014546040516401000000009091046001600160a01b0316906108fc8415029084906000818181858888f1935050505015801561196d573d6000803e3d6000fd5b505b80156119b1576016546040516001600160a01b039091169082156108fc029083906000818181858888f193505050501580156119af573d6000803e3d6000fd5b505b50506014805460ff191690555050565b6001600160a01b0383166119e75760405162461bcd60e51b815260040161113090611ce1565b6001600160a01b038216611a0d5760405162461bcd60e51b815260040161113090611c9e565b611a4a81604051806060016040528060268152602001611e6e602691396001600160a01b0386166000908152602081905260409020549190611567565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611a79908261113e565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91016112bc565b80358015158114611ada57600080fd5b919050565b600060208284031215611af0578081fd5b813561119d81611e55565b600060208284031215611b0c578081fd5b815161119d81611e55565b60008060408385031215611b29578081fd5b8235611b3481611e55565b91506020830135611b4481611e55565b809150509250929050565b600080600060608486031215611b63578081fd5b8335611b6e81611e55565b92506020840135611b7e81611e55565b929592945050506040919091013590565b60008060408385031215611ba1578182fd5b8235611bac81611e55565b9150611bba60208401611aca565b90509250929050565b60008060408385031215611bd5578182fd5b8235611be081611e55565b946020939093013593505050565b600060208284031215611bff578081fd5b61119d82611aca565b600060208284031215611c19578081fd5b5035919050565b600080600060608486031215611c34578283fd5b505081359360208301359350604090920135919050565b6000602080835283518082850152825b81811015611c7757858101830151858201604001528201611c5b565b81811115611c885783604083870101525b50601f01601f1916929092016040019392505050565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b600060a082018783526020878185015260a0604085015281875180845260c0860191508289019350845b81811015611d755784516001600160a01b031683529383019391830191600101611d50565b50506001600160a01b03969096166060850152505050608001529392505050565b60008219821115611da957611da9611e3f565b500190565b600082611dc957634e487b7160e01b81526012600452602481fd5b500490565b6000816000190483118215151615611de857611de8611e3f565b500290565b600082821015611dff57611dff611e3f565b500390565b600181811c90821680611e1857607f821691505b60208210811415611e3957634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b0381168114611e6a57600080fd5b5056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220518c4a14fc5bb2e6b6130a30623657137381817138dff9c7badb78bace6ebc7264736f6c63430008040033000000000000000000000000103ee780580b032eb0b824ab2009d7d32df9cb68000000000000000000000000bde314e7a15306ca7bc6292bec8e7914c36d2c4800000000000000000000000001d5687e35e7ca8efa5ccd83975a7bd2b5989dd200000000000000000000000052c6d1148443f7972afe2e0e775688106a84457a

Deployed Bytecode

0x6080604052600436106102815760003560e01c80636fc3eaec1161014f578063b3d5eee1116100c1578063ea2f0b371161007a578063ea2f0b37146107f7578063ecca3b1614610817578063f2fde38b14610847578063fd45bc9914610867578063ff3914a314610887578063ff768b20146108a757600080fd5b8063b3d5eee11461071b578063b41c9eda1461073c578063c3c8cd801461075c578063da53267914610771578063dd62ed3e14610791578063e4a0f9f5146107d757600080fd5b80638da5cb5b116101135780638da5cb5b1461064e57806395d89b41146106715780639caf9b0014610686578063a457c2d7146106b6578063a9059cbb146106d6578063b2bdfa7b146106f657600080fd5b80636fc3eaec146105ad57806370a08231146105c25780638720111d146105f8578063876c4cc51461061857806389e7b81b1461062e57600080fd5b806339509351116101f357806349bd5a5e116101ac57806349bd5a5e146104e75780634b8fb314146105075780634ce9f13c1461051d5780634fbee1931461053d578063600775c91461056d57806362b9bbb61461058d57600080fd5b806339509351146104295780633af87bcd146104495780633f8d45fc14610469578063400291f81461048957806341fdc581146104b1578063437823ec146104c757600080fd5b806313096a1a1161024557806313096a1a1461035a578063148d21611461037a5780631694505e1461039a57806318160ddd146103d257806323b872dd146103e7578063313ce5671461040757600080fd5b806306dce8dd1461028d57806306fdde03146102b6578063091646a9146102d8578063095ea7b3146102fa57806309fd82121461032a57600080fd5b3661028857005b600080fd5b34801561029957600080fd5b506102a3600b5481565b6040519081526020015b60405180910390f35b3480156102c257600080fd5b506102cb6108c7565b6040516102ad9190611c4b565b3480156102e457600080fd5b506102f86102f3366004611bee565b610959565b005b34801561030657600080fd5b5061031a610315366004611bc3565b610997565b60405190151581526020016102ad565b34801561033657600080fd5b5061031a610345366004611adf565b600e6020526000908152604090205460ff1681565b34801561036657600080fd5b506102f8610375366004611c08565b6109ae565b34801561038657600080fd5b5060145461031a9062010000900460ff1681565b3480156103a657600080fd5b506007546103ba906001600160a01b031681565b6040516001600160a01b0390911681526020016102ad565b3480156103de57600080fd5b506002546102a3565b3480156103f357600080fd5b5061031a610402366004611b4f565b6109d3565b34801561041357600080fd5b5060055460405160ff90911681526020016102ad565b34801561043557600080fd5b5061031a610444366004611bc3565b610a3c565b34801561045557600080fd5b506102f8610464366004611b8f565b610a72565b34801561047557600080fd5b506102f8610484366004611adf565b610abd565b34801561049557600080fd5b506014546103ba9064010000000090046001600160a01b031681565b3480156104bd57600080fd5b506102a360135481565b3480156104d357600080fd5b506102f86104e2366004611adf565b610b0b565b3480156104f357600080fd5b506008546103ba906001600160a01b031681565b34801561051357600080fd5b506102a360095481565b34801561052957600080fd5b506102f8610538366004611adf565b610b4f565b34801561054957600080fd5b5061031a610558366004611adf565b600c6020526000908152604090205460ff1681565b34801561057957600080fd5b506102f8610588366004611adf565b610b91565b34801561059957600080fd5b506015546103ba906001600160a01b031681565b3480156105b957600080fd5b506102f8610bd3565b3480156105ce57600080fd5b506102a36105dd366004611adf565b6001600160a01b031660009081526020819052604090205490565b34801561060457600080fd5b506016546103ba906001600160a01b031681565b34801561062457600080fd5b506102a3600a5481565b34801561063a57600080fd5b506102f8610649366004611c08565b610d53565b34801561065a57600080fd5b5060055461010090046001600160a01b03166103ba565b34801561067d57600080fd5b506102cb610dc8565b34801561069257600080fd5b5061031a6106a1366004611adf565b600d6020526000908152604090205460ff1681565b3480156106c257600080fd5b5061031a6106d1366004611bc3565b610dd7565b3480156106e257600080fd5b5061031a6106f1366004611bc3565b610e26565b34801561070257600080fd5b506005546103ba9061010090046001600160a01b031681565b34801561072757600080fd5b5060145461031a906301000000900460ff1681565b34801561074857600080fd5b506102f8610757366004611b8f565b610e33565b34801561076857600080fd5b506102f8610ebb565b34801561077d57600080fd5b506102f861078c366004611adf565b610f14565b34801561079d57600080fd5b506102a36107ac366004611b17565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156107e357600080fd5b506102f86107f2366004611adf565b610f56565b34801561080357600080fd5b506102f8610812366004611adf565b610f9a565b34801561082357600080fd5b5061031a610832366004611adf565b600f6020526000908152604090205460ff1681565b34801561085357600080fd5b506102f8610862366004611adf565b610fdb565b34801561087357600080fd5b506017546103ba906001600160a01b031681565b34801561089357600080fd5b506102f86108a2366004611bee565b611071565b3480156108b357600080fd5b506102f86108c2366004611c20565b6110ad565b6060600380546108d690611e04565b80601f016020809104026020016040519081016040528092919081815260200182805461090290611e04565b801561094f5780601f106109245761010080835404028352916020019161094f565b820191906000526020600020905b81548152906001019060200180831161093257829003601f168201915b5050505050905090565b6017546001600160a01b0316336001600160a01b03161461097957600080fd5b6014805491151563010000000263ff00000019909216919091179055565b60006109a43384846111a4565b5060015b92915050565b6017546001600160a01b0316336001600160a01b0316146109ce57600080fd5b601355565b60006109e08484846112c9565b610a328433610a2d85604051806060016040528060288152602001611e94602891396001600160a01b038a1660009081526001602090815260408083203384529091529020549190611567565b6111a4565b5060019392505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109a4918590610a2d908661113e565b6017546001600160a01b0316336001600160a01b031614610a9257600080fd5b6001600160a01b03919091166000908152600f60205260409020805460ff1916911515919091179055565b6017546001600160a01b0316336001600160a01b031614610add57600080fd5b601480546001600160a01b0390921664010000000002640100000000600160c01b0319909216919091179055565b6017546001600160a01b0316336001600160a01b031614610b2b57600080fd5b6001600160a01b03166000908152600c60205260409020805460ff19166001179055565b6017546001600160a01b0316336001600160a01b031614610b6f57600080fd5b601780546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610bb157600080fd5b601680546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610bf357600080fd5b60004790506000610c34610c20600b54610c1a600a5460095461113e90919063ffffffff16565b9061113e565b600954610c2e90859061159e565b9061161d565b90506000610c66610c58600b54610c1a600a5460095461113e90919063ffffffff16565b600a54610c2e90869061159e565b90506000610c7e82610c788686611678565b90611678565b90508215610cc2576015546040516001600160a01b039091169084156108fc029085906000818181858888f19350505050158015610cc0573d6000803e3d6000fd5b505b8115610d0b576014546040516401000000009091046001600160a01b0316906108fc8415029084906000818181858888f19350505050158015610d09573d6000803e3d6000fd5b505b8015610d4d576016546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015610d4b573d6000803e3d6000fd5b505b50505050565b6014805460ff191660011790556017546001600160a01b0316610d733390565b6001600160a01b031614610d8657600080fd5b3060009081526020819052604081205490610dae83610da884620186a061161d565b9061159e565b9050610db9816116d4565b50506014805460ff1916905550565b6060600480546108d690611e04565b60006109a43384610a2d85604051806060016040528060258152602001611ebc602591393360009081526001602090815260408083206001600160a01b038d1684529091529020549190611567565b60006109a43384846112c9565b6014546301000000900460ff1615610e4a57600080fd5b6001600160a01b0382166000908152600e602052604090205460ff1615610e7057600080fd5b6017546001600160a01b0316336001600160a01b031614610e9057600080fd5b6001600160a01b03919091166000908152600d60205260409020805460ff1916911515919091179055565b6014805460ff191660011790556017546001600160a01b0316610edb3390565b6001600160a01b031614610eee57600080fd5b30600090815260208190526040902054610f07816116d4565b506014805460ff19169055565b6017546001600160a01b0316336001600160a01b031614610f3457600080fd5b601580546001600160a01b0319166001600160a01b0392909216919091179055565b6017546001600160a01b0316336001600160a01b031614610f7657600080fd5b6001600160a01b03166000908152600e60205260409020805460ff19166001179055565b6017546001600160a01b0316336001600160a01b031614610fba57600080fd5b6001600160a01b03166000908152600c60205260409020805460ff19169055565b60055461010090046001600160a01b03163314610ff757600080fd5b6001600160a01b03811661100a57600080fd5b6005546040516001600160a01b0380841692610100900416907f2e3feca4334579203cd183fe1ced9524940047e5586fe13e8cc5dd1babaf6e8290600090a3600580546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6017546001600160a01b0316336001600160a01b03161461109157600080fd5b60148054911515620100000262ff000019909216919091179055565b6017546001600160a01b0316336001600160a01b0316146110cd57600080fd5b6009839055600a829055600b8190556101ea816110ea8486611d96565b6110f49190611d96565b11156111395760405162461bcd60e51b815260206004820152600f60248201526e10da1958dac8199959481b1a5b5a5d608a1b60448201526064015b60405180910390fd5b505050565b60008061114b8385611d96565b90508381101561119d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401611130565b9392505050565b6001600160a01b0383166112065760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401611130565b6001600160a01b0382166112675760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401611130565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b0383166112ef5760405162461bcd60e51b815260040161113090611ce1565b6001600160a01b0382166113155760405162461bcd60e51b815260040161113090611c9e565b600081116113775760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401611130565b6001600160a01b0383166000908152600d602052604090205460ff16156113d65760405162461bcd60e51b8152602060048201526013602482015272165bdd49dc99481a5b88189b1858dadb1a5cdd606a1b6044820152606401611130565b601354306000908152602081905260409020541080159081906113fc575060145460ff16155b801561141657506008546001600160a01b03858116911614155b801561142a575060145462010000900460ff165b1561143757611437611851565b6001600160a01b0384166000908152600c602052604090205460019060ff168061147957506001600160a01b0384166000908152600c602052604090205460ff165b806114f557506008546001600160a01b038681169116148015906114ab57506008546001600160a01b03858116911614155b80156114d057506001600160a01b0385166000908152600f602052604090205460ff16155b80156114f557506001600160a01b0384166000908152600f602052604090205460ff16155b156114fe575060005b828115611554576000611524600b54610c1a600a5460095461113e90919063ffffffff16565b905060006115386103e8610c2e888561159e565b90506115448682611678565b92506115518830836119c1565b50505b61155f8686836119c1565b505050505050565b6000818484111561158b5760405162461bcd60e51b81526004016111309190611c4b565b506115968385611ded565b949350505050565b6000826115ad575060006109a8565b60006115b98385611dce565b9050826115c68583611dae565b1461119d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401611130565b600080821161166e5760405162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f0000000000006044820152606401611130565b61119d8284611dae565b6000828211156116ca5760405162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f7700006044820152606401611130565b61119d8284611ded565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061171757634e487b7160e01b600052603260045260246000fd5b6001600160a01b03928316602091820292909201810191909152600754604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b15801561176b57600080fd5b505afa15801561177f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a39190611afb565b816001815181106117c457634e487b7160e01b600052603260045260246000fd5b6001600160a01b0392831660209182029290920101526007546117ea91309116846111a4565b60075460405163791ac94760e01b81526001600160a01b039091169063791ac94790611823908590600090869030904290600401611d26565b600060405180830381600087803b15801561183d57600080fd5b505af115801561155f573d6000803e3d6000fd5b6014805460ff19166001179055611885611880306001600160a01b031660009081526020819052604090205490565b6116d4565b600047905060006118ac610c20600b54610c1a600a5460095461113e90919063ffffffff16565b905060006118d0610c58600b54610c1a600a5460095461113e90919063ffffffff16565b905060006118e282610c788686611678565b90508215611926576015546040516001600160a01b039091169084156108fc029085906000818181858888f19350505050158015611924573d6000803e3d6000fd5b505b811561196f576014546040516401000000009091046001600160a01b0316906108fc8415029084906000818181858888f1935050505015801561196d573d6000803e3d6000fd5b505b80156119b1576016546040516001600160a01b039091169082156108fc029083906000818181858888f193505050501580156119af573d6000803e3d6000fd5b505b50506014805460ff191690555050565b6001600160a01b0383166119e75760405162461bcd60e51b815260040161113090611ce1565b6001600160a01b038216611a0d5760405162461bcd60e51b815260040161113090611c9e565b611a4a81604051806060016040528060268152602001611e6e602691396001600160a01b0386166000908152602081905260409020549190611567565b6001600160a01b038085166000908152602081905260408082209390935590841681522054611a79908261113e565b6001600160a01b038381166000818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91016112bc565b80358015158114611ada57600080fd5b919050565b600060208284031215611af0578081fd5b813561119d81611e55565b600060208284031215611b0c578081fd5b815161119d81611e55565b60008060408385031215611b29578081fd5b8235611b3481611e55565b91506020830135611b4481611e55565b809150509250929050565b600080600060608486031215611b63578081fd5b8335611b6e81611e55565b92506020840135611b7e81611e55565b929592945050506040919091013590565b60008060408385031215611ba1578182fd5b8235611bac81611e55565b9150611bba60208401611aca565b90509250929050565b60008060408385031215611bd5578182fd5b8235611be081611e55565b946020939093013593505050565b600060208284031215611bff578081fd5b61119d82611aca565b600060208284031215611c19578081fd5b5035919050565b600080600060608486031215611c34578283fd5b505081359360208301359350604090920135919050565b6000602080835283518082850152825b81811015611c7757858101830151858201604001528201611c5b565b81811115611c885783604083870101525b50601f01601f1916929092016040019392505050565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b600060a082018783526020878185015260a0604085015281875180845260c0860191508289019350845b81811015611d755784516001600160a01b031683529383019391830191600101611d50565b50506001600160a01b03969096166060850152505050608001529392505050565b60008219821115611da957611da9611e3f565b500190565b600082611dc957634e487b7160e01b81526012600452602481fd5b500490565b6000816000190483118215151615611de857611de8611e3f565b500290565b600082821015611dff57611dff611e3f565b500390565b600181811c90821680611e1857607f821691505b60208210811415611e3957634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6001600160a01b0381168114611e6a57600080fd5b5056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220518c4a14fc5bb2e6b6130a30623657137381817138dff9c7badb78bace6ebc7264736f6c63430008040033

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

000000000000000000000000103ee780580b032eb0b824ab2009d7d32df9cb68000000000000000000000000bde314e7a15306ca7bc6292bec8e7914c36d2c4800000000000000000000000001d5687e35e7ca8efa5ccd83975a7bd2b5989dd200000000000000000000000052c6d1148443f7972afe2e0e775688106a84457a

-----Decoded View---------------
Arg [0] : _walletSustainability (address): 0x103Ee780580b032eb0B824ab2009D7D32DF9cB68
Arg [1] : _walletDevelopment (address): 0xBDe314e7a15306CA7bC6292bec8e7914C36D2c48
Arg [2] : _walletStaking (address): 0x01D5687e35E7cA8Efa5cCD83975A7Bd2B5989DD2
Arg [3] : _DAOcontrol (address): 0x52C6d1148443F7972AFE2E0e775688106a84457A

-----Encoded View---------------
4 Constructor Arguments found :
Arg [0] : 000000000000000000000000103ee780580b032eb0b824ab2009d7d32df9cb68
Arg [1] : 000000000000000000000000bde314e7a15306ca7bc6292bec8e7914c36d2c48
Arg [2] : 00000000000000000000000001d5687e35e7ca8efa5ccd83975a7bd2b5989dd2
Arg [3] : 00000000000000000000000052c6d1148443f7972afe2e0e775688106a84457a


Deployed Bytecode Sourcemap

33294:8472:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33556:30;;;;;;;;;;;;;;;;;;;8543:25:1;;;8531:2;8516:18;33556:30:0;;;;;;;;13295:91;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;37540:120::-;;;;;;;;;;-1:-1:-1;37540:120:0;;;;;:::i;:::-;;:::i;:::-;;15441:169;;;;;;;;;;-1:-1:-1;15441:169:0;;;;;:::i;:::-;;:::i;:::-;;;3335:14:1;;3328:22;3310:41;;3298:2;3283:18;15441:169:0;3265:92:1;33706:46:0;;;;;;;;;;-1:-1:-1;33706:46:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;36453:145;;;;;;;;;;-1:-1:-1;36453:145:0;;;;;:::i;:::-;;:::i;34066:41::-;;;;;;;;;;-1:-1:-1;34066:41:0;;;;;;;;;;;33386;;;;;;;;;;-1:-1:-1;33386:41:0;;;;-1:-1:-1;;;;;33386:41:0;;;;;;-1:-1:-1;;;;;3126:32:1;;;3108:51;;3096:2;3081:18;33386:41:0;3063:102:1;14394:108:0;;;;;;;;;;-1:-1:-1;14482:12:0;;14394:108;;16092:321;;;;;;;;;;-1:-1:-1;16092:321:0;;;;;:::i;:::-;;:::i;14238:91::-;;;;;;;;;;-1:-1:-1;14312:9:0;;14238:91;;14312:9;;;;9709:36:1;;9697:2;9682:18;14238:91:0;9664:87:1;16822:218:0;;;;;;;;;;-1:-1:-1;16822:218:0;;;;;:::i;:::-;;:::i;37371:161::-;;;;;;;;;;-1:-1:-1;37371:161:0;;;;;:::i;:::-;;:::i;35287:185::-;;;;;;;;;;-1:-1:-1;35287:185:0;;;;;:::i;:::-;;:::i;34146:35::-;;;;;;;;;;-1:-1:-1;34146:35:0;;;;;;;-1:-1:-1;;;;;34146:35:0;;;33951:60;;;;;;;;;;;;;;;;35977:147;;;;;;;;;;-1:-1:-1;35977:147:0;;;;;:::i;:::-;;:::i;33434:28::-;;;;;;;;;;-1:-1:-1;33434:28:0;;;;-1:-1:-1;;;;;33434:28:0;;;33471:34;;;;;;;;;;;;;;;;35824:145;;;;;;;;;;-1:-1:-1;35824:145:0;;;;;:::i;:::-;;:::i;33595:51::-;;;;;;;;;;-1:-1:-1;33595:51:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;35661:157;;;;;;;;;;-1:-1:-1;35661:157:0;;;;;:::i;:::-;;:::i;34188:32::-;;;;;;;;;;-1:-1:-1;34188:32:0;;;;-1:-1:-1;;;;;34188:32:0;;;38185:783;;;;;;;;;;;;;:::i;14565:127::-;;;;;;;;;;-1:-1:-1;14565:127:0;;;;;:::i;:::-;-1:-1:-1;;;;;14666:18:0;14639:7;14666:18;;;;;;;;;;;;14565:127;34227:28;;;;;;;;;;-1:-1:-1;34227:28:0;;;;-1:-1:-1;;;;;34227:28:0;;;33512:37;;;;;;;;;;;;;;;;37880:297;;;;;;;;;;-1:-1:-1;37880:297:0;;;;;:::i;:::-;;:::i;22461:87::-;;;;;;;;;;-1:-1:-1;22534:6:0;;;;;-1:-1:-1;;;;;22534:6:0;22461:87;;13505:95;;;;;;;;;;;;;:::i;33653:46::-;;;;;;;;;;-1:-1:-1;33653:46:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;17543:269;;;;;;;;;;-1:-1:-1;17543:269:0;;;;;:::i;:::-;;:::i;14905:175::-;;;;;;;;;;-1:-1:-1;14905:175:0;;;;;:::i;:::-;;:::i;22194:21::-;;;;;;;;;;-1:-1:-1;22194:21:0;;;;;;;-1:-1:-1;;;;;22194:21:0;;;34114:23;;;;;;;;;;-1:-1:-1;34114:23:0;;;;;;;;;;;36964:240;;;;;;;;;;-1:-1:-1;36964:240:0;;;;;:::i;:::-;;:::i;37670:202::-;;;;;;;;;;;;;:::i;35480:173::-;;;;;;;;;;-1:-1:-1;35480:173:0;;;;;:::i;:::-;;:::i;15143:151::-;;;;;;;;;;-1:-1:-1;15143:151:0;;;;;:::i;:::-;-1:-1:-1;;;;;15259:18:0;;;15232:7;15259:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;15143:151;37212;;;;;;;;;;-1:-1:-1;37212:151:0;;;;;:::i;:::-;;:::i;36136:146::-;;;;;;;;;;-1:-1:-1;36136:146:0;;;;;:::i;:::-;;:::i;33759:46::-;;;;;;;;;;-1:-1:-1;33759:46:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;22556:200;;;;;;;;;;-1:-1:-1;22556:200:0;;;;;:::i;:::-;;:::i;34262:25::-;;;;;;;;;;-1:-1:-1;34262:25:0;;;;-1:-1:-1;;;;;34262:25:0;;;36290:155;;;;;;;;;;-1:-1:-1;36290:155:0;;;;;:::i;:::-;;:::i;36606:350::-;;;;;;;;;;-1:-1:-1;36606:350:0;;;;;:::i;:::-;;:::i;13295:91::-;13340:13;13373:5;13366:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13295:91;:::o;37540:120::-;37617:10;;-1:-1:-1;;;;;37617:10:0;882;-1:-1:-1;;;;;37601:26:0;;37593:35;;;;;;37639:3;:13;;;;;;;-1:-1:-1;;37639:13:0;;;;;;;;;37540:120::o;15441:169::-;15524:4;15541:39;882:10;15564:7;15573:6;15541:8;:39::i;:::-;-1:-1:-1;15598:4:0;15441:169;;;;;:::o;36453:145::-;36538:10;;-1:-1:-1;;;;;36538:10:0;882;-1:-1:-1;;;;;36522:26:0;;36514:35;;;;;;36560:21;:30;36453:145::o;16092:321::-;16198:4;16215:36;16225:6;16233:9;16244:6;16215:9;:36::i;:::-;16262:121;16271:6;882:10;16293:89;16331:6;16293:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;16293:19:0;;;;;;:11;:19;;;;;;;;882:10;16293:33;;;;;;;;;;:37;:89::i;:::-;16262:8;:121::i;:::-;-1:-1:-1;16401:4:0;16092:321;;;;;:::o;16822:218::-;882:10;16910:4;16959:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;16959:34:0;;;;;;;;;;16910:4;;16927:83;;16950:7;;16959:50;;16998:10;16959:38;:50::i;37371:161::-;37470:10;;-1:-1:-1;;;;;37470:10:0;882;-1:-1:-1;;;;;37454:26:0;;37446:35;;;;;;-1:-1:-1;;;;;37492:22:0;;;;;;;;:13;:22;;;;;:32;;-1:-1:-1;;37492:32:0;;;;;;;;;;37371:161::o;35287:185::-;35398:10;;-1:-1:-1;;;;;35398:10:0;882;-1:-1:-1;;;;;35382:26:0;;35374:35;;;;;;35420:20;:44;;-1:-1:-1;;;;;35420:44:0;;;;;-1:-1:-1;;;;;;35420:44:0;;;;;;;;;35287:185::o;35977:147::-;36060:10;;-1:-1:-1;;;;;36060:10:0;882;-1:-1:-1;;;;;36044:26:0;;36036:35;;;;;;-1:-1:-1;;;;;36082:27:0;;;;;:18;:27;;;;;:34;;-1:-1:-1;;36082:34:0;36112:4;36082:34;;;35977:147::o;35824:145::-;35915:10;;-1:-1:-1;;;;;35915:10:0;882;-1:-1:-1;;;;;35899:26:0;;35891:35;;;;;;35937:10;:24;;-1:-1:-1;;;;;;35937:24:0;-1:-1:-1;;;;;35937:24:0;;;;;;;;;;35824:145::o;35661:157::-;35758:10;;-1:-1:-1;;;;;35758:10:0;882;-1:-1:-1;;;;;35742:26:0;;35734:35;;;;;;35780:13;:30;;-1:-1:-1;;;;;;35780:30:0;-1:-1:-1;;;;;35780:30:0;;;;;;;;;;35661:157::o;38185:783::-;38251:10;;-1:-1:-1;;;;;38251:10:0;882;-1:-1:-1;;;;;38235:26:0;;38227:35;;;;;;38273:14;38290:21;38273:38;;38324:22;38349:85;38380:53;38422:10;;38380:37;38399:17;;38380:14;;:18;;:37;;;;:::i;:::-;:41;;:53::i;:::-;38360:14;;38349:26;;:6;;:10;:26::i;:::-;:30;;:85::i;:::-;38324:110;;38445:25;38473:88;38507:53;38549:10;;38507:37;38526:17;;38507:14;;:18;;:37;;;;:::i;:53::-;38484:17;;38473:29;;:6;;:10;:29::i;:88::-;38445:116;-1:-1:-1;38572:18:0;38593:49;38445:116;38593:26;:6;38604:14;38593:10;:26::i;:::-;:30;;:49::i;:::-;38572:70;-1:-1:-1;38683:18:0;;38680:87;;38724:17;;38716:51;;-1:-1:-1;;;;;38724:17:0;;;;38716:51;;;;;38752:14;;38724:17;38716:51;38724:17;38716:51;38752:14;38724:17;38716:51;;;;;;;;;;;;;;;;;;;;;38680:87;38781:21;;38778:96;;38825:20;;38817:57;;38825:20;;;;-1:-1:-1;;;;;38825:20:0;;38817:57;;;;;;;;;;;;38825:20;38817:57;;;;;;;;;;;;;;;;;;;;;38778:96;38888:14;;38885:75;;38925:13;;38917:43;;-1:-1:-1;;;;;38925:13:0;;;;38917:43;;;;;38949:10;;38925:13;38917:43;38925:13;38917:43;38949:10;38925:13;38917:43;;;;;;;;;;;;;;;;;;;;;38885:75;38185:783;;;;:::o;37880:297::-;34328:16;:23;;-1:-1:-1;;34328:23:0;34347:4;34328:23;;;37982:10:::1;::::0;-1:-1:-1;;;;;37982:10:0::1;37966:12;882:10:::0;;794:107;37966:12:::1;-1:-1:-1::0;;;;;37966:26:0::1;;37958:35;;;::::0;::::1;;38048:4;38004:23;14666:18:::0;;;;;;;;;;;;38087:42:::1;38118:10:::0;38087:26:::1;14666:18:::0;38107:5:::1;38087:19;:26::i;:::-;:30:::0;::::1;:42::i;:::-;38065:64;;38140:29;38157:11;38140:16;:29::i;:::-;-1:-1:-1::0;;34374:16:0;:24;;-1:-1:-1;;34374:24:0;;;-1:-1:-1;37880:297:0:o;13505:95::-;13552:13;13585:7;13578:14;;;;;:::i;17543:269::-;17636:4;17653:129;882:10;17676:7;17685:96;17724:15;17685:96;;;;;;;;;;;;;;;;;882:10;17685:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;17685:34:0;;;;;;;;;;;;:38;:96::i;14905:175::-;14991:4;15008:42;882:10;15032:9;15043:6;15008:9;:42::i;36964:240::-;37056:3;;;;;;;37055:4;37047:13;;;;;;-1:-1:-1;;;;;37080:22:0;;;;;;:13;:22;;;;;;;;37079:23;37071:32;;;;;;37138:10;;-1:-1:-1;;;;;37138:10:0;882;-1:-1:-1;;;;;37122:26:0;;37114:35;;;;;;-1:-1:-1;;;;;37160:22:0;;;;;;;;:13;:22;;;;;:36;;-1:-1:-1;;37160:36:0;;;;;;;;;;36964:240::o;37670:202::-;34328:16;:23;;-1:-1:-1;;34328:23:0;34347:4;34328:23;;;37748:10:::1;::::0;-1:-1:-1;;;;;37748:10:0::1;37732:12;882:10:::0;;794:107;37732:12:::1;-1:-1:-1::0;;;;;37732:26:0::1;;37724:35;;;::::0;::::1;;37814:4;37770:23;14666:18:::0;;;;;;;;;;;37831:33:::1;14666:18:::0;37831:16:::1;:33::i;:::-;-1:-1:-1::0;34374:16:0;:24;;-1:-1:-1;;34374:24:0;;;37670:202::o;35480:173::-;35585:10;;-1:-1:-1;;;;;35585:10:0;882;-1:-1:-1;;;;;35569:26:0;;35561:35;;;;;;35607:17;:38;;-1:-1:-1;;;;;;35607:38:0;-1:-1:-1;;;;;35607:38:0;;;;;;;;;;35480:173::o;37212:151::-;37304:10;;-1:-1:-1;;;;;37304:10:0;882;-1:-1:-1;;;;;37288:26:0;;37280:35;;;;;;-1:-1:-1;;;;;37326:22:0;;;;;:13;:22;;;;;:29;;-1:-1:-1;;37326:29:0;37351:4;37326:29;;;37212:151::o;36136:146::-;36217:10;;-1:-1:-1;;;;;36217:10:0;882;-1:-1:-1;;;;;36201:26:0;;36193:35;;;;;;-1:-1:-1;;;;;36239:27:0;36269:5;36239:27;;;:18;:27;;;;;:35;;-1:-1:-1;;36239:35:0;;;36136:146::o;22556:200::-;22426:6;;;;;-1:-1:-1;;;;;22426:6:0;22412:10;:20;22404:29;;;;;;-1:-1:-1;;;;;22638:23:0;::::1;22630:32;;;::::0;::::1;;22701:6;::::0;22678:41:::1;::::0;-1:-1:-1;;;;;22678:41:0;;::::1;::::0;22701:6:::1;::::0;::::1;;::::0;22678:41:::1;::::0;;;::::1;22730:6;:18:::0;;-1:-1:-1;;;;;22730:18:0;;::::1;;;-1:-1:-1::0;;;;;;22730:18:0;;::::1;::::0;;;::::1;::::0;;22556:200::o;36290:155::-;36382:10;;-1:-1:-1;;;;;36382:10:0;882;-1:-1:-1;;;;;36366:26:0;;36358:35;;;;;;36404:22;:33;;;;;;;-1:-1:-1;;36404:33:0;;;;;;;;;36290:155::o;36606:350::-;36735:10;;-1:-1:-1;;;;;36735:10:0;882;-1:-1:-1;;;;;36719:26:0;;36711:35;;;;;;36757:14;:23;;;36791:17;:38;;;36840:10;:23;;;36925:3;36853:10;36882:26;36812:17;36774:6;36882:26;:::i;:::-;:39;;;;:::i;:::-;:46;;36874:74;;;;-1:-1:-1;;;36874:74:0;;8255:2:1;36874:74:0;;;8237:21:1;8294:2;8274:18;;;8267:30;-1:-1:-1;;;8313:18:1;;;8306:45;8368:18;;36874:74:0;;;;;;;;;36606:350;;;:::o;3853:179::-;3911:7;;3943:5;3947:1;3943;:5;:::i;:::-;3931:17;;3972:1;3967;:6;;3959:46;;;;-1:-1:-1;;;3959:46:0;;5214:2:1;3959:46:0;;;5196:21:1;5253:2;5233:18;;;5226:30;5292:29;5272:18;;;5265:57;5339:18;;3959:46:0;5186:177:1;3959:46:0;4023:1;3853:179;-1:-1:-1;;;3853:179:0:o;20690:346::-;-1:-1:-1;;;;;20792:19:0;;20784:68;;;;-1:-1:-1;;;20784:68:0;;7850:2:1;20784:68:0;;;7832:21:1;7889:2;7869:18;;;7862:30;7928:34;7908:18;;;7901:62;-1:-1:-1;;;7979:18:1;;;7972:34;8023:19;;20784:68:0;7822:226:1;20784:68:0;-1:-1:-1;;;;;20871:21:0;;20863:68;;;;-1:-1:-1;;;20863:68:0;;4811:2:1;20863:68:0;;;4793:21:1;4850:2;4830:18;;;4823:30;4889:34;4869:18;;;4862:62;-1:-1:-1;;;4940:18:1;;;4933:32;4982:19;;20863:68:0;4783:224:1;20863:68:0;-1:-1:-1;;;;;20944:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;20996:32;;8543:25:1;;;20996:32:0;;8516:18:1;20996:32:0;;;;;;;;20690:346;;;:::o;38980:1372::-;-1:-1:-1;;;;;39112:18:0;;39104:68;;;;-1:-1:-1;;;39104:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;39191:16:0;;39183:64;;;;-1:-1:-1;;;39183:64:0;;;;;;;:::i;:::-;39275:1;39266:6;:10;39258:64;;;;-1:-1:-1;;;39258:64:0;;7034:2:1;39258:64:0;;;7016:21:1;7073:2;7053:18;;;7046:30;7112:34;7092:18;;;7085:62;-1:-1:-1;;;7163:18:1;;;7156:39;7212:19;;39258:64:0;7006:231:1;39258:64:0;-1:-1:-1;;;;;39341:19:0;;;;;;:13;:19;;;;;;;;:28;39333:60;;;;-1:-1:-1;;;39333:60:0;;5570:2:1;39333:60:0;;;5552:21:1;5609:2;5589:18;;;5582:30;-1:-1:-1;;;5628:18:1;;;5621:49;5687:18;;39333:60:0;5542:169:1;39333:60:0;39461:21;;39451:4;39406:24;14666:18;;;;;;;;;;;-1:-1:-1;39433:49:0;;;;;39511:53;;-1:-1:-1;39548:16:0;;;;39547:17;39511:53;:91;;;;-1:-1:-1;39589:13:0;;-1:-1:-1;;;;;39581:21:0;;;39589:13;;39581:21;;39511:91;:130;;;;-1:-1:-1;39619:22:0;;;;;;;39511:130;39493:204;;;39668:17;:15;:17::i;:::-;-1:-1:-1;;;;;39746:24:0;;39713:12;39746:24;;;:18;:24;;;;;;39728:4;;39746:24;;;:50;;-1:-1:-1;;;;;;39774:22:0;;;;;;:18;:22;;;;;;;;39746:50;:146;;;-1:-1:-1;39809:13:0;;-1:-1:-1;;;;;39801:21:0;;;39809:13;;39801:21;;;;:44;;-1:-1:-1;39832:13:0;;-1:-1:-1;;;;;39826:19:0;;;39832:13;;39826:19;;39801:44;:68;;;;-1:-1:-1;;;;;;39850:19:0;;;;;;:13;:19;;;;;;;;39849:20;39801:68;:90;;;;-1:-1:-1;;;;;;39874:17:0;;;;;;:13;:17;;;;;;;;39873:18;39801:90;39743:193;;;-1:-1:-1;39919:5:0;39743:193;39978:6;39995:291;;;;40022:24;40049:53;40091:10;;40049:37;40068:17;;40049:14;;:18;;:37;;;;:::i;:53::-;40022:80;-1:-1:-1;40114:12:0;40129:38;40162:4;40129:28;:6;40022:80;40129:10;:28::i;:38::-;40114:53;-1:-1:-1;40201:16:0;:6;40114:53;40201:10;:16::i;:::-;40179:38;;40232:42;40248:4;40262;40269;40232:15;:42::i;:::-;39995:291;;;40298:46;40314:4;40320:2;40324:19;40298:15;:46::i;:::-;38980:1372;;;;;;:::o;6680:166::-;6766:7;6802:12;6794:6;;;;6786:29;;;;-1:-1:-1;;;6786:29:0;;;;;;;;:::i;:::-;-1:-1:-1;6833:5:0;6837:1;6833;:5;:::i;:::-;6826:12;6680:166;-1:-1:-1;;;;6680:166:0:o;4732:220::-;4790:7;4814:6;4810:20;;-1:-1:-1;4829:1:0;4822:8;;4810:20;4841:9;4853:5;4857:1;4853;:5;:::i;:::-;4841:17;-1:-1:-1;4886:1:0;4877:5;4881:1;4841:17;4877:5;:::i;:::-;:10;4869:56;;;;-1:-1:-1;;;4869:56:0;;6632:2:1;4869:56:0;;;6614:21:1;6671:2;6651:18;;;6644:30;6710:34;6690:18;;;6683:62;-1:-1:-1;;;6761:18:1;;;6754:31;6802:19;;4869:56:0;6604:223:1;5430:153:0;5488:7;5520:1;5516;:5;5508:44;;;;-1:-1:-1;;;5508:44:0;;6277:2:1;5508:44:0;;;6259:21:1;6316:2;6296:18;;;6289:30;6355:28;6335:18;;;6328:56;6401:18;;5508:44:0;6249:176:1;5508:44:0;5570:5;5574:1;5570;:5;:::i;4315:158::-;4373:7;4406:1;4401;:6;;4393:49;;;;-1:-1:-1;;;4393:49:0;;5918:2:1;4393:49:0;;;5900:21:1;5957:2;5937:18;;;5930:30;5996:32;5976:18;;;5969:60;6046:18;;4393:49:0;5890:180:1;4393:49:0;4460:5;4464:1;4460;:5;:::i;41174:589::-;41324:16;;;41338:1;41324:16;;;;;;;;41300:21;;41324:16;;;;;;;;;;-1:-1:-1;41324:16:0;41300:40;;41369:4;41351;41356:1;41351:7;;;;;;-1:-1:-1;;;41351:7:0;;;;;;;;;-1:-1:-1;;;;;41351:23:0;;;:7;;;;;;;;;;:23;;;;41395:15;;:22;;;-1:-1:-1;;;41395:22:0;;;;:15;;;;;:20;;:22;;;;;41351:7;;41395:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;41385:4;41390:1;41385:7;;;;;;-1:-1:-1;;;41385:7:0;;;;;;;;;-1:-1:-1;;;;;41385:32:0;;;:7;;;;;;;;;:32;41462:15;;41430:62;;41447:4;;41462:15;41480:11;41430:8;:62::i;:::-;41531:15;;:224;;-1:-1:-1;;;41531:224:0;;-1:-1:-1;;;;;41531:15:0;;;;:66;;:224;;41612:11;;41531:15;;41682:4;;41709;;41729:15;;41531:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40360:806;34328:16;:23;;-1:-1:-1;;34328:23:0;34347:4;34328:23;;;40418:42:::1;40435:24;40453:4;-1:-1:-1::0;;;;;14666:18:0;14639:7;14666:18;;;;;;;;;;;;14565:127;40435:24:::1;40418:16;:42::i;:::-;40471:14;40488:21;40471:38;;40522:22;40547:85;40578:53;40620:10;;40578:37;40597:17;;40578:14;;:18;;:37;;;;:::i;40547:85::-;40522:110;;40643:25;40671:88;40705:53;40747:10;;40705:37;40724:17;;40705:14;;:18;;:37;;;;:::i;40671:88::-;40643:116:::0;-1:-1:-1;40770:18:0::1;40791:49;40643:116:::0;40791:26:::1;:6:::0;40802:14;40791:10:::1;:26::i;:49::-;40770:70:::0;-1:-1:-1;40881:18:0;;40878:87:::1;;40922:17;::::0;40914:51:::1;::::0;-1:-1:-1;;;;;40922:17:0;;::::1;::::0;40914:51;::::1;;;::::0;40950:14;;40922:17:::1;40914:51:::0;40922:17;40914:51;40950:14;40922:17;40914:51;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;40878:87;40979:21:::0;;40976:96:::1;;41023:20;::::0;41015:57:::1;::::0;41023:20;;;::::1;-1:-1:-1::0;;;;;41023:20:0::1;::::0;41015:57:::1;::::0;::::1;;::::0;;;::::1;::::0;;;;41023:20;41015:57;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;40976:96;41086:14:::0;;41083:75:::1;;41123:13;::::0;41115:43:::1;::::0;-1:-1:-1;;;;;41123:13:0;;::::1;::::0;41115:43;::::1;;;::::0;41147:10;;41123:13:::1;41115:43:::0;41123:13;41115:43;41147:10;41123:13;41115:43;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;41083:75;-1:-1:-1::0;;34374:16:0;:24;;-1:-1:-1;;34374:24:0;;;-1:-1:-1;;40360:806:0:o;18302:539::-;-1:-1:-1;;;;;18408:20:0;;18400:70;;;;-1:-1:-1;;;18400:70:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;18489:23:0;;18481:71;;;;-1:-1:-1;;;18481:71:0;;;;;;;:::i;:::-;18645;18667:6;18645:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;18645:17:0;;:9;:17;;;;;;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;18625:17:0;;;:9;:17;;;;;;;;;;;:91;;;;18750:20;;;;;;;:32;;18775:6;18750:24;:32::i;:::-;-1:-1:-1;;;;;18727:20:0;;;:9;:20;;;;;;;;;;;;:55;;;;18798:35;8543:25:1;;;18727:20:0;;18798:35;;;;;;8516:18:1;18798:35:0;8498:76:1;14:160;79:20;;135:13;;128:21;118:32;;108:2;;164:1;161;154:12;108:2;60:114;;;:::o;179:257::-;238:6;291:2;279:9;270:7;266:23;262:32;259:2;;;312:6;304;297:22;259:2;356:9;343:23;375:31;400:5;375:31;:::i;441:261::-;511:6;564:2;552:9;543:7;539:23;535:32;532:2;;;585:6;577;570:22;532:2;622:9;616:16;641:31;666:5;641:31;:::i;707:398::-;775:6;783;836:2;824:9;815:7;811:23;807:32;804:2;;;857:6;849;842:22;804:2;901:9;888:23;920:31;945:5;920:31;:::i;:::-;970:5;-1:-1:-1;1027:2:1;1012:18;;999:32;1040:33;999:32;1040:33;:::i;:::-;1092:7;1082:17;;;794:311;;;;;:::o;1110:466::-;1187:6;1195;1203;1256:2;1244:9;1235:7;1231:23;1227:32;1224:2;;;1277:6;1269;1262:22;1224:2;1321:9;1308:23;1340:31;1365:5;1340:31;:::i;:::-;1390:5;-1:-1:-1;1447:2:1;1432:18;;1419:32;1460:33;1419:32;1460:33;:::i;:::-;1214:362;;1512:7;;-1:-1:-1;;;1566:2:1;1551:18;;;;1538:32;;1214:362::o;1581:325::-;1646:6;1654;1707:2;1695:9;1686:7;1682:23;1678:32;1675:2;;;1728:6;1720;1713:22;1675:2;1772:9;1759:23;1791:31;1816:5;1791:31;:::i;:::-;1841:5;-1:-1:-1;1865:35:1;1896:2;1881:18;;1865:35;:::i;:::-;1855:45;;1665:241;;;;;:::o;1911:325::-;1979:6;1987;2040:2;2028:9;2019:7;2015:23;2011:32;2008:2;;;2061:6;2053;2046:22;2008:2;2105:9;2092:23;2124:31;2149:5;2124:31;:::i;:::-;2174:5;2226:2;2211:18;;;;2198:32;;-1:-1:-1;;;1998:238:1:o;2241:190::-;2297:6;2350:2;2338:9;2329:7;2325:23;2321:32;2318:2;;;2371:6;2363;2356:22;2318:2;2399:26;2415:9;2399:26;:::i;2436:190::-;2495:6;2548:2;2536:9;2527:7;2523:23;2519:32;2516:2;;;2569:6;2561;2554:22;2516:2;-1:-1:-1;2597:23:1;;2506:120;-1:-1:-1;2506:120:1:o;2631:326::-;2708:6;2716;2724;2777:2;2765:9;2756:7;2752:23;2748:32;2745:2;;;2798:6;2790;2783:22;2745:2;-1:-1:-1;;2826:23:1;;;2896:2;2881:18;;2868:32;;-1:-1:-1;2947:2:1;2932:18;;;2919:32;;2735:222;-1:-1:-1;2735:222:1:o;3597:603::-;3709:4;3738:2;3767;3756:9;3749:21;3799:6;3793:13;3842:6;3837:2;3826:9;3822:18;3815:34;3867:4;3880:140;3894:6;3891:1;3888:13;3880:140;;;3989:14;;;3985:23;;3979:30;3955:17;;;3974:2;3951:26;3944:66;3909:10;;3880:140;;;4038:6;4035:1;4032:13;4029:2;;;4108:4;4103:2;4094:6;4083:9;4079:22;4075:31;4068:45;4029:2;-1:-1:-1;4184:2:1;4163:15;-1:-1:-1;;4159:29:1;4144:45;;;;4191:2;4140:54;;3718:482;-1:-1:-1;;;3718:482:1:o;4205:399::-;4407:2;4389:21;;;4446:2;4426:18;;;4419:30;4485:34;4480:2;4465:18;;4458:62;-1:-1:-1;;;4551:2:1;4536:18;;4529:33;4594:3;4579:19;;4379:225::o;7242:401::-;7444:2;7426:21;;;7483:2;7463:18;;;7456:30;7522:34;7517:2;7502:18;;7495:62;-1:-1:-1;;;7588:2:1;7573:18;;7566:35;7633:3;7618:19;;7416:227::o;8579:983::-;8841:4;8889:3;8878:9;8874:19;8920:6;8909:9;8902:25;8946:2;8984:6;8979:2;8968:9;8964:18;8957:34;9027:3;9022:2;9011:9;9007:18;9000:31;9051:6;9086;9080:13;9117:6;9109;9102:22;9155:3;9144:9;9140:19;9133:26;;9194:2;9186:6;9182:15;9168:29;;9215:4;9228:195;9242:6;9239:1;9236:13;9228:195;;;9307:13;;-1:-1:-1;;;;;9303:39:1;9291:52;;9398:15;;;;9363:12;;;;9339:1;9257:9;9228:195;;;-1:-1:-1;;;;;;;9479:32:1;;;;9474:2;9459:18;;9452:60;-1:-1:-1;;;9543:3:1;9528:19;9521:35;9440:3;8850:712;-1:-1:-1;;;8850:712:1:o;9756:128::-;9796:3;9827:1;9823:6;9820:1;9817:13;9814:2;;;9833:18;;:::i;:::-;-1:-1:-1;9869:9:1;;9804:80::o;9889:217::-;9929:1;9955;9945:2;;-1:-1:-1;;;9980:31:1;;10034:4;10031:1;10024:15;10062:4;9987:1;10052:15;9945:2;-1:-1:-1;10091:9:1;;9935:171::o;10111:168::-;10151:7;10217:1;10213;10209:6;10205:14;10202:1;10199:21;10194:1;10187:9;10180:17;10176:45;10173:2;;;10224:18;;:::i;:::-;-1:-1:-1;10264:9:1;;10163:116::o;10284:125::-;10324:4;10352:1;10349;10346:8;10343:2;;;10357:18;;:::i;:::-;-1:-1:-1;10394:9:1;;10333:76::o;10414:380::-;10493:1;10489:12;;;;10536;;;10557:2;;10611:4;10603:6;10599:17;10589:27;;10557:2;10664;10656:6;10653:14;10633:18;10630:38;10627:2;;;10710:10;10705:3;10701:20;10698:1;10691:31;10745:4;10742:1;10735:15;10773:4;10770:1;10763:15;10627:2;;10469:325;;;:::o;10799:127::-;10860:10;10855:3;10851:20;10848:1;10841:31;10891:4;10888:1;10881:15;10915:4;10912:1;10905:15;10931:131;-1:-1:-1;;;;;11006:31:1;;10996:42;;10986:2;;11052:1;11049;11042:12;10986:2;10976:86;:::o

Swarm Source

ipfs://518c4a14fc5bb2e6b6130a30623657137381817138dff9c7badb78bace6ebc72
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.