Token Kombai Inu

 

Overview [ERC-20]

Price
$0.00 @ 0.000000 Eth
Fully Diluted Market Cap
Max Total Supply:
919,326,087,185,159.203680197 KOMBAI

Holders:
766 (0.00%)

Transfers:
-

 
Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

OVERVIEW

Kombai is a deflationary meme token for people who love dogs. Kombai’s tax system distributes 4% of every Kombai transaction (buy/sell) amongst existing holders as and incentive.

Market

Volume (24H):$0.00
Market Capitalization:$0.00
Circulating Supply:0.00 KOMBAI
Market Data Source: Coinmarketcap

# Exchange Pair Price  24H Volume % Volume
Loading

Similar Match Source Code
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0xb78c47550c97b6dfe0db4cc35aecf8ab75c2122b

Contract Name:
CoinToken

Compiler Version
v0.8.2+commit.661d1103

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Apache-2.0 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-04-26
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.2;


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 Interface of the BEP20 standard as defined in the EIP.
 */
interface IBEP20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

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

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

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

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

/**
 * @dev 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;
    }
}

/**
 * @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");

        // 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 public _owner;

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


    /**
     * @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;
    }
}

contract CoinToken is Context, IBEP20, Ownable {
    using SafeMath for uint256;
    using Address for address;

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

    mapping (address => bool) private _isExcluded;
    mapping (address => bool) private _isCharity;
    address[] private _excluded;
    
    string  private _NAME;
    string  private _SYMBOL;
    uint256   private _DECIMALS;
	address public FeeAddress;
   
    uint256 private _MAX = ~uint256(0);
    uint256 private _DECIMALFACTOR;
    uint256 private _GRANULARITY = 100;
    
    uint256 private _tTotal;
    uint256 private _rTotal;
    
    uint256 private _tFeeTotal;
    uint256 private _tBurnTotal;
    uint256 private _tCharityTotal;
    
    uint256 public     _TAX_FEE;
    uint256 public    _BURN_FEE;
    uint256 public _CHARITY_FEE;

    // Track original fees to bypass fees for charity account
    uint256 private ORIG_TAX_FEE;
    uint256 private ORIG_BURN_FEE;
    uint256 private ORIG_CHARITY_FEE;

    constructor (string memory _name, string memory _symbol, uint256 _decimals, uint256 _supply, uint256 _txFee,uint256 _burnFee,uint256 _charityFee,address _FeeAddress,address tokenOwner)  {
		_NAME = _name;
		_SYMBOL = _symbol;
		_DECIMALS = _decimals;
		_DECIMALFACTOR = 10 ** uint256(_DECIMALS);
		_tTotal =_supply * _DECIMALFACTOR;
		_rTotal = (_MAX - (_MAX % _tTotal));
		_TAX_FEE = _txFee* 100; 
        _BURN_FEE = _burnFee * 100;
		_CHARITY_FEE = _charityFee* 100;
		ORIG_TAX_FEE = _TAX_FEE;
		ORIG_BURN_FEE = _BURN_FEE;
		ORIG_CHARITY_FEE = _CHARITY_FEE;
		_isCharity[_FeeAddress] = true;
		FeeAddress = _FeeAddress;
		_owner = tokenOwner;
        _rOwned[tokenOwner] = _rTotal;
        emit Transfer(address(0),tokenOwner, _tTotal);
    }

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

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

    function decimals() public view returns (uint256) {
        return _DECIMALS;
    }

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

    function balanceOf(address account) public view override returns (uint256) {
        if (_isExcluded[account]) return _tOwned[account];
        return tokenFromReflection(_rOwned[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()].sub(amount, "TOKEN20: transfer amount exceeds allowance"));
        return true;
    }

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

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

    function isExcluded(address account) public view returns (bool) {
        return _isExcluded[account];
    }
    
    function isCharity(address account) public view returns (bool) {
        return _isCharity[account];
    }

    function totalFees() public view returns (uint256) {
        return _tFeeTotal;
    }
    
    function totalBurn() public view returns (uint256) {
        return _tBurnTotal;
    }
    
    function totalCharity() public view returns (uint256) {
        return _tCharityTotal;
    }

    function deliver(uint256 tAmount) public {
        address sender = _msgSender();
        require(!_isExcluded[sender], "Excluded addresses cannot call this function");
        (uint256 rAmount,,,,,,) = _getValues(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rTotal = _rTotal.sub(rAmount);
        _tFeeTotal = _tFeeTotal.add(tAmount);
    }

    function reflectionFromToken(uint256 tAmount, bool deductTransferFee) public view returns(uint256) {
        require(tAmount <= _tTotal, "Amount must be less than supply");
        if (!deductTransferFee) {
            (uint256 rAmount,,,,,,) = _getValues(tAmount);
            return rAmount;
        } else {
            (,uint256 rTransferAmount,,,,,) = _getValues(tAmount);
            return rTransferAmount;
        }
    }

    function tokenFromReflection(uint256 rAmount) public view returns(uint256) {
        require(rAmount <= _rTotal, "Amount must be less than total reflections");
        uint256 currentRate =  _getRate();
        return rAmount.div(currentRate);
    }

    function excludeAccount(address account) external onlyOwner() {
        require(!_isExcluded[account], "Account is already excluded");
        if(_rOwned[account] > 0) {
            _tOwned[account] = tokenFromReflection(_rOwned[account]);
        }
        _isExcluded[account] = true;
        _excluded.push(account);
    }

    function includeAccount(address account) external onlyOwner() {
        require(_isExcluded[account], "Account is already excluded");
        for (uint256 i = 0; i < _excluded.length; i++) {
            if (_excluded[i] == account) {
                _excluded[i] = _excluded[_excluded.length - 1];
                _tOwned[account] = 0;
                _isExcluded[account] = false;
                _excluded.pop();
                break;
            }
        }
    }

    function setAsCharityAccount(address account) external onlyOwner() {
        require(!_isCharity[account], "Account is already charity account");
        _isCharity[account] = true;
		FeeAddress = account;
    }


	
	function updateFee(uint256 _txFee,uint256 _burnFee,uint256 _charityFee) onlyOwner() public{
        _TAX_FEE = _txFee* 100; 
        _BURN_FEE = _burnFee * 100;
		_CHARITY_FEE = _charityFee* 100;
		ORIG_TAX_FEE = _TAX_FEE;
		ORIG_BURN_FEE = _BURN_FEE;
		ORIG_CHARITY_FEE = _CHARITY_FEE;
	}
	




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

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

    function _transfer(address sender, address recipient, uint256 amount) private {
        require(sender != address(0), "TOKEN20: transfer from the zero address");
        require(recipient != address(0), "TOKEN20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");

        // Remove fees for transfers to and from charity account or to excluded account
        bool takeFee = true;
        if (_isCharity[sender] || _isCharity[recipient] || _isExcluded[recipient]) {
            takeFee = false;
        }

        if (!takeFee) removeAllFee();
        
        
        if (_isExcluded[sender] && !_isExcluded[recipient]) {
            _transferFromExcluded(sender, recipient, amount);
        } else if (!_isExcluded[sender] && _isExcluded[recipient]) {
            _transferToExcluded(sender, recipient, amount);
        } else if (!_isExcluded[sender] && !_isExcluded[recipient]) {
            _transferStandard(sender, recipient, amount);
        } else if (_isExcluded[sender] && _isExcluded[recipient]) {
            _transferBothExcluded(sender, recipient, amount);
        } else {
            _transferStandard(sender, recipient, amount);
        }

        if (!takeFee) restoreAllFee();
    }

    function _transferStandard(address sender, address recipient, uint256 tAmount) private {
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn, uint256 tCharity) = _getValues(tAmount);
        uint256 rBurn =  tBurn.mul(currentRate);
        uint256 rCharity = tCharity.mul(currentRate);     
        _standardTransferContent(sender, recipient, rAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, rCharity, tFee, tBurn, tCharity);
        emit Transfer(sender, recipient, tTransferAmount);
    }
    
    function _standardTransferContent(address sender, address recipient, uint256 rAmount, uint256 rTransferAmount) private {
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);
    }
    
    function _transferToExcluded(address sender, address recipient, uint256 tAmount) private {
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn, uint256 tCharity) = _getValues(tAmount);
        uint256 rBurn =  tBurn.mul(currentRate);
        uint256 rCharity = tCharity.mul(currentRate);
        _excludedFromTransferContent(sender, recipient, tTransferAmount, rAmount, rTransferAmount);        
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, rCharity, tFee, tBurn, tCharity);
        emit Transfer(sender, recipient, tTransferAmount);
    }
    
    function _excludedFromTransferContent(address sender, address recipient, uint256 tTransferAmount, uint256 rAmount, uint256 rTransferAmount) private {
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);    
    }
    

    function _transferFromExcluded(address sender, address recipient, uint256 tAmount) private {
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn, uint256 tCharity) = _getValues(tAmount);
        uint256 rBurn =  tBurn.mul(currentRate);
        uint256 rCharity = tCharity.mul(currentRate);
        _excludedToTransferContent(sender, recipient, tAmount, rAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, rCharity, tFee, tBurn, tCharity);
        emit Transfer(sender, recipient, tTransferAmount);
    }
    
    function _excludedToTransferContent(address sender, address recipient, uint256 tAmount, uint256 rAmount, uint256 rTransferAmount) private {
        _tOwned[sender] = _tOwned[sender].sub(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);  
    }

    function _transferBothExcluded(address sender, address recipient, uint256 tAmount) private {
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tBurn, uint256 tCharity) = _getValues(tAmount);
        uint256 rBurn =  tBurn.mul(currentRate);
        uint256 rCharity = tCharity.mul(currentRate);    
        _bothTransferContent(sender, recipient, tAmount, rAmount, tTransferAmount, rTransferAmount);  
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, rCharity, tFee, tBurn, tCharity);
        emit Transfer(sender, recipient, tTransferAmount);
    }
    
    function _bothTransferContent(address sender, address recipient, uint256 tAmount, uint256 rAmount, uint256 tTransferAmount, uint256 rTransferAmount) private {
        _tOwned[sender] = _tOwned[sender].sub(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);  
    }

    function _reflectFee(uint256 rFee, uint256 rBurn, uint256 rCharity, uint256 tFee, uint256 tBurn, uint256 tCharity) private {
        _rTotal = _rTotal.sub(rFee).sub(rBurn).sub(rCharity);
        _tFeeTotal = _tFeeTotal.add(tFee);
        _tBurnTotal = _tBurnTotal.add(tBurn);
        _tCharityTotal = _tCharityTotal.add(tCharity);
        _tTotal = _tTotal.sub(tBurn);
		emit Transfer(address(this), address(0), tBurn);
    }
    

    function _getValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256, uint256, uint256) {
        (uint256 tFee, uint256 tBurn, uint256 tCharity) = _getTBasics(tAmount, _TAX_FEE, _BURN_FEE, _CHARITY_FEE);
        uint256 tTransferAmount = getTTransferAmount(tAmount, tFee, tBurn, tCharity);
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rFee) = _getRBasics(tAmount, tFee, currentRate);
        uint256 rTransferAmount = _getRTransferAmount(rAmount, rFee, tBurn, tCharity, currentRate);
        return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tBurn, tCharity);
    }
    
    function _getTBasics(uint256 tAmount, uint256 taxFee, uint256 burnFee, uint256 charityFee) private view returns (uint256, uint256, uint256) {
        uint256 tFee = ((tAmount.mul(taxFee)).div(_GRANULARITY)).div(100);
        uint256 tBurn = ((tAmount.mul(burnFee)).div(_GRANULARITY)).div(100);
        uint256 tCharity = ((tAmount.mul(charityFee)).div(_GRANULARITY)).div(100);
        return (tFee, tBurn, tCharity);
    }
    
    function getTTransferAmount(uint256 tAmount, uint256 tFee, uint256 tBurn, uint256 tCharity) private pure returns (uint256) {
        return tAmount.sub(tFee).sub(tBurn).sub(tCharity);
    }
    
    function _getRBasics(uint256 tAmount, uint256 tFee, uint256 currentRate) private pure returns (uint256, uint256) {
        uint256 rAmount = tAmount.mul(currentRate);
        uint256 rFee = tFee.mul(currentRate);
        return (rAmount, rFee);
    }
    
    function _getRTransferAmount(uint256 rAmount, uint256 rFee, uint256 tBurn, uint256 tCharity, uint256 currentRate) private pure returns (uint256) {
        uint256 rBurn = tBurn.mul(currentRate);
        uint256 rCharity = tCharity.mul(currentRate);
        uint256 rTransferAmount = rAmount.sub(rFee).sub(rBurn).sub(rCharity);
        return rTransferAmount;
    }

    function _getRate() private view returns(uint256) {
        (uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
        return rSupply.div(tSupply);
    }

    function _getCurrentSupply() private view returns(uint256, uint256) {
        uint256 rSupply = _rTotal;
        uint256 tSupply = _tTotal;      
        for (uint256 i = 0; i < _excluded.length; i++) {
            if (_rOwned[_excluded[i]] > rSupply || _tOwned[_excluded[i]] > tSupply) return (_rTotal, _tTotal);
            rSupply = rSupply.sub(_rOwned[_excluded[i]]);
            tSupply = tSupply.sub(_tOwned[_excluded[i]]);
        }
        if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal);
        return (rSupply, tSupply);
    }

    function _sendToCharity(uint256 tCharity, address sender) private {
        uint256 currentRate = _getRate();
        uint256 rCharity = tCharity.mul(currentRate);
        _rOwned[FeeAddress] = _rOwned[FeeAddress].add(rCharity);
        _tOwned[FeeAddress] = _tOwned[FeeAddress].add(tCharity);
        emit Transfer(sender, FeeAddress, tCharity);
    }

    function removeAllFee() private {
        if(_TAX_FEE == 0 && _BURN_FEE == 0 && _CHARITY_FEE == 0) return;
        
        ORIG_TAX_FEE = _TAX_FEE;
        ORIG_BURN_FEE = _BURN_FEE;
        ORIG_CHARITY_FEE = _CHARITY_FEE;
        
        _TAX_FEE = 0;
        _BURN_FEE = 0;
        _CHARITY_FEE = 0;
    }
    
    function restoreAllFee() private {
        _TAX_FEE = ORIG_TAX_FEE;
        _BURN_FEE = ORIG_BURN_FEE;
        _CHARITY_FEE = ORIG_CHARITY_FEE;
    }
    
    function _getTaxFee() private view returns(uint256) {
        return _TAX_FEE;
    }


}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint256","name":"_decimals","type":"uint256"},{"internalType":"uint256","name":"_supply","type":"uint256"},{"internalType":"uint256","name":"_txFee","type":"uint256"},{"internalType":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_charityFee","type":"uint256"},{"internalType":"address","name":"_FeeAddress","type":"address"},{"internalType":"address","name":"tokenOwner","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":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":"FeeAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_BURN_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_CHARITY_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_TAX_FEE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tAmount","type":"uint256"}],"name":"deliver","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeAccount","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":"isCharity","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcluded","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":[{"internalType":"uint256","name":"tAmount","type":"uint256"},{"internalType":"bool","name":"deductTransferFee","type":"bool"}],"name":"reflectionFromToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"setAsCharityAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"rAmount","type":"uint256"}],"name":"tokenFromReflection","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalBurn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalCharity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_txFee","type":"uint256"},{"internalType":"uint256","name":"_burnFee","type":"uint256"},{"internalType":"uint256","name":"_charityFee","type":"uint256"}],"name":"updateFee","outputs":[],"stateMutability":"nonpayable","type":"function"}]

6080604052600019600b556064600d553480156200001c57600080fd5b5060405162002712380380620027128339810160408190526200003f916200030b565b8851620000549060079060208c019062000195565b5087516200006a9060089060208b019062000195565b5060098790556200007d87600a62000415565b600c8190556200008e90876200050a565b600e819055600b54620000a2919062000583565b600b54620000b191906200052c565b600f55620000c18560646200050a565b601355620000d18460646200050a565b601455620000e18360646200050a565b60158190556013546016556014546017556018556001600160a01b038281166000818152600560209081526040808320805460ff19166001908117909155600a80546001600160a01b0319908116909617905583549587169590941685178355600f5485845293825280832093909355600e54925192835290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a3505050505050505050620005d0565b828054620001a39062000546565b90600052602060002090601f016020900481019282620001c7576000855562000212565b82601f10620001e257805160ff191683800117855562000212565b8280016001018555821562000212579182015b8281111562000212578251825591602001919060010190620001f5565b506200022092915062000224565b5090565b5b8082111562000220576000815560010162000225565b80516001600160a01b03811681146200025357600080fd5b919050565b600082601f83011262000269578081fd5b81516001600160401b0380821115620002865762000286620005ba565b604051601f8301601f19908116603f01168101908282118183101715620002b157620002b1620005ba565b81604052838152602092508683858801011115620002cd578485fd5b8491505b83821015620002f05785820183015181830184015290820190620002d1565b838211156200030157848385830101525b9695505050505050565b60008060008060008060008060006101208a8c0312156200032a578485fd5b89516001600160401b038082111562000341578687fd5b6200034f8d838e0162000258565b9a5060208c015191508082111562000365578687fd5b50620003748c828d0162000258565b98505060408a0151965060608a0151955060808a0151945060a08a0151935060c08a01519250620003a860e08b016200023b565b9150620003b96101008b016200023b565b90509295985092959850929598565b80825b6001808611620003dc57506200040c565b818704821115620003f157620003f1620005a4565b80861615620003ff57918102915b9490941c938002620003cb565b94509492505050565b60006200042660001984846200042d565b9392505050565b6000826200043e5750600162000426565b816200044d5750600062000426565b81600181146200046657600281146200047157620004a5565b600191505062000426565b60ff841115620004855762000485620005a4565b6001841b9150848211156200049e576200049e620005a4565b5062000426565b5060208310610133831016604e8410600b8410161715620004dd575081810a83811115620004d757620004d7620005a4565b62000426565b620004ec8484846001620003c8565b808604821115620005015762000501620005a4565b02949350505050565b6000816000190483118215151615620005275762000527620005a4565b500290565b600082821015620005415762000541620005a4565b500390565b6002810460018216806200055b57607f821691505b602082108114156200057d57634e487b7160e01b600052602260045260246000fd5b50919050565b6000826200059f57634e487b7160e01b81526012600452602481fd5b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052604160045260246000fd5b61213280620005e06000396000f3fe608060405234801561001057600080fd5b50600436106101e55760003560e01c80637b7e8bac1161010f578063cba0e996116100a2578063f2cc0c1811610071578063f2cc0c1814610415578063f2fde38b14610428578063f84354f11461043b578063fc061a4f1461044e576101e5565b8063cba0e9961461037c578063d608b3b2146103a8578063dd62ed3e146103b0578063e81ffbef146103e9576101e5565b8063a9059cbb116100de578063a9059cbb14610344578063ae9dd5e014610357578063b2bdfa7b14610360578063b586242814610373576101e5565b80637b7e8bac146102ed5780638da5cb5b1461031857806395d89b4114610329578063a457c2d714610331576101e5565b80633950935111610187578063457bdf6c11610156578063457bdf6c146102b657806370a08231146102c9578063715018a6146102dc57806377ef7993146102e4576101e5565b806339509351146102735780633bd5d173146102865780633c9f861d1461029b5780634549b039146102a3576101e5565b806318160ddd116101c357806318160ddd1461023d57806323b872dd146102455780632d83811914610258578063313ce5671461026b576101e5565b806306fdde03146101ea578063095ea7b31461020857806313114a9d1461022b575b600080fd5b6101f2610461565b6040516101ff9190611f49565b60405180910390f35b61021b610216366004611eaa565b6104f3565b60405190151581526020016101ff565b6010545b6040519081526020016101ff565b600e5461022f565b61021b610253366004611e6f565b61050a565b61022f610266366004611ed3565b610573565b60095461022f565b61021b610281366004611eaa565b6105fe565b610299610294366004611ed3565b610634565b005b60115461022f565b61022f6102b1366004611eeb565b610720565b6102996102c4366004611e23565b6107af565b61022f6102d7366004611e23565b610884565b6102996108e6565b61022f60145481565b600a54610300906001600160a01b031681565b6040516001600160a01b0390911681526020016101ff565b6000546001600160a01b0316610300565b6101f261095a565b61021b61033f366004611eaa565b610969565b61021b610352366004611eaa565b6109b8565b61022f60155481565b600054610300906001600160a01b031681565b61022f60135481565b61021b61038a366004611e23565b6001600160a01b031660009081526004602052604090205460ff1690565b60125461022f565b61022f6103be366004611e3d565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b61021b6103f7366004611e23565b6001600160a01b031660009081526005602052604090205460ff1690565b610299610423366004611e23565b6109c5565b610299610436366004611e23565b610b18565b610299610449366004611e23565b610c02565b61029961045c366004611f1e565b610df2565b6060600780546104709061203f565b80601f016020809104026020016040519081016040528092919081815260200182805461049c9061203f565b80156104e95780601f106104be576101008083540402835291602001916104e9565b820191906000526020600020905b8154815290600101906020018083116104cc57829003601f168201915b5050505050905090565b6000610500338484610e5c565b5060015b92915050565b6000610517848484610f84565b6105698433610564856040518060600160405280602a81526020016120d3602a91396001600160a01b038a16600090815260036020908152604080832033845290915290205491906112a1565b610e5c565b5060019392505050565b6000600f548211156105df5760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b60648201526084015b60405180910390fd5b60006105e96112db565b90506105f583826112fe565b9150505b919050565b3360008181526003602090815260408083206001600160a01b038716845290915281205490916105009185906105649086611347565b3360008181526004602052604090205460ff16156106a95760405162461bcd60e51b815260206004820152602c60248201527f4578636c75646564206164647265737365732063616e6e6f742063616c6c207460448201526b3434b990333ab731ba34b7b760a11b60648201526084016105d6565b60006106b4836113a6565b5050506001600160a01b0386166000908152600160205260409020549394506106e29392508491505061142a565b6001600160a01b038316600090815260016020526040902055600f54610708908261142a565b600f556010546107189084611347565b601055505050565b6000600e548311156107745760405162461bcd60e51b815260206004820152601f60248201527f416d6f756e74206d757374206265206c657373207468616e20737570706c790060448201526064016105d6565b81610794576000610784846113a6565b5094965061050495505050505050565b600061079f846113a6565b5093965061050495505050505050565b6000546001600160a01b031633146107d95760405162461bcd60e51b81526004016105d690611f9c565b6001600160a01b03811660009081526005602052604090205460ff161561084d5760405162461bcd60e51b815260206004820152602260248201527f4163636f756e7420697320616c72656164792063686172697479206163636f756044820152611b9d60f21b60648201526084016105d6565b6001600160a01b03166000818152600560205260409020805460ff19166001179055600a80546001600160a01b0319169091179055565b6001600160a01b03811660009081526004602052604081205460ff16156108c457506001600160a01b0381166000908152600260205260409020546105f9565b6001600160a01b03821660009081526001602052604090205461050490610573565b6000546001600160a01b031633146109105760405162461bcd60e51b81526004016105d690611f9c565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600880546104709061203f565b60006105003384610564856040518060600160405280602781526020016120ac602791393360009081526003602090815260408083206001600160a01b038d16845290915290205491906112a1565b6000610500338484610f84565b6000546001600160a01b031633146109ef5760405162461bcd60e51b81526004016105d690611f9c565b6001600160a01b03811660009081526004602052604090205460ff1615610a585760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c7265616479206578636c75646564000000000060448201526064016105d6565b6001600160a01b03811660009081526001602052604090205415610ab2576001600160a01b038116600090815260016020526040902054610a9890610573565b6001600160a01b0382166000908152600260205260409020555b6001600160a01b03166000818152600460205260408120805460ff191660019081179091556006805491820181559091527ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f0180546001600160a01b0319169091179055565b6000546001600160a01b03163314610b425760405162461bcd60e51b81526004016105d690611f9c565b6001600160a01b038116610ba75760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016105d6565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314610c2c5760405162461bcd60e51b81526004016105d690611f9c565b6001600160a01b03811660009081526004602052604090205460ff16610c945760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c7265616479206578636c75646564000000000060448201526064016105d6565b60005b600654811015610dee57816001600160a01b031660068281548110610ccc57634e487b7160e01b600052603260045260246000fd5b6000918252602090912001546001600160a01b03161415610ddc5760068054610cf790600190612028565b81548110610d1557634e487b7160e01b600052603260045260246000fd5b600091825260209091200154600680546001600160a01b039092169183908110610d4f57634e487b7160e01b600052603260045260246000fd5b600091825260208083209190910180546001600160a01b0319166001600160a01b039485161790559184168152600282526040808220829055600490925220805460ff191690556006805480610db557634e487b7160e01b600052603160045260246000fd5b600082815260209020810160001990810180546001600160a01b0319169055019055610dee565b80610de68161207a565b915050610c97565b5050565b6000546001600160a01b03163314610e1c5760405162461bcd60e51b81526004016105d690611f9c565b610e27836064612009565b601355610e35826064612009565b601455610e43816064612009565b6015819055601354601655601454601755601855505050565b6001600160a01b038316610ec15760405162461bcd60e51b815260206004820152602660248201527f544f4b454e32303a20617070726f76652066726f6d20746865207a65726f206160448201526564647265737360d01b60648201526084016105d6565b6001600160a01b038216610f235760405162461bcd60e51b8152602060048201526024808201527f544f4b454e32303a20617070726f766520746f20746865207a65726f206164646044820152637265737360e01b60648201526084016105d6565b6001600160a01b0383811660008181526003602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610fea5760405162461bcd60e51b815260206004820152602760248201527f544f4b454e32303a207472616e736665722066726f6d20746865207a65726f206044820152666164647265737360c81b60648201526084016105d6565b6001600160a01b03821661104e5760405162461bcd60e51b815260206004820152602560248201527f544f4b454e32303a207472616e7366657220746f20746865207a65726f206164604482015264647265737360d81b60648201526084016105d6565b600081116110b05760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016105d6565b6001600160a01b03831660009081526005602052604090205460019060ff16806110f257506001600160a01b03831660009081526005602052604090205460ff165b8061111557506001600160a01b03831660009081526004602052604090205460ff165b1561111e575060005b8061112b5761112b61146c565b6001600160a01b03841660009081526004602052604090205460ff16801561116c57506001600160a01b03831660009081526004602052604090205460ff16155b156111815761117c8484846114b5565b61127f565b6001600160a01b03841660009081526004602052604090205460ff161580156111c257506001600160a01b03831660009081526004602052604090205460ff165b156111d25761117c848484611589565b6001600160a01b03841660009081526004602052604090205460ff1615801561121457506001600160a01b03831660009081526004602052604090205460ff16155b156112245761117c8484846115e9565b6001600160a01b03841660009081526004602052604090205460ff16801561126457506001600160a01b03831660009081526004602052604090205460ff165b156112745761117c848484611648565b61127f8484846115e9565b8061129b5761129b601654601355601754601455601854601555565b50505050565b600081848411156112c55760405162461bcd60e51b81526004016105d69190611f49565b5060006112d28486612028565b95945050505050565b60008060006112e86116a9565b90925090506112f782826112fe565b9250505090565b600061134083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611866565b9392505050565b6000806113548385611fd1565b9050838110156113405760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016105d6565b6000806000806000806000806000806113c78b601354601454601554611894565b92509250925060006113db8c858585611913565b905060006113e76112db565b90506000806113f78f888561192b565b91509150600061140a8383898988611955565b929e50919c509a5091985093965091945092505050919395979092949650565b600061134083836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506112a1565b60135415801561147c5750601454155b80156114885750601554155b15611492576114b3565b60138054601655601480546017556015805460185560009283905590829055555b565b60006114bf6112db565b905060008060008060008060006114d5896113a6565b965096509650965096509650965060006114f8898461199190919063ffffffff16565b90506000611506838b611991565b90506115158d8d8d8c8c611a10565b61151f838e611ab4565b61152d878383888888611b95565b8b6001600160a01b03168d6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8860405161157291815260200190565b60405180910390a350505050505050505050505050565b60006115936112db565b905060008060008060008060006115a9896113a6565b965096509650965096509650965060006115cc898461199190919063ffffffff16565b905060006115da838b611991565b90506115158d8d888c8c611c35565b60006115f36112db565b90506000806000806000806000611609896113a6565b9650965096509650965096509650600061162c898461199190919063ffffffff16565b9050600061163a838b611991565b90506115158d8d8b8b611cbd565b60006116526112db565b90506000806000806000806000611668896113a6565b9650965096509650965096509650600061168b898461199190919063ffffffff16565b90506000611699838b611991565b90506115158d8d8d8c8a8d611d31565b600f54600e546000918291825b600654811015611834578260016000600684815481106116e657634e487b7160e01b600052603260045260246000fd5b60009182526020808320909101546001600160a01b03168352820192909252604001902054118061175f575081600260006006848154811061173857634e487b7160e01b600052603260045260246000fd5b60009182526020808320909101546001600160a01b03168352820192909252604001902054115b1561177657600f54600e5494509450505050611862565b6117ca600160006006848154811061179e57634e487b7160e01b600052603260045260246000fd5b60009182526020808320909101546001600160a01b03168352820192909252604001902054849061142a565b925061182060026000600684815481106117f457634e487b7160e01b600052603260045260246000fd5b60009182526020808320909101546001600160a01b03168352820192909252604001902054839061142a565b91508061182c8161207a565b9150506116b6565b50600e54600f54611844916112fe565b82101561185c57600f54600e54935093505050611862565b90925090505b9091565b600081836118875760405162461bcd60e51b81526004016105d69190611f49565b5060006112d28486611fe9565b6000806000806118be60646118b8600d546118b88b8d61199190919063ffffffff16565b906112fe565b905060006118e060646118b8600d546118b88b8e61199190919063ffffffff16565b9050600061190260646118b8600d546118b88b8f61199190919063ffffffff16565b929a91995091975095505050505050565b60006112d2826119258581898961142a565b9061142a565b600080806119398685611991565b905060006119478686611991565b919791965090945050505050565b6000806119628584611991565b905060006119708585611991565b905060006119848261192585818d8d61142a565b9998505050505050505050565b6000826119a057506000610504565b60006119ac8385612009565b9050826119b98583611fe9565b146113405760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016105d6565b6001600160a01b038516600090815260026020526040902054611a33908461142a565b6001600160a01b038616600090815260026020908152604080832093909355600190522054611a62908361142a565b6001600160a01b038087166000908152600160205260408082209390935590861681522054611a919082611347565b6001600160a01b0390941660009081526001602052604090209390935550505050565b6000611abe6112db565b90506000611acc8483611991565b600a546001600160a01b0316600090815260016020526040902054909150611af49082611347565b600a80546001600160a01b039081166000908152600160209081526040808320959095559254909116815260029091522054611b309085611347565b600a80546001600160a01b03908116600090815260026020908152604091829020949094559154915187815291811692908616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a350505050565b611bb284611925876119258a600f5461142a90919063ffffffff16565b600f55601054611bc29084611347565b601055601154611bd29083611347565b601155601254611be29082611347565b601255600e54611bf2908361142a565b600e5560405182815260009030907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050505050565b6001600160a01b038516600090815260016020526040902054611c58908361142a565b6001600160a01b03808716600090815260016020908152604080832094909455918716815260029091522054611c8e9084611347565b6001600160a01b038516600090815260026020908152604080832093909355600190522054611a919082611347565b6001600160a01b038416600090815260016020526040902054611ce0908361142a565b6001600160a01b038086166000908152600160205260408082209390935590851681522054611d0f9082611347565b6001600160a01b03909316600090815260016020526040902092909255505050565b6001600160a01b038616600090815260026020526040902054611d54908561142a565b6001600160a01b038716600090815260026020908152604080832093909355600190522054611d83908461142a565b6001600160a01b03808816600090815260016020908152604080832094909455918816815260029091522054611db99083611347565b6001600160a01b038616600090815260026020908152604080832093909355600190522054611de89082611347565b6001600160a01b039095166000908152600160205260409020949094555050505050565b80356001600160a01b03811681146105f957600080fd5b600060208284031215611e34578081fd5b61134082611e0c565b60008060408385031215611e4f578081fd5b611e5883611e0c565b9150611e6660208401611e0c565b90509250929050565b600080600060608486031215611e83578081fd5b611e8c84611e0c565b9250611e9a60208501611e0c565b9150604084013590509250925092565b60008060408385031215611ebc578182fd5b611ec583611e0c565b946020939093013593505050565b600060208284031215611ee4578081fd5b5035919050565b60008060408385031215611efd578182fd5b8235915060208301358015158114611f13578182fd5b809150509250929050565b600080600060608486031215611f32578283fd5b505081359360208301359350604090920135919050565b6000602080835283518082850152825b81811015611f7557858101830151858201604001528201611f59565b81811115611f865783604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115611fe457611fe4612095565b500190565b60008261200457634e487b7160e01b81526012600452602481fd5b500490565b600081600019048311821515161561202357612023612095565b500290565b60008282101561203a5761203a612095565b500390565b60028104600182168061205357607f821691505b6020821081141561207457634e487b7160e01b600052602260045260246000fd5b50919050565b600060001982141561208e5761208e612095565b5060010190565b634e487b7160e01b600052601160045260246000fdfe544f4b454e32303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726f544f4b454e32303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220a2e57e8ca3fa6e04321bfd10b15b8b63165de09dd76571d821a3ba851a3044db64736f6c63430008020033000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001600000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000746a5288000000000000000000000000000000000000000000000000000000000000000005000000000000000000000000000000000000000000000000000000000000000500000000000000000000000000000000000000000000000000000000000000050000000000000000000000009584832a5fa3bd9ec88d99aeab63bfcfe0beecbc00000000000000000000000061eb6146538436c4cc4b968ff6c769ea48e562bb00000000000000000000000000000000000000000000000000000000000000124e6f7446696e616e6369616c416476696365000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034e46410000000000000000000000000000000000000000000000000000000000

Deployed ByteCode Sourcemap

16567:16729:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18488:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;19402:161;;;;;;:::i;:::-;;:::i;:::-;;;2545:14:1;;2538:22;2520:41;;2508:2;2493:18;19402:161:0;2475:92:1;20637:87:0;20706:10;;20637:87;;;8831:25:1;;;8819:2;8804:18;20637:87:0;8786:76:1;18767:95:0;18847:7;;18767:95;;19571:315;;;;;;:::i;:::-;;:::i;21770:253::-;;;;;;:::i;:::-;;:::i;18674:85::-;18742:9;;18674:85;;19894:218;;;;;;:::i;:::-;;:::i;20938:378::-;;;;;;:::i;:::-;;:::i;:::-;;20736:88;20805:11;;20736:88;;21324:438;;;;;;:::i;:::-;;:::i;22857:215::-;;;;;;:::i;:::-;;:::i;18870:198::-;;;;;;:::i;:::-;;:::i;16013:148::-;;;:::i;17472:27::-;;;;;;17100:25;;;;;-1:-1:-1;;;;;17100:25:0;;;;;;-1:-1:-1;;;;;2336:32:1;;;2318:51;;2306:2;2291:18;17100:25:0;2273:102:1;15371:79:0;15409:7;15436:6;-1:-1:-1;;;;;15436:6:0;15371:79;;18579:87;;;:::i;20120:271::-;;;;;;:::i;:::-;;:::i;19076:167::-;;;;;;:::i;:::-;;:::i;17506:27::-;;;;;;15174:21;;;;;-1:-1:-1;;;;;15174:21:0;;;17438:27;;;;;;20399:110;;;;;;:::i;:::-;-1:-1:-1;;;;;20481:20:0;20457:4;20481:20;;;:11;:20;;;;;;;;;20399:110;20836:94;20908:14;;20836:94;;19251:143;;;;;;:::i;:::-;-1:-1:-1;;;;;19359:18:0;;;19332:7;19359:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;19251:143;20521:108;;;;;;:::i;:::-;-1:-1:-1;;;;;20602:19:0;20578:4;20602:19;;;:10;:19;;;;;;;;;20521:108;22031:332;;;;;;:::i;:::-;;:::i;16316:244::-;;;;;;:::i;:::-;;:::i;22371:478::-;;;;;;:::i;:::-;;:::i;23082:296::-;;;;;;:::i;:::-;;:::i;18488:83::-;18525:13;18558:5;18551:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18488:83;:::o;19402:161::-;19477:4;19494:39;193:10;19517:7;19526:6;19494:8;:39::i;:::-;-1:-1:-1;19551:4:0;19402:161;;;;;:::o;19571:315::-;19669:4;19686:36;19696:6;19704:9;19715:6;19686:9;:36::i;:::-;19733:123;19742:6;193:10;19764:91;19802:6;19764:91;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;19764:19:0;;;;;;:11;:19;;;;;;;;193:10;19764:33;;;;;;;;;;:37;:91::i;:::-;19733:8;:123::i;:::-;-1:-1:-1;19874:4:0;19571:315;;;;;:::o;21770:253::-;21836:7;21875;;21864;:18;;21856:73;;;;-1:-1:-1;;;21856:73:0;;4196:2:1;21856:73:0;;;4178:21:1;4235:2;4215:18;;;4208:30;4274:34;4254:18;;;4247:62;-1:-1:-1;;;4325:18:1;;;4318:40;4375:19;;21856:73:0;;;;;;;;;21940:19;21963:10;:8;:10::i;:::-;21940:33;-1:-1:-1;21991:24:0;:7;21940:33;21991:11;:24::i;:::-;21984:31;;;21770:253;;;;:::o;19894:218::-;193:10;19982:4;20031:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;20031:34:0;;;;;;;;;;19982:4;;19999:83;;20022:7;;20031:50;;20070:10;20031:38;:50::i;20938:378::-;193:10;20990:14;21039:19;;;:11;:19;;;;;;;;21038:20;21030:77;;;;-1:-1:-1;;;21030:77:0;;8474:2:1;21030:77:0;;;8456:21:1;8513:2;8493:18;;;8486:30;8552:34;8532:18;;;8525:62;-1:-1:-1;;;8603:18:1;;;8596:42;8655:19;;21030:77:0;8446:234:1;21030:77:0;21119:15;21144:19;21155:7;21144:10;:19::i;:::-;-1:-1:-1;;;;;;;;21192:15:0;;;;;;:7;:15;;;;;;21118:45;;-1:-1:-1;21192:28:0;;:15;-1:-1:-1;21118:45:0;;-1:-1:-1;;21192:19:0;:28::i;:::-;-1:-1:-1;;;;;21174:15:0;;;;;;:7;:15;;;;;:46;21241:7;;:20;;21253:7;21241:11;:20::i;:::-;21231:7;:30;21285:10;;:23;;21300:7;21285:14;:23::i;:::-;21272:10;:36;-1:-1:-1;;;20938:378:0:o;21324:438::-;21414:7;21453;;21442;:18;;21434:62;;;;-1:-1:-1;;;21434:62:0;;6129:2:1;21434:62:0;;;6111:21:1;6168:2;6148:18;;;6141:30;6207:33;6187:18;;;6180:61;6258:18;;21434:62:0;6101:181:1;21434:62:0;21512:17;21507:248;;21547:15;21572:19;21583:7;21572:10;:19::i;:::-;-1:-1:-1;21546:45:0;;-1:-1:-1;21606:14:0;;-1:-1:-1;;;;;;21606:14:0;21507:248;21655:23;21687:19;21698:7;21687:10;:19::i;:::-;-1:-1:-1;21653:53:0;;-1:-1:-1;21721:22:0;;-1:-1:-1;;;;;;21721:22:0;22857:215;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22944:19:0;::::1;;::::0;;;:10:::1;:19;::::0;;;;;::::1;;22943:20;22935:67;;;::::0;-1:-1:-1;;;22935:67:0;;5726:2:1;22935:67:0::1;::::0;::::1;5708:21:1::0;5765:2;5745:18;;;5738:30;5804:34;5784:18;;;5777:62;-1:-1:-1;;;5855:18:1;;;5848:32;5897:19;;22935:67:0::1;5698:224:1::0;22935:67:0::1;-1:-1:-1::0;;;;;23013:19:0::1;;::::0;;;:10:::1;:19;::::0;;;;:26;;-1:-1:-1;;23013:26:0::1;23035:4;23013:26;::::0;;23044:10:::1;:20:::0;;-1:-1:-1;;;;;;23044:20:0::1;::::0;;::::1;::::0;;22857:215::o;18870:198::-;-1:-1:-1;;;;;18960:20:0;;18936:7;18960:20;;;:11;:20;;;;;;;;18956:49;;;-1:-1:-1;;;;;;18989:16:0;;;;;;:7;:16;;;;;;18982:23;;18956:49;-1:-1:-1;;;;;19043:16:0;;;;;;:7;:16;;;;;;19023:37;;:19;:37::i;16013:148::-;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;16120:1:::1;16104:6:::0;;16083:40:::1;::::0;-1:-1:-1;;;;;16104:6:0;;::::1;::::0;16083:40:::1;::::0;16120:1;;16083:40:::1;16151:1;16134:19:::0;;-1:-1:-1;;;;;;16134:19:0::1;::::0;;16013:148::o;18579:87::-;18618:13;18651:7;18644:14;;;;;:::i;20120:271::-;20213:4;20230:131;193:10;20253:7;20262:98;20301:15;20262:98;;;;;;;;;;;;;;;;;193:10;20262:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;20262:34:0;;;;;;;;;;;;:38;:98::i;19076:167::-;19154:4;19171:42;193:10;19195:9;19206:6;19171:9;:42::i;22031:332::-;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22113:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;22112:21;22104:61;;;::::0;-1:-1:-1;;;22104:61:0;;5370:2:1;22104:61:0::1;::::0;::::1;5352:21:1::0;5409:2;5389:18;;;5382:30;5448:29;5428:18;;;5421:57;5495:18;;22104:61:0::1;5342:177:1::0;22104:61:0::1;-1:-1:-1::0;;;;;22179:16:0;::::1;22198:1;22179:16:::0;;;:7:::1;:16;::::0;;;;;:20;22176:108:::1;;-1:-1:-1::0;;;;;22255:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;;22235:37:::1;::::0;:19:::1;:37::i;:::-;-1:-1:-1::0;;;;;22216:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;:56;22176:108:::1;-1:-1:-1::0;;;;;22294:20:0::1;;::::0;;;:11:::1;:20;::::0;;;;:27;;-1:-1:-1;;22294:27:0::1;22317:4;22294:27:::0;;::::1;::::0;;;22332:9:::1;:23:::0;;;;::::1;::::0;;;;;;::::1;::::0;;-1:-1:-1;;;;;;22332:23:0::1;::::0;;::::1;::::0;;22031:332::o;16316:244::-;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;16405:22:0;::::1;16397:73;;;::::0;-1:-1:-1;;;16397:73:0;;4607:2:1;16397:73:0::1;::::0;::::1;4589:21:1::0;4646:2;4626:18;;;4619:30;4685:34;4665:18;;;4658:62;-1:-1:-1;;;4736:18:1;;;4729:36;4782:19;;16397:73:0::1;4579:228:1::0;16397:73:0::1;16507:6;::::0;;16486:38:::1;::::0;-1:-1:-1;;;;;16486:38:0;;::::1;::::0;16507:6;::::1;::::0;16486:38:::1;::::0;::::1;16535:6;:17:::0;;-1:-1:-1;;;;;;16535:17:0::1;-1:-1:-1::0;;;;;16535:17:0;;;::::1;::::0;;;::::1;::::0;;16316:244::o;22371:478::-;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22452:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;22444:60;;;::::0;-1:-1:-1;;;22444:60:0;;5370:2:1;22444:60:0::1;::::0;::::1;5352:21:1::0;5409:2;5389:18;;;5382:30;5448:29;5428:18;;;5421:57;5495:18;;22444:60:0::1;5342:177:1::0;22444:60:0::1;22520:9;22515:327;22539:9;:16:::0;22535:20;::::1;22515:327;;;22597:7;-1:-1:-1::0;;;;;22581:23:0::1;:9;22591:1;22581:12;;;;;;-1:-1:-1::0;;;22581:12:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;22581:12:0::1;:23;22577:254;;;22640:9;22650:16:::0;;:20:::1;::::0;22669:1:::1;::::0;22650:20:::1;:::i;:::-;22640:31;;;;;;-1:-1:-1::0;;;22640:31:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;::::1;::::0;22625:9:::1;:12:::0;;-1:-1:-1;;;;;22640:31:0;;::::1;::::0;22635:1;;22625:12;::::1;;;-1:-1:-1::0;;;22625:12:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;;;;::::1;:46:::0;;-1:-1:-1;;;;;;22625:46:0::1;-1:-1:-1::0;;;;;22625:46:0;;::::1;;::::0;;22690:16;;::::1;::::0;;:7:::1;:16:::0;;;;;;:20;;;22729:11:::1;:20:::0;;;;:28;;-1:-1:-1;;22729:28:0::1;::::0;;22776:9:::1;:15:::0;;;::::1;;-1:-1:-1::0;;;22776:15:0::1;;;;;;;;;;::::0;;;::::1;::::0;;;;-1:-1:-1;;22776:15:0;;;;;-1:-1:-1;;;;;;22776:15:0::1;::::0;;;;;22810:5:::1;;22577:254;22557:3:::0;::::1;::::0;::::1;:::i;:::-;;;;22515:327;;;;22371:478:::0;:::o;23082:296::-;15583:6;;-1:-1:-1;;;;;15583:6:0;193:10;15583:22;15575:67;;;;-1:-1:-1;;;15575:67:0;;;;;;;:::i;:::-;23194:11:::1;:6:::0;23202:3:::1;23194:11;:::i;:::-;23183:8;:22:::0;23229:14:::1;:8:::0;23240:3:::1;23229:14;:::i;:::-;23217:9;:26:::0;23263:16:::1;:11:::0;23276:3:::1;23263:16;:::i;:::-;23248:12;:31:::0;;;23299:8:::1;::::0;23284:12:::1;:23:::0;23328:9:::1;::::0;23312:13:::1;:25:::0;23342:16:::1;:31:::0;-1:-1:-1;;;23082:296:0:o;23395:341::-;-1:-1:-1;;;;;23488:19:0;;23480:70;;;;-1:-1:-1;;;23480:70:0;;8067:2:1;23480:70:0;;;8049:21:1;8106:2;8086:18;;;8079:30;8145:34;8125:18;;;8118:62;-1:-1:-1;;;8196:18:1;;;8189:36;8242:19;;23480:70:0;8039:228:1;23480:70:0;-1:-1:-1;;;;;23569:21:0;;23561:70;;;;-1:-1:-1;;;23561:70:0;;7662:2:1;23561:70:0;;;7644:21:1;7701:2;7681:18;;;7674:30;7740:34;7720:18;;;7713:62;-1:-1:-1;;;7791:18:1;;;7784:34;7835:19;;23561:70:0;7634:226:1;23561:70:0;-1:-1:-1;;;;;23644:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;23696:32;;8831:25:1;;;23696:32:0;;8804:18:1;23696:32:0;;;;;;;23395:341;;;:::o;23744:1286::-;-1:-1:-1;;;;;23841:20:0;;23833:72;;;;-1:-1:-1;;;23833:72:0;;3788:2:1;23833:72:0;;;3770:21:1;3827:2;3807:18;;;3800:30;3866:34;3846:18;;;3839:62;-1:-1:-1;;;3917:18:1;;;3910:37;3964:19;;23833:72:0;3760:229:1;23833:72:0;-1:-1:-1;;;;;23924:23:0;;23916:73;;;;-1:-1:-1;;;23916:73:0;;3382:2:1;23916:73:0;;;3364:21:1;3421:2;3401:18;;;3394:30;3460:34;3440:18;;;3433:62;-1:-1:-1;;;3511:18:1;;;3504:35;3556:19;;23916:73:0;3354:227:1;23916:73:0;24017:1;24008:6;:10;24000:64;;;;-1:-1:-1;;;24000:64:0;;7252:2:1;24000:64:0;;;7234:21:1;7291:2;7271:18;;;7264:30;7330:34;7310:18;;;7303:62;-1:-1:-1;;;7381:18:1;;;7374:39;7430:19;;24000:64:0;7224:231:1;24000:64:0;-1:-1:-1;;;;;24200:18:0;;24166:12;24200:18;;;:10;:18;;;;;;24181:4;;24200:18;;;:43;;-1:-1:-1;;;;;;24222:21:0;;;;;;:10;:21;;;;;;;;24200:43;:69;;;-1:-1:-1;;;;;;24247:22:0;;;;;;:11;:22;;;;;;;;24200:69;24196:117;;;-1:-1:-1;24296:5:0;24196:117;24330:7;24325:28;;24339:14;:12;:14::i;:::-;-1:-1:-1;;;;;24388:19:0;;;;;;:11;:19;;;;;;;;:46;;;;-1:-1:-1;;;;;;24412:22:0;;;;;;:11;:22;;;;;;;;24411:23;24388:46;24384:597;;;24451:48;24473:6;24481:9;24492:6;24451:21;:48::i;:::-;24384:597;;;-1:-1:-1;;;;;24522:19:0;;;;;;:11;:19;;;;;;;;24521:20;:46;;;;-1:-1:-1;;;;;;24545:22:0;;;;;;:11;:22;;;;;;;;24521:46;24517:464;;;24584:46;24604:6;24612:9;24623:6;24584:19;:46::i;24517:464::-;-1:-1:-1;;;;;24653:19:0;;;;;;:11;:19;;;;;;;;24652:20;:47;;;;-1:-1:-1;;;;;;24677:22:0;;;;;;:11;:22;;;;;;;;24676:23;24652:47;24648:333;;;24716:44;24734:6;24742:9;24753:6;24716:17;:44::i;24648:333::-;-1:-1:-1;;;;;24782:19:0;;;;;;:11;:19;;;;;;;;:45;;;;-1:-1:-1;;;;;;24805:22:0;;;;;;:11;:22;;;;;;;;24782:45;24778:203;;;24844:48;24866:6;24874:9;24885:6;24844:21;:48::i;24778:203::-;24925:44;24943:6;24951:9;24962:6;24925:17;:44::i;:::-;24998:7;24993:29;;25007:15;33093:12;;33082:8;:23;33128:13;;33116:9;:25;33167:16;;33152:12;:31;33038:153;25007:15;23744:1286;;;;:::o;4916:192::-;5002:7;5038:12;5030:6;;;;5022:29;;;;-1:-1:-1;;;5022:29:0;;;;;;;;:::i;:::-;-1:-1:-1;5062:9:0;5074:5;5078:1;5074;:5;:::i;:::-;5062:17;4916:192;-1:-1:-1;;;;;4916:192:0:o;31600:163::-;31641:7;31662:15;31679;31698:19;:17;:19::i;:::-;31661:56;;-1:-1:-1;31661:56:0;-1:-1:-1;31735:20:0;31661:56;;31735:11;:20::i;:::-;31728:27;;;;31600:163;:::o;6314:132::-;6372:7;6399:39;6403:1;6406;6399:39;;;;;;;;;;;;;;;;;:3;:39::i;:::-;6392:46;6314:132;-1:-1:-1;;;6314:132:0:o;4013:181::-;4071:7;;4103:5;4107:1;4103;:5;:::i;:::-;4091:17;;4132:1;4127;:6;;4119:46;;;;-1:-1:-1;;;4119:46:0;;5014:2:1;4119:46:0;;;4996:21:1;5053:2;5033:18;;;5026:30;5092:29;5072:18;;;5065:57;5139:18;;4119:46:0;4986:177:1;29651:652:0;29710:7;29719;29728;29737;29746;29755;29764;29785:12;29799:13;29814:16;29834:55;29846:7;29855:8;;29865:9;;29876:12;;29834:11;:55::i;:::-;29784:105;;;;;;29900:23;29926:50;29945:7;29954:4;29960:5;29967:8;29926:18;:50::i;:::-;29900:76;;29987:19;30010:10;:8;:10::i;:::-;29987:33;;30032:15;30049:12;30065:39;30077:7;30086:4;30092:11;30065;:39::i;:::-;30031:73;;;;30115:23;30141:64;30161:7;30170:4;30176:5;30183:8;30193:11;30141:19;:64::i;:::-;30224:7;;-1:-1:-1;30115:90:0;;-1:-1:-1;30250:4:0;-1:-1:-1;30256:15:0;;-1:-1:-1;30273:4:0;;-1:-1:-1;30279:5:0;;-1:-1:-1;30286:8:0;-1:-1:-1;;;29651:652:0;;;;;;;;;:::o;4477:136::-;4535:7;4562:43;4566:1;4569;4562:43;;;;;;;;;;;;;;;;;:3;:43::i;32706:320::-;32752:8;;:13;:31;;;;-1:-1:-1;32769:9:0;;:14;32752:31;:52;;;;-1:-1:-1;32787:12:0;;:17;32752:52;32749:64;;;32806:7;;32749:64;32848:8;;;32833:12;:23;32883:9;;;32867:13;:25;32922:12;;;32903:16;:31;-1:-1:-1;32955:12:0;;;;32978:13;;;;33002:16;32706:320;:::o;27050:671::-;27152:19;27175:10;:8;:10::i;:::-;27152:33;;27197:15;27214:23;27239:12;27253:23;27278:12;27292:13;27307:16;27327:19;27338:7;27327:10;:19::i;:::-;27196:150;;;;;;;;;;;;;;27357:13;27374:22;27384:11;27374:5;:9;;:22;;;;:::i;:::-;27357:39;-1:-1:-1;27407:16:0;27426:25;:8;27439:11;27426:12;:25::i;:::-;27407:44;;27462:80;27489:6;27497:9;27508:7;27517;27526:15;27462:26;:80::i;:::-;27553:32;27568:8;27578:6;27553:14;:32::i;:::-;27596:57;27608:4;27614:5;27621:8;27631:4;27637:5;27644:8;27596:11;:57::i;:::-;27686:9;-1:-1:-1;;;;;27669:44:0;27678:6;-1:-1:-1;;;;;27669:44:0;;27697:15;27669:44;;;;8831:25:1;;8819:2;8804:18;;8786:76;27669:44:0;;;;;;;;27050:671;;;;;;;;;;;;;:::o;25978:687::-;26078:19;26101:10;:8;:10::i;:::-;26078:33;;26123:15;26140:23;26165:12;26179:23;26204:12;26218:13;26233:16;26253:19;26264:7;26253:10;:19::i;:::-;26122:150;;;;;;;;;;;;;;26283:13;26300:22;26310:11;26300:5;:9;;:22;;;;:::i;:::-;26283:39;-1:-1:-1;26333:16:0;26352:25;:8;26365:11;26352:12;:25::i;:::-;26333:44;;26388:90;26417:6;26425:9;26436:15;26453:7;26462:15;26388:28;:90::i;25038:661::-;25136:19;25159:10;:8;:10::i;:::-;25136:33;;25181:15;25198:23;25223:12;25237:23;25262:12;25276:13;25291:16;25311:19;25322:7;25311:10;:19::i;:::-;25180:150;;;;;;;;;;;;;;25341:13;25358:22;25368:11;25358:5;:9;;:22;;;;:::i;:::-;25341:39;-1:-1:-1;25391:16:0;25410:25;:8;25423:11;25410:12;:25::i;:::-;25391:44;;25451:69;25476:6;25484:9;25495:7;25504:15;25451:24;:69::i;28074:688::-;28176:19;28199:10;:8;:10::i;:::-;28176:33;;28221:15;28238:23;28263:12;28277:23;28302:12;28316:13;28331:16;28351:19;28362:7;28351:10;:19::i;:::-;28220:150;;;;;;;;;;;;;;28381:13;28398:22;28408:11;28398:5;:9;;:22;;;;:::i;:::-;28381:39;-1:-1:-1;28431:16:0;28450:25;:8;28463:11;28450:12;:25::i;:::-;28431:44;;28490:91;28511:6;28519:9;28530:7;28539;28548:15;28565;28490:20;:91::i;31771:561::-;31868:7;;31904;;31821;;;;;31928:289;31952:9;:16;31948:20;;31928:289;;;32018:7;31994;:21;32002:9;32012:1;32002:12;;;;;;-1:-1:-1;;;32002:12:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32002:12:0;31994:21;;;;;;;;;;;;;:31;;:66;;;32053:7;32029;:21;32037:9;32047:1;32037:12;;;;;;-1:-1:-1;;;32037:12:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32037:12:0;32029:21;;;;;;;;;;;;;:31;31994:66;31990:97;;;32070:7;;32079;;32062:25;;;;;;;;;31990:97;32112:34;32124:7;:21;32132:9;32142:1;32132:12;;;;;;-1:-1:-1;;;32132:12:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32132:12:0;32124:21;;;;;;;;;;;;;32112:7;;:11;:34::i;:::-;32102:44;;32171:34;32183:7;:21;32191:9;32201:1;32191:12;;;;;;-1:-1:-1;;;32191:12:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32191:12:0;32183:21;;;;;;;;;;;;;32171:7;;:11;:34::i;:::-;32161:44;-1:-1:-1;31970:3:0;;;;:::i;:::-;;;;31928:289;;;-1:-1:-1;32253:7:0;;32241;;:20;;:11;:20::i;:::-;32231:7;:30;32227:61;;;32271:7;;32280;;32263:25;;;;;;;;32227:61;32307:7;;-1:-1:-1;32316:7:0;-1:-1:-1;31771:561:0;;;:::o;6942:278::-;7028:7;7063:12;7056:5;7048:28;;;;-1:-1:-1;;;7048:28:0;;;;;;;;:::i;:::-;-1:-1:-1;7087:9:0;7099:5;7103:1;7099;:5;:::i;30315:427::-;30428:7;30437;30446;30466:12;30481:50;30527:3;30482:39;30508:12;;30483:19;30495:6;30483:7;:11;;:19;;;;:::i;:::-;30482:25;;:39::i;30481:50::-;30466:65;;30542:13;30558:51;30605:3;30559:40;30586:12;;30560:20;30572:7;30560;:11;;:20;;;;:::i;30558:51::-;30542:67;;30620:16;30639:54;30689:3;30640:43;30670:12;;30641:23;30653:10;30641:7;:11;;:23;;;;:::i;30639:54::-;30712:4;;30718:5;;-1:-1:-1;30712:4:0;;-1:-1:-1;30315:427:0;-1:-1:-1;;;;;;30315:427:0:o;30754:191::-;30868:7;30895:42;30928:8;30895:28;30917:5;30895:28;:7;30907:4;30895:11;:17::i;:::-;:21;;:28::i;30957:254::-;31052:7;;;31099:24;:7;31111:11;31099;:24::i;:::-;31081:42;-1:-1:-1;31134:12:0;31149:21;:4;31158:11;31149:8;:21::i;:::-;31189:7;;;;-1:-1:-1;30957:254:0;;-1:-1:-1;;;;;30957:254:0:o;31223:369::-;31359:7;;31395:22;:5;31405:11;31395:9;:22::i;:::-;31379:38;-1:-1:-1;31428:16:0;31447:25;:8;31460:11;31447:12;:25::i;:::-;31428:44;-1:-1:-1;31483:23:0;31509:42;31428:44;31509:28;31531:5;31509:28;:7;31521:4;31509:11;:17::i;:42::-;31483:68;31223:369;-1:-1:-1;;;;;;;;;31223:369:0:o;5367:471::-;5425:7;5670:6;5666:47;;-1:-1:-1;5700:1:0;5693:8;;5666:47;5725:9;5737:5;5741:1;5737;:5;:::i;:::-;5725:17;-1:-1:-1;5770:1:0;5761:5;5765:1;5725:17;5761:5;:::i;:::-;:10;5753:56;;;;-1:-1:-1;;;5753:56:0;;6489:2:1;5753:56:0;;;6471:21:1;6528:2;6508:18;;;6501:30;6567:34;6547:18;;;6540:62;-1:-1:-1;;;6618:18:1;;;6611:31;6659:19;;5753:56:0;6461:223:1;27733:333:0;-1:-1:-1;;;;;27900:15:0;;;;;;:7;:15;;;;;;:28;;27920:7;27900:19;:28::i;:::-;-1:-1:-1;;;;;27882:15:0;;;;;;:7;:15;;;;;;;;:46;;;;27957:7;:15;;;;:28;;27977:7;27957:19;:28::i;:::-;-1:-1:-1;;;;;27939:15:0;;;;;;;:7;:15;;;;;;:46;;;;28017:18;;;;;;;:39;;28040:15;28017:22;:39::i;:::-;-1:-1:-1;;;;;27996:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;;27733:333:0:o;32340:358::-;32417:19;32439:10;:8;:10::i;:::-;32417:32;-1:-1:-1;32460:16:0;32479:25;:8;32417:32;32479:12;:25::i;:::-;32545:10;;-1:-1:-1;;;;;32545:10:0;32537:19;;;;:7;:19;;;;;;32460:44;;-1:-1:-1;32537:33:0;;32460:44;32537:23;:33::i;:::-;32523:10;;;-1:-1:-1;;;;;32523:10:0;;;32515:19;;;;:7;:19;;;;;;;;:55;;;;32611:10;;;;;32603:19;;:7;:19;;;;;:33;;32627:8;32603:23;:33::i;:::-;32589:10;;;-1:-1:-1;;;;;32589:10:0;;;32581:19;;;;:7;:19;;;;;;;;;:55;;;;32669:10;;32652:38;;8831:25:1;;;32669:10:0;;;;32652:38;;;;;;8804:18:1;32652:38:0;;;;;;;32340:358;;;;:::o;29205:432::-;29349:42;29382:8;29349:28;29371:5;29349:17;29361:4;29349:7;;:11;;:17;;;;:::i;:42::-;29339:7;:52;29415:10;;:20;;29430:4;29415:14;:20::i;:::-;29402:10;:33;29460:11;;:22;;29476:5;29460:15;:22::i;:::-;29446:11;:36;29510:14;;:28;;29529:8;29510:18;:28::i;:::-;29493:14;:45;29559:7;;:18;;29571:5;29559:11;:18::i;:::-;29549:7;:28;29587:42;;8831:25:1;;;29619:1:0;;29604:4;;29587:42;;8819:2:1;8804:18;29587:42:0;;;;;;;29205:432;;;;;;:::o;26677:359::-;-1:-1:-1;;;;;26854:15:0;;;;;;:7;:15;;;;;;:28;;26874:7;26854:19;:28::i;:::-;-1:-1:-1;;;;;26836:15:0;;;;;;;:7;:15;;;;;;;;:46;;;;26914:18;;;;;:7;:18;;;;;:39;;26937:15;26914:22;:39::i;:::-;-1:-1:-1;;;;;26893:18:0;;;;;;:7;:18;;;;;;;;:60;;;;26985:7;:18;;;;:39;;27008:15;26985:22;:39::i;25711:255::-;-1:-1:-1;;;;;25859:15:0;;;;;;:7;:15;;;;;;:28;;25879:7;25859:19;:28::i;:::-;-1:-1:-1;;;;;25841:15:0;;;;;;;:7;:15;;;;;;:46;;;;25919:18;;;;;;;:39;;25942:15;25919:22;:39::i;:::-;-1:-1:-1;;;;;25898:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;25711:255:0:o;28774:423::-;-1:-1:-1;;;;;28960:15:0;;;;;;:7;:15;;;;;;:28;;28980:7;28960:19;:28::i;:::-;-1:-1:-1;;;;;28942:15:0;;;;;;:7;:15;;;;;;;;:46;;;;29017:7;:15;;;;:28;;29037:7;29017:19;:28::i;:::-;-1:-1:-1;;;;;28999:15:0;;;;;;;:7;:15;;;;;;;;:46;;;;29077:18;;;;;:7;:18;;;;;:39;;29100:15;29077:22;:39::i;:::-;-1:-1:-1;;;;;29056:18:0;;;;;;:7;:18;;;;;;;;:60;;;;29148:7;:18;;;;:39;;29171:15;29148:22;:39::i;:::-;-1:-1:-1;;;;;29127:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;;;28774:423:0:o;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:2;;177:1;174;167:12;192:196;;304:2;292:9;283:7;279:23;275:32;272:2;;;325:6;317;310:22;272:2;353:29;372:9;353:29;:::i;393:270::-;;;522:2;510:9;501:7;497:23;493:32;490:2;;;543:6;535;528:22;490:2;571:29;590:9;571:29;:::i;:::-;561:39;;619:38;653:2;642:9;638:18;619:38;:::i;:::-;609:48;;480:183;;;;;:::o;668:338::-;;;;814:2;802:9;793:7;789:23;785:32;782:2;;;835:6;827;820:22;782:2;863:29;882:9;863:29;:::i;:::-;853:39;;911:38;945:2;934:9;930:18;911:38;:::i;:::-;901:48;;996:2;985:9;981:18;968:32;958:42;;772:234;;;;;:::o;1011:264::-;;;1140:2;1128:9;1119:7;1115:23;1111:32;1108:2;;;1161:6;1153;1146:22;1108:2;1189:29;1208:9;1189:29;:::i;:::-;1179:39;1265:2;1250:18;;;;1237:32;;-1:-1:-1;;;1098:177:1:o;1280:190::-;;1392:2;1380:9;1371:7;1367:23;1363:32;1360:2;;;1413:6;1405;1398:22;1360:2;-1:-1:-1;1441:23:1;;1350:120;-1:-1:-1;1350:120:1:o;1475:361::-;;;1601:2;1589:9;1580:7;1576:23;1572:32;1569:2;;;1622:6;1614;1607:22;1569:2;1663:9;1650:23;1640:33;;1723:2;1712:9;1708:18;1695:32;1770:5;1763:13;1756:21;1749:5;1746:32;1736:2;;1797:6;1789;1782:22;1736:2;1825:5;1815:15;;;1559:277;;;;;:::o;1841:326::-;;;;1987:2;1975:9;1966:7;1962:23;1958:32;1955:2;;;2008:6;2000;1993:22;1955:2;-1:-1:-1;;2036:23:1;;;2106:2;2091:18;;2078:32;;-1:-1:-1;2157:2:1;2142:18;;;2129:32;;1945:222;-1:-1:-1;1945:222:1:o;2572:603::-;;2713:2;2742;2731:9;2724:21;2774:6;2768:13;2817:6;2812:2;2801:9;2797:18;2790:34;2842:4;2855:140;2869:6;2866:1;2863:13;2855:140;;;2964:14;;;2960:23;;2954:30;2930:17;;;2949:2;2926:26;2919:66;2884:10;;2855:140;;;3013:6;3010:1;3007:13;3004:2;;;3083:4;3078:2;3069:6;3058:9;3054:22;3050:31;3043:45;3004:2;-1:-1:-1;3159:2:1;3138:15;-1:-1:-1;;3134:29:1;3119:45;;;;3166:2;3115:54;;2693:482;-1:-1:-1;;;2693:482:1:o;6689:356::-;6891:2;6873:21;;;6910:18;;;6903:30;6969:34;6964:2;6949:18;;6942:62;7036:2;7021:18;;6863:182::o;8867:128::-;;8938:1;8934:6;8931:1;8928:13;8925:2;;;8944:18;;:::i;:::-;-1:-1:-1;8980:9:1;;8915:80::o;9000:217::-;;9066:1;9056:2;;-1:-1:-1;;;9091:31:1;;9145:4;9142:1;9135:15;9173:4;9098:1;9163:15;9056:2;-1:-1:-1;9202:9:1;;9046:171::o;9222:168::-;;9328:1;9324;9320:6;9316:14;9313:1;9310:21;9305:1;9298:9;9291:17;9287:45;9284:2;;;9335:18;;:::i;:::-;-1:-1:-1;9375:9:1;;9274:116::o;9395:125::-;;9463:1;9460;9457:8;9454:2;;;9468:18;;:::i;:::-;-1:-1:-1;9505:9:1;;9444:76::o;9525:380::-;9610:1;9600:12;;9657:1;9647:12;;;9668:2;;9722:4;9714:6;9710:17;9700:27;;9668:2;9775;9767:6;9764:14;9744:18;9741:38;9738:2;;;9821:10;9816:3;9812:20;9809:1;9802:31;9856:4;9853:1;9846:15;9884:4;9881:1;9874:15;9738:2;;9580:325;;;:::o;9910:135::-;;-1:-1:-1;;9970:17:1;;9967:2;;;9990:18;;:::i;:::-;-1:-1:-1;10037:1:1;10026:13;;9957:88::o;10050:127::-;10111:10;10106:3;10102:20;10099:1;10092:31;10142:4;10139:1;10132:15;10166:4;10163:1;10156:15

Swarm Source

ipfs://a2e57e8ca3fa6e04321bfd10b15b8b63165de09dd76571d821a3ba851a3044db

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.