ETH Price: $2,530.66 (-2.76%)

Token

OracleAI (OAI)
 

Overview

Max Total Supply

10,000,000,000 OAI

Holders

134

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 8 Decimals)

Balance
0.88154359 OAI

Value
$0.00
0xFba9771FA557Bc12a5187b68118a76C3E0e62820
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:
ERC20Token

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 1 : OracleAIToken.sol
// SPDX-License-Identifier: Unlicensed

/**
Discover the future of DeFi trading with Oracle AI, an intelligent Telegram bot-wallet designed to optimize your trading strategies and maximize profits across multiple networks.

Max Wallet
3% = 300,000,000 OAI

Buy & Sell fees
2% Marketing
1% Burn

Website
https://oracleai.io

Telegram
https://t.me/OracleAI_portal

Twitter
https://twitter.com/OracleAI_erc20
*/

pragma solidity ^0.8.4;

abstract contract Context {

    function _msgSender() internal view virtual returns (address payable) {
        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;
    }
}

interface IERC20 {

    function totalSupply() external view returns (uint256);

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

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

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

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

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

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

library SafeMath {

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

        return c;
    }

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

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

        return c;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }

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

        return c;
    }

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

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

        return c;
    }

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

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

library Address {

    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly {codehash := extcodehash(account)}
        return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success,) = recipient.call{value : amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{value : weiValue}(data);
        if (success) {
            return returndata;
        } else {

            if (returndata.length > 0) {
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _transferOwnership(_msgSender());
    }

    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

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

    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, 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;
}

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

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

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

contract ERC20Token is Context, IERC20, Ownable {

    using SafeMath for uint256;
    using Address for address;

    string private _name;
    string private _symbol;
    uint8 private _decimals;
    address payable public marketingWalletAddress;
    address payable public teamWalletAddress;
    address public deadAddress = address(0);

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

    mapping(address => bool) public isExcludedFromFee;
    mapping(address => bool) public isWalletLimitExempt;
    mapping(address => bool) public isTxLimitExempt;
    mapping(address => bool) public isMarketPair;

    uint256 public _buyLiquidityFee = 0;
    uint256 public _buyMarketingFee = 95;
    uint256 public _buyTeamFee = 0;
    uint256 public _buyBurnFee = 1;

    uint256 public _sellLiquidityFee = 0;
    uint256 public _sellMarketingFee = 95;
    uint256 public _sellTeamFee = 0;
    uint256 public _sellBurnFee = 1;

    uint256 public _liquidityShare = 0;
    uint256 public _marketingShare = 100;
    uint256 public _teamShare = 0;
    uint256 public _totalDistributionShares;

    uint256 public _totalTaxIfBuying;
    uint256 public _totalTaxIfSelling;

    uint256 public _totalBurnedTokens;
    uint256 public _maxBurnAmount;
    uint256 private _totalSupply;
    uint256 public _maxTxAmount;
    uint256 public _walletMax;
    uint256 private _minimumTokensBeforeSwap;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapPair;

    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = true;
    bool public swapAndLiquifyByLimitOnly = false;
    bool public checkWalletLimit = true;

    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );

    event SwapETHForTokens(
        uint256 amountIn,
        address[] path
    );

    event SwapTokensForETH(
        uint256 amountIn,
        address[] path
    );

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

    constructor(
        string memory tokenName,
        string memory tokenSymbol,
        uint8 tokenDecimals,
        uint256 tokenTotalSupply,
        address router
    ) {
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);
        uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory())
        .createPair(address(this), _uniswapV2Router.WETH());
        uniswapV2Router = _uniswapV2Router;

        // Base token info
        _name = tokenName;
        _symbol = tokenSymbol;
        _decimals = tokenDecimals;
        _totalSupply = tokenTotalSupply * 10 ** _decimals;

        // Limits
        _maxTxAmount = tokenTotalSupply * 10 ** _decimals;
        _walletMax = tokenTotalSupply * 3 / 100 * 10 ** _decimals; // 300mln OAI
        _maxBurnAmount = tokenTotalSupply * 10 ** _decimals;
        _minimumTokensBeforeSwap = 100000 * 10 ** _decimals; // 100k OAI

        // Wallets
        marketingWalletAddress = payable(owner());

        // Fees
        _totalTaxIfBuying = _buyLiquidityFee.add(_buyMarketingFee).add(_buyTeamFee);
        _totalTaxIfSelling = _sellLiquidityFee.add(_sellMarketingFee).add(_sellTeamFee);
        _totalDistributionShares = _liquidityShare.add(_marketingShare).add(_teamShare);

        isExcludedFromFee[owner()] = true;
        isExcludedFromFee[address(this)] = true;

        isWalletLimitExempt[owner()] = true;
        isWalletLimitExempt[address(uniswapPair)] = true;
        isWalletLimitExempt[address(this)] = true;
        isWalletLimitExempt[deadAddress] = true;

        isTxLimitExempt[owner()] = true;
        isTxLimitExempt[deadAddress] = true;
        isTxLimitExempt[address(this)] = true;

        isMarketPair[address(uniswapPair)] = true;

        // Mint tokens
        _balances[address(this)] = _totalSupply;
        emit Transfer(address(0), address(this), _totalSupply);
    }

    function initLiquidityPool() external payable onlyOwner {
        // Approve tokens
        _allowances[address(this)][address(uniswapV2Router)] = balanceOf(address(this));

        // Disable
        isExcludedFromFee[address(uniswapV2Router)] = true;
        swapAndLiquifyEnabled = false;

        // Init liquidity pool
        uniswapV2Router.addLiquidityETH{value : address(this).balance}(
            address(this),
            _totalSupply,
            0,
            0,
            owner(),
            block.timestamp
        );

        // Enable
        isExcludedFromFee[address(uniswapV2Router)] = false;
        swapAndLiquifyEnabled = true;
    }

    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 allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    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 minimumTokensBeforeSwapAmount() public view returns (uint256) {
        return _minimumTokensBeforeSwap;
    }

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

    function _approve(address owner, address spender, uint256 amount) private {
        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 setMarketPairStatus(address account, bool newValue) public onlyOwner {
        isMarketPair[account] = newValue;
    }

    function setIsTxLimitExempt(address holder, bool exempt) external onlyOwner {
        isTxLimitExempt[holder] = exempt;
    }

    function setIsExcludedFromFee(address account, bool newValue) public onlyOwner {
        isExcludedFromFee[account] = newValue;
    }

    function setMaxBurnAmount(uint256 maxBurn) public onlyOwner {
        _maxBurnAmount = maxBurn;
    }

    function setBuyBurnFee(uint256 newBuyBurnFee) public onlyOwner {
        _buyBurnFee = newBuyBurnFee;
        _totalTaxIfBuying = _buyLiquidityFee.add(_buyMarketingFee).add(_buyTeamFee).add(_buyBurnFee);
    }

    function setSellBurnFee(uint256 newSellBurnFee) public onlyOwner {
        _sellBurnFee = newSellBurnFee;
        _totalTaxIfSelling = _sellLiquidityFee.add(_sellMarketingFee).add(_sellTeamFee).add(_sellBurnFee);
    }

    function setBuyTaxes(uint256 newLiquidityTax, uint256 newMarketingTax, uint256 newTeamTax) external onlyOwner() {
        _buyLiquidityFee = newLiquidityTax;
        _buyMarketingFee = newMarketingTax;
        _buyTeamFee = newTeamTax;

        _totalTaxIfBuying = _buyLiquidityFee.add(_buyMarketingFee).add(_buyTeamFee).add(_buyBurnFee);
    }

    function setSellTaxes(uint256 newLiquidityTax, uint256 newMarketingTax, uint256 newTeamTax) external onlyOwner() {
        _sellLiquidityFee = newLiquidityTax;
        _sellMarketingFee = newMarketingTax;
        _sellTeamFee = newTeamTax;

        _totalTaxIfSelling = _sellLiquidityFee.add(_sellMarketingFee).add(_sellTeamFee).add(_sellBurnFee);
    }

    function setDistributionSettings(uint256 newLiquidityShare, uint256 newMarketingShare, uint256 newTeamShare) external onlyOwner() {
        _liquidityShare = newLiquidityShare;
        _marketingShare = newMarketingShare;
        _teamShare = newTeamShare;

        _totalDistributionShares = _liquidityShare.add(_marketingShare).add(_teamShare);
    }

    function setMaxTxAmount(uint256 maxTxAmount) external onlyOwner() {
        _maxTxAmount = maxTxAmount;
    }

    function enableDisableWalletLimit(bool newValue) external onlyOwner {
        checkWalletLimit = newValue;
    }

    function setIsWalletLimitExempt(address holder, bool exempt) external onlyOwner {
        isWalletLimitExempt[holder] = exempt;
    }

    function setWalletLimit(uint256 newLimit) external onlyOwner {
        _walletMax = newLimit;
    }

    function setNumTokensBeforeSwap(uint256 newLimit) external onlyOwner() {
        _minimumTokensBeforeSwap = newLimit;
    }

    function setMarketingWalletAddress(address newAddress) external onlyOwner() {
        marketingWalletAddress = payable(newAddress);
    }

    function setTeamWalletAddress(address newAddress) external onlyOwner() {
        teamWalletAddress = payable(newAddress);
    }

    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }

    function setSwapAndLiquifyByLimitOnly(bool newValue) public onlyOwner {
        swapAndLiquifyByLimitOnly = newValue;
    }

    function getCirculatingSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(deadAddress));
    }

    function transferToAddressETH(address payable recipient, uint256 amount) private {
        recipient.transfer(amount);
    }

    function changeRouterVersion(address newRouterAddress) public onlyOwner returns (address newPairAddress) {

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(newRouterAddress);

        newPairAddress = IUniswapV2Factory(_uniswapV2Router.factory()).getPair(address(this), _uniswapV2Router.WETH());

        if (newPairAddress == address(0)) //Create If Doesnt exist
        {
            newPairAddress = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());
        }

        uniswapPair = newPairAddress;
        //Set new pair address
        uniswapV2Router = _uniswapV2Router;
        //Set new router address

        isWalletLimitExempt[address(uniswapPair)] = true;
        isMarketPair[address(uniswapPair)] = true;
    }

    //to receive ETH from uniswapV2Router when swapping
    receive() external payable {}

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

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

    function _transfer(address sender, address recipient, uint256 amount) private returns (bool) {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        if (inSwapAndLiquify) {
            return _basicTransfer(sender, recipient, amount);
        } else {
            if (!isTxLimitExempt[sender] && !isTxLimitExempt[recipient]) {
                require(amount <= _maxTxAmount, "Transfer amount exceeds the maxTxAmount.");
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            bool overMinimumTokenBalance = contractTokenBalance >= _minimumTokensBeforeSwap;

            if (overMinimumTokenBalance && !inSwapAndLiquify && !isMarketPair[sender] && swapAndLiquifyEnabled) {
                if (swapAndLiquifyByLimitOnly) {
                    contractTokenBalance = _minimumTokensBeforeSwap;
                }
                swapAndLiquify(contractTokenBalance);
            }

            _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");

            uint256 finalAmount = (isExcludedFromFee[sender] || isExcludedFromFee[recipient])
            ? amount : takeFees(sender, recipient, amount);

            if (checkWalletLimit && !isWalletLimitExempt[recipient]) {
                require(balanceOf(recipient).add(finalAmount) <= _walletMax);
            }

            _balances[recipient] = _balances[recipient].add(finalAmount);
            emit Transfer(sender, recipient, finalAmount);

            return true;
        }
    }

    function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }

    function swapAndLiquify(uint256 tAmount) private lockTheSwap {
        uint256 tokensForLP = tAmount.mul(_liquidityShare).div(_totalDistributionShares).div(2);
        uint256 tokensForSwap = tAmount.sub(tokensForLP);

        swapTokensForEth(tokensForSwap);
        uint256 amountReceived = address(this).balance;

        uint256 totalFee = _totalDistributionShares.sub(_liquidityShare.div(2));

        uint256 amountLiquidity = amountReceived.mul(_liquidityShare).div(totalFee).div(2);
        uint256 amountTeam = amountReceived.mul(_teamShare).div(totalFee);
        uint256 amountMarketing = amountReceived.sub(amountLiquidity).sub(amountTeam);

        if (amountMarketing > 0)
            transferToAddressETH(marketingWalletAddress, amountMarketing);

        if (amountTeam > 0)
            transferToAddressETH(teamWalletAddress, amountTeam);

        if (amountLiquidity > 0 && tokensForLP > 0)
            addLiquidity(tokensForLP, amountLiquidity);
    }

    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), // The contract
            block.timestamp
        );

        emit SwapTokensForETH(tokenAmount, path);
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value : ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );
    }

    function takeFees(address sender, address recipient, uint256 amount) internal returns (uint256) {
        uint256 feeAmount = 0;
        uint256 burnAmount = 0;

        if (isMarketPair[sender]) {
            feeAmount = amount.mul(_totalTaxIfBuying.sub(_buyBurnFee)).div(100);
            if (_buyBurnFee > 0 && _totalBurnedTokens < _maxBurnAmount) {
                burnAmount = amount.mul(_buyBurnFee).div(100);
                takeBurnFee(sender, burnAmount);
            }
        } else if (isMarketPair[recipient]) {
            feeAmount = amount.mul(_totalTaxIfSelling.sub(_sellBurnFee)).div(100);
            if (_sellBurnFee > 0 && _totalBurnedTokens < _maxBurnAmount) {
                burnAmount = amount.mul(_sellBurnFee).div(100);
                takeBurnFee(sender, burnAmount);
            }
        }

        if (feeAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(feeAmount);
            emit Transfer(sender, address(this), feeAmount);
        }

        return amount.sub(feeAmount.add(burnAmount));
    }

    function takeBurnFee(address sender, uint256 tAmount) private {
        // stop burn
        if (_totalBurnedTokens >= _maxBurnAmount) return;

        _balances[deadAddress] = _balances[deadAddress].add(tAmount);
        _totalBurnedTokens = _totalBurnedTokens.add(tAmount);
        emit Transfer(sender, deadAddress, tAmount);
    }
}

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

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"tokenName","type":"string"},{"internalType":"string","name":"tokenSymbol","type":"string"},{"internalType":"uint8","name":"tokenDecimals","type":"uint8"},{"internalType":"uint256","name":"tokenTotalSupply","type":"uint256"},{"internalType":"address","name":"router","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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"SwapAndLiquifyEnabledUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountIn","type":"uint256"},{"indexed":false,"internalType":"address[]","name":"path","type":"address[]"}],"name":"SwapETHForTokens","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountIn","type":"uint256"},{"indexed":false,"internalType":"address[]","name":"path","type":"address[]"}],"name":"SwapTokensForETH","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":[],"name":"_buyBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyTeamFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_liquidityShare","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_marketingShare","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxBurnAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellTeamFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_teamShare","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalBurnedTokens","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalDistributionShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalTaxIfBuying","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalTaxIfSelling","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_walletMax","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":[{"internalType":"address","name":"newRouterAddress","type":"address"}],"name":"changeRouterVersion","outputs":[{"internalType":"address","name":"newPairAddress","type":"address"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"checkWalletLimit","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"deadAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"bool","name":"newValue","type":"bool"}],"name":"enableDisableWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getCirculatingSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"initLiquidityPool","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isMarketPair","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isTxLimitExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isWalletLimitExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingWalletAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minimumTokensBeforeSwapAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newBuyBurnFee","type":"uint256"}],"name":"setBuyBurnFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityTax","type":"uint256"},{"internalType":"uint256","name":"newMarketingTax","type":"uint256"},{"internalType":"uint256","name":"newTeamTax","type":"uint256"}],"name":"setBuyTaxes","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityShare","type":"uint256"},{"internalType":"uint256","name":"newMarketingShare","type":"uint256"},{"internalType":"uint256","name":"newTeamShare","type":"uint256"}],"name":"setDistributionSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"newValue","type":"bool"}],"name":"setIsExcludedFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsTxLimitExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setIsWalletLimitExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"newValue","type":"bool"}],"name":"setMarketPairStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setMarketingWalletAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxBurn","type":"uint256"}],"name":"setMaxBurnAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxAmount","type":"uint256"}],"name":"setMaxTxAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLimit","type":"uint256"}],"name":"setNumTokensBeforeSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newSellBurnFee","type":"uint256"}],"name":"setSellBurnFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityTax","type":"uint256"},{"internalType":"uint256","name":"newMarketingTax","type":"uint256"},{"internalType":"uint256","name":"newTeamTax","type":"uint256"}],"name":"setSellTaxes","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"newValue","type":"bool"}],"name":"setSwapAndLiquifyByLimitOnly","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setSwapAndLiquifyEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setTeamWalletAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLimit","type":"uint256"}],"name":"setWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndLiquifyByLimitOnly","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapAndLiquifyEnabled","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":"teamWalletAddress","outputs":[{"internalType":"address payable","name":"","type":"address"}],"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":"uniswapPair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

6080604052600580546001600160a01b03191690556000600c819055605f600d819055600e8290556001600f81905560108390556011919091556012829055601355601481905560646015556016556021805462ffffff60a81b19166201000160a81b1790553480156200007257600080fd5b506040516200333a3803806200333a833981016040819052620000959162000729565b620000a03362000588565b6000819050806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015620000e4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200010a9190620007ca565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000158573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200017e9190620007ca565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620001cc573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001f29190620007ca565b602180546001600160a01b03199081166001600160a01b03938416179091556020805490911691831691909117905560016200022f87826200087e565b5060026200023e86826200087e565b506003805460ff191660ff86169081179091556200025e90600a62000a5d565b6200026a908462000a6e565b601c55600354620002809060ff16600a62000a5d565b6200028c908462000a6e565b601d55600354620002a29060ff16600a62000a5d565b6064620002b185600362000a6e565b620002bd919062000a88565b620002c9919062000a6e565b601e55600354620002df9060ff16600a62000a5d565b620002eb908462000a6e565b601b55600354620003019060ff16600a62000a5d565b6200031090620186a062000a6e565b601f556000546001600160a01b0316600360016101000a8154816001600160a01b0302191690836001600160a01b031602179055506200037e600e546200036a600d54600c54620005d860201b620015951790919060201c565b620005d860201b620015951790919060201c565b601881905550620003a96012546200036a601154601054620005d860201b620015951790919060201c565b601981905550620003d46016546200036a601554601454620005d860201b620015951790919060201c565b601755600160086000620003f06000546001600160a01b031690565b6001600160a01b0316815260208082019290925260409081016000908120805494151560ff199586161790553081526008909252812080549092166001908117909255600990620004496000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790556021548216815260099093528183208054851660019081179091553084528284208054861682179055600554909116835290822080549093168117909255600a90620004cb6000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff1996871617905560055482168152600a84528281208054861660019081179091553080835284832080548816831790556021549093168252600b8552838220805490961617909455601c5481855260068452828520819055915191825292917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a350505050505062000ac1565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600080620005e7838562000aab565b9050838110156200063e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640160405180910390fd5b90505b92915050565b634e487b7160e01b600052604160045260246000fd5b600082601f8301126200066f57600080fd5b81516001600160401b03808211156200068c576200068c62000647565b604051601f8301601f19908116603f01168101908282118183101715620006b757620006b762000647565b81604052838152602092508683858801011115620006d457600080fd5b600091505b83821015620006f85785820183015181830184015290820190620006d9565b600093810190920192909252949350505050565b80516001600160a01b03811681146200072457600080fd5b919050565b600080600080600060a086880312156200074257600080fd5b85516001600160401b03808211156200075a57600080fd5b6200076889838a016200065d565b965060208801519150808211156200077f57600080fd5b506200078e888289016200065d565b945050604086015160ff81168114620007a657600080fd5b60608701519093509150620007be608087016200070c565b90509295509295909350565b600060208284031215620007dd57600080fd5b620007e8826200070c565b9392505050565b600181811c908216806200080457607f821691505b6020821081036200082557634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200087957600081815260208120601f850160051c81016020861015620008545750805b601f850160051c820191505b81811015620008755782815560010162000860565b5050505b505050565b81516001600160401b038111156200089a576200089a62000647565b620008b281620008ab8454620007ef565b846200082b565b602080601f831160018114620008ea5760008415620008d15750858301515b600019600386901b1c1916600185901b17855562000875565b600085815260208120601f198616915b828110156200091b57888601518255948401946001909101908401620008fa565b50858210156200093a5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052601160045260246000fd5b600181815b80851115620009a15781600019048211156200098557620009856200094a565b808516156200099357918102915b93841c939080029062000965565b509250929050565b600082620009ba5750600162000641565b81620009c95750600062000641565b8160018114620009e25760028114620009ed5762000a0d565b600191505062000641565b60ff84111562000a015762000a016200094a565b50506001821b62000641565b5060208310610133831016604e8410600b841016171562000a32575081810a62000641565b62000a3e838362000960565b806000190482111562000a555762000a556200094a565b029392505050565b6000620007e860ff841683620009a9565b80820281158282048414176200064157620006416200094a565b60008262000aa657634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156200064157620006416200094a565b6128698062000ad16000396000f3fe6080604052600436106103dd5760003560e01c8063844d591c116101fd578063c5d2418911610118578063dc44b6a0116100ab578063f0cd1dac1161007a578063f0cd1dac14610b56578063f1d5f51714610b6c578063f2fde38b14610b8c578063f84ba65d14610bac578063f872858a14610bcc57600080fd5b8063dc44b6a014610aba578063dd62ed3e14610ad0578063ec28438a14610b16578063ef422a1814610b3657600080fd5b8063cab03471116100e7578063cab0347114610a48578063d158272d14610a5e578063d187f41714610a83578063da00097d14610a9957600080fd5b8063c5d24189146109cc578063c816841b146109e2578063c860795214610a02578063c867d60b14610a1857600080fd5b8063a457c2d711610190578063b0a863f91161015f578063b0a863f914610956578063c2d4640e14610976578063c469b6dd14610996578063c49b9a80146109ac57600080fd5b8063a457c2d7146108e0578063a5d69d1f14610900578063a83f53a714610920578063a9059cbb1461093657600080fd5b806391fe5a64116101cc57806391fe5a641461088a57806395d89b41146108a0578063a073d37f146108b5578063a08e671f146108ca57600080fd5b8063844d591c1461080657806388790a68146108265780638b42507f1461083c5780638da5cb5b1461086c57600080fd5b80633b97084a116102f857806357a5802f1161028b578063715018a61161025a578063715018a6146107995780637abdc1ca146107ae5780637d1db4a5146107c4578063807c2d9c146107da57806382eefb43146107f057600080fd5b806357a5802f146107175780635881f3ef1461072d57806361a23c691461074d57806370a082311461076357600080fd5b80634acd87d5116102c75780634acd87d51461069f5780634b7cf256146106bf5780634cb80fd5146106c75780635342acb4146106e757600080fd5b80633b97084a1461060e5780633ecad2711461062e578063405dcb1b1461065e5780634a74bb021461067e57600080fd5b80632198cf6c116103705780632b112e491161033f5780632b112e49146105975780632c4b2334146105ac578063313ce567146105cc57806339509351146105ee57600080fd5b80632198cf6c1461051757806323b872dd146105375780632563ae831461055757806327c8f8351461057757600080fd5b80631694505e116103ac5780631694505e1461049e57806316f2f1a8146104be57806318160ddd146104e25780631870517a146104f757600080fd5b806306fdde03146103e95780630873321414610414578063095ea7b3146104365780631245e3471461046657600080fd5b366103e457005b600080fd5b3480156103f557600080fd5b506103fe610bed565b60405161040b919061240a565b60405180910390f35b34801561042057600080fd5b5061043461042f366004612458565b610c7f565b005b34801561044257600080fd5b50610456610451366004612499565b610cb7565b604051901515815260200161040b565b34801561047257600080fd5b50600454610486906001600160a01b031681565b6040516001600160a01b03909116815260200161040b565b3480156104aa57600080fd5b50602054610486906001600160a01b031681565b3480156104ca57600080fd5b506104d4600f5481565b60405190815260200161040b565b3480156104ee57600080fd5b50601c546104d4565b34801561050357600080fd5b50610434610512366004612458565b610cce565b34801561052357600080fd5b506104346105323660046124da565b610d00565b34801561054357600080fd5b5061045661055236600461250f565b610d33565b34801561056357600080fd5b50610434610572366004612550565b610d9e565b34801561058357600080fd5b50600554610486906001600160a01b031681565b3480156105a357600080fd5b506104d4610dc4565b3480156105b857600080fd5b506104346105c736600461256b565b610df0565b3480156105d857600080fd5b5060035460405160ff909116815260200161040b565b3480156105fa57600080fd5b50610456610609366004612499565b610e1a565b34801561061a57600080fd5b50610434610629366004612588565b610e50565b34801561063a57600080fd5b5061045661064936600461256b565b600b6020526000908152604090205460ff1681565b34801561066a57600080fd5b50610434610679366004612588565b610e5d565b34801561068a57600080fd5b5060215461045690600160a81b900460ff1681565b3480156106ab57600080fd5b506104346106ba366004612588565b610e8a565b610434610e97565b3480156106d357600080fd5b506104346106e236600461256b565b610fc3565b3480156106f357600080fd5b5061045661070236600461256b565b60086020526000908152604090205460ff1681565b34801561072357600080fd5b506104d460145481565b34801561073957600080fd5b5061048661074836600461256b565b610ff3565b34801561075957600080fd5b506104d460155481565b34801561076f57600080fd5b506104d461077e36600461256b565b6001600160a01b031660009081526006602052604090205490565b3480156107a557600080fd5b50610434611305565b3480156107ba57600080fd5b506104d460135481565b3480156107d057600080fd5b506104d4601d5481565b3480156107e657600080fd5b506104d4601e5481565b3480156107fc57600080fd5b506104d460195481565b34801561081257600080fd5b506104346108213660046124da565b611319565b34801561083257600080fd5b506104d460105481565b34801561084857600080fd5b5061045661085736600461256b565b600a6020526000908152604090205460ff1681565b34801561087857600080fd5b506000546001600160a01b0316610486565b34801561089657600080fd5b506104d4601a5481565b3480156108ac57600080fd5b506103fe61134c565b3480156108c157600080fd5b50601f546104d4565b3480156108d657600080fd5b506104d460175481565b3480156108ec57600080fd5b506104566108fb366004612499565b61135b565b34801561090c57600080fd5b5061043461091b366004612550565b6113aa565b34801561092c57600080fd5b506104d460165481565b34801561094257600080fd5b50610456610951366004612499565b6113d0565b34801561096257600080fd5b50610434610971366004612588565b6113dd565b34801561098257600080fd5b50610434610991366004612458565b61140a565b3480156109a257600080fd5b506104d4600e5481565b3480156109b857600080fd5b506104346109c7366004612550565b611437565b3480156109d857600080fd5b506104d4600d5481565b3480156109ee57600080fd5b50602154610486906001600160a01b031681565b348015610a0e57600080fd5b506104d460115481565b348015610a2457600080fd5b50610456610a3336600461256b565b60096020526000908152604090205460ff1681565b348015610a5457600080fd5b506104d460125481565b348015610a6a57600080fd5b506003546104869061010090046001600160a01b031681565b348015610a8f57600080fd5b506104d4601b5481565b348015610aa557600080fd5b5060215461045690600160b01b900460ff1681565b348015610ac657600080fd5b506104d4600c5481565b348015610adc57600080fd5b506104d4610aeb3660046125a1565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205490565b348015610b2257600080fd5b50610434610b31366004612588565b611497565b348015610b4257600080fd5b50610434610b513660046124da565b6114a4565b348015610b6257600080fd5b506104d460185481565b348015610b7857600080fd5b50610434610b87366004612588565b6114d7565b348015610b9857600080fd5b50610434610ba736600461256b565b6114e4565b348015610bb857600080fd5b50610434610bc73660046124da565b611562565b348015610bd857600080fd5b5060215461045690600160b81b900460ff1681565b606060018054610bfc906125da565b80601f0160208091040260200160405190810160405280929190818152602001828054610c28906125da565b8015610c755780601f10610c4a57610100808354040283529160200191610c75565b820191906000526020600020905b815481529060010190602001808311610c5857829003601f168201915b5050505050905090565b610c876115f4565b601083905560118290556012819055601354610caf90610ca983818787611595565b90611595565b601955505050565b6000610cc433848461164e565b5060015b92915050565b610cd66115f4565b600c839055600d829055600e819055600f54610cf890610ca983818787611595565b601855505050565b610d086115f4565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b6000610d40848484611772565b50610d938433610d8e856040518060600160405280602881526020016127c7602891396001600160a01b038a1660009081526007602090815260408083203384529091529020549190611b91565b61164e565b5060015b9392505050565b610da66115f4565b60218054911515600160b81b0260ff60b81b19909216919091179055565b6005546001600160a01b0316600090815260066020526040812054601c54610deb91611bcb565b905090565b610df86115f4565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b3360008181526007602090815260408083206001600160a01b03871684529091528120549091610cc4918590610d8e9086611595565b610e586115f4565b601f55565b610e656115f4565b600f819055600e54600d54600c54610e84928492610ca9928391611595565b60185550565b610e926115f4565b601b55565b610e9f6115f4565b3060009081526006602052604090205430600081815260076020908152604080832082546001600160a01b03908116855290835281842095909555815485168352600882528220805460ff191660011790556021805460ff60a81b1916905554601c5493169263f305d71992479290919080610f236000546001600160a01b031690565b426040518863ffffffff1660e01b8152600401610f4596959493929190612614565b60606040518083038185885af1158015610f63573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610f88919061264f565b5050602080546001600160a01b03166000908152600890915260409020805460ff19169055506021805460ff60a81b1916600160a81b179055565b610fcb6115f4565b600380546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6000610ffd6115f4565b6000829050806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611040573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611064919061267d565b6001600160a01b031663e6a4390530836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110b1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110d5919061267d565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381865afa158015611120573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611144919061267d565b91506001600160a01b03821661129b57806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611192573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b6919061267d565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611203573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611227919061267d565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015611274573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611298919061267d565b91505b602180546001600160a01b03199081166001600160a01b038581169182178455602080549093169481169490941782556000908152600982526040808220805460ff19908116600190811790925594549095168252600b9092522080549091169091179055919050565b61130d6115f4565b6113176000611c0d565b565b6113216115f4565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b606060028054610bfc906125da565b6000610cc43384610d8e8560405180606001604052806025815260200161280f602591393360009081526007602090815260408083206001600160a01b038d1684529091529020549190611b91565b6113b26115f4565b60218054911515600160b01b0260ff60b01b19909216919091179055565b6000610d93338484611772565b6113e56115f4565b6013819055601254601154601054611404928492610ca9928391611595565b60195550565b6114126115f4565b60148390556015829055601681905561142f81610ca98585611595565b601755505050565b61143f6115f4565b60218054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc1599061148c90831515815260200190565b60405180910390a150565b61149f6115f4565b601d55565b6114ac6115f4565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6114df6115f4565b601e55565b6114ec6115f4565b6001600160a01b0381166115565760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b61155f81611c0d565b50565b61156a6115f4565b6001600160a01b03919091166000908152600a60205260409020805460ff1916911515919091179055565b6000806115a283856126b0565b905083811015610d975760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161154d565b6000546001600160a01b031633146113175760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161154d565b6001600160a01b0383166116b05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161154d565b6001600160a01b0382166117115760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161154d565b6001600160a01b0383811660008181526007602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b0384166117d85760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161154d565b6001600160a01b03831661183a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161154d565b6000821161189c5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161154d565b602154600160a01b900460ff16156118c0576118b9848484611c5d565b9050610d97565b6001600160a01b0384166000908152600a602052604090205460ff1615801561190257506001600160a01b0383166000908152600a602052604090205460ff16155b1561196a57601d5482111561196a5760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b606482015260840161154d565b30600090815260066020526040902054601f54811080159081906119985750602154600160a01b900460ff16155b80156119bd57506001600160a01b0386166000908152600b602052604090205460ff16155b80156119d25750602154600160a81b900460ff165b156119f857602154600160b01b900460ff16156119ef57601f5491505b6119f882611d31565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260069091529190912054611a4a918690611b91565b6001600160a01b038716600090815260066020908152604080832093909355600890529081205460ff1680611a9757506001600160a01b03861660009081526008602052604090205460ff165b611aab57611aa6878787611e6c565b611aad565b845b602154909150600160b81b900460ff168015611ae257506001600160a01b03861660009081526009602052604090205460ff16155b15611b1857601e54611b0d82610ca9896001600160a01b031660009081526006602052604090205490565b1115611b1857600080fd5b6001600160a01b038616600090815260066020526040902054611b3b9082611595565b6001600160a01b0380881660008181526006602052604090819020939093559151908916906000805160206127ef83398151915290611b7d9085815260200190565b60405180910390a360019350505050610d97565b60008184841115611bb55760405162461bcd60e51b815260040161154d919061240a565b506000611bc284866126c3565b95945050505050565b6000610d9783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611b91565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386166000908152600690915291822054611cae918490611b91565b6001600160a01b038086166000908152600660205260408082209390935590851681522054611cdd9083611595565b6001600160a01b0380851660008181526006602052604090819020939093559151908616906000805160206127ef83398151915290611d1f9086815260200190565b60405180910390a35060019392505050565b6021805460ff60a01b1916600160a01b179055601754601454600091611d6791600291611d619182908790612006565b90612088565b90506000611d758383611bcb565b9050611d80816120ca565b6014544790600090611da090611d97906002612088565b60175490611bcb565b90506000611dc26002611d6184611d616014548861200690919063ffffffff16565b90506000611ddf83611d616016548761200690919063ffffffff16565b90506000611df782611df18786611bcb565b90611bcb565b90508015611e1a57600354611e1a9061010090046001600160a01b03168261225e565b8115611e3657600454611e36906001600160a01b03168361225e565b600083118015611e465750600087115b15611e5557611e558784612299565b50506021805460ff60a01b19169055505050505050565b6001600160a01b0383166000908152600b60205260408120548190819060ff1615611efe57611eb76064611d61611eb0600f54601854611bcb90919063ffffffff16565b8790612006565b91506000600f54118015611ece5750601b54601a54105b15611ef957611eed6064611d61600f548761200690919063ffffffff16565b9050611ef98682612346565b611f80565b6001600160a01b0385166000908152600b602052604090205460ff1615611f8057611f3e6064611d61611eb0601354601954611bcb90919063ffffffff16565b91506000601354118015611f555750601b54601a54105b15611f8057611f746064611d616013548761200690919063ffffffff16565b9050611f808682612346565b8115611fe85730600090815260066020526040902054611fa09083611595565b30600081815260066020526040908190209290925590516001600160a01b038816906000805160206127ef83398151915290611fdf9086815260200190565b60405180910390a35b611ffc611ff58383611595565b8590611bcb565b9695505050505050565b60008260000361201857506000610cc8565b600061202483856126d6565b90508261203185836126ed565b14610d975760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161154d565b6000610d9783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506123dc565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106120ff576120ff61270f565b6001600160a01b039283166020918202929092018101919091528054604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612157573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061217b919061267d565b8160018151811061218e5761218e61270f565b6001600160a01b03928316602091820292909201810191909152546121b6913091168461164e565b60205460405163791ac94760e01b81526001600160a01b039091169063791ac947906121ef908590600090869030904290600401612769565b600060405180830381600087803b15801561220957600080fd5b505af115801561221d573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a782826040516122529291906127a5565b60405180910390a15050565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015612294573d6000803e3d6000fd5b505050565b6020546122b19030906001600160a01b03168461164e565b6020546001600160a01b031663f305d7198230856000806122da6000546001600160a01b031690565b426040518863ffffffff1660e01b81526004016122fc96959493929190612614565b60606040518083038185885af115801561231a573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061233f919061264f565b5050505050565b601b54601a5410612355575050565b6005546001600160a01b031660009081526006602052604090205461237a9082611595565b6005546001600160a01b0316600090815260066020526040902055601a546123a29082611595565b601a556005546040518281526001600160a01b03918216918416906000805160206127ef8339815191529060200160405180910390a35050565b600081836123fd5760405162461bcd60e51b815260040161154d919061240a565b506000611bc284866126ed565b600060208083528351808285015260005b818110156124375785810183015185820160400152820161241b565b506000604082860101526040601f19601f8301168501019250505092915050565b60008060006060848603121561246d57600080fd5b505081359360208301359350604090920135919050565b6001600160a01b038116811461155f57600080fd5b600080604083850312156124ac57600080fd5b82356124b781612484565b946020939093013593505050565b803580151581146124d557600080fd5b919050565b600080604083850312156124ed57600080fd5b82356124f881612484565b9150612506602084016124c5565b90509250929050565b60008060006060848603121561252457600080fd5b833561252f81612484565b9250602084013561253f81612484565b929592945050506040919091013590565b60006020828403121561256257600080fd5b610d97826124c5565b60006020828403121561257d57600080fd5b8135610d9781612484565b60006020828403121561259a57600080fd5b5035919050565b600080604083850312156125b457600080fd5b82356125bf81612484565b915060208301356125cf81612484565b809150509250929050565b600181811c908216806125ee57607f821691505b60208210810361260e57634e487b7160e01b600052602260045260246000fd5b50919050565b6001600160a01b039687168152602081019590955260408501939093526060840191909152909216608082015260a081019190915260c00190565b60008060006060848603121561266457600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561268f57600080fd5b8151610d9781612484565b634e487b7160e01b600052601160045260246000fd5b80820180821115610cc857610cc861269a565b81810381811115610cc857610cc861269a565b8082028115828204841417610cc857610cc861269a565b60008261270a57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600081518084526020808501945080840160005b8381101561275e5781516001600160a01b031687529582019590820190600101612739565b509495945050505050565b85815284602082015260a06040820152600061278860a0830186612725565b6001600160a01b0394909416606083015250608001529392505050565b8281526040602082015260006127be6040830184612725565b94935050505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220d43da998a395c38fca5c628da1bd45032c1ec37f618591974963098a2deb9f9264736f6c6343000812003300000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000002540be4000000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d00000000000000000000000000000000000000000000000000000000000000084f7261636c65414900000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034f41490000000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x6080604052600436106103dd5760003560e01c8063844d591c116101fd578063c5d2418911610118578063dc44b6a0116100ab578063f0cd1dac1161007a578063f0cd1dac14610b56578063f1d5f51714610b6c578063f2fde38b14610b8c578063f84ba65d14610bac578063f872858a14610bcc57600080fd5b8063dc44b6a014610aba578063dd62ed3e14610ad0578063ec28438a14610b16578063ef422a1814610b3657600080fd5b8063cab03471116100e7578063cab0347114610a48578063d158272d14610a5e578063d187f41714610a83578063da00097d14610a9957600080fd5b8063c5d24189146109cc578063c816841b146109e2578063c860795214610a02578063c867d60b14610a1857600080fd5b8063a457c2d711610190578063b0a863f91161015f578063b0a863f914610956578063c2d4640e14610976578063c469b6dd14610996578063c49b9a80146109ac57600080fd5b8063a457c2d7146108e0578063a5d69d1f14610900578063a83f53a714610920578063a9059cbb1461093657600080fd5b806391fe5a64116101cc57806391fe5a641461088a57806395d89b41146108a0578063a073d37f146108b5578063a08e671f146108ca57600080fd5b8063844d591c1461080657806388790a68146108265780638b42507f1461083c5780638da5cb5b1461086c57600080fd5b80633b97084a116102f857806357a5802f1161028b578063715018a61161025a578063715018a6146107995780637abdc1ca146107ae5780637d1db4a5146107c4578063807c2d9c146107da57806382eefb43146107f057600080fd5b806357a5802f146107175780635881f3ef1461072d57806361a23c691461074d57806370a082311461076357600080fd5b80634acd87d5116102c75780634acd87d51461069f5780634b7cf256146106bf5780634cb80fd5146106c75780635342acb4146106e757600080fd5b80633b97084a1461060e5780633ecad2711461062e578063405dcb1b1461065e5780634a74bb021461067e57600080fd5b80632198cf6c116103705780632b112e491161033f5780632b112e49146105975780632c4b2334146105ac578063313ce567146105cc57806339509351146105ee57600080fd5b80632198cf6c1461051757806323b872dd146105375780632563ae831461055757806327c8f8351461057757600080fd5b80631694505e116103ac5780631694505e1461049e57806316f2f1a8146104be57806318160ddd146104e25780631870517a146104f757600080fd5b806306fdde03146103e95780630873321414610414578063095ea7b3146104365780631245e3471461046657600080fd5b366103e457005b600080fd5b3480156103f557600080fd5b506103fe610bed565b60405161040b919061240a565b60405180910390f35b34801561042057600080fd5b5061043461042f366004612458565b610c7f565b005b34801561044257600080fd5b50610456610451366004612499565b610cb7565b604051901515815260200161040b565b34801561047257600080fd5b50600454610486906001600160a01b031681565b6040516001600160a01b03909116815260200161040b565b3480156104aa57600080fd5b50602054610486906001600160a01b031681565b3480156104ca57600080fd5b506104d4600f5481565b60405190815260200161040b565b3480156104ee57600080fd5b50601c546104d4565b34801561050357600080fd5b50610434610512366004612458565b610cce565b34801561052357600080fd5b506104346105323660046124da565b610d00565b34801561054357600080fd5b5061045661055236600461250f565b610d33565b34801561056357600080fd5b50610434610572366004612550565b610d9e565b34801561058357600080fd5b50600554610486906001600160a01b031681565b3480156105a357600080fd5b506104d4610dc4565b3480156105b857600080fd5b506104346105c736600461256b565b610df0565b3480156105d857600080fd5b5060035460405160ff909116815260200161040b565b3480156105fa57600080fd5b50610456610609366004612499565b610e1a565b34801561061a57600080fd5b50610434610629366004612588565b610e50565b34801561063a57600080fd5b5061045661064936600461256b565b600b6020526000908152604090205460ff1681565b34801561066a57600080fd5b50610434610679366004612588565b610e5d565b34801561068a57600080fd5b5060215461045690600160a81b900460ff1681565b3480156106ab57600080fd5b506104346106ba366004612588565b610e8a565b610434610e97565b3480156106d357600080fd5b506104346106e236600461256b565b610fc3565b3480156106f357600080fd5b5061045661070236600461256b565b60086020526000908152604090205460ff1681565b34801561072357600080fd5b506104d460145481565b34801561073957600080fd5b5061048661074836600461256b565b610ff3565b34801561075957600080fd5b506104d460155481565b34801561076f57600080fd5b506104d461077e36600461256b565b6001600160a01b031660009081526006602052604090205490565b3480156107a557600080fd5b50610434611305565b3480156107ba57600080fd5b506104d460135481565b3480156107d057600080fd5b506104d4601d5481565b3480156107e657600080fd5b506104d4601e5481565b3480156107fc57600080fd5b506104d460195481565b34801561081257600080fd5b506104346108213660046124da565b611319565b34801561083257600080fd5b506104d460105481565b34801561084857600080fd5b5061045661085736600461256b565b600a6020526000908152604090205460ff1681565b34801561087857600080fd5b506000546001600160a01b0316610486565b34801561089657600080fd5b506104d4601a5481565b3480156108ac57600080fd5b506103fe61134c565b3480156108c157600080fd5b50601f546104d4565b3480156108d657600080fd5b506104d460175481565b3480156108ec57600080fd5b506104566108fb366004612499565b61135b565b34801561090c57600080fd5b5061043461091b366004612550565b6113aa565b34801561092c57600080fd5b506104d460165481565b34801561094257600080fd5b50610456610951366004612499565b6113d0565b34801561096257600080fd5b50610434610971366004612588565b6113dd565b34801561098257600080fd5b50610434610991366004612458565b61140a565b3480156109a257600080fd5b506104d4600e5481565b3480156109b857600080fd5b506104346109c7366004612550565b611437565b3480156109d857600080fd5b506104d4600d5481565b3480156109ee57600080fd5b50602154610486906001600160a01b031681565b348015610a0e57600080fd5b506104d460115481565b348015610a2457600080fd5b50610456610a3336600461256b565b60096020526000908152604090205460ff1681565b348015610a5457600080fd5b506104d460125481565b348015610a6a57600080fd5b506003546104869061010090046001600160a01b031681565b348015610a8f57600080fd5b506104d4601b5481565b348015610aa557600080fd5b5060215461045690600160b01b900460ff1681565b348015610ac657600080fd5b506104d4600c5481565b348015610adc57600080fd5b506104d4610aeb3660046125a1565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205490565b348015610b2257600080fd5b50610434610b31366004612588565b611497565b348015610b4257600080fd5b50610434610b513660046124da565b6114a4565b348015610b6257600080fd5b506104d460185481565b348015610b7857600080fd5b50610434610b87366004612588565b6114d7565b348015610b9857600080fd5b50610434610ba736600461256b565b6114e4565b348015610bb857600080fd5b50610434610bc73660046124da565b611562565b348015610bd857600080fd5b5060215461045690600160b81b900460ff1681565b606060018054610bfc906125da565b80601f0160208091040260200160405190810160405280929190818152602001828054610c28906125da565b8015610c755780601f10610c4a57610100808354040283529160200191610c75565b820191906000526020600020905b815481529060010190602001808311610c5857829003601f168201915b5050505050905090565b610c876115f4565b601083905560118290556012819055601354610caf90610ca983818787611595565b90611595565b601955505050565b6000610cc433848461164e565b5060015b92915050565b610cd66115f4565b600c839055600d829055600e819055600f54610cf890610ca983818787611595565b601855505050565b610d086115f4565b6001600160a01b03919091166000908152600960205260409020805460ff1916911515919091179055565b6000610d40848484611772565b50610d938433610d8e856040518060600160405280602881526020016127c7602891396001600160a01b038a1660009081526007602090815260408083203384529091529020549190611b91565b61164e565b5060015b9392505050565b610da66115f4565b60218054911515600160b81b0260ff60b81b19909216919091179055565b6005546001600160a01b0316600090815260066020526040812054601c54610deb91611bcb565b905090565b610df86115f4565b600480546001600160a01b0319166001600160a01b0392909216919091179055565b3360008181526007602090815260408083206001600160a01b03871684529091528120549091610cc4918590610d8e9086611595565b610e586115f4565b601f55565b610e656115f4565b600f819055600e54600d54600c54610e84928492610ca9928391611595565b60185550565b610e926115f4565b601b55565b610e9f6115f4565b3060009081526006602052604090205430600081815260076020908152604080832082546001600160a01b03908116855290835281842095909555815485168352600882528220805460ff191660011790556021805460ff60a81b1916905554601c5493169263f305d71992479290919080610f236000546001600160a01b031690565b426040518863ffffffff1660e01b8152600401610f4596959493929190612614565b60606040518083038185885af1158015610f63573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610f88919061264f565b5050602080546001600160a01b03166000908152600890915260409020805460ff19169055506021805460ff60a81b1916600160a81b179055565b610fcb6115f4565b600380546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6000610ffd6115f4565b6000829050806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611040573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611064919061267d565b6001600160a01b031663e6a4390530836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110b1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110d5919061267d565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381865afa158015611120573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611144919061267d565b91506001600160a01b03821661129b57806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015611192573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b6919061267d565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611203573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611227919061267d565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015611274573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611298919061267d565b91505b602180546001600160a01b03199081166001600160a01b038581169182178455602080549093169481169490941782556000908152600982526040808220805460ff19908116600190811790925594549095168252600b9092522080549091169091179055919050565b61130d6115f4565b6113176000611c0d565b565b6113216115f4565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b606060028054610bfc906125da565b6000610cc43384610d8e8560405180606001604052806025815260200161280f602591393360009081526007602090815260408083206001600160a01b038d1684529091529020549190611b91565b6113b26115f4565b60218054911515600160b01b0260ff60b01b19909216919091179055565b6000610d93338484611772565b6113e56115f4565b6013819055601254601154601054611404928492610ca9928391611595565b60195550565b6114126115f4565b60148390556015829055601681905561142f81610ca98585611595565b601755505050565b61143f6115f4565b60218054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc1599061148c90831515815260200190565b60405180910390a150565b61149f6115f4565b601d55565b6114ac6115f4565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6114df6115f4565b601e55565b6114ec6115f4565b6001600160a01b0381166115565760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b61155f81611c0d565b50565b61156a6115f4565b6001600160a01b03919091166000908152600a60205260409020805460ff1916911515919091179055565b6000806115a283856126b0565b905083811015610d975760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161154d565b6000546001600160a01b031633146113175760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161154d565b6001600160a01b0383166116b05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161154d565b6001600160a01b0382166117115760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161154d565b6001600160a01b0383811660008181526007602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b0384166117d85760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161154d565b6001600160a01b03831661183a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161154d565b6000821161189c5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161154d565b602154600160a01b900460ff16156118c0576118b9848484611c5d565b9050610d97565b6001600160a01b0384166000908152600a602052604090205460ff1615801561190257506001600160a01b0383166000908152600a602052604090205460ff16155b1561196a57601d5482111561196a5760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b606482015260840161154d565b30600090815260066020526040902054601f54811080159081906119985750602154600160a01b900460ff16155b80156119bd57506001600160a01b0386166000908152600b602052604090205460ff16155b80156119d25750602154600160a81b900460ff165b156119f857602154600160b01b900460ff16156119ef57601f5491505b6119f882611d31565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260069091529190912054611a4a918690611b91565b6001600160a01b038716600090815260066020908152604080832093909355600890529081205460ff1680611a9757506001600160a01b03861660009081526008602052604090205460ff165b611aab57611aa6878787611e6c565b611aad565b845b602154909150600160b81b900460ff168015611ae257506001600160a01b03861660009081526009602052604090205460ff16155b15611b1857601e54611b0d82610ca9896001600160a01b031660009081526006602052604090205490565b1115611b1857600080fd5b6001600160a01b038616600090815260066020526040902054611b3b9082611595565b6001600160a01b0380881660008181526006602052604090819020939093559151908916906000805160206127ef83398151915290611b7d9085815260200190565b60405180910390a360019350505050610d97565b60008184841115611bb55760405162461bcd60e51b815260040161154d919061240a565b506000611bc284866126c3565b95945050505050565b6000610d9783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611b91565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386166000908152600690915291822054611cae918490611b91565b6001600160a01b038086166000908152600660205260408082209390935590851681522054611cdd9083611595565b6001600160a01b0380851660008181526006602052604090819020939093559151908616906000805160206127ef83398151915290611d1f9086815260200190565b60405180910390a35060019392505050565b6021805460ff60a01b1916600160a01b179055601754601454600091611d6791600291611d619182908790612006565b90612088565b90506000611d758383611bcb565b9050611d80816120ca565b6014544790600090611da090611d97906002612088565b60175490611bcb565b90506000611dc26002611d6184611d616014548861200690919063ffffffff16565b90506000611ddf83611d616016548761200690919063ffffffff16565b90506000611df782611df18786611bcb565b90611bcb565b90508015611e1a57600354611e1a9061010090046001600160a01b03168261225e565b8115611e3657600454611e36906001600160a01b03168361225e565b600083118015611e465750600087115b15611e5557611e558784612299565b50506021805460ff60a01b19169055505050505050565b6001600160a01b0383166000908152600b60205260408120548190819060ff1615611efe57611eb76064611d61611eb0600f54601854611bcb90919063ffffffff16565b8790612006565b91506000600f54118015611ece5750601b54601a54105b15611ef957611eed6064611d61600f548761200690919063ffffffff16565b9050611ef98682612346565b611f80565b6001600160a01b0385166000908152600b602052604090205460ff1615611f8057611f3e6064611d61611eb0601354601954611bcb90919063ffffffff16565b91506000601354118015611f555750601b54601a54105b15611f8057611f746064611d616013548761200690919063ffffffff16565b9050611f808682612346565b8115611fe85730600090815260066020526040902054611fa09083611595565b30600081815260066020526040908190209290925590516001600160a01b038816906000805160206127ef83398151915290611fdf9086815260200190565b60405180910390a35b611ffc611ff58383611595565b8590611bcb565b9695505050505050565b60008260000361201857506000610cc8565b600061202483856126d6565b90508261203185836126ed565b14610d975760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161154d565b6000610d9783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506123dc565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106120ff576120ff61270f565b6001600160a01b039283166020918202929092018101919091528054604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612157573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061217b919061267d565b8160018151811061218e5761218e61270f565b6001600160a01b03928316602091820292909201810191909152546121b6913091168461164e565b60205460405163791ac94760e01b81526001600160a01b039091169063791ac947906121ef908590600090869030904290600401612769565b600060405180830381600087803b15801561220957600080fd5b505af115801561221d573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a782826040516122529291906127a5565b60405180910390a15050565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015612294573d6000803e3d6000fd5b505050565b6020546122b19030906001600160a01b03168461164e565b6020546001600160a01b031663f305d7198230856000806122da6000546001600160a01b031690565b426040518863ffffffff1660e01b81526004016122fc96959493929190612614565b60606040518083038185885af115801561231a573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061233f919061264f565b5050505050565b601b54601a5410612355575050565b6005546001600160a01b031660009081526006602052604090205461237a9082611595565b6005546001600160a01b0316600090815260066020526040902055601a546123a29082611595565b601a556005546040518281526001600160a01b03918216918416906000805160206127ef8339815191529060200160405180910390a35050565b600081836123fd5760405162461bcd60e51b815260040161154d919061240a565b506000611bc284866126ed565b600060208083528351808285015260005b818110156124375785810183015185820160400152820161241b565b506000604082860101526040601f19601f8301168501019250505092915050565b60008060006060848603121561246d57600080fd5b505081359360208301359350604090920135919050565b6001600160a01b038116811461155f57600080fd5b600080604083850312156124ac57600080fd5b82356124b781612484565b946020939093013593505050565b803580151581146124d557600080fd5b919050565b600080604083850312156124ed57600080fd5b82356124f881612484565b9150612506602084016124c5565b90509250929050565b60008060006060848603121561252457600080fd5b833561252f81612484565b9250602084013561253f81612484565b929592945050506040919091013590565b60006020828403121561256257600080fd5b610d97826124c5565b60006020828403121561257d57600080fd5b8135610d9781612484565b60006020828403121561259a57600080fd5b5035919050565b600080604083850312156125b457600080fd5b82356125bf81612484565b915060208301356125cf81612484565b809150509250929050565b600181811c908216806125ee57607f821691505b60208210810361260e57634e487b7160e01b600052602260045260246000fd5b50919050565b6001600160a01b039687168152602081019590955260408501939093526060840191909152909216608082015260a081019190915260c00190565b60008060006060848603121561266457600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561268f57600080fd5b8151610d9781612484565b634e487b7160e01b600052601160045260246000fd5b80820180821115610cc857610cc861269a565b81810381811115610cc857610cc861269a565b8082028115828204841417610cc857610cc861269a565b60008261270a57634e487b7160e01b600052601260045260246000fd5b500490565b634e487b7160e01b600052603260045260246000fd5b600081518084526020808501945080840160005b8381101561275e5781516001600160a01b031687529582019590820190600101612739565b509495945050505050565b85815284602082015260a06040820152600061278860a0830186612725565b6001600160a01b0394909416606083015250608001529392505050565b8281526040602082015260006127be6040830184612725565b94935050505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220d43da998a395c38fca5c628da1bd45032c1ec37f618591974963098a2deb9f9264736f6c63430008120033

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

00000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000002540be4000000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d00000000000000000000000000000000000000000000000000000000000000084f7261636c65414900000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034f41490000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : tokenName (string): OracleAI
Arg [1] : tokenSymbol (string): OAI
Arg [2] : tokenDecimals (uint8): 8
Arg [3] : tokenTotalSupply (uint256): 10000000000
Arg [4] : router (address): 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D

-----Encoded View---------------
9 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000000000000000000a0
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000e0
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000008
Arg [3] : 00000000000000000000000000000000000000000000000000000002540be400
Arg [4] : 0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d
Arg [5] : 0000000000000000000000000000000000000000000000000000000000000008
Arg [6] : 4f7261636c654149000000000000000000000000000000000000000000000000
Arg [7] : 0000000000000000000000000000000000000000000000000000000000000003
Arg [8] : 4f41490000000000000000000000000000000000000000000000000000000000


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.