ETH Price: $2,441.68 (-0.36%)

Transaction Decoder

Block:
17077570 at Apr-19-2023 02:01:59 AM +UTC
Transaction Fee:
0.009692310455203488 ETH $23.67
Gas Used:
207,968 Gas / 46.604816391 Gwei

Emitted Events:

183 0x47bcd03a0b66a9d01f4c4db709b8debb462900e6.0xcaab7ec5b2cc3b2c5624a3ee2d5d1e5bb716dd5685f921d7a7a97e0fa1b43051( 0xcaab7ec5b2cc3b2c5624a3ee2d5d1e5bb716dd5685f921d7a7a97e0fa1b43051, 0x000000000000000000000000821f7bf86e9f339f53d5dfabf9071931c949c10b, 0000000000000000000000000000000000000000000000000000000000000031 )
184 FluffyToken.Transfer( from=[Receiver] 0x9820f7784b674d27076d75e3a7e35efaf2f7917e, to=[Sender] 0x821f7bf86e9f339f53d5dfabf9071931c949c10b, value=880000000000000000000 )
185 0x9820f7784b674d27076d75e3a7e35efaf2f7917e.0xf279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568( 0xf279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568, 0x000000000000000000000000821f7bf86e9f339f53d5dfabf9071931c949c10b, 00000000000000000000000000000000000000000000037252dfd60e61d00000, 00000000000000000000000000000000000000000000003635c9adc5dea00000 )
186 FluffyToken.Transfer( from=[Receiver] 0x9820f7784b674d27076d75e3a7e35efaf2f7917e, to=0xcC17168Dc4f0051C7Bd5651D4936914Ae43cD946, value=60000000000000000000 )

Account State Difference:

  Address   Before After State Difference Code
0x47BCD03A...B462900e6
0x821F7bf8...1C949c10B
1.92785224498456059 Eth
Nonce: 709
1.918159934529357102 Eth
Nonce: 710
0.009692310455203488
0x9820f778...af2f7917e
(Fee Recipient: 0xa2...91F)
3.438865274882151078 Eth3.438886071682151078 Eth0.0000207968
0xc2a2E9B8...d5cB14c31
0xcC17168D...Ae43cD946

Execution Trace

0x9820f7784b674d27076d75e3a7e35efaf2f7917e.c9d10992( )
  • 0xcb06cf89bb4876c354a5ddd4db74ff03f3e998fe.c9d10992( )
    • 0x47bcd03a0b66a9d01f4c4db709b8debb462900e6.ed8eda6d( )
      • 0x1fb0c4deac032df07021ddcdc0f09740ce53047d.ed8eda6d( )
        • FluffyToken.isFluffyContract( 0x9820f7784B674D27076d75e3a7e35Efaf2f7917e ) => ( True )
        • Null: 0x000...001.c83db2a6( )
        • FluffyToken.transfer( to=0x821F7bf86E9f339F53d5dfABF9071931C949c10B, amount=880000000000000000000 ) => ( True )
        • FluffyToken.transfer( to=0xcC17168Dc4f0051C7Bd5651D4936914Ae43cD946, amount=60000000000000000000 ) => ( True )
        • 0xcc17168dc4f0051c7bd5651d4936914ae43cd946.eb661179( )
          • 0x8613eb60337b4e4880ed14249f48c136a00b4245.eb661179( )
            • FluffyToken.isFluffyContract( 0x9820f7784B674D27076d75e3a7e35Efaf2f7917e ) => ( True )
            • FluffyToken.balanceOf( account=0xA0365B9A26D0f4bc773848F6c94190084ec8183d ) => ( 316800000000000000000 )
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)
              pragma solidity ^0.8.0;
              import "../utils/Context.sol";
              /**
               * @dev Contract module which provides a basic access control mechanism, where
               * there is an account (an owner) that can be granted exclusive access to
               * specific functions.
               *
               * By default, the owner account will be the one that deploys the contract. This
               * can later be changed with {transferOwnership}.
               *
               * This module is used through inheritance. It will make available the modifier
               * `onlyOwner`, which can be applied to your functions to restrict their use to
               * the owner.
               */
              abstract contract Ownable is Context {
                  address private _owner;
                  event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
                  /**
                   * @dev Initializes the contract setting the deployer as the initial owner.
                   */
                  constructor() {
                      _transferOwnership(_msgSender());
                  }
                  /**
                   * @dev Throws if called by any account other than the owner.
                   */
                  modifier onlyOwner() {
                      _checkOwner();
                      _;
                  }
                  /**
                   * @dev Returns the address of the current owner.
                   */
                  function owner() public view virtual returns (address) {
                      return _owner;
                  }
                  /**
                   * @dev Throws if the sender is not the owner.
                   */
                  function _checkOwner() internal view virtual {
                      require(owner() == _msgSender(), "Ownable: caller is not the owner");
                  }
                  /**
                   * @dev Leaves the contract without owner. It will not be possible to call
                   * `onlyOwner` functions anymore. Can only be called by the current owner.
                   *
                   * NOTE: Renouncing ownership will leave the contract without an owner,
                   * thereby removing any functionality that is only available to the owner.
                   */
                  function renounceOwnership() public virtual onlyOwner {
                      _transferOwnership(address(0));
                  }
                  /**
                   * @dev Transfers ownership of the contract to a new account (`newOwner`).
                   * Can only be called by the current owner.
                   */
                  function transferOwnership(address newOwner) public virtual onlyOwner {
                      require(newOwner != address(0), "Ownable: new owner is the zero address");
                      _transferOwnership(newOwner);
                  }
                  /**
                   * @dev Transfers ownership of the contract to a new account (`newOwner`).
                   * Internal function without access restriction.
                   */
                  function _transferOwnership(address newOwner) internal virtual {
                      address oldOwner = _owner;
                      _owner = newOwner;
                      emit OwnershipTransferred(oldOwner, newOwner);
                  }
              }
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts (last updated v4.8.0) (token/ERC20/ERC20.sol)
              pragma solidity ^0.8.0;
              import "./IERC20.sol";
              import "./extensions/IERC20Metadata.sol";
              import "../../utils/Context.sol";
              /**
               * @dev Implementation of the {IERC20} interface.
               *
               * This implementation is agnostic to the way tokens are created. This means
               * that a supply mechanism has to be added in a derived contract using {_mint}.
               * For a generic mechanism see {ERC20PresetMinterPauser}.
               *
               * TIP: For a detailed writeup see our guide
               * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
               * to implement supply mechanisms].
               *
               * We have followed general OpenZeppelin Contracts guidelines: functions revert
               * instead returning `false` on failure. This behavior is nonetheless
               * conventional and does not conflict with the expectations of ERC20
               * applications.
               *
               * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
               * This allows applications to reconstruct the allowance for all accounts just
               * by listening to said events. Other implementations of the EIP may not emit
               * these events, as it isn't required by the specification.
               *
               * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
               * functions have been added to mitigate the well-known issues around setting
               * allowances. See {IERC20-approve}.
               */
              contract ERC20 is Context, IERC20, IERC20Metadata {
                  mapping(address => uint256) private _balances;
                  mapping(address => mapping(address => uint256)) private _allowances;
                  uint256 private _totalSupply;
                  string private _name;
                  string private _symbol;
                  /**
                   * @dev Sets the values for {name} and {symbol}.
                   *
                   * The default value of {decimals} is 18. To select a different value for
                   * {decimals} you should overload it.
                   *
                   * All two of these values are immutable: they can only be set once during
                   * construction.
                   */
                  constructor(string memory name_, string memory symbol_) {
                      _name = name_;
                      _symbol = symbol_;
                  }
                  /**
                   * @dev Returns the name of the token.
                   */
                  function name() public view virtual override returns (string memory) {
                      return _name;
                  }
                  /**
                   * @dev Returns the symbol of the token, usually a shorter version of the
                   * name.
                   */
                  function symbol() public view virtual override returns (string memory) {
                      return _symbol;
                  }
                  /**
                   * @dev Returns the number of decimals used to get its user representation.
                   * For example, if `decimals` equals `2`, a balance of `505` tokens should
                   * be displayed to a user as `5.05` (`505 / 10 ** 2`).
                   *
                   * Tokens usually opt for a value of 18, imitating the relationship between
                   * Ether and Wei. This is the value {ERC20} uses, unless this function is
                   * overridden;
                   *
                   * NOTE: This information is only used for _display_ purposes: it in
                   * no way affects any of the arithmetic of the contract, including
                   * {IERC20-balanceOf} and {IERC20-transfer}.
                   */
                  function decimals() public view virtual override returns (uint8) {
                      return 18;
                  }
                  /**
                   * @dev See {IERC20-totalSupply}.
                   */
                  function totalSupply() public view virtual override returns (uint256) {
                      return _totalSupply;
                  }
                  /**
                   * @dev See {IERC20-balanceOf}.
                   */
                  function balanceOf(address account) public view virtual override returns (uint256) {
                      return _balances[account];
                  }
                  /**
                   * @dev See {IERC20-transfer}.
                   *
                   * Requirements:
                   *
                   * - `to` cannot be the zero address.
                   * - the caller must have a balance of at least `amount`.
                   */
                  function transfer(address to, uint256 amount) public virtual override returns (bool) {
                      address owner = _msgSender();
                      _transfer(owner, to, amount);
                      return true;
                  }
                  /**
                   * @dev See {IERC20-allowance}.
                   */
                  function allowance(address owner, address spender) public view virtual override returns (uint256) {
                      return _allowances[owner][spender];
                  }
                  /**
                   * @dev See {IERC20-approve}.
                   *
                   * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
                   * `transferFrom`. This is semantically equivalent to an infinite approval.
                   *
                   * Requirements:
                   *
                   * - `spender` cannot be the zero address.
                   */
                  function approve(address spender, uint256 amount) public virtual override returns (bool) {
                      address owner = _msgSender();
                      _approve(owner, spender, amount);
                      return true;
                  }
                  /**
                   * @dev See {IERC20-transferFrom}.
                   *
                   * Emits an {Approval} event indicating the updated allowance. This is not
                   * required by the EIP. See the note at the beginning of {ERC20}.
                   *
                   * NOTE: Does not update the allowance if the current allowance
                   * is the maximum `uint256`.
                   *
                   * Requirements:
                   *
                   * - `from` and `to` cannot be the zero address.
                   * - `from` must have a balance of at least `amount`.
                   * - the caller must have allowance for ``from``'s tokens of at least
                   * `amount`.
                   */
                  function transferFrom(
                      address from,
                      address to,
                      uint256 amount
                  ) public virtual override returns (bool) {
                      address spender = _msgSender();
                      _spendAllowance(from, spender, amount);
                      _transfer(from, to, amount);
                      return true;
                  }
                  /**
                   * @dev Atomically increases the allowance granted to `spender` by the caller.
                   *
                   * This is an alternative to {approve} that can be used as a mitigation for
                   * problems described in {IERC20-approve}.
                   *
                   * Emits an {Approval} event indicating the updated allowance.
                   *
                   * Requirements:
                   *
                   * - `spender` cannot be the zero address.
                   */
                  function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
                      address owner = _msgSender();
                      _approve(owner, spender, allowance(owner, spender) + addedValue);
                      return true;
                  }
                  /**
                   * @dev Atomically decreases the allowance granted to `spender` by the caller.
                   *
                   * This is an alternative to {approve} that can be used as a mitigation for
                   * problems described in {IERC20-approve}.
                   *
                   * Emits an {Approval} event indicating the updated allowance.
                   *
                   * Requirements:
                   *
                   * - `spender` cannot be the zero address.
                   * - `spender` must have allowance for the caller of at least
                   * `subtractedValue`.
                   */
                  function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
                      address owner = _msgSender();
                      uint256 currentAllowance = allowance(owner, spender);
                      require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
                      unchecked {
                          _approve(owner, spender, currentAllowance - subtractedValue);
                      }
                      return true;
                  }
                  /**
                   * @dev Moves `amount` of tokens from `from` to `to`.
                   *
                   * This internal function is equivalent to {transfer}, and can be used to
                   * e.g. implement automatic token fees, slashing mechanisms, etc.
                   *
                   * Emits a {Transfer} event.
                   *
                   * Requirements:
                   *
                   * - `from` cannot be the zero address.
                   * - `to` cannot be the zero address.
                   * - `from` must have a balance of at least `amount`.
                   */
                  function _transfer(
                      address from,
                      address to,
                      uint256 amount
                  ) internal virtual {
                      require(from != address(0), "ERC20: transfer from the zero address");
                      require(to != address(0), "ERC20: transfer to the zero address");
                      _beforeTokenTransfer(from, to, amount);
                      uint256 fromBalance = _balances[from];
                      require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
                      unchecked {
                          _balances[from] = fromBalance - amount;
                          // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
                          // decrementing then incrementing.
                          _balances[to] += amount;
                      }
                      emit Transfer(from, to, amount);
                      _afterTokenTransfer(from, to, amount);
                  }
                  /** @dev Creates `amount` tokens and assigns them to `account`, increasing
                   * the total supply.
                   *
                   * Emits a {Transfer} event with `from` set to the zero address.
                   *
                   * Requirements:
                   *
                   * - `account` cannot be the zero address.
                   */
                  function _mint(address account, uint256 amount) internal virtual {
                      require(account != address(0), "ERC20: mint to the zero address");
                      _beforeTokenTransfer(address(0), account, amount);
                      _totalSupply += amount;
                      unchecked {
                          // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
                          _balances[account] += amount;
                      }
                      emit Transfer(address(0), account, amount);
                      _afterTokenTransfer(address(0), account, amount);
                  }
                  /**
                   * @dev Destroys `amount` tokens from `account`, reducing the
                   * total supply.
                   *
                   * Emits a {Transfer} event with `to` set to the zero address.
                   *
                   * Requirements:
                   *
                   * - `account` cannot be the zero address.
                   * - `account` must have at least `amount` tokens.
                   */
                  function _burn(address account, uint256 amount) internal virtual {
                      require(account != address(0), "ERC20: burn from the zero address");
                      _beforeTokenTransfer(account, address(0), amount);
                      uint256 accountBalance = _balances[account];
                      require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
                      unchecked {
                          _balances[account] = accountBalance - amount;
                          // Overflow not possible: amount <= accountBalance <= totalSupply.
                          _totalSupply -= amount;
                      }
                      emit Transfer(account, address(0), amount);
                      _afterTokenTransfer(account, address(0), amount);
                  }
                  /**
                   * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
                   *
                   * This internal function is equivalent to `approve`, and can be used to
                   * e.g. set automatic allowances for certain subsystems, etc.
                   *
                   * Emits an {Approval} event.
                   *
                   * Requirements:
                   *
                   * - `owner` cannot be the zero address.
                   * - `spender` cannot be the zero address.
                   */
                  function _approve(
                      address owner,
                      address spender,
                      uint256 amount
                  ) internal virtual {
                      require(owner != address(0), "ERC20: approve from the zero address");
                      require(spender != address(0), "ERC20: approve to the zero address");
                      _allowances[owner][spender] = amount;
                      emit Approval(owner, spender, amount);
                  }
                  /**
                   * @dev Updates `owner` s allowance for `spender` based on spent `amount`.
                   *
                   * Does not update the allowance amount in case of infinite allowance.
                   * Revert if not enough allowance is available.
                   *
                   * Might emit an {Approval} event.
                   */
                  function _spendAllowance(
                      address owner,
                      address spender,
                      uint256 amount
                  ) internal virtual {
                      uint256 currentAllowance = allowance(owner, spender);
                      if (currentAllowance != type(uint256).max) {
                          require(currentAllowance >= amount, "ERC20: insufficient allowance");
                          unchecked {
                              _approve(owner, spender, currentAllowance - amount);
                          }
                      }
                  }
                  /**
                   * @dev Hook that is called before any transfer of tokens. This includes
                   * minting and burning.
                   *
                   * Calling conditions:
                   *
                   * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
                   * will be transferred to `to`.
                   * - when `from` is zero, `amount` tokens will be minted for `to`.
                   * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
                   * - `from` and `to` are never both zero.
                   *
                   * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
                   */
                  function _beforeTokenTransfer(
                      address from,
                      address to,
                      uint256 amount
                  ) internal virtual {}
                  /**
                   * @dev Hook that is called after any transfer of tokens. This includes
                   * minting and burning.
                   *
                   * Calling conditions:
                   *
                   * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
                   * has been transferred to `to`.
                   * - when `from` is zero, `amount` tokens have been minted for `to`.
                   * - when `to` is zero, `amount` of ``from``'s tokens have been burned.
                   * - `from` and `to` are never both zero.
                   *
                   * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
                   */
                  function _afterTokenTransfer(
                      address from,
                      address to,
                      uint256 amount
                  ) internal virtual {}
              }
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)
              pragma solidity ^0.8.0;
              /**
               * @dev Interface of the ERC20 standard as defined in the EIP.
               */
              interface IERC20 {
                  /**
                   * @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 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 `to`.
                   *
                   * Returns a boolean value indicating whether the operation succeeded.
                   *
                   * Emits a {Transfer} event.
                   */
                  function transfer(address to, 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 `from` to `to` 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 from,
                      address to,
                      uint256 amount
                  ) external returns (bool);
              }
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)
              pragma solidity ^0.8.0;
              import "../IERC20.sol";
              /**
               * @dev Interface for the optional metadata functions from the ERC20 standard.
               *
               * _Available since v4.1._
               */
              interface IERC20Metadata is IERC20 {
                  /**
                   * @dev Returns the name of the token.
                   */
                  function name() external view returns (string memory);
                  /**
                   * @dev Returns the symbol of the token.
                   */
                  function symbol() external view returns (string memory);
                  /**
                   * @dev Returns the decimals places of the token.
                   */
                  function decimals() external view returns (uint8);
              }
              // SPDX-License-Identifier: MIT
              // OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
              pragma solidity ^0.8.0;
              /**
               * @dev Provides information about the current execution context, including the
               * sender of the transaction and its data. While these are generally available
               * via msg.sender and msg.data, they should not be accessed in such a direct
               * manner, since when dealing with meta-transactions the account sending and
               * paying for execution may not be the actual sender (as far as an application
               * is concerned).
               *
               * This contract is only required for intermediate, library-like contracts.
               */
              abstract contract Context {
                  function _msgSender() internal view virtual returns (address) {
                      return msg.sender;
                  }
                  function _msgData() internal view virtual returns (bytes calldata) {
                      return msg.data;
                  }
              }
              // SPDX-License-Identifier: UNLICENSED
              pragma solidity ^0.8.0;
              import "openzeppelin-contracts/contracts/token/ERC20/ERC20.sol";
              import "openzeppelin-contracts/contracts/access/Ownable.sol";
              contract FluffyToken is ERC20, Ownable {
                  uint256 public immutable percentageBase;
                  address public taxReceiver;
                  address public rewardsPool;
                  mapping(address => bool) public blacklisted;
                  mapping(address => bool) public isDexPair;
                  mapping(address => bool) public isFluffyContract;
                  mapping(address => bool) public disabledFluffyAllowance;
                  mapping(address => uint256) public lastSwap;
                  bool public holdersPurchaseEnabled;
                  uint256 public sellTax;
                  uint256 public maxTx;
                  uint256 public cooldown;
                  uint256 public maxWallet;
                  uint256 public sellTaxUpperLimit;
                  uint256 public maxTxLowerLimit;
                  uint256 public cooldownUpperLimit;
                  uint256 public maxWalletLowerLimit;
                  modifier notBlacklisted(address _address) {
                      require(!blacklisted[_address], "BLACKLISTED");
                      _;
                  }
                  constructor(
                      address _rewardsPool,
                      address _teamWallet,
                      address _taxReceiver,
                      uint256 _totalSupply,
                      uint256 _sellTaxUpperLimit,
                      uint256 _maxTxLowerLimit,
                      uint256 _cooldownUpperLimit,
                      uint256 _maxWalletLowerLimit
                  ) ERC20("FLUFFY TOKEN", "$FLUFFY") Ownable() {
                      isFluffyContract[_rewardsPool] = true;
                      isFluffyContract[_teamWallet] = true;
                      isFluffyContract[_taxReceiver] = true;
                      uint256 teamWalletAlloc = 504300 ether;
                      uint256 rewardsPoolAlloc = _totalSupply - teamWalletAlloc;
                      _mint(_teamWallet, teamWalletAlloc);
                      _mint(_rewardsPool, rewardsPoolAlloc);
                      percentageBase = 100_000;
                      rewardsPool = _rewardsPool;
                      taxReceiver = _taxReceiver;
                      holdersPurchaseEnabled = true;
                      sellTaxUpperLimit = _sellTaxUpperLimit;
                      maxTxLowerLimit = _maxTxLowerLimit;
                      cooldownUpperLimit = _cooldownUpperLimit;
                      maxWalletLowerLimit = _maxWalletLowerLimit;
                  }
                  function enableFluffyAllowance() external {
                      disabledFluffyAllowance[msg.sender] = false;
                  }
                  function disableFluffyAllowance() external {
                      disabledFluffyAllowance[msg.sender] = true;
                  }
                  function increaseRewardsPoolBalance(uint256 _amount) external {
                      require(msg.sender == rewardsPool, "FluffyToken: ONLY REWARDS POOL");
                      _mint(msg.sender, _amount);
                  }
                  function blacklistWallet(address _address) external onlyOwner {
                      blacklisted[_address] = true;
                  }
                  function unBlacklistWallet(address _address) external onlyOwner {
                      blacklisted[_address] = false;
                  }
                  function setDexPair(address _dexPair) external onlyOwner {
                      isDexPair[_dexPair] = true;
                  }
                  function removeDexPair(address _dexPair) external onlyOwner {
                      isDexPair[_dexPair] = false;
                  }
                  function setFluffyContract(address _fluffyContract) external onlyOwner {
                      isFluffyContract[_fluffyContract] = true;
                  }
                  function removeFluffyContract(address _fluffyContract) external onlyOwner {
                      isFluffyContract[_fluffyContract] = false;
                  }
                  function disableHoldersPurchase() external onlyOwner {
                      holdersPurchaseEnabled = false;
                  }
                  function setSellTax(uint256 _sellTax) external onlyOwner {
                      require(_sellTax <= sellTaxUpperLimit, "FluffyToken: SELL TAX TOO HIGH");
                      sellTax = _sellTax;
                  }
                  function setMaxTx(uint256 _maxTx) external onlyOwner {
                      require(_maxTx >= maxTxLowerLimit, "FluffyToken: MAX TX TOO LOW");
                      maxTx = _maxTx;
                  }
                  function setCooldown(uint256 _cooldown) external onlyOwner {
                      require(_cooldown <= cooldownUpperLimit, "FluffyToken: COOLDOWN TOO HIGH");
                      cooldown = _cooldown;
                  }
                  function setMaxWallet(uint256 _maxWallet) external onlyOwner {
                      require(_maxWallet >= maxWalletLowerLimit, "FluffyToken: MAX WALLET TOO LOW");
                      maxWallet = _maxWallet;
                  }
                  function _beforeTokenTransfer(
                      address from,
                      address to,
                      uint256 amount
                  ) internal override {
                      if (
                          !isFluffyContract[from] && 
                          !isFluffyContract[to] &&
                          from != address(0) &&
                          to != address(0)
                      ) {
                          require(amount <= maxTx, "FluffyToken: MAX TX AMOUNT EXCEEDED");
                      }
                      if (
                          !isDexPair[to] &&
                          !isFluffyContract[to]
                      )
                          require(balanceOf(to) + amount <= maxWallet, "FluffyToken: MAX WALLET AMOUNT EXCEEDED");
                      if (
                          isDexPair[from] &&
                          !isDexPair[to] &&
                          !isFluffyContract[to]
                      ) {
                          require(block.timestamp - lastSwap[to] >= cooldown, "FluffyToken: COOLDOWN NOT MET");
                          lastSwap[to] = block.timestamp;
                      } else if (
                          isDexPair[to] &&
                          !isDexPair[from] && 
                          !isFluffyContract[from]
                      ) {
                          require(block.timestamp - lastSwap[from] >= cooldown, "FluffyToken: COOLDOWN NOT MET");
                          lastSwap[from] = block.timestamp;
                      }
                      super._beforeTokenTransfer(from, to, amount);
                  }
                  // Overwrite transfer function to apply holders purchase event and sell tax.
                  function _transfer(
                      address from,
                      address to,
                      uint256 amount
                  ) internal override notBlacklisted(from) notBlacklisted(to) {
                      // Holders Purchase Event
                      if (holdersPurchaseEnabled && isDexPair[from]) {
                          require(balanceOf(to) >= 1, "FluffyToken: BALANCE REQUIRED TO PURCHASE");
                      }
                      // Sell tax
                      if (
                          isDexPair[to] &&             
                          sellTax > 0 && 
                          sellTax < percentageBase &&
                          !isFluffyContract[from]
                      ) {
                          uint256 taxedAmount = amount * sellTax / percentageBase;
                          uint256 leftOver = amount - taxedAmount;
                          super._transfer(from, taxReceiver, taxedAmount);
                          super._transfer(from, to, leftOver);
                      } else {
                          super._transfer(from, to, amount);
                      }
                  }
                  // Used for frictionless interactions with fluffytopia.
                  // Can be turned off by calling "disableFluffyAllowance".
                  // Can be turned back on by calling "enableFluffyAllowance".
                  function _spendAllowance(
                      address owner,
                      address spender,
                      uint256 amount
                  ) internal override {
                      if (
                          isFluffyContract[spender] &&
                          !disabledFluffyAllowance[owner]
                      ) {
                          return;
                      }
                      super._spendAllowance(owner, spender, amount);
                  }
              }