Token ATEN

 

Overview [ERC-20]

Max Total Supply:
3,000,000,000 ATEN

Holders:
1

Transfers:
-

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

OVERVIEW

The Athena Ins project will offer everyone the opportunity to take the place of an insurer by creating a smart insurance contract and accessible to everyone to generate income.

# Exchange Pair Price  24H Volume % Volume
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
ATEN

Compiler Version
v0.8.6+commit.11564f7e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-07-29
*/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.2;

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

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

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

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

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

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

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

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

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

  function _msgData() internal view virtual returns (bytes calldata) {
    this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
    return msg.data;
 // SPDX-License-Identifier: UNLICENSED
  }
}
/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
  address private _owner;

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

  /**
   * @dev Initializes the contract setting the deployer as the initial owner.
   */
  constructor() {
    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 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 onlyOwner {
    _transferOwnership(newOwner);
  }

  /**
   * @dev Transfers ownership of the contract to a new account (`newOwner`).
   */
  function _transferOwnership(address newOwner) internal {
    require(newOwner != address(0), 'Ownable: new owner is the zero address');
    emit OwnershipTransferred(_owner, newOwner);
    _owner = newOwner;

  }
}

contract ATEN is Context, IERC20, 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;
    address[] private _excluded;

    string  private _name = "ATEN";
    string  private _symbol = "ATEN";
    uint256 private _decimals = 18;
	  address private FeeAddress = 0x967d98e659f2787A38d928B9B7a49a2E4701B30C;

    uint256 private _MAX = ~uint256(0);
    uint256 private _GRANULARITY = 1000;

    uint256 private _tTotal = 3000000000 * 10**18;
    uint256 private _rTotal = (_MAX - (_MAX % _tTotal));

    uint256 private _tFeeTotal;
    uint256 private _tBurnTotal;
    uint256 private _tCharityTotal;

    uint256 public     _TAX_FEE = 25; // 0.025%
    uint256 public    _BURN_FEE = 0;
    uint256 public _CHARITY_FEE = 0;

    // Track original fees to bypass fees for charity account
    uint256 private ORIG_TAX_FEE = _TAX_FEE;
    uint256 private ORIG_BURN_FEE = _BURN_FEE;
    uint256 private ORIG_CHARITY_FEE = _CHARITY_FEE;

    constructor () {
        _rOwned[owner()] = _rTotal;
        emit Transfer(address(0), owner(), _tTotal);
    }

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

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

    function decimals() public view returns (uint8) {
        return uint8(_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, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

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

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

    function isExcluded(address account) public view returns (bool) {
        return _isExcluded[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 included");
        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() {
		    FeeAddress = account;
    }

    function setTaxFeePercent(uint256 taxFee) external onlyOwner() {
        _TAX_FEE = taxFee;
    }

    function setBurnFeePercent(uint256 burnFee) external onlyOwner() {
        _BURN_FEE = burnFee;
    }

    function setCharityFeePercent(uint256 charityFee) external onlyOwner() {
        _CHARITY_FEE = charityFee;
    }

  	function updateFee(uint256 _txFee,uint256 _burnFee,uint256 _charityFee) onlyOwner() public{
    	  require(_txFee < 100 && _burnFee < 100 && _charityFee < 100);
        _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), "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 sender, address recipient, uint256 amount) private {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");

        // Remove fees for transfers to and from charity account or to excluded account
        bool takeFee = true;
        if (FeeAddress == sender || FeeAddress == 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);
        _standardTransferContent(sender, recipient, rAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, 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);
        _excludedFromTransferContent(sender, recipient, tTransferAmount, rAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, 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);
        _excludedToTransferContent(sender, recipient, tAmount, rAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, 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);
        _bothTransferContent(sender, recipient, tAmount, rAmount, tTransferAmount, rTransferAmount);
        _sendToCharity(tCharity, sender);
        _reflectFee(rFee, rBurn, 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 tFee, uint256 tBurn, uint256 tCharity) private {
        _rTotal = _rTotal.sub(rFee).sub(rBurn);
        _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":[],"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":"_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":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"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":"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":[{"internalType":"uint256","name":"burnFee","type":"uint256"}],"name":"setBurnFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"charityFee","type":"uint256"}],"name":"setCharityFeePercent","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"taxFee","type":"uint256"}],"name":"setTaxFeePercent","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"}]

60c0604052600460808190526320aa22a760e11b60a0908152620000279160069190620001cb565b506040805180820190915260048082526320aa22a760e11b60209092019182526200005591600791620001cb565b506012600855600980546001600160a01b03191673967d98e659f2787a38d928b9b7a49a2e4701b30c179055600019600a8190556103e8600b556b09b18ab5df7180b6b8000000600c819055620000ac91620002d4565b600a54620000bb919062000271565b600d55601960115560006012556000601355601154601455601254601555601354601655348015620000ec57600080fd5b50600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600d5460016000620001486000546001600160a01b031690565b6001600160a01b03168152602081019190915260400160002055620001756000546001600160a01b031690565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600c54604051620001bd91815260200190565b60405180910390a3620002f7565b828054620001d99062000297565b90600052602060002090601f016020900481019282620001fd576000855562000248565b82601f106200021857805160ff191683800117855562000248565b8280016001018555821562000248579182015b82811115620002485782518255916020019190600101906200022b565b50620002569291506200025a565b5090565b5b808211156200025657600081556001016200025b565b6000828210156200029257634e487b7160e01b600052601160045260246000fd5b500390565b600181811c90821680620002ac57607f821691505b60208210811415620002ce57634e487b7160e01b600052602260045260246000fd5b50919050565b600082620002f257634e487b7160e01b600052601260045260246000fd5b500690565b6120a980620003076000396000f3fe608060405234801561001057600080fd5b50600436106101e55760003560e01c806377ef79931161010f578063cba0e996116100a2578063f2cc0c1811610071578063f2cc0c18146103fb578063f2fde38b1461040e578063f84354f114610421578063fc061a4f1461043457600080fd5b8063cba0e9961461037b578063cea26958146103a7578063d608b3b2146103ba578063dd62ed3e146103c257600080fd5b8063a9059cbb116100de578063a9059cbb14610343578063ae9dd5e014610356578063af41063b1461035f578063b58624281461037257600080fd5b806377ef7993146103045780638da5cb5b1461030d57806395d89b4114610328578063a457c2d71461033057600080fd5b8063313ce567116101875780634549b039116101565780634549b039146102c3578063457bdf6c146102d657806370a08231146102e9578063715018a6146102fc57600080fd5b8063313ce5671461028057806339509351146102955780633bd5d173146102a85780633c9f861d146102bb57600080fd5b806313114a9d116101c357806313114a9d1461024057806318160ddd1461025257806323b872dd1461025a5780632d8381191461026d57600080fd5b8063061c82d0146101ea57806306fdde03146101ff578063095ea7b31461021d575b600080fd5b6101fd6101f8366004611e1a565b610447565b005b61020761047f565b6040516102149190611e94565b60405180910390f35b61023061022b366004611df0565b610511565b6040519015158152602001610214565b600e545b604051908152602001610214565b600c54610244565b610230610268366004611db4565b610528565b61024461027b366004611e1a565b610591565b60085460405160ff9091168152602001610214565b6102306102a3366004611df0565b610615565b6101fd6102b6366004611e1a565b61064b565b600f54610244565b6102446102d1366004611e33565b610737565b6101fd6102e4366004611d66565b6107c6565b6102446102f7366004611d66565b610812565b6101fd610871565b61024460125481565b6000546040516001600160a01b039091168152602001610214565b6102076108e5565b61023061033e366004611df0565b6108f4565b610230610351366004611df0565b610943565b61024460135481565b6101fd61036d366004611e1a565b610950565b61024460115481565b610230610389366004611d66565b6001600160a01b031660009081526004602052604090205460ff1690565b6101fd6103b5366004611e1a565b61097f565b601054610244565b6102446103d0366004611d81565b6001600160a01b03918216600090815260036020908152604080832093909416825291909152205490565b6101fd610409366004611d66565b6109ae565b6101fd61041c366004611d66565b610b01565b6101fd61042f366004611d66565b610b37565b6101fd610442366004611e68565b610cee565b6000546001600160a01b0316331461047a5760405162461bcd60e51b815260040161047190611ee9565b60405180910390fd5b601155565b60606006805461048e90611f8e565b80601f01602080910402602001604051908101604052809291908181526020018280546104ba90611f8e565b80156105075780601f106104dc57610100808354040283529160200191610507565b820191906000526020600020905b8154815290600101906020018083116104ea57829003601f168201915b5050505050905090565b600061051e338484610d7d565b5060015b92915050565b6000610535848484610ea1565b610587843361058285604051806060016040528060288152602001612027602891396001600160a01b038a16600090815260036020908152604080832033845290915290205491906111a4565b610d7d565b5060019392505050565b6000600d548211156105f85760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b6064820152608401610471565b60006106026111de565b905061060e8382611201565b9392505050565b3360008181526003602090815260408083206001600160a01b0387168452909152812054909161051e9185906105829086611243565b3360008181526004602052604090205460ff16156106c05760405162461bcd60e51b815260206004820152602c60248201527f4578636c75646564206164647265737365732063616e6e6f742063616c6c207460448201526b3434b990333ab731ba34b7b760a11b6064820152608401610471565b60006106cb836112a2565b5050506001600160a01b0386166000908152600160205260409020549394506106f993925084915050611326565b6001600160a01b038316600090815260016020526040902055600d5461071f9082611326565b600d55600e5461072f9084611243565b600e55505050565b6000600c5483111561078b5760405162461bcd60e51b815260206004820152601f60248201527f416d6f756e74206d757374206265206c657373207468616e20737570706c79006044820152606401610471565b816107ab57600061079b846112a2565b5094965061052295505050505050565b60006107b6846112a2565b5093965061052295505050505050565b6000546001600160a01b031633146107f05760405162461bcd60e51b815260040161047190611ee9565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b03811660009081526004602052604081205460ff161561084f57506001600160a01b031660009081526002602052604090205490565b6001600160a01b03821660009081526001602052604090205461052290610591565b6000546001600160a01b0316331461089b5760405162461bcd60e51b815260040161047190611ee9565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60606007805461048e90611f8e565b600061051e33846105828560405180606001604052806025815260200161204f602591393360009081526003602090815260408083206001600160a01b038d16845290915290205491906111a4565b600061051e338484610ea1565b6000546001600160a01b0316331461097a5760405162461bcd60e51b815260040161047190611ee9565b601355565b6000546001600160a01b031633146109a95760405162461bcd60e51b815260040161047190611ee9565b601255565b6000546001600160a01b031633146109d85760405162461bcd60e51b815260040161047190611ee9565b6001600160a01b03811660009081526004602052604090205460ff1615610a415760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c7265616479206578636c7564656400000000006044820152606401610471565b6001600160a01b03811660009081526001602052604090205415610a9b576001600160a01b038116600090815260016020526040902054610a8190610591565b6001600160a01b0382166000908152600260205260409020555b6001600160a01b03166000818152600460205260408120805460ff191660019081179091556005805491820181559091527f036b6384b5eca791c62761152d0c79bb0604c104a5fb6f4eb0703f3154bb3db00180546001600160a01b0319169091179055565b6000546001600160a01b03163314610b2b5760405162461bcd60e51b815260040161047190611ee9565b610b3481611368565b50565b6000546001600160a01b03163314610b615760405162461bcd60e51b815260040161047190611ee9565b6001600160a01b03811660009081526004602052604090205460ff16610bc95760405162461bcd60e51b815260206004820152601b60248201527f4163636f756e7420697320616c726561647920696e636c7564656400000000006044820152606401610471565b60005b600554811015610cea57816001600160a01b031660058281548110610bf357610bf3612010565b6000918252602090912001546001600160a01b03161415610cd85760058054610c1e90600190611f77565b81548110610c2e57610c2e612010565b600091825260209091200154600580546001600160a01b039092169183908110610c5a57610c5a612010565b600091825260208083209190910180546001600160a01b0319166001600160a01b039485161790559184168152600282526040808220829055600490925220805460ff191690556005805480610cb257610cb2611ffa565b600082815260209020810160001990810180546001600160a01b03191690550190555050565b80610ce281611fc9565b915050610bcc565b5050565b6000546001600160a01b03163314610d185760405162461bcd60e51b815260040161047190611ee9565b606483108015610d285750606482105b8015610d345750606481105b610d3d57600080fd5b610d48836064611f58565b601155610d56826064611f58565b601255610d64816064611f58565b6013819055601154601455601254601555601655505050565b6001600160a01b038316610ddf5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610471565b6001600160a01b038216610e405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610471565b6001600160a01b0383811660008181526003602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610f055760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610471565b6001600160a01b038216610f675760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610471565b60008111610fc95760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610471565b6009546001906001600160a01b0385811691161480610ff557506009546001600160a01b038481169116145b8061101857506001600160a01b03831660009081526004602052604090205460ff165b15611021575060005b8061102e5761102e611428565b6001600160a01b03841660009081526004602052604090205460ff16801561106f57506001600160a01b03831660009081526004602052604090205460ff16155b156110845761107f84848461146d565b611182565b6001600160a01b03841660009081526004602052604090205460ff161580156110c557506001600160a01b03831660009081526004602052604090205460ff165b156110d55761107f848484611531565b6001600160a01b03841660009081526004602052604090205460ff1615801561111757506001600160a01b03831660009081526004602052604090205460ff16155b156111275761107f848484611583565b6001600160a01b03841660009081526004602052604090205460ff16801561116757506001600160a01b03831660009081526004602052604090205460ff165b156111775761107f8484846115d4565b611182848484611583565b8061119e5761119e601454601155601554601255601654601355565b50505050565b600081848411156111c85760405162461bcd60e51b81526004016104719190611e94565b5060006111d58486611f77565b95945050505050565b60008060006111eb611627565b90925090506111fa8282611201565b9250505090565b600061060e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506117a9565b6000806112508385611f1e565b90508381101561060e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610471565b6000806000806000806000806000806112c38b6011546012546013546117d7565b92509250925060006112d78c858585611856565b905060006112e36111de565b90506000806112f38f888561186e565b9150915060006113068383898988611898565b929e50919c509a5091985093965091945092505050919395979092949650565b600061060e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506111a4565b6001600160a01b0381166113cd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610471565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6011541580156114385750601254155b80156114445750601354155b1561144b57565b6011805460145560128054601555601380546016556000928390559082905555565b60006114776111de565b9050600080600080600080600061148d896112a2565b965096509650965096509650965060006114b089846118d490919063ffffffff16565b90506114bf8c8c8c8b8b611953565b6114c9828d6119f7565b6114d68682868686611ad8565b8a6001600160a01b03168c6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8760405161151b91815260200190565b60405180910390a3505050505050505050505050565b600061153b6111de565b90506000806000806000806000611551896112a2565b9650965096509650965096509650600061157489846118d490919063ffffffff16565b90506114bf8c8c878b8b611b73565b600061158d6111de565b905060008060008060008060006115a3896112a2565b965096509650965096509650965060006115c689846118d490919063ffffffff16565b90506114bf8c8c8a8a611bfb565b60006115de6111de565b905060008060008060008060006115f4896112a2565b9650965096509650965096509650600061161789846118d490919063ffffffff16565b90506114bf8c8c8c8b898c611c6f565b600d54600c546000918291825b6005548110156117795782600160006005848154811061165657611656612010565b60009182526020808320909101546001600160a01b0316835282019290925260400190205411806116c1575081600260006005848154811061169a5761169a612010565b60009182526020808320909101546001600160a01b03168352820192909252604001902054115b156116d757600d54600c54945094505050509091565b61171d60016000600584815481106116f1576116f1612010565b60009182526020808320909101546001600160a01b031683528201929092526040019020548490611326565b9250611765600260006005848154811061173957611739612010565b60009182526020808320909101546001600160a01b031683528201929092526040019020548390611326565b91508061177181611fc9565b915050611634565b50600c54600d5461178991611201565b8210156117a057600d54600c549350935050509091565b90939092509050565b600081836117ca5760405162461bcd60e51b81526004016104719190611e94565b5060006111d58486611f36565b60008060008061180160646117fb600b546117fb8b8d6118d490919063ffffffff16565b90611201565b9050600061182360646117fb600b546117fb8b8e6118d490919063ffffffff16565b9050600061184560646117fb600b546117fb8b8f6118d490919063ffffffff16565b929a91995091975095505050505050565b60006111d58261186885818989611326565b90611326565b6000808061187c86856118d4565b9050600061188a86866118d4565b919791965090945050505050565b6000806118a585846118d4565b905060006118b385856118d4565b905060006118c78261186885818d8d611326565b9998505050505050505050565b6000826118e357506000610522565b60006118ef8385611f58565b9050826118fc8583611f36565b1461060e5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610471565b6001600160a01b0385166000908152600260205260409020546119769084611326565b6001600160a01b0386166000908152600260209081526040808320939093556001905220546119a59083611326565b6001600160a01b0380871660009081526001602052604080822093909355908616815220546119d49082611243565b6001600160a01b0390941660009081526001602052604090209390935550505050565b6000611a016111de565b90506000611a0f84836118d4565b6009546001600160a01b0316600090815260016020526040902054909150611a379082611243565b600980546001600160a01b039081166000908152600160209081526040808320959095559254909116815260029091522054611a739085611243565b600980546001600160a01b03908116600090815260026020908152604091829020949094559154915187815291811692908616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a350505050565b611af18461186887600d5461132690919063ffffffff16565b600d55600e54611b019084611243565b600e55600f54611b119083611243565b600f55601054611b219082611243565b601055600c54611b319083611326565b600c5560405182815260009030907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050505050565b6001600160a01b038516600090815260016020526040902054611b969083611326565b6001600160a01b03808716600090815260016020908152604080832094909455918716815260029091522054611bcc9084611243565b6001600160a01b0385166000908152600260209081526040808320939093556001905220546119d49082611243565b6001600160a01b038416600090815260016020526040902054611c1e9083611326565b6001600160a01b038086166000908152600160205260408082209390935590851681522054611c4d9082611243565b6001600160a01b03909316600090815260016020526040902092909255505050565b6001600160a01b038616600090815260026020526040902054611c929085611326565b6001600160a01b038716600090815260026020908152604080832093909355600190522054611cc19084611326565b6001600160a01b03808816600090815260016020908152604080832094909455918816815260029091522054611cf79083611243565b6001600160a01b038616600090815260026020908152604080832093909355600190522054611d269082611243565b6001600160a01b039095166000908152600160205260409020949094555050505050565b80356001600160a01b0381168114611d6157600080fd5b919050565b600060208284031215611d7857600080fd5b61060e82611d4a565b60008060408385031215611d9457600080fd5b611d9d83611d4a565b9150611dab60208401611d4a565b90509250929050565b600080600060608486031215611dc957600080fd5b611dd284611d4a565b9250611de060208501611d4a565b9150604084013590509250925092565b60008060408385031215611e0357600080fd5b611e0c83611d4a565b946020939093013593505050565b600060208284031215611e2c57600080fd5b5035919050565b60008060408385031215611e4657600080fd5b8235915060208301358015158114611e5d57600080fd5b809150509250929050565b600080600060608486031215611e7d57600080fd5b505081359360208301359350604090920135919050565b600060208083528351808285015260005b81811015611ec157858101830151858201604001528201611ea5565b81811115611ed3576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115611f3157611f31611fe4565b500190565b600082611f5357634e487b7160e01b600052601260045260246000fd5b500490565b6000816000190483118215151615611f7257611f72611fe4565b500290565b600082821015611f8957611f89611fe4565b500390565b600181811c90821680611fa257607f821691505b60208210811415611fc357634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415611fdd57611fdd611fe4565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603160045260246000fd5b634e487b7160e01b600052603260045260246000fdfe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212203c3dee7c097c8faf3d64399675358e4e3b924ab36e04730a21625c7f9ee0afd164736f6c63430008060033

Deployed ByteCode Sourcemap

17434:15916:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23129:99;;;;;;:::i;:::-;;:::i;:::-;;18775:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;19694:161;;;;;;:::i;:::-;;:::i;:::-;;;2465:14:1;;2458:22;2440:41;;2428:2;2413:18;19694:161:0;2395:92:1;20805:87:0;20874:10;;20805:87;;;8690:25:1;;;8678:2;8663:18;20805:87:0;8645:76:1;19059:95:0;19139:7;;19059:95;;19863:313;;;;;;:::i;:::-;;:::i;21930:253::-;;;;;;:::i;:::-;;:::i;18961:90::-;19033:9;;18961:90;;8898:4:1;8886:17;;;8868:36;;8856:2;8841:18;18961:90:0;8823:87:1;20184:218:0;;;;;;:::i;:::-;;:::i;21098:378::-;;;;;;:::i;:::-;;:::i;20900:88::-;20969:11;;20900:88;;21484:438;;;;;;:::i;:::-;;:::i;23017:104::-;;;;;;:::i;:::-;;:::i;19162:198::-;;;;;;:::i;:::-;;:::i;16734:130::-;;;:::i;18362:31::-;;;;;;16132:73;16170:7;16193:6;16132:73;;-1:-1:-1;;;;;16193:6:0;;;2238:51:1;;2226:2;2211:18;16132:73:0;2193:102:1;18866:87:0;;;:::i;20410:269::-;;;;;;:::i;:::-;;:::i;19368:167::-;;;;;;:::i;:::-;;:::i;18400:31::-;;;;;;23347:115;;;;;;:::i;:::-;;:::i;18313:32::-;;;;;;20687:110;;;;;;:::i;:::-;-1:-1:-1;;;;;20769:20:0;20745:4;20769:20;;;:11;:20;;;;;;;;;20687:110;23236:103;;;;;;:::i;:::-;;:::i;20996:94::-;21068:14;;20996:94;;19543:143;;;;;;:::i;:::-;-1:-1:-1;;;;;19651:18:0;;;19624:7;19651:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;19543:143;22191:332;;;;;;:::i;:::-;;:::i;17009:103::-;;;;;;:::i;:::-;;:::i;22531:478::-;;;;;;:::i;:::-;;:::i;23469:385::-;;;;;;:::i;:::-;;:::i;23129:99::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;;;;;;;;;23203:8:::1;:17:::0;23129:99::o;18775:83::-;18812:13;18845:5;18838:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;18775:83;:::o;19694:161::-;19769:4;19786:39;14851:10;19809:7;19818:6;19786:8;:39::i;:::-;-1:-1:-1;19843:4:0;19694:161;;;;;:::o;19863:313::-;19961:4;19978:36;19988:6;19996:9;20007:6;19978:9;:36::i;:::-;20025:121;20034:6;14851:10;20056:89;20094:6;20056:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;20056:19:0;;;;;;:11;:19;;;;;;;;14851:10;20056:33;;;;;;;;;;:37;:89::i;:::-;20025:8;:121::i;:::-;-1:-1:-1;20164:4:0;19863:313;;;;;:::o;21930:253::-;21996:7;22035;;22024;:18;;22016:73;;;;-1:-1:-1;;;22016:73:0;;3700:2:1;22016:73:0;;;3682:21:1;3739:2;3719:18;;;3712:30;3778:34;3758:18;;;3751:62;-1:-1:-1;;;3829:18:1;;;3822:40;3879:19;;22016:73:0;3672:232:1;22016:73:0;22100:19;22123:10;:8;:10::i;:::-;22100:33;-1:-1:-1;22151:24:0;:7;22100:33;22151:11;:24::i;:::-;22144:31;21930:253;-1:-1:-1;;;21930:253:0:o;20184:218::-;14851:10;20272:4;20321:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;20321:34:0;;;;;;;;;;20272:4;;20289:83;;20312:7;;20321:50;;20360:10;20321:38;:50::i;21098:378::-;14851:10;21150:14;21199:19;;;:11;:19;;;;;;;;21198:20;21190:77;;;;-1:-1:-1;;;21190:77:0;;8333:2:1;21190:77:0;;;8315:21:1;8372:2;8352:18;;;8345:30;8411:34;8391:18;;;8384:62;-1:-1:-1;;;8462:18:1;;;8455:42;8514:19;;21190:77:0;8305:234:1;21190:77:0;21279:15;21304:19;21315:7;21304:10;:19::i;:::-;-1:-1:-1;;;;;;;;21352:15:0;;;;;;:7;:15;;;;;;21278:45;;-1:-1:-1;21352:28:0;;:15;-1:-1:-1;21278:45:0;;-1:-1:-1;;21352:19:0;:28::i;:::-;-1:-1:-1;;;;;21334:15:0;;;;;;:7;:15;;;;;:46;21401:7;;:20;;21413:7;21401:11;:20::i;:::-;21391:7;:30;21445:10;;:23;;21460:7;21445:14;:23::i;:::-;21432:10;:36;-1:-1:-1;;;21098:378:0:o;21484:438::-;21574:7;21613;;21602;:18;;21594:62;;;;-1:-1:-1;;;21594:62:0;;5989:2:1;21594:62:0;;;5971:21:1;6028:2;6008:18;;;6001:30;6067:33;6047:18;;;6040:61;6118:18;;21594:62:0;5961:181:1;21594:62:0;21672:17;21667:248;;21707:15;21732:19;21743:7;21732:10;:19::i;:::-;-1:-1:-1;21706:45:0;;-1:-1:-1;21766:14:0;;-1:-1:-1;;;;;;21766:14:0;21667:248;21815:23;21847:19;21858:7;21847:10;:19::i;:::-;-1:-1:-1;21813:53:0;;-1:-1:-1;21881:22:0;;-1:-1:-1;;;;;;21881:22:0;23017:104;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;23093:10:::1;:20:::0;;-1:-1:-1;;;;;;23093:20:0::1;-1:-1:-1::0;;;;;23093:20:0;;;::::1;::::0;;;::::1;::::0;;23017:104::o;19162:198::-;-1:-1:-1;;;;;19252:20:0;;19228:7;19252:20;;;:11;:20;;;;;;;;19248:49;;;-1:-1:-1;;;;;;19281:16:0;;;;;:7;:16;;;;;;;19162:198::o;19248:49::-;-1:-1:-1;;;;;19335:16:0;;;;;;:7;:16;;;;;;19315:37;;:19;:37::i;16734:130::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;16829:1:::1;16813:6:::0;;16792:40:::1;::::0;-1:-1:-1;;;;;16813:6:0;;::::1;::::0;16792:40:::1;::::0;16829:1;;16792:40:::1;16856:1;16839:19:::0;;-1:-1:-1;;;;;;16839:19:0::1;::::0;;16734:130::o;18866:87::-;18905:13;18938:7;18931:14;;;;;:::i;20410:269::-;20503:4;20520:129;14851:10;20543:7;20552:96;20591:15;20552:96;;;;;;;;;;;;;;;;;14851:10;20552:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;20552:34:0;;;;;;;;;;;;:38;:96::i;19368:167::-;19446:4;19463:42;14851:10;19487:9;19498:6;19463:9;:42::i;23347:115::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;23429:12:::1;:25:::0;23347:115::o;23236:103::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;23312:9:::1;:19:::0;23236:103::o;22191:332::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22273:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;22272:21;22264:61;;;::::0;-1:-1:-1;;;22264:61:0;;5277:2:1;22264:61:0::1;::::0;::::1;5259:21:1::0;5316:2;5296:18;;;5289:30;5355:29;5335:18;;;5328:57;5402:18;;22264:61:0::1;5249:177:1::0;22264:61:0::1;-1:-1:-1::0;;;;;22339:16:0;::::1;22358:1;22339:16:::0;;;:7:::1;:16;::::0;;;;;:20;22336:108:::1;;-1:-1:-1::0;;;;;22415:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;;22395:37:::1;::::0;:19:::1;:37::i;:::-;-1:-1:-1::0;;;;;22376:16:0;::::1;;::::0;;;:7:::1;:16;::::0;;;;:56;22336:108:::1;-1:-1:-1::0;;;;;22454:20:0::1;;::::0;;;:11:::1;:20;::::0;;;;:27;;-1:-1:-1;;22454:27:0::1;22477:4;22454:27:::0;;::::1;::::0;;;22492:9:::1;:23:::0;;;;::::1;::::0;;;;;;::::1;::::0;;-1:-1:-1;;;;;;22492:23:0::1;::::0;;::::1;::::0;;22191:332::o;17009:103::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;17078:28:::1;17097:8;17078:18;:28::i;:::-;17009:103:::0;:::o;22531:478::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;22612:20:0;::::1;;::::0;;;:11:::1;:20;::::0;;;;;::::1;;22604:60;;;::::0;-1:-1:-1;;;22604:60:0;;5633:2:1;22604:60:0::1;::::0;::::1;5615:21:1::0;5672:2;5652:18;;;5645:30;5711:29;5691:18;;;5684:57;5758:18;;22604:60:0::1;5605:177:1::0;22604:60:0::1;22680:9;22675:327;22699:9;:16:::0;22695:20;::::1;22675:327;;;22757:7;-1:-1:-1::0;;;;;22741:23:0::1;:9;22751:1;22741:12;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;-1:-1:-1;;;;;22741:12:0::1;:23;22737:254;;;22800:9;22810:16:::0;;:20:::1;::::0;22829:1:::1;::::0;22810:20:::1;:::i;:::-;22800:31;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;22785:9:::1;:12:::0;;-1:-1:-1;;;;;22800:31:0;;::::1;::::0;22795:1;;22785:12;::::1;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;;::::1;:46:::0;;-1:-1:-1;;;;;;22785:46:0::1;-1:-1:-1::0;;;;;22785:46:0;;::::1;;::::0;;22850:16;;::::1;::::0;;:7:::1;:16:::0;;;;;;:20;;;22889:11:::1;:20:::0;;;;:28;;-1:-1:-1;;22889:28:0::1;::::0;;22936:9:::1;:15:::0;;;::::1;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;-1:-1:-1;;22936:15:0;;;;;-1:-1:-1;;;;;;22936:15:0::1;::::0;;;;;22675:327:::1;22531:478:::0;:::o;22737:254::-:1;22717:3:::0;::::1;::::0;::::1;:::i;:::-;;;;22675:327;;;;22531:478:::0;:::o;23469:385::-;16326:6;;-1:-1:-1;;;;;16326:6:0;14851:10;16326:22;16318:67;;;;-1:-1:-1;;;16318:67:0;;;;;;;:::i;:::-;23586:3:::1;23577:6;:12;:30;;;;;23604:3;23593:8;:14;23577:30;:51;;;;;23625:3;23611:11;:17;23577:51;23569:60;;;::::0;::::1;;23651:12;:6:::0;23660:3:::1;23651:12;:::i;:::-;23640:8;:23:::0;23686:14:::1;:8:::0;23697:3:::1;23686:14;:::i;:::-;23674:9;:26:::0;23724:17:::1;:11:::0;23738:3:::1;23724:17;:::i;:::-;23709:12;:32:::0;;;23765:8:::1;::::0;23750:12:::1;:23:::0;23798:9:::1;::::0;23782:13:::1;:25:::0;23816:16:::1;:31:::0;-1:-1:-1;;;23469:385:0:o;23862:337::-;-1:-1:-1;;;;;23955:19:0;;23947:68;;;;-1:-1:-1;;;23947:68:0;;7928:2:1;23947:68:0;;;7910:21:1;7967:2;7947:18;;;7940:30;8006:34;7986:18;;;7979:62;-1:-1:-1;;;8057:18:1;;;8050:34;8101:19;;23947:68:0;7900:226:1;23947:68:0;-1:-1:-1;;;;;24034:21:0;;24026:68;;;;-1:-1:-1;;;24026:68:0;;4518:2:1;24026:68:0;;;4500:21:1;4557:2;4537:18;;;4530:30;4596:34;4576:18;;;4569:62;-1:-1:-1;;;4647:18:1;;;4640:32;4689:19;;24026:68:0;4490:224:1;24026:68:0;-1:-1:-1;;;;;24107:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;24159:32;;8690:25:1;;;24159:32:0;;8663:18:1;24159:32:0;;;;;;;23862:337;;;:::o;24207:1268::-;-1:-1:-1;;;;;24304:20:0;;24296:70;;;;-1:-1:-1;;;24296:70:0;;7522:2:1;24296:70:0;;;7504:21:1;7561:2;7541:18;;;7534:30;7600:34;7580:18;;;7573:62;-1:-1:-1;;;7651:18:1;;;7644:35;7696:19;;24296:70:0;7494:227:1;24296:70:0;-1:-1:-1;;;;;24385:23:0;;24377:71;;;;-1:-1:-1;;;24377:71:0;;3296:2:1;24377:71:0;;;3278:21:1;3335:2;3315:18;;;3308:30;3374:34;3354:18;;;3347:62;-1:-1:-1;;;3425:18:1;;;3418:33;3468:19;;24377:71:0;3268:225:1;24377:71:0;24476:1;24467:6;:10;24459:64;;;;-1:-1:-1;;;24459:64:0;;7112:2:1;24459:64:0;;;7094:21:1;7151:2;7131:18;;;7124:30;7190:34;7170:18;;;7163:62;-1:-1:-1;;;7241:18:1;;;7234:39;7290:19;;24459:64:0;7084:231:1;24459:64:0;24659:10;;24640:4;;-1:-1:-1;;;;;24659:20:0;;;:10;;:20;;:47;;-1:-1:-1;24683:10:0;;-1:-1:-1;;;;;24683:23:0;;;:10;;:23;24659:47;:73;;;-1:-1:-1;;;;;;24710:22:0;;;;;;:11;:22;;;;;;;;24659:73;24655:121;;;-1:-1:-1;24759:5:0;24655:121;24793:7;24788:28;;24802:14;:12;:14::i;:::-;-1:-1:-1;;;;;24833:19:0;;;;;;:11;:19;;;;;;;;:46;;;;-1:-1:-1;;;;;;24857:22:0;;;;;;:11;:22;;;;;;;;24856:23;24833:46;24829:597;;;24896:48;24918:6;24926:9;24937:6;24896:21;:48::i;:::-;24829:597;;;-1:-1:-1;;;;;24967:19:0;;;;;;:11;:19;;;;;;;;24966:20;:46;;;;-1:-1:-1;;;;;;24990:22:0;;;;;;:11;:22;;;;;;;;24966:46;24962:464;;;25029:46;25049:6;25057:9;25068:6;25029:19;:46::i;24962:464::-;-1:-1:-1;;;;;25098:19:0;;;;;;:11;:19;;;;;;;;25097:20;:47;;;;-1:-1:-1;;;;;;25122:22:0;;;;;;:11;:22;;;;;;;;25121:23;25097:47;25093:333;;;25161:44;25179:6;25187:9;25198:6;25161:17;:44::i;25093:333::-;-1:-1:-1;;;;;25227:19:0;;;;;;:11;:19;;;;;;;;:45;;;;-1:-1:-1;;;;;;25250:22:0;;;;;;:11;:22;;;;;;;;25227:45;25223:203;;;25289:48;25311:6;25319:9;25330:6;25289:21;:48::i;25223:203::-;25370:44;25388:6;25396:9;25407:6;25370:17;:44::i;:::-;25443:7;25438:29;;25452:15;33151:12;;33140:8;:23;33186:13;;33174:9;:25;33225:16;;33210:12;:31;33096:153;25452:15;24285:1190;24207:1268;;;:::o;4518:192::-;4604:7;4640:12;4632:6;;;;4624:29;;;;-1:-1:-1;;;4624:29:0;;;;;;;;:::i;:::-;-1:-1:-1;4664:9:0;4676:5;4680:1;4676;:5;:::i;:::-;4664:17;4518:192;-1:-1:-1;;;;;4518:192:0:o;31684:163::-;31725:7;31746:15;31763;31782:19;:17;:19::i;:::-;31745:56;;-1:-1:-1;31745:56:0;-1:-1:-1;31819:20:0;31745:56;;31819:11;:20::i;:::-;31812:27;;;;31684:163;:::o;5916:132::-;5974:7;6001:39;6005:1;6008;6001:39;;;;;;;;;;;;;;;;;:3;:39::i;3615:181::-;3673:7;;3705:5;3709:1;3705;:5;:::i;:::-;3693:17;;3734:1;3729;:6;;3721:46;;;;-1:-1:-1;;;3721:46:0;;4921:2:1;3721:46:0;;;4903:21:1;4960:2;4940:18;;;4933:30;4999:29;4979:18;;;4972:57;5046:18;;3721:46:0;4893:177:1;29751:652:0;29810:7;29819;29828;29837;29846;29855;29864;29885:12;29899:13;29914:16;29934:55;29946:7;29955:8;;29965:9;;29976:12;;29934:11;:55::i;:::-;29884:105;;;;;;30000:23;30026:50;30045:7;30054:4;30060:5;30067:8;30026:18;:50::i;:::-;30000:76;;30087:19;30110:10;:8;:10::i;:::-;30087:33;;30132:15;30149:12;30165:39;30177:7;30186:4;30192:11;30165;:39::i;:::-;30131:73;;;;30215:23;30241:64;30261:7;30270:4;30276:5;30283:8;30293:11;30241:19;:64::i;:::-;30324:7;;-1:-1:-1;30215:90:0;;-1:-1:-1;30350:4:0;-1:-1:-1;30356:15:0;;-1:-1:-1;30373:4:0;;-1:-1:-1;30379:5:0;;-1:-1:-1;30386:8:0;-1:-1:-1;;;29751:652:0;;;;;;;;;:::o;4079:136::-;4137:7;4164:43;4168:1;4171;4164:43;;;;;;;;;;;;;;;;;:3;:43::i;17210:217::-;-1:-1:-1;;;;;17280:22:0;;17272:73;;;;-1:-1:-1;;;17272:73:0;;4111:2:1;17272:73:0;;;4093:21:1;4150:2;4130:18;;;4123:30;4189:34;4169:18;;;4162:62;-1:-1:-1;;;4240:18:1;;;4233:36;4286:19;;17272:73:0;4083:228:1;17272:73:0;17378:6;;;17357:38;;-1:-1:-1;;;;;17357:38:0;;;;17378:6;;;17357:38;;;17402:6;:17;;-1:-1:-1;;;;;;17402:17:0;-1:-1:-1;;;;;17402:17:0;;;;;;;;;;17210:217::o;32784:304::-;32830:8;;:13;:31;;;;-1:-1:-1;32847:9:0;;:14;32830:31;:52;;;;-1:-1:-1;32865:12:0;;:17;32830:52;32827:64;;;32784:304::o;32827:64::-;32918:8;;;32903:12;:23;32953:9;;;32937:13;:25;32992:12;;;32973:16;:31;-1:-1:-1;33017:12:0;;;;33040:13;;;;33064:16;32784:304::o;27332:606::-;27434:19;27457:10;:8;:10::i;:::-;27434:33;;27479:15;27496:23;27521:12;27535:23;27560:12;27574:13;27589:16;27609:19;27620:7;27609:10;:19::i;:::-;27478:150;;;;;;;;;;;;;;27639:13;27656:22;27666:11;27656:5;:9;;:22;;;;:::i;:::-;27639:39;;27689:80;27716:6;27724:9;27735:7;27744;27753:15;27689:26;:80::i;:::-;27780:32;27795:8;27805:6;27780:14;:32::i;:::-;27823:47;27835:4;27841:5;27848:4;27854:5;27861:8;27823:11;:47::i;:::-;27903:9;-1:-1:-1;;;;;27886:44:0;27895:6;-1:-1:-1;;;;;27886:44:0;;27914:15;27886:44;;;;8690:25:1;;8678:2;8663:18;;8645:76;27886:44:0;;;;;;;;27423:515;;;;;;;;;27332:606;;;:::o;26345:614::-;26445:19;26468:10;:8;:10::i;:::-;26445:33;;26490:15;26507:23;26532:12;26546:23;26571:12;26585:13;26600:16;26620:19;26631:7;26620:10;:19::i;:::-;26489:150;;;;;;;;;;;;;;26650:13;26667:22;26677:11;26667:5;:9;;:22;;;;:::i;:::-;26650:39;;26700:90;26729:6;26737:9;26748:15;26765:7;26774:15;26700:28;:90::i;25483:591::-;25581:19;25604:10;:8;:10::i;:::-;25581:33;;25626:15;25643:23;25668:12;25682:23;25707:12;25721:13;25736:16;25756:19;25767:7;25756:10;:19::i;:::-;25625:150;;;;;;;;;;;;;;25786:13;25803:22;25813:11;25803:5;:9;;:22;;;;:::i;:::-;25786:39;;25836:69;25861:6;25869:9;25880:7;25889:15;25836:24;:69::i;28285:617::-;28387:19;28410:10;:8;:10::i;:::-;28387:33;;28432:15;28449:23;28474:12;28488:23;28513:12;28527:13;28542:16;28562:19;28573:7;28562:10;:19::i;:::-;28431:150;;;;;;;;;;;;;;28592:13;28609:22;28619:11;28609:5;:9;;:22;;;;:::i;:::-;28592:39;;28642:91;28663:6;28671:9;28682:7;28691;28700:15;28717;28642:20;:91::i;31855:555::-;31952:7;;31988;;31905;;;;;32006:289;32030:9;:16;32026:20;;32006:289;;;32096:7;32072;:21;32080:9;32090:1;32080:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;32080:12:0;32072:21;;;;;;;;;;;;;:31;;:66;;;32131:7;32107;:21;32115:9;32125:1;32115:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;32115:12:0;32107:21;;;;;;;;;;;;;:31;32072:66;32068:97;;;32148:7;;32157;;32140:25;;;;;;;31855:555;;:::o;32068:97::-;32190:34;32202:7;:21;32210:9;32220:1;32210:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;32210:12:0;32202:21;;;;;;;;;;;;;32190:7;;:11;:34::i;:::-;32180:44;;32249:34;32261:7;:21;32269:9;32279:1;32269:12;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;32269:12:0;32261:21;;;;;;;;;;;;;32249:7;;:11;:34::i;:::-;32239:44;-1:-1:-1;32048:3:0;;;;:::i;:::-;;;;32006:289;;;-1:-1:-1;32331:7:0;;32319;;:20;;:11;:20::i;:::-;32309:7;:30;32305:61;;;32349:7;;32358;;32341:25;;;;;;31855:555;;:::o;32305:61::-;32385:7;;32394;;-1:-1:-1;31855:555:0;-1:-1:-1;31855:555:0:o;6544:278::-;6630:7;6665:12;6658:5;6650:28;;;;-1:-1:-1;;;6650:28:0;;;;;;;;:::i;:::-;-1:-1:-1;6689:9:0;6701:5;6705:1;6701;:5;:::i;30411:427::-;30524:7;30533;30542;30562:12;30577:50;30623:3;30578:39;30604:12;;30579:19;30591:6;30579:7;:11;;:19;;;;:::i;:::-;30578:25;;:39::i;30577:50::-;30562:65;;30638:13;30654:51;30701:3;30655:40;30682:12;;30656:20;30668:7;30656;:11;;:20;;;;:::i;30654:51::-;30638:67;;30716:16;30735:54;30785:3;30736:43;30766:12;;30737:23;30749:10;30737:7;:11;;:23;;;;:::i;30735:54::-;30808:4;;30814:5;;-1:-1:-1;30808:4:0;;-1:-1:-1;30411:427:0;-1:-1:-1;;;;;;30411:427:0:o;30846:191::-;30960:7;30987:42;31020:8;30987:28;31009:5;30987:28;:7;30999:4;30987:11;:17::i;:::-;:21;;:28::i;31045:254::-;31140:7;;;31187:24;:7;31199:11;31187;:24::i;:::-;31169:42;-1:-1:-1;31222:12:0;31237:21;:4;31246:11;31237:8;:21::i;:::-;31277:7;;;;-1:-1:-1;31045:254:0;;-1:-1:-1;;;;;31045:254:0:o;31307:369::-;31443:7;;31479:22;:5;31489:11;31479:9;:22::i;:::-;31463:38;-1:-1:-1;31512:16:0;31531:25;:8;31544:11;31531:12;:25::i;:::-;31512:44;-1:-1:-1;31567:23:0;31593:42;31512:44;31593:28;31615:5;31593:28;:7;31605:4;31593:11;:17::i;:42::-;31567:68;31307:369;-1:-1:-1;;;;;;;;;31307:369:0:o;4969:471::-;5027:7;5272:6;5268:47;;-1:-1:-1;5302:1:0;5295:8;;5268:47;5327:9;5339:5;5343:1;5339;:5;:::i;:::-;5327:17;-1:-1:-1;5372:1:0;5363:5;5367:1;5327:17;5363:5;:::i;:::-;:10;5355:56;;;;-1:-1:-1;;;5355:56:0;;6349:2:1;5355:56:0;;;6331:21:1;6388:2;6368:18;;;6361:30;6427:34;6407:18;;;6400:62;-1:-1:-1;;;6478:18:1;;;6471:31;6519:19;;5355:56:0;6321:223:1;27946:331:0;-1:-1:-1;;;;;28113:15:0;;;;;;:7;:15;;;;;;:28;;28133:7;28113:19;:28::i;:::-;-1:-1:-1;;;;;28095:15:0;;;;;;:7;:15;;;;;;;;:46;;;;28170:7;:15;;;;:28;;28190:7;28170:19;:28::i;:::-;-1:-1:-1;;;;;28152:15:0;;;;;;;:7;:15;;;;;;:46;;;;28230:18;;;;;;;:39;;28253:15;28230:22;:39::i;:::-;-1:-1:-1;;;;;28209:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;;27946:331:0:o;32418:358::-;32495:19;32517:10;:8;:10::i;:::-;32495:32;-1:-1:-1;32538:16:0;32557:25;:8;32495:32;32557:12;:25::i;:::-;32623:10;;-1:-1:-1;;;;;32623:10:0;32615:19;;;;:7;:19;;;;;;32538:44;;-1:-1:-1;32615:33:0;;32538:44;32615:23;:33::i;:::-;32601:10;;;-1:-1:-1;;;;;32601:10:0;;;32593:19;;;;:7;:19;;;;;;;;:55;;;;32689:10;;;;;32681:19;;:7;:19;;;;;:33;;32705:8;32681:23;:33::i;:::-;32667:10;;;-1:-1:-1;;;;;32667:10:0;;;32659:19;;;;:7;:19;;;;;;;;;:55;;;;32747:10;;32730:38;;8690:25:1;;;32747:10:0;;;;32730:38;;;;;;8663:18:1;32730:38:0;;;;;;;32484:292;;32418:358;;:::o;29339:404::-;29465:28;29487:5;29465:17;29477:4;29465:7;;:11;;:17;;;;:::i;:28::-;29455:7;:38;29517:10;;:20;;29532:4;29517:14;:20::i;:::-;29504:10;:33;29562:11;;:22;;29578:5;29562:15;:22::i;:::-;29548:11;:36;29612:14;;:28;;29631:8;29612:18;:28::i;:::-;29595:14;:45;29661:7;;:18;;29673:5;29661:11;:18::i;:::-;29651:7;:28;29693:42;;8690:25:1;;;29725:1:0;;29710:4;;29693:42;;8678:2:1;8663:18;29693:42:0;;;;;;;29339:404;;;;;:::o;26967:355::-;-1:-1:-1;;;;;27144:15:0;;;;;;:7;:15;;;;;;:28;;27164:7;27144:19;:28::i;:::-;-1:-1:-1;;;;;27126:15:0;;;;;;;:7;:15;;;;;;;;:46;;;;27204:18;;;;;:7;:18;;;;;:39;;27227:15;27204:22;:39::i;:::-;-1:-1:-1;;;;;27183:18:0;;;;;;:7;:18;;;;;;;;:60;;;;27275:7;:18;;;;:39;;27298:15;27275:22;:39::i;26082:255::-;-1:-1:-1;;;;;26230:15:0;;;;;;:7;:15;;;;;;:28;;26250:7;26230:19;:28::i;:::-;-1:-1:-1;;;;;26212:15:0;;;;;;;:7;:15;;;;;;:46;;;;26290:18;;;;;;;:39;;26313:15;26290:22;:39::i;:::-;-1:-1:-1;;;;;26269:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;26082:255:0:o;28910:421::-;-1:-1:-1;;;;;29096:15:0;;;;;;:7;:15;;;;;;:28;;29116:7;29096:19;:28::i;:::-;-1:-1:-1;;;;;29078:15:0;;;;;;:7;:15;;;;;;;;:46;;;;29153:7;:15;;;;:28;;29173:7;29153:19;:28::i;:::-;-1:-1:-1;;;;;29135:15:0;;;;;;;:7;:15;;;;;;;;:46;;;;29213:18;;;;;:7;:18;;;;;:39;;29236:15;29213:22;:39::i;:::-;-1:-1:-1;;;;;29192:18:0;;;;;;:7;:18;;;;;;;;:60;;;;29284:7;:18;;;;:39;;29307:15;29284:22;:39::i;:::-;-1:-1:-1;;;;;29263:18:0;;;;;;;:7;:18;;;;;:60;;;;-1:-1:-1;;;;;28910:421:0:o;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:2;;177:1;174;167:12;111:2;63:124;;;:::o;192:186::-;251:6;304:2;292:9;283:7;279:23;275:32;272:2;;;320:1;317;310:12;272:2;343:29;362:9;343:29;:::i;383:260::-;451:6;459;512:2;500:9;491:7;487:23;483:32;480:2;;;528:1;525;518:12;480:2;551:29;570:9;551:29;:::i;:::-;541:39;;599:38;633:2;622:9;618:18;599:38;:::i;:::-;589:48;;470:173;;;;;:::o;648:328::-;725:6;733;741;794:2;782:9;773:7;769:23;765:32;762:2;;;810:1;807;800:12;762:2;833:29;852:9;833:29;:::i;:::-;823:39;;881:38;915:2;904:9;900:18;881:38;:::i;:::-;871:48;;966:2;955:9;951:18;938:32;928:42;;752:224;;;;;:::o;981:254::-;1049:6;1057;1110:2;1098:9;1089:7;1085:23;1081:32;1078:2;;;1126:1;1123;1116:12;1078:2;1149:29;1168:9;1149:29;:::i;:::-;1139:39;1225:2;1210:18;;;;1197:32;;-1:-1:-1;;;1068:167:1:o;1240:180::-;1299:6;1352:2;1340:9;1331:7;1327:23;1323:32;1320:2;;;1368:1;1365;1358:12;1320:2;-1:-1:-1;1391:23:1;;1310:110;-1:-1:-1;1310:110:1:o;1425:341::-;1490:6;1498;1551:2;1539:9;1530:7;1526:23;1522:32;1519:2;;;1567:1;1564;1557:12;1519:2;1603:9;1590:23;1580:33;;1663:2;1652:9;1648:18;1635:32;1710:5;1703:13;1696:21;1689:5;1686:32;1676:2;;1732:1;1729;1722:12;1676:2;1755:5;1745:15;;;1509:257;;;;;:::o;1771:316::-;1848:6;1856;1864;1917:2;1905:9;1896:7;1892:23;1888:32;1885:2;;;1933:1;1930;1923:12;1885:2;-1:-1:-1;;1956:23:1;;;2026:2;2011:18;;1998:32;;-1:-1:-1;2077:2:1;2062:18;;;2049:32;;1875:212;-1:-1:-1;1875:212:1:o;2492:597::-;2604:4;2633:2;2662;2651:9;2644:21;2694:6;2688:13;2737:6;2732:2;2721:9;2717:18;2710:34;2762:1;2772:140;2786:6;2783:1;2780:13;2772:140;;;2881:14;;;2877:23;;2871:30;2847:17;;;2866:2;2843:26;2836:66;2801:10;;2772:140;;;2930:6;2927:1;2924:13;2921:2;;;3000:1;2995:2;2986:6;2975:9;2971:22;2967:31;2960:42;2921:2;-1:-1:-1;3073:2:1;3052:15;-1:-1:-1;;3048:29:1;3033:45;;;;3080:2;3029:54;;2613:476;-1:-1:-1;;;2613:476:1:o;6549:356::-;6751:2;6733:21;;;6770:18;;;6763:30;6829:34;6824:2;6809:18;;6802:62;6896:2;6881:18;;6723:182::o;8915:128::-;8955:3;8986:1;8982:6;8979:1;8976:13;8973:2;;;8992:18;;:::i;:::-;-1:-1:-1;9028:9:1;;8963:80::o;9048:217::-;9088:1;9114;9104:2;;9158:10;9153:3;9149:20;9146:1;9139:31;9193:4;9190:1;9183:15;9221:4;9218:1;9211:15;9104:2;-1:-1:-1;9250:9:1;;9094:171::o;9270:168::-;9310:7;9376:1;9372;9368:6;9364:14;9361:1;9358:21;9353:1;9346:9;9339:17;9335:45;9332:2;;;9383:18;;:::i;:::-;-1:-1:-1;9423:9:1;;9322:116::o;9443:125::-;9483:4;9511:1;9508;9505:8;9502:2;;;9516:18;;:::i;:::-;-1:-1:-1;9553:9:1;;9492:76::o;9573:380::-;9652:1;9648:12;;;;9695;;;9716:2;;9770:4;9762:6;9758:17;9748:27;;9716:2;9823;9815:6;9812:14;9792:18;9789:38;9786:2;;;9869:10;9864:3;9860:20;9857:1;9850:31;9904:4;9901:1;9894:15;9932:4;9929:1;9922:15;9786:2;;9628:325;;;:::o;9958:135::-;9997:3;-1:-1:-1;;10018:17:1;;10015:2;;;10038:18;;:::i;:::-;-1:-1:-1;10085:1:1;10074:13;;10005:88::o;10098:127::-;10159:10;10154:3;10150:20;10147:1;10140:31;10190:4;10187:1;10180:15;10214:4;10211:1;10204:15;10230:127;10291:10;10286:3;10282:20;10279:1;10272:31;10322:4;10319:1;10312:15;10346:4;10343:1;10336:15;10362:127;10423:10;10418:3;10414:20;10411:1;10404:31;10454:4;10451:1;10444:15;10478:4;10475:1;10468:15

Swarm Source

ipfs://3c3dee7c097c8faf3d64399675358e4e3b924ab36e04730a21625c7f9ee0afd1

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.