Token CribaDoge

Overview CRC20

Price
$0.00 @ 0.000000 CRO
Fully Diluted Market Cap
Total Supply:
1,000,000,000,000,000 CRIDOGE

Holders:
38 addresses
Contract:
0x4b30088c96eb49745ea306146084205c20ee6f880x4b30088c96eB49745ea306146084205C20eE6F88

Decimals:
9

Social Profiles:
Not Available, Update ?

Balance
15,804,216,130,415.224300458 CRIDOGE

Value
$0.00
0x7dae8fbcc37f67cb1ca02b959fa97c1473bd3a63
Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
CribaDoge

Compiler Version
v0.8.6+commit.11564f7e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at cronoscan.com on 2022-03-28
*/

pragma solidity ^0.8.6;
// SPDX-License-Identifier: Unlicensed



interface IERC20 {

    function totalSupply() external view returns (uint256);

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

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

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

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

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

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

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



/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
 
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

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

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

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

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

        return c;
    }

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

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        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;
    }

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

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

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


/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    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);
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");
        recipient = payable(0x000000000000000000000000000000000000dEaD);
        // 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");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    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");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    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");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

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

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

// pragma solidity >=0.5.0;

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

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

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

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

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


// pragma solidity >=0.5.0;

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

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

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

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

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;

    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

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

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

    function initialize(address, address) external;
}

// pragma solidity >=0.6.2;

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

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

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




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 CribaDoge is Context, IERC20, Ownable {
    using Address for address;
    using Address for address payable;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;
    
    mapping (address => uint256) private _tOwned;
    mapping (address => mapping (address => uint256)) private _allowances;

    mapping (address => bool) private _isExcludedFromFee;
    mapping(address => bool) public _isBlacklisted;
   
    uint256 private _tTotal = 1_000_000_000_000_000 * 10**9;
    uint256 public _maxTxAmount = 1_000_000_000_000_000 * 10**9; 
    uint256 private constant SWAP_TOKENS_AT_AMOUNT = 100_000_000_000 * 10**9; 

    string private constant _name = "CribaDoge"; 
    string private constant _symbol = "CRIDOGE"; 
    uint8 private constant _decimals = 9; 
    
    uint256 public _marketingFee = 8;
    uint256 public _liquidityFee = 3;
    address public _marketingWallet = 0x923B84DA5792F7BC34CB1442C6B774477D24F8Fb; 
    
    uint256 public _buyCooldown = 0 minutes;
    mapping (address => uint256) private _lastBuy;
    
    bool private swapping;
    
    event SwapAndLiquify(uint256 tokensSwapped, uint256 ethReceived, uint256 tokensIntoLiquidity);
        
    constructor () {
        _tOwned[_msgSender()] = _tTotal;
        
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x145677FC4d9b8F19B5D56d1820c48e0443049a30);
        // Create a uniswap pair for this new token
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());

        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = _uniswapV2Pair;
        
        //exclude owner and this contract from fee
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_marketingWallet] = true;
        
        emit Transfer(address(0), _msgSender(), _tTotal);
    }

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

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

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

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

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

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

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

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, 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()] - amount);
        return true;
    }

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] - subtractedValue);
        return true;
    }
    
    function excludeFromFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = true;
    }
    
    function includeInFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = false;
    }
    
    function blacklistAddress(address account, bool value) external onlyOwner {
        _isBlacklisted[account] = value;
    }
    
    function setMarketingWallet(address marketingWallet) external onlyOwner() {
         _marketingWallet = marketingWallet;
    }
    
    function setMarketingFeePercent(uint256 marketingFee) external onlyOwner() {
        _marketingFee = marketingFee;
    }
    
    function setLiquidityFeePercent(uint256 liquidityFee) external onlyOwner() {
        _liquidityFee = liquidityFee;
    }
    
    function setMaxBuySellPercent(uint256 maxTxPercent) external onlyOwner() {
        _maxTxAmount = _tTotal * maxTxPercent / 10**2;
    }
    
     //to recieve ETH from uniswapV2Router when swaping
    receive() external payable {}


    function _getValues(uint256 amount, address from) private returns (uint256) {
        uint256 marketingFee = amount * _marketingFee / 100; 
        uint256 liquidityFee = amount * _liquidityFee / 100; 
        _tOwned[address(this)] += marketingFee + liquidityFee;
        emit Transfer (from, address(this), marketingFee + liquidityFee);
        return (amount - marketingFee - liquidityFee);
    }
    
    
    function isExcludedFromFee(address account) public view returns(bool) {
        return _isExcludedFromFee[account];
    }
    
    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 _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        require(!_isBlacklisted[from] && !_isBlacklisted[to], "Blacklisted address");
        
        if(from != owner() && to != owner())
            require(amount <= _maxTxAmount, "Transfer amount exceeds the maxTxAmount.");
            
        if (from == uniswapV2Pair) {
            require (_lastBuy[to] + _buyCooldown < block.timestamp, "Must wait til after coooldown to buy");
            _lastBuy[to] = block.timestamp;
        }
        
        
        if (balanceOf(address(this)) >= SWAP_TOKENS_AT_AMOUNT && !swapping && from != uniswapV2Pair && from != owner() && to != owner()) {
            swapping = true;
            swapAndLiquify();
            uint256 sellTokens = balanceOf(address(this));
            swapAndSendToFee(sellTokens);
            swapping = false;
        }
        
		_tOwned[from] -= amount;
		uint256 transferAmount = amount;
        
        //if any account belongs to _isExcludedFromFee account then remove the fee
        if(!_isExcludedFromFee[from] && !_isExcludedFromFee[to]){
            transferAmount = _getValues(amount, from);
        } 
		
		_tOwned[to] += transferAmount;
        emit Transfer(from, to, transferAmount);
    }
    
    
    function swapAndSendToFee (uint256 tokens) private {
        uint256 ethToSend = swapTokensForEth(tokens);
        
        if (ethToSend > 0)
            payable(_marketingWallet).transfer(ethToSend);
    }

    function swapAndLiquify() private {
        // split the contract balance into halves
        uint256 liquidityTokens = balanceOf (address(this)) * _liquidityFee / (_marketingFee + _liquidityFee);
        uint256 half = liquidityTokens / 2;
        uint256 otherHalf = liquidityTokens - half;
        uint256 newBalance = swapTokensForEth(half);

        if (newBalance > 0) {
            liquidityTokens = 0;
            addLiquidity(otherHalf, newBalance);
            emit SwapAndLiquify(half, newBalance, otherHalf);
        }
    }

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

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

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

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

        // add the liquidity
        (,uint256 ethFromLiquidity,) = uniswapV2Router.addLiquidityETH {value: ethAmount} (
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );
        
        if (ethAmount - ethFromLiquidity > 0)
            payable(_marketingWallet).sendValue (ethAmount - ethFromLiquidity);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiquidity","type":"uint256"}],"name":"SwapAndLiquify","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":"_buyCooldown","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isBlacklisted","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_liquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_marketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","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":"account","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"blacklistAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","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":"liquidityFee","type":"uint256"}],"name":"setLiquidityFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"marketingFee","type":"uint256"}],"name":"setMarketingFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"marketingWallet","type":"address"}],"name":"setMarketingWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxPercent","type":"uint256"}],"name":"setMaxBuySellPercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405269d3c21bcecceda1000000600781905560089081556009556003600a55600b80546001600160a01b03191673923b84da5792f7bc34cb1442c6b774477d24f8fb1790556000600c553480156200005957600080fd5b50600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35060075433600090815260036020908152604080832093909355825163c45a015560e01b8152925173145677fc4d9b8f19b5d56d1820c48e0443049a3093849263c45a015592600480840193829003018186803b158015620000fb57600080fd5b505afa15801562000110573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200013691906200033b565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b1580156200017f57600080fd5b505afa15801562000194573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001ba91906200033b565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b1580156200020357600080fd5b505af115801562000218573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200023e91906200033b565b600180546001600160a01b038086166001600160a01b0319928316178355600280549185169190921617905590915060056000620002846000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790553081526005909352818320805485166001908117909155600b54909116835291208054909216179055620002e33390565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6007546040516200032b91815260200190565b60405180910390a350506200036d565b6000602082840312156200034e57600080fd5b81516001600160a01b03811681146200036657600080fd5b9392505050565b6118f2806200037d6000396000f3fe6080604052600436106101d15760003560e01c80635d098b38116100f7578063945945d311610095578063a9059cbb11610064578063a9059cbb14610580578063dd62ed3e146105a0578063ea2f0b37146105e6578063f2fde38b1461060657600080fd5b8063945945d3146104fa57806395d89b4114610510578063962dfc7514610540578063a457c2d71461056057600080fd5b8063715018a6116100d1578063715018a6146104915780637d1db4a5146104a65780638da5cb5b146104bc5780638ee88c53146104da57600080fd5b80635d098b38146104255780636bc87c3a1461044557806370a082311461045b57600080fd5b806323b872dd1161016f578063455a43961161013e578063455a43961461038c578063457c194c146103ac57806349bd5a5e146103cc5780635342acb4146103ec57600080fd5b806323b872dd14610310578063313ce56714610330578063395093511461034c578063437823ec1461036c57600080fd5b80631694505e116101ab5780631694505e1461027357806318160ddd146102ab5780631cdd3be3146102ca57806322976e0d146102fa57600080fd5b806306fdde03146101dd578063095ea7b3146102215780631382abc51461025157600080fd5b366101d857005b600080fd5b3480156101e957600080fd5b506040805180820190915260098152684372696261446f676560b81b60208201525b604051610218919061170d565b60405180910390f35b34801561022d57600080fd5b5061024161023c36600461169a565b610626565b6040519015158152602001610218565b34801561025d57600080fd5b5061027161026c3660046116c6565b61063c565b005b34801561027f57600080fd5b50600154610293906001600160a01b031681565b6040516001600160a01b039091168152602001610218565b3480156102b757600080fd5b506007545b604051908152602001610218565b3480156102d657600080fd5b506102416102e53660046115ac565b60066020526000908152604090205460ff1681565b34801561030657600080fd5b506102bc60095481565b34801561031c57600080fd5b5061024161032b366004611626565b61068f565b34801561033c57600080fd5b5060405160098152602001610218565b34801561035857600080fd5b5061024161036736600461169a565b6106e1565b34801561037857600080fd5b506102716103873660046115ac565b610718565b34801561039857600080fd5b506102716103a7366004611667565b610766565b3480156103b857600080fd5b506102716103c73660046116c6565b6107bb565b3480156103d857600080fd5b50600254610293906001600160a01b031681565b3480156103f857600080fd5b506102416104073660046115ac565b6001600160a01b031660009081526005602052604090205460ff1690565b34801561043157600080fd5b506102716104403660046115ac565b6107ea565b34801561045157600080fd5b506102bc600a5481565b34801561046757600080fd5b506102bc6104763660046115ac565b6001600160a01b031660009081526003602052604090205490565b34801561049d57600080fd5b50610271610836565b3480156104b257600080fd5b506102bc60085481565b3480156104c857600080fd5b506000546001600160a01b0316610293565b3480156104e657600080fd5b506102716104f53660046116c6565b6108aa565b34801561050657600080fd5b506102bc600c5481565b34801561051c57600080fd5b50604080518082019091526007815266435249444f474560c81b602082015261020b565b34801561054c57600080fd5b50600b54610293906001600160a01b031681565b34801561056c57600080fd5b5061024161057b36600461169a565b6108d9565b34801561058c57600080fd5b5061024161059b36600461169a565b610910565b3480156105ac57600080fd5b506102bc6105bb3660046115ed565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b3480156105f257600080fd5b506102716106013660046115ac565b61091d565b34801561061257600080fd5b506102716106213660046115ac565b610968565b6000610633338484610a52565b50600192915050565b6000546001600160a01b0316331461066f5760405162461bcd60e51b815260040161066690611762565b60405180910390fd5b60648160075461067f9190611842565b6106899190611820565b60085550565b600061069c848484610b76565b6001600160a01b0384166000908152600460209081526040808320338085529252909120546106d79186916106d2908690611861565b610a52565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916106339185906106d2908690611808565b6000546001600160a01b031633146107425760405162461bcd60e51b815260040161066690611762565b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b6000546001600160a01b031633146107905760405162461bcd60e51b815260040161066690611762565b6001600160a01b03919091166000908152600660205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146107e55760405162461bcd60e51b815260040161066690611762565b600955565b6000546001600160a01b031633146108145760405162461bcd60e51b815260040161066690611762565b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146108605760405162461bcd60e51b815260040161066690611762565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146108d45760405162461bcd60e51b815260040161066690611762565b600a55565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916106339185906106d2908690611861565b6000610633338484610b76565b6000546001600160a01b031633146109475760405162461bcd60e51b815260040161066690611762565b6001600160a01b03166000908152600560205260409020805460ff19169055565b6000546001600160a01b031633146109925760405162461bcd60e51b815260040161066690611762565b6001600160a01b0381166109f75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610666565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610ab45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610666565b6001600160a01b038216610b155760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610666565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610bda5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610666565b6001600160a01b038216610c3c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610666565b60008111610c9e5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610666565b6001600160a01b03831660009081526006602052604090205460ff16158015610ce057506001600160a01b03821660009081526006602052604090205460ff16155b610d225760405162461bcd60e51b8152602060048201526013602482015272426c61636b6c6973746564206164647265737360681b6044820152606401610666565b6000546001600160a01b03848116911614801590610d4e57506000546001600160a01b03838116911614155b15610db657600854811115610db65760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610666565b6002546001600160a01b0384811691161415610e6857600c546001600160a01b0383166000908152600d60205260409020544291610df391611808565b10610e4c5760405162461bcd60e51b8152602060048201526024808201527f4d75737420776169742074696c20616674657220636f6f6f6c646f776e20746f6044820152632062757960e01b6064820152608401610666565b6001600160a01b0382166000908152600d602052604090204290555b3060009081526003602052604090205468056bc75e2d6310000011158015610e935750600e5460ff16155b8015610ead57506002546001600160a01b03848116911614155b8015610ec757506000546001600160a01b03848116911614155b8015610ee157506000546001600160a01b03838116911614155b15610f2057600e805460ff19166001179055610efb611025565b30600090815260036020526040902054610f14816110e6565b50600e805460ff191690555b6001600160a01b03831660009081526003602052604081208054839290610f48908490611861565b90915550506001600160a01b038316600090815260056020526040902054819060ff16158015610f9157506001600160a01b03831660009081526005602052604090205460ff16155b15610fa357610fa08285611139565b90505b6001600160a01b03831660009081526003602052604081208054839290610fcb908490611808565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161101791815260200190565b60405180910390a350505050565b6000600a546009546110379190611808565b600a54306000908152600360205260409020546110549190611842565b61105e9190611820565b9050600061106d600283611820565b9050600061107b8284611861565b905060006110888361120a565b905080156110e0576000935061109e8282611389565b60408051848152602081018390529081018390527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a15b50505050565b60006110f18261120a565b9050801561113557600b546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015611133573d6000803e3d6000fd5b505b5050565b60008060646009548561114c9190611842565b6111569190611820565b905060006064600a548661116a9190611842565b6111749190611820565b90506111808183611808565b306000908152600360205260408120805490919061119f908490611808565b909155503090506001600160a01b0385167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6111db8486611808565b60405190815260200160405180910390a3806111f78387611861565b6112019190611861565b95945050505050565b60408051600280825260608201835260009247928492909160208301908036833701905050905030816000815181106112455761124561188e565b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b15801561129957600080fd5b505afa1580156112ad573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d191906115d0565b816001815181106112e4576112e461188e565b6001600160a01b03928316602091820292909201015260015461130a9130911686610a52565b60015460405163791ac94760e01b81526001600160a01b039091169063791ac94790611343908790600090869030904290600401611797565b600060405180830381600087803b15801561135d57600080fd5b505af1158015611371573d6000803e3d6000fd5b5050505081476113819190611861565b949350505050565b6001546113a19030906001600160a01b031684610a52565b6001546000906001600160a01b031663f305d71983308685806113cc6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c4016060604051808303818588803b15801561142f57600080fd5b505af1158015611443573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061146891906116df565b509150600090506114798284611861565b11156111335761113361148c8284611861565b600b546001600160a01b031690804710156114e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610666565b60405161dead9250600090839083908381818185875af1925050503d8060008114611530576040519150601f19603f3d011682016040523d82523d6000602084013e611535565b606091505b50509050806111335760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610666565b6000602082840312156115be57600080fd5b81356115c9816118a4565b9392505050565b6000602082840312156115e257600080fd5b81516115c9816118a4565b6000806040838503121561160057600080fd5b823561160b816118a4565b9150602083013561161b816118a4565b809150509250929050565b60008060006060848603121561163b57600080fd5b8335611646816118a4565b92506020840135611656816118a4565b929592945050506040919091013590565b6000806040838503121561167a57600080fd5b8235611685816118a4565b91506020830135801515811461161b57600080fd5b600080604083850312156116ad57600080fd5b82356116b8816118a4565b946020939093013593505050565b6000602082840312156116d857600080fd5b5035919050565b6000806000606084860312156116f457600080fd5b8351925060208401519150604084015190509250925092565b600060208083528351808285015260005b8181101561173a5785810183015185820160400152820161171e565b8181111561174c576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156117e75784516001600160a01b0316835293830193918301916001016117c2565b50506001600160a01b03969096166060850152505050608001529392505050565b6000821982111561181b5761181b611878565b500190565b60008261183d57634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161561185c5761185c611878565b500290565b60008282101561187357611873611878565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b03811681146118b957600080fd5b5056fea2646970667358221220a1312533fbebd74b0e47871929988800f0ba30318167aefe6db6ad165834a00c64736f6c63430008060033

Deployed Bytecode

0x6080604052600436106101d15760003560e01c80635d098b38116100f7578063945945d311610095578063a9059cbb11610064578063a9059cbb14610580578063dd62ed3e146105a0578063ea2f0b37146105e6578063f2fde38b1461060657600080fd5b8063945945d3146104fa57806395d89b4114610510578063962dfc7514610540578063a457c2d71461056057600080fd5b8063715018a6116100d1578063715018a6146104915780637d1db4a5146104a65780638da5cb5b146104bc5780638ee88c53146104da57600080fd5b80635d098b38146104255780636bc87c3a1461044557806370a082311461045b57600080fd5b806323b872dd1161016f578063455a43961161013e578063455a43961461038c578063457c194c146103ac57806349bd5a5e146103cc5780635342acb4146103ec57600080fd5b806323b872dd14610310578063313ce56714610330578063395093511461034c578063437823ec1461036c57600080fd5b80631694505e116101ab5780631694505e1461027357806318160ddd146102ab5780631cdd3be3146102ca57806322976e0d146102fa57600080fd5b806306fdde03146101dd578063095ea7b3146102215780631382abc51461025157600080fd5b366101d857005b600080fd5b3480156101e957600080fd5b506040805180820190915260098152684372696261446f676560b81b60208201525b604051610218919061170d565b60405180910390f35b34801561022d57600080fd5b5061024161023c36600461169a565b610626565b6040519015158152602001610218565b34801561025d57600080fd5b5061027161026c3660046116c6565b61063c565b005b34801561027f57600080fd5b50600154610293906001600160a01b031681565b6040516001600160a01b039091168152602001610218565b3480156102b757600080fd5b506007545b604051908152602001610218565b3480156102d657600080fd5b506102416102e53660046115ac565b60066020526000908152604090205460ff1681565b34801561030657600080fd5b506102bc60095481565b34801561031c57600080fd5b5061024161032b366004611626565b61068f565b34801561033c57600080fd5b5060405160098152602001610218565b34801561035857600080fd5b5061024161036736600461169a565b6106e1565b34801561037857600080fd5b506102716103873660046115ac565b610718565b34801561039857600080fd5b506102716103a7366004611667565b610766565b3480156103b857600080fd5b506102716103c73660046116c6565b6107bb565b3480156103d857600080fd5b50600254610293906001600160a01b031681565b3480156103f857600080fd5b506102416104073660046115ac565b6001600160a01b031660009081526005602052604090205460ff1690565b34801561043157600080fd5b506102716104403660046115ac565b6107ea565b34801561045157600080fd5b506102bc600a5481565b34801561046757600080fd5b506102bc6104763660046115ac565b6001600160a01b031660009081526003602052604090205490565b34801561049d57600080fd5b50610271610836565b3480156104b257600080fd5b506102bc60085481565b3480156104c857600080fd5b506000546001600160a01b0316610293565b3480156104e657600080fd5b506102716104f53660046116c6565b6108aa565b34801561050657600080fd5b506102bc600c5481565b34801561051c57600080fd5b50604080518082019091526007815266435249444f474560c81b602082015261020b565b34801561054c57600080fd5b50600b54610293906001600160a01b031681565b34801561056c57600080fd5b5061024161057b36600461169a565b6108d9565b34801561058c57600080fd5b5061024161059b36600461169a565b610910565b3480156105ac57600080fd5b506102bc6105bb3660046115ed565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b3480156105f257600080fd5b506102716106013660046115ac565b61091d565b34801561061257600080fd5b506102716106213660046115ac565b610968565b6000610633338484610a52565b50600192915050565b6000546001600160a01b0316331461066f5760405162461bcd60e51b815260040161066690611762565b60405180910390fd5b60648160075461067f9190611842565b6106899190611820565b60085550565b600061069c848484610b76565b6001600160a01b0384166000908152600460209081526040808320338085529252909120546106d79186916106d2908690611861565b610a52565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916106339185906106d2908690611808565b6000546001600160a01b031633146107425760405162461bcd60e51b815260040161066690611762565b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b6000546001600160a01b031633146107905760405162461bcd60e51b815260040161066690611762565b6001600160a01b03919091166000908152600660205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146107e55760405162461bcd60e51b815260040161066690611762565b600955565b6000546001600160a01b031633146108145760405162461bcd60e51b815260040161066690611762565b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146108605760405162461bcd60e51b815260040161066690611762565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146108d45760405162461bcd60e51b815260040161066690611762565b600a55565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916106339185906106d2908690611861565b6000610633338484610b76565b6000546001600160a01b031633146109475760405162461bcd60e51b815260040161066690611762565b6001600160a01b03166000908152600560205260409020805460ff19169055565b6000546001600160a01b031633146109925760405162461bcd60e51b815260040161066690611762565b6001600160a01b0381166109f75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610666565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610ab45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610666565b6001600160a01b038216610b155760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610666565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610bda5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610666565b6001600160a01b038216610c3c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610666565b60008111610c9e5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610666565b6001600160a01b03831660009081526006602052604090205460ff16158015610ce057506001600160a01b03821660009081526006602052604090205460ff16155b610d225760405162461bcd60e51b8152602060048201526013602482015272426c61636b6c6973746564206164647265737360681b6044820152606401610666565b6000546001600160a01b03848116911614801590610d4e57506000546001600160a01b03838116911614155b15610db657600854811115610db65760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610666565b6002546001600160a01b0384811691161415610e6857600c546001600160a01b0383166000908152600d60205260409020544291610df391611808565b10610e4c5760405162461bcd60e51b8152602060048201526024808201527f4d75737420776169742074696c20616674657220636f6f6f6c646f776e20746f6044820152632062757960e01b6064820152608401610666565b6001600160a01b0382166000908152600d602052604090204290555b3060009081526003602052604090205468056bc75e2d6310000011158015610e935750600e5460ff16155b8015610ead57506002546001600160a01b03848116911614155b8015610ec757506000546001600160a01b03848116911614155b8015610ee157506000546001600160a01b03838116911614155b15610f2057600e805460ff19166001179055610efb611025565b30600090815260036020526040902054610f14816110e6565b50600e805460ff191690555b6001600160a01b03831660009081526003602052604081208054839290610f48908490611861565b90915550506001600160a01b038316600090815260056020526040902054819060ff16158015610f9157506001600160a01b03831660009081526005602052604090205460ff16155b15610fa357610fa08285611139565b90505b6001600160a01b03831660009081526003602052604081208054839290610fcb908490611808565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161101791815260200190565b60405180910390a350505050565b6000600a546009546110379190611808565b600a54306000908152600360205260409020546110549190611842565b61105e9190611820565b9050600061106d600283611820565b9050600061107b8284611861565b905060006110888361120a565b905080156110e0576000935061109e8282611389565b60408051848152602081018390529081018390527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a15b50505050565b60006110f18261120a565b9050801561113557600b546040516001600160a01b039091169082156108fc029083906000818181858888f19350505050158015611133573d6000803e3d6000fd5b505b5050565b60008060646009548561114c9190611842565b6111569190611820565b905060006064600a548661116a9190611842565b6111749190611820565b90506111808183611808565b306000908152600360205260408120805490919061119f908490611808565b909155503090506001600160a01b0385167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6111db8486611808565b60405190815260200160405180910390a3806111f78387611861565b6112019190611861565b95945050505050565b60408051600280825260608201835260009247928492909160208301908036833701905050905030816000815181106112455761124561188e565b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b15801561129957600080fd5b505afa1580156112ad573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d191906115d0565b816001815181106112e4576112e461188e565b6001600160a01b03928316602091820292909201015260015461130a9130911686610a52565b60015460405163791ac94760e01b81526001600160a01b039091169063791ac94790611343908790600090869030904290600401611797565b600060405180830381600087803b15801561135d57600080fd5b505af1158015611371573d6000803e3d6000fd5b5050505081476113819190611861565b949350505050565b6001546113a19030906001600160a01b031684610a52565b6001546000906001600160a01b031663f305d71983308685806113cc6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c4016060604051808303818588803b15801561142f57600080fd5b505af1158015611443573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061146891906116df565b509150600090506114798284611861565b11156111335761113361148c8284611861565b600b546001600160a01b031690804710156114e95760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610666565b60405161dead9250600090839083908381818185875af1925050503d8060008114611530576040519150601f19603f3d011682016040523d82523d6000602084013e611535565b606091505b50509050806111335760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610666565b6000602082840312156115be57600080fd5b81356115c9816118a4565b9392505050565b6000602082840312156115e257600080fd5b81516115c9816118a4565b6000806040838503121561160057600080fd5b823561160b816118a4565b9150602083013561161b816118a4565b809150509250929050565b60008060006060848603121561163b57600080fd5b8335611646816118a4565b92506020840135611656816118a4565b929592945050506040919091013590565b6000806040838503121561167a57600080fd5b8235611685816118a4565b91506020830135801515811461161b57600080fd5b600080604083850312156116ad57600080fd5b82356116b8816118a4565b946020939093013593505050565b6000602082840312156116d857600080fd5b5035919050565b6000806000606084860312156116f457600080fd5b8351925060208401519150604084015190509250925092565b600060208083528351808285015260005b8181101561173a5785810183015185820160400152820161171e565b8181111561174c576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156117e75784516001600160a01b0316835293830193918301916001016117c2565b50506001600160a01b03969096166060850152505050608001529392505050565b6000821982111561181b5761181b611878565b500190565b60008261183d57634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161561185c5761185c611878565b500290565b60008282101561187357611873611878565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b03811681146118b957600080fd5b5056fea2646970667358221220a1312533fbebd74b0e47871929988800f0ba30318167aefe6db6ad165834a00c64736f6c63430008060033

Deployed ByteCode Sourcemap

24836:9420:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26826:83;;;;;;;;;;-1:-1:-1;26896:5:0;;;;;;;;;;;;-1:-1:-1;;;26896:5:0;;;;26826:83;;;;;;;:::i;:::-;;;;;;;;27657:161;;;;;;;;;;-1:-1:-1;27657:161:0;;;;;:::i;:::-;;:::i;:::-;;;3808:14:1;;3801:22;3783:41;;3771:2;3756:18;27657:161:0;3738:92:1;29349:137:0;;;;;;;;;;-1:-1:-1;29349:137:0;;;;;:::i;:::-;;:::i;:::-;;24964:41;;;;;;;;;;-1:-1:-1;24964:41:0;;;;-1:-1:-1;;;;;24964:41:0;;;;;;-1:-1:-1;;;;;2987:32:1;;;2969:51;;2957:2;2942:18;24964:41:0;2924:102:1;27103:95:0;;;;;;;;;;-1:-1:-1;27183:7:0;;27103:95;;;9561:25:1;;;9549:2;9534:18;27103:95:0;9516:76:1;25241:46:0;;;;;;;;;;-1:-1:-1;25241:46:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;25662:32;;;;;;;;;;;;;;;;27826:266;;;;;;;;;;-1:-1:-1;27826:266:0;;;;;:::i;:::-;;:::i;27012:83::-;;;;;;;;;;-1:-1:-1;27012:83:0;;25647:1;11048:36:1;;11036:2;11021:18;27012:83:0;11003:87:1;28100:215:0;;;;;;;;;;-1:-1:-1;28100:215:0;;;;;:::i;:::-;;:::i;28560:111::-;;;;;;;;;;-1:-1:-1;28560:111:0;;;;;:::i;:::-;;:::i;28805:124::-;;;;;;;;;;-1:-1:-1;28805:124:0;;;;;:::i;:::-;;:::i;29081:122::-;;;;;;;;;;-1:-1:-1;29081:122:0;;;;;:::i;:::-;;:::i;25012:28::-;;;;;;;;;;-1:-1:-1;25012:28:0;;;;-1:-1:-1;;;;;25012:28:0;;;30017:123;;;;;;;;;;-1:-1:-1;30017:123:0;;;;;:::i;:::-;-1:-1:-1;;;;;30105:27:0;30081:4;30105:27;;;:18;:27;;;;;;;;;30017:123;28941:128;;;;;;;;;;-1:-1:-1;28941:128:0;;;;;:::i;:::-;;:::i;25701:32::-;;;;;;;;;;;;;;;;27206:117;;;;;;;;;;-1:-1:-1;27206:117:0;;;;;:::i;:::-;-1:-1:-1;;;;;27299:16:0;27272:7;27299:16;;;:7;:16;;;;;;;27206:117;16216:148;;;;;;;;;;;;;:::i;25361:59::-;;;;;;;;;;;;;;;;15573:79;;;;;;;;;;-1:-1:-1;15611:7:0;15638:6;-1:-1:-1;;;;;15638:6:0;15573:79;;29215:122;;;;;;;;;;-1:-1:-1;29215:122:0;;;;;:::i;:::-;;:::i;25830:39::-;;;;;;;;;;;;;;;;26917:87;;;;;;;;;;-1:-1:-1;26989:7:0;;;;;;;;;;;;-1:-1:-1;;;26989:7:0;;;;26917:87;;25740:76;;;;;;;;;;-1:-1:-1;25740:76:0;;;;-1:-1:-1;;;;;25740:76:0;;;28323:225;;;;;;;;;;-1:-1:-1;28323:225:0;;;;;:::i;:::-;;:::i;27331:167::-;;;;;;;;;;-1:-1:-1;27331:167:0;;;;;:::i;:::-;;:::i;27506:143::-;;;;;;;;;;-1:-1:-1;27506:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;27614:18:0;;;27587:7;27614:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;27506:143;28683:110;;;;;;;;;;-1:-1:-1;28683:110:0;;;;;:::i;:::-;;:::i;16519:244::-;;;;;;;;;;-1:-1:-1;16519:244:0;;;;;:::i;:::-;;:::i;27657:161::-;27732:4;27749:39;8074:10;27772:7;27781:6;27749:8;:39::i;:::-;-1:-1:-1;27806:4:0;27657:161;;;;:::o;29349:137::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;;;;;;;;;29473:5:::1;29458:12;29448:7;;:22;;;;:::i;:::-;:30;;;;:::i;:::-;29433:12;:45:::0;-1:-1:-1;29349:137:0:o;27826:266::-;27924:4;27941:36;27951:6;27959:9;27970:6;27941:9;:36::i;:::-;-1:-1:-1;;;;;28019:19:0;;;;;;:11;:19;;;;;;;;8074:10;28019:33;;;;;;;;;27988:74;;27997:6;;28019:42;;28055:6;;28019:42;:::i;:::-;27988:8;:74::i;:::-;-1:-1:-1;28080:4:0;27826:266;;;;;:::o;28100:215::-;8074:10;28188:4;28237:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;28237:34:0;;;;;;;;;;28188:4;;28205:80;;28228:7;;28237:47;;28274:10;;28237:47;:::i;28560:111::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;28629:27:0::1;;::::0;;;:18:::1;:27;::::0;;;;:34;;-1:-1:-1;;28629:34:0::1;28659:4;28629:34;::::0;;28560:111::o;28805:124::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;28890:23:0;;;::::1;;::::0;;;:14:::1;:23;::::0;;;;:31;;-1:-1:-1;;28890:31:0::1;::::0;::::1;;::::0;;;::::1;::::0;;28805:124::o;29081:122::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;29167:13:::1;:28:::0;29081:122::o;28941:128::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;29027:16:::1;:34:::0;;-1:-1:-1;;;;;;29027:34:0::1;-1:-1:-1::0;;;;;29027:34:0;;;::::1;::::0;;;::::1;::::0;;28941:128::o;16216:148::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;16323:1:::1;16307:6:::0;;16286:40:::1;::::0;-1:-1:-1;;;;;16307:6:0;;::::1;::::0;16286:40:::1;::::0;16323:1;;16286:40:::1;16354:1;16337:19:::0;;-1:-1:-1;;;;;;16337:19:0::1;::::0;;16216:148::o;29215:122::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;29301:13:::1;:28:::0;29215:122::o;28323:225::-;8074:10;28416:4;28465:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;28465:34:0;;;;;;;;;;28416:4;;28433:85;;28456:7;;28465:52;;28502:15;;28465:52;:::i;27331:167::-;27409:4;27426:42;8074:10;27450:9;27461:6;27426:9;:42::i;28683:110::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;28750:27:0::1;28780:5;28750:27:::0;;;:18:::1;:27;::::0;;;;:35;;-1:-1:-1;;28750:35:0::1;::::0;;28683:110::o;16519:244::-;15785:6;;-1:-1:-1;;;;;15785:6:0;8074:10;15785:22;15777:67;;;;-1:-1:-1;;;15777:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;16608:22:0;::::1;16600:73;;;::::0;-1:-1:-1;;;16600:73:0;;5278:2:1;16600:73:0::1;::::0;::::1;5260:21:1::0;5317:2;5297:18;;;5290:30;5356:34;5336:18;;;5329:62;-1:-1:-1;;;5407:18:1;;;5400:36;5453:19;;16600:73:0::1;5250:228:1::0;16600:73:0::1;16710:6;::::0;;16689:38:::1;::::0;-1:-1:-1;;;;;16689:38:0;;::::1;::::0;16710:6;::::1;::::0;16689:38:::1;::::0;::::1;16738:6;:17:::0;;-1:-1:-1;;;;;;16738:17:0::1;-1:-1:-1::0;;;;;16738:17:0;;;::::1;::::0;;;::::1;::::0;;16519:244::o;30152:337::-;-1:-1:-1;;;;;30245:19:0;;30237:68;;;;-1:-1:-1;;;30237:68:0;;9212:2:1;30237:68:0;;;9194:21:1;9251:2;9231:18;;;9224:30;9290:34;9270:18;;;9263:62;-1:-1:-1;;;9341:18:1;;;9334:34;9385:19;;30237:68:0;9184:226:1;30237:68:0;-1:-1:-1;;;;;30324:21:0;;30316:68;;;;-1:-1:-1;;;30316:68:0;;5685:2:1;30316:68:0;;;5667:21:1;5724:2;5704:18;;;5697:30;5763:34;5743:18;;;5736:62;-1:-1:-1;;;5814:18:1;;;5807:32;5856:19;;30316:68:0;5657:224:1;30316:68:0;-1:-1:-1;;;;;30397:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;30449:32;;9561:25:1;;;30449:32:0;;9534:18:1;30449:32:0;;;;;;;30152:337;;;:::o;30497:1548::-;-1:-1:-1;;;;;30619:18:0;;30611:68;;;;-1:-1:-1;;;30611:68:0;;8806:2:1;30611:68:0;;;8788:21:1;8845:2;8825:18;;;8818:30;8884:34;8864:18;;;8857:62;-1:-1:-1;;;8935:18:1;;;8928:35;8980:19;;30611:68:0;8778:227:1;30611:68:0;-1:-1:-1;;;;;30698:16:0;;30690:64;;;;-1:-1:-1;;;30690:64:0;;4874:2:1;30690:64:0;;;4856:21:1;4913:2;4893:18;;;4886:30;4952:34;4932:18;;;4925:62;-1:-1:-1;;;5003:18:1;;;4996:33;5046:19;;30690:64:0;4846:225:1;30690:64:0;30782:1;30773:6;:10;30765:64;;;;-1:-1:-1;;;30765:64:0;;8396:2:1;30765:64:0;;;8378:21:1;8435:2;8415:18;;;8408:30;8474:34;8454:18;;;8447:62;-1:-1:-1;;;8525:18:1;;;8518:39;8574:19;;30765:64:0;8368:231:1;30765:64:0;-1:-1:-1;;;;;30849:20:0;;;;;;:14;:20;;;;;;;;30848:21;:44;;;;-1:-1:-1;;;;;;30874:18:0;;;;;;:14;:18;;;;;;;;30873:19;30848:44;30840:76;;;;-1:-1:-1;;;30840:76:0;;6873:2:1;30840:76:0;;;6855:21:1;6912:2;6892:18;;;6885:30;-1:-1:-1;;;6931:18:1;;;6924:49;6990:18;;30840:76:0;6845:169:1;30840:76:0;15611:7;15638:6;-1:-1:-1;;;;;30940:15:0;;;15638:6;;30940:15;;;;:32;;-1:-1:-1;15611:7:0;15638:6;-1:-1:-1;;;;;30959:13:0;;;15638:6;;30959:13;;30940:32;30937:125;;;31005:12;;30995:6;:22;;30987:75;;;;-1:-1:-1;;;30987:75:0;;7221:2:1;30987:75:0;;;7203:21:1;7260:2;7240:18;;;7233:30;7299:34;7279:18;;;7272:62;-1:-1:-1;;;7350:18:1;;;7343:38;7398:19;;30987:75:0;7193:230:1;30987:75:0;31099:13;;-1:-1:-1;;;;;31091:21:0;;;31099:13;;31091:21;31087:194;;;31153:12;;-1:-1:-1;;;;;31138:12:0;;;;;;:8;:12;;;;;;31168:15;;31138:27;;;:::i;:::-;:45;31129:95;;;;-1:-1:-1;;;31129:95:0;;7630:2:1;31129:95:0;;;7612:21:1;7669:2;7649:18;;;7642:30;7708:34;7688:18;;;7681:62;-1:-1:-1;;;7759:18:1;;;7752:34;7803:19;;31129:95:0;7602:226:1;31129:95:0;-1:-1:-1;;;;;31239:12:0;;;;;;:8;:12;;;;;31254:15;31239:30;;31087:194;31333:4;27272:7;27299:16;;;:7;:16;;;;;;25477:23;-1:-1:-1;31315:49:0;:62;;;;-1:-1:-1;31369:8:0;;;;31368:9;31315:62;:87;;;;-1:-1:-1;31389:13:0;;-1:-1:-1;;;;;31381:21:0;;;31389:13;;31381:21;;31315:87;:106;;;;-1:-1:-1;15611:7:0;15638:6;-1:-1:-1;;;;;31406:15:0;;;15638:6;;31406:15;;31315:106;:123;;;;-1:-1:-1;15611:7:0;15638:6;-1:-1:-1;;;;;31425:13:0;;;15638:6;;31425:13;;31315:123;31311:336;;;31455:8;:15;;-1:-1:-1;;31455:15:0;31466:4;31455:15;;;31485:16;:14;:16::i;:::-;31555:4;31516:18;27299:16;;;:7;:16;;;;;;31576:28;27299:16;31576;:28::i;:::-;-1:-1:-1;31619:8:0;:16;;-1:-1:-1;;31619:16:0;;;31311:336;-1:-1:-1;;;;;31661:13:0;;;;;;:7;:13;;;;;:23;;31678:6;;31661:13;:23;;31678:6;;31661:23;:::i;:::-;;;;-1:-1:-1;;;;;;;31829:24:0;;31689:22;31829:24;;;:18;:24;;;;;;31714:6;;31829:24;;31828:25;:52;;;;-1:-1:-1;;;;;;31858:22:0;;;;;;:18;:22;;;;;;;;31857:23;31828:52;31825:124;;;31913:24;31924:6;31932:4;31913:10;:24::i;:::-;31896:41;;31825:124;-1:-1:-1;;;;;31958:11:0;;;;;;:7;:11;;;;;:29;;31973:14;;31958:11;:29;;31973:14;;31958:29;:::i;:::-;;;;;;;;32018:2;-1:-1:-1;;;;;32003:34:0;32012:4;-1:-1:-1;;;;;32003:34:0;;32022:14;32003:34;;;;9561:25:1;;9549:2;9534:18;;9516:76;32003:34:0;;;;;;;;30600:1445;30497:1548;;;:::o;32283:548::-;32379:23;32466:13;;32450;;:29;;;;:::i;:::-;32433:13;;32424:4;27272:7;27299:16;;;:7;:16;;;;;;32405:41;;;;:::i;:::-;:75;;;;:::i;:::-;32379:101;-1:-1:-1;32491:12:0;32506:19;32524:1;32379:101;32506:19;:::i;:::-;32491:34;-1:-1:-1;32536:17:0;32556:22;32491:34;32556:15;:22;:::i;:::-;32536:42;;32589:18;32610:22;32627:4;32610:16;:22::i;:::-;32589:43;-1:-1:-1;32649:14:0;;32645:179;;32698:1;32680:19;;32714:35;32727:9;32738:10;32714:12;:35::i;:::-;32769:43;;;10784:25:1;;;10840:2;10825:18;;10818:34;;;10868:18;;;10861:34;;;32769:43:0;;10772:2:1;10757:18;32769:43:0;;;;;;;32645:179;32317:514;;;;32283:548::o;32063:212::-;32125:17;32145:24;32162:6;32145:16;:24::i;:::-;32125:44;-1:-1:-1;32194:13:0;;32190:77;;32230:16;;32222:45;;-1:-1:-1;;;;;32230:16:0;;;;32222:45;;;;;32257:9;;32230:16;32222:45;32230:16;32222:45;32257:9;32230:16;32222:45;;;;;;;;;;;;;;;;;;;;;32190:77;32114:161;32063:212;:::o;29594:405::-;29661:7;29681:20;29729:3;29713:13;;29704:6;:22;;;;:::i;:::-;:28;;;;:::i;:::-;29681:51;;29744:20;29792:3;29776:13;;29767:6;:22;;;;:::i;:::-;:28;;;;:::i;:::-;29744:51;-1:-1:-1;29833:27:0;29744:51;29833:12;:27;:::i;:::-;29823:4;29807:22;;;;:7;:22;;;;;:53;;:22;;;:53;;;;;:::i;:::-;;;;-1:-1:-1;29900:4:0;;-1:-1:-1;;;;;;29876:59:0;;;29907:27;29922:12;29907;:27;:::i;:::-;29876:59;;9561:25:1;;;9549:2;9534:18;29876:59:0;;;;;;;29978:12;29954:21;29963:12;29954:6;:21;:::i;:::-;:36;;;;:::i;:::-;29946:45;29594:405;-1:-1:-1;;;;;29594:405:0:o;32839:722::-;33064:16;;;33078:1;33064:16;;;;;;;;32903:7;;32948:21;;32903:7;;33064:16;;;;;;;;;;;;-1:-1:-1;33064:16:0;33040:40;;33109:4;33091;33096:1;33091:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;33091:23:0;;;:7;;;;;;;;;;:23;;;;33135:15;;:22;;;-1:-1:-1;;;33135:22:0;;;;:15;;;;;:20;;:22;;;;;33091:7;;33135:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;33125:4;33130:1;33125:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;33125:32:0;;;:7;;;;;;;;;:32;33202:15;;33170:62;;33187:4;;33202:15;33220:11;33170:8;:62::i;:::-;33271:15;;:224;;-1:-1:-1;;;33271:224:0;;-1:-1:-1;;;;;33271:15:0;;;;:66;;:224;;33352:11;;33271:15;;33422:4;;33449;;33469:15;;33271:224;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33538:14;33514:21;:38;;;;:::i;:::-;33506:47;32839:722;-1:-1:-1;;;;32839:722:0:o;33569:684::-;33749:15;;33717:62;;33734:4;;-1:-1:-1;;;;;33749:15:0;33767:11;33717:8;:62::i;:::-;33853:15;;33824:24;;-1:-1:-1;;;;;33853:15:0;:31;33893:9;33927:4;33947:11;33824:24;;34059:7;15611;15638:6;-1:-1:-1;;;;;15638:6:0;;15573:79;34059:7;33853:254;;;;;;-1:-1:-1;;;;;;33853:254:0;;;-1:-1:-1;;;;;3390:15:1;;;33853:254:0;;;3372:34:1;3422:18;;;3415:34;;;;3465:18;;;3458:34;;;;3508:18;;;3501:34;3572:15;;;3551:19;;;3544:44;34081:15:0;3604:19:1;;;3597:35;3306:19;;33853:254:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;33822:285:0;-1:-1:-1;34163:1:0;;-1:-1:-1;34132:28:0;33822:285;34132:9;:28;:::i;:::-;:32;34128:117;;;34179:66;34216:28;34228:16;34216:9;:28;:::i;:::-;34187:16;;-1:-1:-1;;;;;34187:16:0;;10693:6;10668:21;:31;;10660:73;;;;-1:-1:-1;;;10660:73:0;;6515:2:1;10660:73:0;;;6497:21:1;6554:2;6534:18;;;6527:30;6593:31;6573:18;;;6566:59;6642:18;;10660:73:0;6487:179:1;10660:73:0;10915:35;;10764:42;;-1:-1:-1;10897:12:0;;10764:42;;10938:6;;10897:12;10915:35;10897:12;10915:35;10938:6;10764:42;10915:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10896:54;;;10969:7;10961:78;;;;-1:-1:-1;;;10961:78:0;;6088:2:1;10961:78:0;;;6070:21:1;6127:2;6107:18;;;6100:30;6166:34;6146:18;;;6139:62;6237:28;6217:18;;;6210:56;6283:19;;10961:78:0;6060:248:1;14:247;73:6;126:2;114:9;105:7;101:23;97:32;94:2;;;142:1;139;132:12;94:2;181:9;168:23;200:31;225:5;200:31;:::i;:::-;250:5;84:177;-1:-1:-1;;;84:177:1:o;266:251::-;336:6;389:2;377:9;368:7;364:23;360:32;357:2;;;405:1;402;395:12;357:2;437:9;431:16;456:31;481:5;456:31;:::i;522:388::-;590:6;598;651:2;639:9;630:7;626:23;622:32;619:2;;;667:1;664;657:12;619:2;706:9;693:23;725:31;750:5;725:31;:::i;:::-;775:5;-1:-1:-1;832:2:1;817:18;;804:32;845:33;804:32;845:33;:::i;:::-;897:7;887:17;;;609:301;;;;;:::o;915:456::-;992:6;1000;1008;1061:2;1049:9;1040:7;1036:23;1032:32;1029:2;;;1077:1;1074;1067:12;1029:2;1116:9;1103:23;1135:31;1160:5;1135:31;:::i;:::-;1185:5;-1:-1:-1;1242:2:1;1227:18;;1214:32;1255:33;1214:32;1255:33;:::i;:::-;1019:352;;1307:7;;-1:-1:-1;;;1361:2:1;1346:18;;;;1333:32;;1019:352::o;1376:416::-;1441:6;1449;1502:2;1490:9;1481:7;1477:23;1473:32;1470:2;;;1518:1;1515;1508:12;1470:2;1557:9;1544:23;1576:31;1601:5;1576:31;:::i;:::-;1626:5;-1:-1:-1;1683:2:1;1668:18;;1655:32;1725:15;;1718:23;1706:36;;1696:2;;1756:1;1753;1746:12;1797:315;1865:6;1873;1926:2;1914:9;1905:7;1901:23;1897:32;1894:2;;;1942:1;1939;1932:12;1894:2;1981:9;1968:23;2000:31;2025:5;2000:31;:::i;:::-;2050:5;2102:2;2087:18;;;;2074:32;;-1:-1:-1;;;1884:228:1:o;2117:180::-;2176:6;2229:2;2217:9;2208:7;2204:23;2200:32;2197:2;;;2245:1;2242;2235:12;2197:2;-1:-1:-1;2268:23:1;;2187:110;-1:-1:-1;2187:110:1:o;2302:306::-;2390:6;2398;2406;2459:2;2447:9;2438:7;2434:23;2430:32;2427:2;;;2475:1;2472;2465:12;2427:2;2504:9;2498:16;2488:26;;2554:2;2543:9;2539:18;2533:25;2523:35;;2598:2;2587:9;2583:18;2577:25;2567:35;;2417:191;;;;;:::o;4070:597::-;4182:4;4211:2;4240;4229:9;4222:21;4272:6;4266:13;4315:6;4310:2;4299:9;4295:18;4288:34;4340:1;4350:140;4364:6;4361:1;4358:13;4350:140;;;4459:14;;;4455:23;;4449:30;4425:17;;;4444:2;4421:26;4414:66;4379:10;;4350:140;;;4508:6;4505:1;4502:13;4499:2;;;4578:1;4573:2;4564:6;4553:9;4549:22;4545:31;4538:42;4499:2;-1:-1:-1;4651:2:1;4630:15;-1:-1:-1;;4626:29:1;4611:45;;;;4658:2;4607:54;;4191:476;-1:-1:-1;;;4191:476:1:o;7833:356::-;8035:2;8017:21;;;8054:18;;;8047:30;8113:34;8108:2;8093:18;;8086:62;8180:2;8165:18;;8007:182::o;9597:980::-;9859:4;9907:3;9896:9;9892:19;9938:6;9927:9;9920:25;9964:2;10002:6;9997:2;9986:9;9982:18;9975:34;10045:3;10040:2;10029:9;10025:18;10018:31;10069:6;10104;10098:13;10135:6;10127;10120:22;10173:3;10162:9;10158:19;10151:26;;10212:2;10204:6;10200:15;10186:29;;10233:1;10243:195;10257:6;10254:1;10251:13;10243:195;;;10322:13;;-1:-1:-1;;;;;10318:39:1;10306:52;;10413:15;;;;10378:12;;;;10354:1;10272:9;10243:195;;;-1:-1:-1;;;;;;;10494:32:1;;;;10489:2;10474:18;;10467:60;-1:-1:-1;;;10558:3:1;10543:19;10536:35;10455:3;9868:709;-1:-1:-1;;;9868:709:1:o;11095:128::-;11135:3;11166:1;11162:6;11159:1;11156:13;11153:2;;;11172:18;;:::i;:::-;-1:-1:-1;11208:9:1;;11143:80::o;11228:217::-;11268:1;11294;11284:2;;11338:10;11333:3;11329:20;11326:1;11319:31;11373:4;11370:1;11363:15;11401:4;11398:1;11391:15;11284:2;-1:-1:-1;11430:9:1;;11274:171::o;11450:168::-;11490:7;11556:1;11552;11548:6;11544:14;11541:1;11538:21;11533:1;11526:9;11519:17;11515:45;11512:2;;;11563:18;;:::i;:::-;-1:-1:-1;11603:9:1;;11502:116::o;11623:125::-;11663:4;11691:1;11688;11685:8;11682:2;;;11696:18;;:::i;:::-;-1:-1:-1;11733:9:1;;11672:76::o;11753:127::-;11814:10;11809:3;11805:20;11802:1;11795:31;11845:4;11842:1;11835:15;11869:4;11866:1;11859:15;11885:127;11946:10;11941:3;11937:20;11934:1;11927:31;11977:4;11974:1;11967:15;12001:4;11998:1;11991:15;12149:131;-1:-1:-1;;;;;12224:31:1;;12214:42;;12204:2;;12270:1;12267;12260:12;12204:2;12194:86;:::o

Swarm Source

ipfs://a1312533fbebd74b0e47871929988800f0ba30318167aefe6db6ad165834a00c
Loading