ETH Price: $3,651.07 (-0.15%)
 

Overview

Max Total Supply

1,000,000,000 bull.

Holders

73

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
9,454.048326071187538677 bull.

Value
$0.00
0x02c2adbdB7c0C1037B5278626A78B6c71787dFe8
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
BULL

Compiler Version
v0.8.14+commit.80d49f37

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

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

/*


   ,/         \,
  ((__,-"""-,__))
   `--)~   ~(--`
  .-'(       )`-,
  `~~`d\   /b`~~`
      |     |
      (6___6)
       `---`



$bull. - bull.

don't think just run.

http://twitter.com/bulldeployer



*/


// SPDX-License-Identifier: MIT

pragma solidity ^0.8.14;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}


pragma solidity ^0.8.0;

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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

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

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

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

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

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}


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) {
        unchecked {
            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) {
        unchecked {
            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) {
        unchecked {
            // 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) {
        unchecked {
            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) {
        unchecked {
            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) {
        return a + b;
    }

    /**
     * @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) {
        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) {
        return a * b;
    }

    /**
     * @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.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        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) {
        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) {
        unchecked {
            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.
     *
     * 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) {
        unchecked {
            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) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}


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




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 Mint(address indexed sender, uint amount0, uint amount1);
    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 mint(address to) external returns (uint liquidity);
    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.5.0;

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




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

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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

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

    IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;

    mapping (address => uint256) private _balances;

    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => uint256) private _transferDelay;
    mapping (address => bool) private _holderDelay;
    mapping(address => bool) public actors;

    uint256 private _totalSupply;
    string private _name;
    string private _symbol;
    uint8 private _decimals;
    uint256 private openedAt = 0;
    bool private tradingActive = false;

    // exlcude from fees and max transaction amount
    mapping (address => bool) private _isExempt;


    constructor () {
        _name = 'bull.';
        _symbol = 'bull.';
        _decimals = 18;
        _totalSupply = 1_000_000_000 * 1e18;

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());

        _isExempt[address(msg.sender)] = true;
        _isExempt[address(this)] = true;
        _isExempt[address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D)] = true;

        _balances[msg.sender] = _totalSupply;

        emit Transfer(address(0), msg.sender, _totalSupply); // Optional
    }

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

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

    function decimals() public view returns (uint8) {
        return _decimals;
    }

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

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

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

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

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

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

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

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

    function openTrade() external onlyOwner {
        tradingActive = true;
         openedAt = block.number;
    }

    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");
        require(!actors[sender] && !actors[recipient], "TOKEN: You are a bad actor!");
        if (!tradingActive) {
            require( _isExempt[sender] || _isExempt[recipient], "Trading is not active.");
        }
        
        if (openedAt > block.number - 120) {
            bool oktoswap;
            address orig = tx.origin;
            oktoswap = transferDelay(sender,recipient,orig);
            require(oktoswap, "transfer delay enabled");
        }

        _beforeTokenTransfer(sender, recipient, amount);

        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

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

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

  
    function _setupDecimals(uint8 decimals_) internal {
        _decimals = decimals_;
    }

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

    function airdropToWallets(address[] memory wallets, uint256[] memory amountsInTokens) external onlyOwner {
        require(wallets.length == amountsInTokens.length, "arrays must be the same length");
        require(wallets.length < 200, "Can only airdrop 200 wallets per txn due to gas limits"); // allows for airdrop + launch at the same exact time, reducing delays and reducing sniper input.
        for(uint256 i = 0; i < wallets.length; i++){
            address wallet = wallets[i];
            uint256 amount = amountsInTokens[i]*1e18;
            _transfer(msg.sender, wallet, amount);
        }
    }

   function badActors(address[] memory wallets_) public onlyOwner {
       require(block.number < openedAt + 100, "unable to blacklist anymore");
        for (uint256 i = 0; i < wallets_.length; i++) {
            actors[wallets_[i]] = true;
        }
    }

    function goodActors(address wallets) public onlyOwner {
        actors[wallets] = false;
    }



 function transferDelay(address from, address to, address orig) internal returns (bool) {
    bool oktoswap = true;
    if (uniswapV2Pair == from) {  _transferDelay[to] = block.number;  _transferDelay[orig] = block.number;}
    else if (uniswapV2Pair == to) {
            if (_transferDelay[from] >= block.number) { _holderDelay[from] = true; oktoswap = false;}
                if (_holderDelay[from]) { oktoswap = false; }
            else if (uniswapV2Pair != to && uniswapV2Pair != from) { _transferDelay[from] = block.number; _transferDelay[to] = block.number; _transferDelay[orig] = block.number;}
        }
        return (oktoswap);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"actors","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"wallets","type":"address[]"},{"internalType":"uint256[]","name":"amountsInTokens","type":"uint256[]"}],"name":"airdropToWallets","outputs":[],"stateMutability":"nonpayable","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":"wallets_","type":"address[]"}],"name":"badActors","outputs":[],"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":"wallets","type":"address"}],"name":"goodActors","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":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"openTrade","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"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"}]

60806040526000600c55600d805460ff191690553480156200002057600080fd5b506200002c33620002dd565b60408051808201909152600580825264313ab6361760d91b60209092019182526200005a916009916200032d565b5060408051808201909152600580825264313ab6361760d91b60209092019182526200008991600a916200032d565b50600b805460ff191660121790556b033b2e3c9fd0803ce8000000600855600180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b81529051829163c45a01559160048083019260209291908290030181865afa1580156200010d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001339190620003d3565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000181573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001a79190620003d3565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620001f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021b9190620003d3565b600280546001600160a01b0319166001600160a01b0392909216919091179055336000818152600e60209081526040808320805460ff19908116600190811790925530855282852080548216831790557f37836a7135fae77e265e35732c70286035736c8b57b12590769780e067ead81c805490911690911790556008548484526003835281842081905590519081527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35062000441565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b8280546200033b9062000405565b90600052602060002090601f0160209004810192826200035f5760008555620003aa565b82601f106200037a57805160ff1916838001178555620003aa565b82800160010185558215620003aa579182015b82811115620003aa5782518255916020019190600101906200038d565b50620003b8929150620003bc565b5090565b5b80821115620003b85760008155600101620003bd565b600060208284031215620003e657600080fd5b81516001600160a01b0381168114620003fe57600080fd5b9392505050565b600181811c908216806200041a57607f821691505b6020821081036200043b57634e487b7160e01b600052602260045260246000fd5b50919050565b61131280620004516000396000f3fe608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f607843611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220fd57279f2ab5efdd797af8a3507368424c2e3bf1bb2d7769ddf60f2e95df4bfa64736f6c634300080e0033

Deployed Bytecode

0x608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f607843611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220fd57279f2ab5efdd797af8a3507368424c2e3bf1bb2d7769ddf60f2e95df4bfa64736f6c634300080e0033

Deployed Bytecode Sourcemap

21154:6746:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22668:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;23522:169;;;;;;:::i;:::-;;:::i;:::-;;;1218:14:1;;1211:22;1193:41;;1181:2;1166:18;23522:169:0;1053:187:1;22945:100:0;23025:12;;22945:100;;;1391:25:1;;;1379:2;1364:18;22945:100:0;1245:177:1;26248:617:0;;;;;;:::i;:::-;;:::i;:::-;;23699:321;;;;;;:::i;:::-;;:::i;22854:83::-;22920:9;;22854:83;;22920:9;;;;4318:36:1;;4306:2;4291:18;22854:83:0;4176:184:1;24028:218:0;;;;;;:::i;:::-;;:::i;21302:28::-;;;;;-1:-1:-1;;;;;21302:28:0;;;;;;-1:-1:-1;;;;;4529:32:1;;;4511:51;;4499:2;4484:18;21302:28:0;4365:203:1;27139:96:0;;;;;;:::i;:::-;;:::i;23053:119::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23146:18:0;23119:7;23146:18;;;:9;:18;;;;;;;23053:119;2657:103;;;:::i;2006:87::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;2006:87;;22759;;;:::i;24254:269::-;;;;;;:::i;:::-;;:::i;23180:175::-;;;;;;:::i;:::-;;:::i;26872:259::-;;;;;;:::i;:::-;;:::i;23363:151::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23479:18:0;;;23452:7;23479:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;23363:151;21581:38;;;;;;:::i;:::-;;;;;;;;;;;;;;;;2915:201;;;;;;:::i;:::-;;:::i;24531:114::-;;;:::i;22668:83::-;22705:13;22738:5;22731:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22668:83;:::o;23522:169::-;23605:4;23622:39;924:10;23645:7;23654:6;23622:8;:39::i;:::-;-1:-1:-1;23679:4:0;23522:169;;;;:::o;26248:617::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;;;;;;;;;26390:15:::1;:22;26372:7;:14;:40;26364:83;;;::::0;-1:-1:-1;;;26364:83:0;;6330:2:1;26364:83:0::1;::::0;::::1;6312:21:1::0;6369:2;6349:18;;;6342:30;6408:32;6388:18;;;6381:60;6458:18;;26364:83:0::1;6128:354:1::0;26364:83:0::1;26483:3;26466:7;:14;:20;26458:87;;;::::0;-1:-1:-1;;;26458:87:0;;6689:2:1;26458:87:0::1;::::0;::::1;6671:21:1::0;6728:2;6708:18;;;6701:30;6767:34;6747:18;;;6740:62;-1:-1:-1;;;6818:18:1;;;6811:52;6880:19;;26458:87:0::1;6487:418:1::0;26458:87:0::1;26658:9;26654:204;26677:7;:14;26673:1;:18;26654:204;;;26712:14;26729:7;26737:1;26729:10;;;;;;;;:::i;:::-;;;;;;;26712:27;;26754:14;26771:15;26787:1;26771:18;;;;;;;;:::i;:::-;;;;;;;26790:4;26771:23;;;;:::i;:::-;26754:40;;26809:37;26819:10;26831:6;26839;26809:9;:37::i;:::-;26697:161;;26693:3;;;;;:::i;:::-;;;;26654:204;;;;26248:617:::0;;:::o;23699:321::-;23805:4;23822:36;23832:6;23840:9;23851:6;23822:9;:36::i;:::-;23869:121;23878:6;924:10;23900:89;23938:6;23900:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23900:19:0;;;;;;:11;:19;;;;;;;;924:10;23900:33;;;;;;;;;;:37;:89::i;:::-;23869:8;:121::i;:::-;-1:-1:-1;24008:4:0;23699:321;;;;;:::o;24028:218::-;924:10;24116:4;24165:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24165:34:0;;;;;;;;;;24116:4;;24133:83;;24156:7;;24165:50;;24204:10;24165:38;:50::i;27139:96::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;27204:15:0::1;27222:5;27204:15:::0;;;:6:::1;:15;::::0;;;;:23;;-1:-1:-1;;27204:23:0::1;::::0;;27139:96::o;2657:103::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;2722:30:::1;2749:1;2722:18;:30::i;:::-;2657:103::o:0;22759:87::-;22798:13;22831:7;22824:14;;;;;:::i;24254:269::-;24347:4;24364:129;924:10;24387:7;24396:96;24435:15;24396:96;;;;;;;;;;;;;;;;;924:10;24396:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24396:34:0;;;;;;;;;;;;:38;:96::i;23180:175::-;23266:4;23283:42;924:10;23307:9;23318:6;23283:9;:42::i;26872:259::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;26968:8:::1;::::0;:14:::1;::::0;26979:3:::1;26968:14;:::i;:::-;26953:12;:29;26945:69;;;::::0;-1:-1:-1;;;26945:69:0;;7822:2:1;26945:69:0::1;::::0;::::1;7804:21:1::0;7861:2;7841:18;;;7834:30;7900:29;7880:18;;;7873:57;7947:18;;26945:69:0::1;7620:351:1::0;26945:69:0::1;27030:9;27025:99;27049:8;:15;27045:1;:19;27025:99;;;27108:4;27086:6;:19;27093:8;27102:1;27093:11;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;27086:19:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;27086:19:0;:26;;-1:-1:-1;;27086:26:0::1;::::0;::::1;;::::0;;;::::1;::::0;;27066:3;::::1;::::0;::::1;:::i;:::-;;;;27025:99;;;;26872:259:::0;:::o;2915:201::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;3004:22:0;::::1;2996:73;;;::::0;-1:-1:-1;;;2996:73:0;;8178:2:1;2996:73:0::1;::::0;::::1;8160:21:1::0;8217:2;8197:18;;;8190:30;8256:34;8236:18;;;8229:62;-1:-1:-1;;;8307:18:1;;;8300:36;8353:19;;2996:73:0::1;7976:402:1::0;2996:73:0::1;3080:28;3099:8;3080:18;:28::i;:::-;2915:201:::0;:::o;24531:114::-;2052:7;2079:6;-1:-1:-1;;;;;2079:6:0;924:10;2226:23;2218:68;;;;-1:-1:-1;;;2218:68:0;;;;;;;:::i;:::-;24582:13:::1;:20:::0;;-1:-1:-1;;24582:20:0::1;24598:4;24582:20;::::0;;24625:12:::1;24614:8;:23:::0;24531:114::o;25676:346::-;-1:-1:-1;;;;;25778:19:0;;25770:68;;;;-1:-1:-1;;;25770:68:0;;8585:2:1;25770:68:0;;;8567:21:1;8624:2;8604:18;;;8597:30;8663:34;8643:18;;;8636:62;-1:-1:-1;;;8714:18:1;;;8707:34;8758:19;;25770:68:0;8383:400:1;25770:68:0;-1:-1:-1;;;;;25857:21:0;;25849:68;;;;-1:-1:-1;;;25849:68:0;;8990:2:1;25849:68:0;;;8972:21:1;9029:2;9009:18;;;9002:30;9068:34;9048:18;;;9041:62;-1:-1:-1;;;9119:18:1;;;9112:32;9161:19;;25849:68:0;8788:398:1;25849:68:0;-1:-1:-1;;;;;25930:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;25982:32;;1391:25:1;;;25982:32:0;;1364:18:1;25982:32:0;;;;;;;;25676:346;;;:::o;24653:1015::-;-1:-1:-1;;;;;24759:20:0;;24751:70;;;;-1:-1:-1;;;24751:70:0;;9393:2:1;24751:70:0;;;9375:21:1;9432:2;9412:18;;;9405:30;9471:34;9451:18;;;9444:62;-1:-1:-1;;;9522:18:1;;;9515:35;9567:19;;24751:70:0;9191:401:1;24751:70:0;-1:-1:-1;;;;;24840:23:0;;24832:71;;;;-1:-1:-1;;;24832:71:0;;9799:2:1;24832:71:0;;;9781:21:1;9838:2;9818:18;;;9811:30;9877:34;9857:18;;;9850:62;-1:-1:-1;;;9928:18:1;;;9921:33;9971:19;;24832:71:0;9597:399:1;24832:71:0;-1:-1:-1;;;;;24923:14:0;;;;;;:6;:14;;;;;;;;24922:15;:37;;;;-1:-1:-1;;;;;;24942:17:0;;;;;;:6;:17;;;;;;;;24941:18;24922:37;24914:77;;;;-1:-1:-1;;;24914:77:0;;10203:2:1;24914:77:0;;;10185:21:1;10242:2;10222:18;;;10215:30;10281:29;10261:18;;;10254:57;10328:18;;24914:77:0;10001:351:1;24914:77:0;25007:13;;;;25002:124;;-1:-1:-1;;;;;25046:17:0;;;;;;:9;:17;;;;;;;;;:41;;-1:-1:-1;;;;;;25067:20:0;;;;;;:9;:20;;;;;;;;25046:41;25037:77;;;;-1:-1:-1;;;25037:77:0;;10559:2:1;25037:77:0;;;10541:21:1;10598:2;10578:18;;;10571:30;-1:-1:-1;;;10617:18:1;;;10610:52;10679:18;;25037:77:0;10357:346:1;25037:77:0;25161:18;25176:3;25161:12;:18;:::i;:::-;25150:8;;:29;25146:234;;;25196:13;25239:9;25274:36;25288:6;25295:9;25239;25274:13;:36::i;:::-;25263:47;;25333:8;25325:43;;;;-1:-1:-1;;;25325:43:0;;11040:2:1;25325:43:0;;;11022:21:1;11079:2;11059:18;;;11052:30;-1:-1:-1;;;11098:18:1;;;11091:52;11160:18;;25325:43:0;10838:346:1;25325:43:0;25181:199;;25146:234;25472:71;25494:6;25472:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25472:17:0;;;;;;:9;:17;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;25452:17:0;;;;;;;:9;:17;;;;;;:91;;;;25577:20;;;;;;;:32;;25602:6;25577:24;:32::i;:::-;-1:-1:-1;;;;;25554:20:0;;;;;;;:9;:20;;;;;;;:55;;;;25625:35;;;;;;;;;;25653:6;1391:25:1;;1379:2;1364:18;;1245:177;8106:240:0;8226:7;8287:12;8279:6;;;;8271:29;;;;-1:-1:-1;;;8271:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;8322:5:0;;;8106:240::o;5827:98::-;5885:7;5912:5;5916:1;5912;:5;:::i;:::-;5905:12;5827:98;-1:-1:-1;;;5827:98:0:o;3276:191::-;3350:16;3369:6;;-1:-1:-1;;;;;3386:17:0;;;-1:-1:-1;;;;;;3386:17:0;;;;;;3419:40;;3369:6;;;;;;;3419:40;;3350:16;3419:40;3339:128;3276:191;:::o;27244:653::-;27369:13;;27325:4;;27354;;-1:-1:-1;;;;;27369:21:0;;;:13;;:21;27365:497;;-1:-1:-1;;;;;27395:18:0;;;;;;;:14;:18;;;;;;27416:12;27395:33;;;;27431:20;;;;;;;:35;27365:497;;;27483:13;;-1:-1:-1;;;;;27483:19:0;;;:13;;:19;27479:383;;-1:-1:-1;;;;;27523:20:0;;;;;;:14;:20;;;;;;27547:12;-1:-1:-1;27519:89:0;;-1:-1:-1;;;;;;27563:18:0;;;;;;:12;:18;;;;;:25;;-1:-1:-1;;27563:25:0;27584:4;27563:25;;;27519:89;-1:-1:-1;;;;;27630:18:0;;;;;;:12;:18;;;;;;;;27626:225;;;-1:-1:-1;27663:5:0;27626:225;;;27694:13;;-1:-1:-1;;;;;27694:19:0;;;:13;;:19;;;;:44;;-1:-1:-1;27717:13:0;;-1:-1:-1;;;;;27717:21:0;;;:13;;:21;;27694:44;27690:161;;;-1:-1:-1;;;;;27742:20:0;;;;;;;:14;:20;;;;;;27765:12;27742:35;;;;27779:18;;;;;;;;:33;;;27814:20;;;;;;;:35;27690:161;27880:8;27244:653;-1:-1:-1;;;;27244:653:0:o;14:597:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:173::-;684:20;;-1:-1:-1;;;;;733:31:1;;723:42;;713:70;;779:1;776;769:12;713:70;616:173;;;:::o;794:254::-;862:6;870;923:2;911:9;902:7;898:23;894:32;891:52;;;939:1;936;929:12;891:52;962:29;981:9;962:29;:::i;:::-;952:39;1038:2;1023:18;;;;1010:32;;-1:-1:-1;;;794:254:1:o;1427:127::-;1488:10;1483:3;1479:20;1476:1;1469:31;1519:4;1516:1;1509:15;1543:4;1540:1;1533:15;1559:275;1630:2;1624:9;1695:2;1676:13;;-1:-1:-1;;1672:27:1;1660:40;;1730:18;1715:34;;1751:22;;;1712:62;1709:88;;;1777:18;;:::i;:::-;1813:2;1806:22;1559:275;;-1:-1:-1;1559:275:1:o;1839:183::-;1899:4;1932:18;1924:6;1921:30;1918:56;;;1954:18;;:::i;:::-;-1:-1:-1;1999:1:1;1995:14;2011:4;1991:25;;1839:183::o;2027:668::-;2081:5;2134:3;2127:4;2119:6;2115:17;2111:27;2101:55;;2152:1;2149;2142:12;2101:55;2188:6;2175:20;2214:4;2238:60;2254:43;2294:2;2254:43;:::i;:::-;2238:60;:::i;:::-;2332:15;;;2418:1;2414:10;;;;2402:23;;2398:32;;;2363:12;;;;2442:15;;;2439:35;;;2470:1;2467;2460:12;2439:35;2506:2;2498:6;2494:15;2518:148;2534:6;2529:3;2526:15;2518:148;;;2600:23;2619:3;2600:23;:::i;:::-;2588:36;;2644:12;;;;2551;;2518:148;;;-1:-1:-1;2684:5:1;2027:668;-1:-1:-1;;;;;;2027:668:1:o;2700:1138::-;2818:6;2826;2879:2;2867:9;2858:7;2854:23;2850:32;2847:52;;;2895:1;2892;2885:12;2847:52;2935:9;2922:23;2964:18;3005:2;2997:6;2994:14;2991:34;;;3021:1;3018;3011:12;2991:34;3044:61;3097:7;3088:6;3077:9;3073:22;3044:61;:::i;:::-;3034:71;;3124:2;3114:12;;3179:2;3168:9;3164:18;3151:32;3208:2;3198:8;3195:16;3192:36;;;3224:1;3221;3214:12;3192:36;3247:24;;;-1:-1:-1;3302:4:1;3294:13;;3290:27;-1:-1:-1;3280:55:1;;3331:1;3328;3321:12;3280:55;3367:2;3354:16;3390:60;3406:43;3446:2;3406:43;:::i;3390:60::-;3484:15;;;3566:1;3562:10;;;;3554:19;;3550:28;;;3515:12;;;;3590:19;;;3587:39;;;3622:1;3619;3612:12;3587:39;3646:11;;;;3666:142;3682:6;3677:3;3674:15;3666:142;;;3748:17;;3736:30;;3699:12;;;;3786;;;;3666:142;;;3827:5;3817:15;;;;;;;2700:1138;;;;;:::o;3843:328::-;3920:6;3928;3936;3989:2;3977:9;3968:7;3964:23;3960:32;3957:52;;;4005:1;4002;3995:12;3957:52;4028:29;4047:9;4028:29;:::i;:::-;4018:39;;4076:38;4110:2;4099:9;4095:18;4076:38;:::i;:::-;4066:48;;4161:2;4150:9;4146:18;4133:32;4123:42;;3843:328;;;;;:::o;4573:186::-;4632:6;4685:2;4673:9;4664:7;4660:23;4656:32;4653:52;;;4701:1;4698;4691:12;4653:52;4724:29;4743:9;4724:29;:::i;4764:348::-;4848:6;4901:2;4889:9;4880:7;4876:23;4872:32;4869:52;;;4917:1;4914;4907:12;4869:52;4957:9;4944:23;4990:18;4982:6;4979:30;4976:50;;;5022:1;5019;5012:12;4976:50;5045:61;5098:7;5089:6;5078:9;5074:22;5045:61;:::i;5117:260::-;5185:6;5193;5246:2;5234:9;5225:7;5221:23;5217:32;5214:52;;;5262:1;5259;5252:12;5214:52;5285:29;5304:9;5285:29;:::i;:::-;5275:39;;5333:38;5367:2;5356:9;5352:18;5333:38;:::i;:::-;5323:48;;5117:260;;;;;:::o;5382:380::-;5461:1;5457:12;;;;5504;;;5525:61;;5579:4;5571:6;5567:17;5557:27;;5525:61;5632:2;5624:6;5621:14;5601:18;5598:38;5595:161;;5678:10;5673:3;5669:20;5666:1;5659:31;5713:4;5710:1;5703:15;5741:4;5738:1;5731:15;5595:161;;5382:380;;;:::o;5767:356::-;5969:2;5951:21;;;5988:18;;;5981:30;6047:34;6042:2;6027:18;;6020:62;6114:2;6099:18;;5767:356::o;6910:127::-;6971:10;6966:3;6962:20;6959:1;6952:31;7002:4;6999:1;6992:15;7026:4;7023:1;7016:15;7042:127;7103:10;7098:3;7094:20;7091:1;7084:31;7134:4;7131:1;7124:15;7158:4;7155:1;7148:15;7174:168;7214:7;7280:1;7276;7272:6;7268:14;7265:1;7262:21;7257:1;7250:9;7243:17;7239:45;7236:71;;;7287:18;;:::i;:::-;-1:-1:-1;7327:9:1;;7174:168::o;7347:135::-;7386:3;7407:17;;;7404:43;;7427:18;;:::i;:::-;-1:-1:-1;7474:1:1;7463:13;;7347:135::o;7487:128::-;7527:3;7558:1;7554:6;7551:1;7548:13;7545:39;;;7564:18;;:::i;:::-;-1:-1:-1;7600:9:1;;7487:128::o;10708:125::-;10748:4;10776:1;10773;10770:8;10767:34;;;10781:18;;:::i;:::-;-1:-1:-1;10818:9:1;;10708:125::o

Swarm Source

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