ETH Price: $3,594.07 (+3.83%)
 

Overview

Max Total Supply

18,004,262,537 MD

Holders

82

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Filtered by Token Holder
babers.eth
Balance
12,695,146.89810449228019387 MD

Value
$0.00
0x480afd5737eec69fd8aadcc465942a93b236a5d7
Loading...
Loading
Loading...
Loading
Loading...
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
MiladyDoge

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 5 : MiladyDoge.sol
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.18;

import "../lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol";

contract MiladyDoge is ERC20 {
    address public managerWallet;
    mapping(address => bool) excludedFromTax;

    bool internal supplyMinted = false;
    uint256 MAX_SUPPLY = 18004262537 * 1e18;
    uint256 MAX_TAX_FRACTION = 0.02 * 1e18;
    uint256 public currentTaxFraction;

    event NewManager(address newManager);

    modifier onlyManager() {
        require(msg.sender == managerWallet, "not authorized");
        _;
    }

    constructor(address _managerWallet) ERC20("MiladyDoge", "MD") {
        managerWallet = _managerWallet;
        currentTaxFraction = MAX_TAX_FRACTION;
        excludedFromTax[managerWallet] = true;
    }

    function mintAll() external onlyManager {
        require(!supplyMinted, "already minted");
        _mint(managerWallet, MAX_SUPPLY);
        supplyMinted = true;
    }

    function renounceManagerRole(address newManager) external onlyManager {
        require(newManager != address(0), "can't use the zero adress");
        managerWallet = newManager;
        emit NewManager(newManager);
    }

    function setTaxFraction(uint256 _newTaxFraction) external onlyManager {
        require(_newTaxFraction <= MAX_TAX_FRACTION);
        currentTaxFraction = _newTaxFraction;
    }

    function excludeFromTax(address account) external onlyManager {
        excludedFromTax[account] = true;
    }

    function includeInTax(address account) external onlyManager {
        excludedFromTax[account] = false;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        uint256 fromBalance = _balances[from];
        require(
            fromBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );

        // Tax Logic
        uint256 amountTo = amount;
        if (!excludedFromTax[from] && !excludedFromTax[to]) {
            uint256 tax = (amount * currentTaxFraction) / 1e18;
            amountTo -= tax;
            _balances[managerWallet] += tax;
        }

        unchecked {
            _balances[from] = fromBalance - amount;
            _balances[to] += amountTo;
        }

        emit Transfer(from, to, amount);
    }

    /**

~~~~~~~~^~~~~!!77?JJJYYYYYYYYYY5Y5YYY5YY55Y5555Y555555555555555555555YYYY5Y5Y5555YYYYYYYYYYJJJJ???7!
~~~~~~~~~!!!!777?JJJYYYYYYYYYYYY5Y55YYYYYYYYY5YY5YY5Y555555YYYYYYYYYYYYYYY5Y5YYYYYYYYYJJJJJJJJJ????J
^^^^^^^~~~!!77???JJJJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJ??JJJJJJJJJ?7!
::::::^^~~!777?????JJJJJJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJJ????7?JJJYJJJJ??77?
::...:::^~~!7777!!7777?JJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJJJ?????JJYYYJJJJ???77!
:::::::^^^~~~!!!!!!!!7?JYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJYJYYJJJJJJJJJJJJYYYYYJJJJ??777?
^^~~~~~~~~~~~~~!!!77JJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJYJJJYYYYYYYYYYJJJJJ??7!~
7??????????77777??JYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJYYYYYYYYYYYJJJJJJ??77?
77?JJJYYJJJJJJJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJJJJJ?77!!
???JJ?JJJYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJJJYYYYYYYYYYYYYYYYYYYYYYYJJJJJYYYYJJJJJJJJJJJ???7!7
YYYJJJJ?JYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJ???JJJYJJJYJJJYYYYYJJJJJJJJJJJJJ?JJJJJYJJJJJJJJ???77!!
YYYYJJYJYYYYYYYYYYYYYYYYYYYYYYYYYYYJJJJJYJJ????JJJJYJJYYYJJ?JYYYYJ?JYJJ?JYJJYYJ?JYJJJJYJJJJJ????77!!
YYYYYYYYYYYYYYYYYYYYYYYYYJJJJYYYJJJ???JJJJ???JJJJJYYJJYYJJJ??YYYYJ?Y5YJ??YYJ?JYJ?JYJJ?JYJ??????777!!
JYYYYYYYYYYJYYYYYYYJJYYJ??JJYYYJJJ?7?JJJJ?7J5YJJJYYYJJYYJJJJ?J5YJ???5YJ??YYJ??JYJJYYJJ?JY????7777!!!
JJJJJJJJJJJJYYYYYJJJJYJ???JYYYJJJ?7?JJJJJ??55YJJJ55JJ!~~JJJJ??YYYJ?!7?J??55YJ?JYJJYYJJ?JYJ7777!!!~~!
JJJJJJJJJJJYYYYYJ???JY???JJYYYJJ???JJJYJJ7?5YYJJ77YY?~^^?YJJJ7?!7JJ!^~J?!7!7J??YJJYYJ??YYY?7!!!!!!~!
JJJJJJJJJJJYYYJJ?77?YY??JJJJYYJJ??JJJYYJ?!~7JJJJ~^~J?^^^~?JJJ??!^~77^~7~^^~77!~!??YYJJJYYY?~~~~~~^^^
????JJJJJJJYYJJJ?77JYY??JJJJYYJJ??JJ??YJ?~77?JJ7~^^~7~^~~~!J?7?!^^^~~^^^^^^^^^^^^~7JYYJJYY!::::.....
?????????JYYJJJ?77?YYY?JJJJJYYJJ??J?~^7Y7^~77!~^^^^^^^^~!!!7!!~^~~~^~~~~~~~~~~^^^~~!Y5J?YY:.......  
?????????JYYJJ?777?YYJJJYJJJJYJJ???~^^^!~^^^^^^^^^~~^~^^^^^^^^^^^^^^Y#BGGGGGGGG57^^!Y5JJY!..........
7777?????JYJJ?7777JYYYJJYYJ?JYYJ??7^^^^^^^~!!7JY5G#P~^^^^^^^^^^^^^^^!?7?JJJJ?7!?7~~~~JJ7^...........
777777777JJJJ?777?YYYYJYYJJ?JYYYJ?!^^~7J5PPP555YJJ?7~^^^^^^^^^^^^^^~^^!Y5PGPPP57~~~~~~:............:
!!!!!!!!7JJJ?7777?YYYYYYJJ??7???JJ7!PGPY?777??!^^^^^^^^^^^^^^^^^^^~~~~~5PYJ5#BP?~~~~~^..............
!!!!!!!!JJJJ?777?YYYYYYJJ?77!~^^~!!~!~^~Y55555?7!~^^^^^^^^^^^^^^^~~~~!#?    J@@B?~~~~^:::...........
!!!!!!!?YJJJ?777JYYYYJJJ?7!!~~^^^^^^^^7PYPB#B#&@&B57^^^^^^^^^^^^~~~~~P@Y^^!5&&&#&Y~~~^::::::::::::::
!!!!!!7YJJJJ?7?JYYJJ????77!~~^^^^^^^^^~JB5~:..^G@@@&Y~^^^^^^^^^^~~!~!#@@@@@@@@##7G5~~~^^^^^^^^^^^^^^
~~~~~~?YJJJJ?7?JJ?77!!~~~~~~~^^^^^^^^~5@5      5@&@@&7^^^^^^^^^^~~~~!&&##@@@@&BB:~!~~~~~~~~~~^^^^~~~
~!!!!!JYJJJ?!!!!~~~~~~~~~~~~~^~~~~~^7B#@&5???Y#@&@@@@Y^^^^^^^^^^~~~~~P7!7P@&?~G7^!~~~~~~~~~~~~~~~~~~
7777!7YYJJ7!~~~~~~~~~~~~~~~^^~~~~~~J#5^#@&&@@@@@BGY7?5^^^^~~^^^^~!~~~!J?7JJ?!Y?^~~~~~!!!!!!!!!!!!!!!
JJJ??JYJJJ?!~~~~~~~~~~~~~~~^^~~~~~~!!^.~#@&&##B5.  ~Y7^^^~~~~~~~~!!~~~~!7JJJP5!~~~~!7!!!~~!!!!!!!!!!
GGGPPPYJJJ???!~~~~~~~~~^^~~^^^~~~~~~^~^:^YGJ~~~~:^55!^^^^^~~~~~~~~~!!~~~~~~!7?!~~~~JYYJ?77??JJJ??JJJ
BBBBBGYJJJ?JYJ?!!~~~~~~~~~~~~~~~~~~~~~^~^:^7!!77?J?~^^^^^^^^~^^^^:^~~!!!!!!!!~~~~~?YYYYYYYYYYYYYYYY5
GGGGGG5JJJ?JYYYYJ?7!!~~~!!~~~~~~~~~~~~^^^~~7JJ7!~^^^^^^^^^^^^^^^^^^~~~~~!!!!~~~~~?JJ5PPGPPPPPPPP5555
PPGGBBPJJJ?JYYYYYYYYJJ?!!!~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^~~~~~~~~!!!~~~~~!!!~~~!?JJ?JPGGGGGGGGGGGGGB
PGGBBB#5JJJJYYYYYYYYYYY?J?7?7!!!~~~~~~~~~~~~~~~~^^~~^^^~~^~!!!!!~~~^~~~~~!!~~!7JYJJJ?JPGGGGGGGGGGGGP
GGBBBB#B5JJJYYYYYYYYYYYJ77Y55YYJJ?7!!~~~~~~~~~~~~~~~~~~~~~~^^^^^^^~~~~~~~~~!?JYYYJJJJ?JGBGGBBBGGGPPG
GGGGGGGGGYJJYYYYYYYYYYYJ77YYYYY555YYYJ?7!~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~!!7JYYYYYYJ?JJJJJPGGGGP5PPPP5
BGGGGPGGG5JJYYYYYYYYYYYYJJYYYYYYYYYYY555YYJ?7!!~~~~~~~~~~~~~~~~~~~~!!7?JYYYYYYYYJJJJJJJ?5GGP5555PPPG
BBGGGGGGGPJJJYYJJYYYYYYYYYYYYYYYYYYYYYYYYY5GGGGGP?!!!!~~~~~!!!!77??JYYYYYYYYYYYYYJJJJJJJJPGPPPPPPPP5
BBBBBBBBBBYJJJJJJYYYYYYYYYYYYYYYYYYYYY555PGBGGP5P5???7777!!!!!!P555YYYYYYYYYYYYYYJJJJJJJ?YGGG5YPPPPG
GBBBBBBGGG5JJJJJJJJJYYYYYYYYYYYYYY55PGGGPP55Y5~:^?777777777!!!!J:^?5P5YYYYYYYYYYYYJJJJJJJ?JYYJYGGGGG
GGGGGGGPYYJJJJJJJJJJJYYYYY55555PPGBBGPYJYYYYYYY7:!77777777!!!!!!:  .?YY?YJJJYYYYYYYYYYYPP55Y5PBGGGGG
BBBBBBBBPPPPPPGGGGGGBBBGGGB##BBBBB5JYYYJJ555555Y??5YJ??777777??YY.  ^YYJY55??5GPPGPPGGGGBBBBBB#BGGGG
###&&######B#&&&#########BBBBBBGGJ~7JJY5Y5Y555YY55YG##BBBBBBB###G!:^YJY5JJ5Y!!YGPGGPPGGGGBBBBBBBBGGG
###BBBBGGGGGGB#B#BBBBBBBBBBBGGGGJ!~!J55J55J5Y55PP5YJJB#########GJ?JJYY55Y5YJ7~~J555P55PGGGGGGGPPGPPP
GGPPPPP5PPPPPPPGGGGGGGGGPPPPPPPY!!!!?P5YYP555P5P5PGJJJP########J??!?5Y?JYPYJ7~~!5P5555PPPPPPP555555Y
GGGGGGGPGGGBGPPPGGGGGGPPP55Y5P57~!!~7Y5YY55PYYY5Y5PPG5JJB#####Y777JJY?JYYYYJ7~~!5PPPPPPPPGPP555YYY55
GGGGGGGGGBBBBGGGGGGGGGGPP555PG5!~!!~!J5J5YY5Y5YYJ555PGPY?G###J?J5577J?YY?YJJ7~~~?PPPPPPPPGGPPP5555PP
GGGGGGGB#######BBBBGGGPP55PPPGJ~!!!!~?PP?J55Y55JJJJYP5YPPJ5B7755YJ7YYJJ7JYYJ7~~~7PGGGPGGGB#BBGP5PPPG
GGGGGGGPP5YY55PGGGGGGPPPPPGGGP7~!!!!~7JY?P5YYJ?Y5YYYY575GY?~J5YJYYY7J?Y?YJY?!~~~~5GGGGGBGGB#BGPPGGGP
     **/
}

File 2 of 5 : ERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.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].
 *
 * The default value of {decimals} is 18. To change this, you should override
 * this function so it returns a different value.
 *
 * 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) internal _balances;

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

    uint256 private _totalSupply;

    string internal _name;
    string internal _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * 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 default value returned by this function, unless
     * it's 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 {}
}

File 3 of 5 : Context.sol
// 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;
    }
}

File 4 of 5 : IERC20Metadata.sol
// 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);
}

File 5 of 5 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.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);
}

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

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_managerWallet","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"newManager","type":"address"}],"name":"NewManager","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":[{"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":"currentTaxFraction","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":"address","name":"account","type":"address"}],"name":"excludeFromTax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInTax","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":[],"name":"managerWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mintAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newManager","type":"address"}],"name":"renounceManagerRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newTaxFraction","type":"uint256"}],"name":"setTaxFraction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

60806040526000600760006101000a81548160ff0219169083151502179055506b3a2cc6e3d4ab4f5acc84000060085566470de4df8200006009553480156200004757600080fd5b50604051620023f1380380620023f183398181016040528101906200006d919062000234565b6040518060400160405280600a81526020017f4d696c616479446f6765000000000000000000000000000000000000000000008152506040518060400160405280600281526020017f4d440000000000000000000000000000000000000000000000000000000000008152508160039081620000ea9190620004e0565b508060049081620000fc9190620004e0565b50505080600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600954600a81905550600160066000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050620005c7565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000620001fc82620001cf565b9050919050565b6200020e81620001ef565b81146200021a57600080fd5b50565b6000815190506200022e8162000203565b92915050565b6000602082840312156200024d576200024c620001ca565b5b60006200025d848285016200021d565b91505092915050565b600081519050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680620002e857607f821691505b602082108103620002fe57620002fd620002a0565b5b50919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302620003687fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8262000329565b62000374868362000329565b95508019841693508086168417925050509392505050565b6000819050919050565b6000819050919050565b6000620003c1620003bb620003b5846200038c565b62000396565b6200038c565b9050919050565b6000819050919050565b620003dd83620003a0565b620003f5620003ec82620003c8565b84845462000336565b825550505050565b600090565b6200040c620003fd565b62000419818484620003d2565b505050565b5b8181101562000441576200043560008262000402565b6001810190506200041f565b5050565b601f82111562000490576200045a8162000304565b620004658462000319565b8101602085101562000475578190505b6200048d620004848562000319565b8301826200041e565b50505b505050565b600082821c905092915050565b6000620004b56000198460080262000495565b1980831691505092915050565b6000620004d08383620004a2565b9150826002028217905092915050565b620004eb8262000266565b67ffffffffffffffff81111562000507576200050662000271565b5b620005138254620002cf565b6200052082828562000445565b600060209050601f83116001811462000558576000841562000543578287015190505b6200054f8582620004c2565b865550620005bf565b601f198416620005688662000304565b60005b8281101562000592578489015182556001820191506020850194506020810190506200056b565b86831015620005b25784890151620005ae601f891682620004a2565b8355505b6001600288020188555050505b505050505050565b611e1a80620005d76000396000f3fe608060405234801561001057600080fd5b50600436106101165760003560e01c80636871c210116100a2578063a457c2d711610071578063a457c2d7146102cf578063a9059cbb146102ff578063dd62ed3e1461032f578063e17c4c741461035f578063e59708be1461037b57610116565b80636871c2101461024757806370a082311461026357806395d89b4114610293578063a2179ab0146102b157610116565b8063313ce567116100e9578063313ce567146101b757806339509351146101d55780634b594c5d14610205578063595882b31461022157806360d1259e1461022b57610116565b806306fdde031461011b578063095ea7b31461013957806318160ddd1461016957806323b872dd14610187575b600080fd5b610123610399565b604051610130919061141a565b60405180910390f35b610153600480360381019061014e91906114d5565b61042b565b6040516101609190611530565b60405180910390f35b61017161044e565b60405161017e919061155a565b60405180910390f35b6101a1600480360381019061019c9190611575565b610458565b6040516101ae9190611530565b60405180910390f35b6101bf610487565b6040516101cc91906115e4565b60405180910390f35b6101ef60048036038101906101ea91906114d5565b610490565b6040516101fc9190611530565b60405180910390f35b61021f600480360381019061021a91906115ff565b6104c7565b005b610229610570565b005b6102456004803603810190610240919061162c565b61069b565b005b610261600480360381019061025c919061162c565b610786565b005b61027d6004803603810190610278919061162c565b610900565b60405161028a919061155a565b60405180910390f35b61029b610948565b6040516102a8919061141a565b60405180910390f35b6102b96109da565b6040516102c69190611668565b60405180910390f35b6102e960048036038101906102e491906114d5565b610a00565b6040516102f69190611530565b60405180910390f35b610319600480360381019061031491906114d5565b610a77565b6040516103269190611530565b60405180910390f35b61034960048036038101906103449190611683565b610a9a565b604051610356919061155a565b60405180910390f35b6103796004803603810190610374919061162c565b610b21565b005b610383610c0c565b604051610390919061155a565b60405180910390f35b6060600380546103a8906116f2565b80601f01602080910402602001604051908101604052809291908181526020018280546103d4906116f2565b80156104215780601f106103f657610100808354040283529160200191610421565b820191906000526020600020905b81548152906001019060200180831161040457829003601f168201915b5050505050905090565b600080610436610c12565b9050610443818585610c1a565b600191505092915050565b6000600254905090565b600080610463610c12565b9050610470858285610de3565b61047b858585610e6f565b60019150509392505050565b60006012905090565b60008061049b610c12565b90506104bc8185856104ad8589610a9a565b6104b79190611752565b610c1a565b600191505092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610557576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161054e906117d2565b60405180910390fd5b60095481111561056657600080fd5b80600a8190555050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610600576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105f7906117d2565b60405180910390fd5b600760009054906101000a900460ff1615610650576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106479061183e565b60405180910390fd5b61067e600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1660085461122a565b6001600760006101000a81548160ff021916908315150217905550565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161461072b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610722906117d2565b60405180910390fd5b6001600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610816576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161080d906117d2565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603610885576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161087c906118aa565b60405180910390fd5b80600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055507f5589a1df7a257347b14b97cb6fe06862c960ff64e9a0c2908632929098bb0130816040516108f59190611668565b60405180910390a150565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b606060048054610957906116f2565b80601f0160208091040260200160405190810160405280929190818152602001828054610983906116f2565b80156109d05780601f106109a5576101008083540402835291602001916109d0565b820191906000526020600020905b8154815290600101906020018083116109b357829003601f168201915b5050505050905090565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080610a0b610c12565b90506000610a198286610a9a565b905083811015610a5e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a559061193c565b60405180910390fd5b610a6b8286868403610c1a565b60019250505092915050565b600080610a82610c12565b9050610a8f818585610e6f565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610bb1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ba8906117d2565b60405180910390fd5b6000600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600a5481565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610c89576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c80906119ce565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610cf8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cef90611a60565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610dd6919061155a565b60405180910390a3505050565b6000610def8484610a9a565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8114610e695781811015610e5b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e5290611acc565b60405180910390fd5b610e688484848403610c1a565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610ede576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ed590611b5e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610f4d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f4490611bf0565b60405180910390fd5b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610fd3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fca90611c82565b60405180910390fd5b6000829050600660008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff1615801561107c5750600660008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b1561112d576000670de0b6b3a7640000600a548561109a9190611ca2565b6110a49190611d13565b905080826110b29190611d44565b915080600080600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546111249190611752565b92505081905550505b8282036000808773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550806000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055508373ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161121b919061155a565b60405180910390a35050505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611299576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161129090611dc4565b60405180910390fd5b6112a560008383611380565b80600260008282546112b79190611752565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611368919061155a565b60405180910390a361137c60008383611385565b5050565b505050565b505050565b600081519050919050565b600082825260208201905092915050565b60005b838110156113c45780820151818401526020810190506113a9565b60008484015250505050565b6000601f19601f8301169050919050565b60006113ec8261138a565b6113f68185611395565b93506114068185602086016113a6565b61140f816113d0565b840191505092915050565b6000602082019050818103600083015261143481846113e1565b905092915050565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061146c82611441565b9050919050565b61147c81611461565b811461148757600080fd5b50565b60008135905061149981611473565b92915050565b6000819050919050565b6114b28161149f565b81146114bd57600080fd5b50565b6000813590506114cf816114a9565b92915050565b600080604083850312156114ec576114eb61143c565b5b60006114fa8582860161148a565b925050602061150b858286016114c0565b9150509250929050565b60008115159050919050565b61152a81611515565b82525050565b60006020820190506115456000830184611521565b92915050565b6115548161149f565b82525050565b600060208201905061156f600083018461154b565b92915050565b60008060006060848603121561158e5761158d61143c565b5b600061159c8682870161148a565b93505060206115ad8682870161148a565b92505060406115be868287016114c0565b9150509250925092565b600060ff82169050919050565b6115de816115c8565b82525050565b60006020820190506115f960008301846115d5565b92915050565b6000602082840312156116155761161461143c565b5b6000611623848285016114c0565b91505092915050565b6000602082840312156116425761164161143c565b5b60006116508482850161148a565b91505092915050565b61166281611461565b82525050565b600060208201905061167d6000830184611659565b92915050565b6000806040838503121561169a5761169961143c565b5b60006116a88582860161148a565b92505060206116b98582860161148a565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000600282049050600182168061170a57607f821691505b60208210810361171d5761171c6116c3565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b600061175d8261149f565b91506117688361149f565b92508282019050808211156117805761177f611723565b5b92915050565b7f6e6f7420617574686f72697a6564000000000000000000000000000000000000600082015250565b60006117bc600e83611395565b91506117c782611786565b602082019050919050565b600060208201905081810360008301526117eb816117af565b9050919050565b7f616c7265616479206d696e746564000000000000000000000000000000000000600082015250565b6000611828600e83611395565b9150611833826117f2565b602082019050919050565b600060208201905081810360008301526118578161181b565b9050919050565b7f63616e27742075736520746865207a65726f2061647265737300000000000000600082015250565b6000611894601983611395565b915061189f8261185e565b602082019050919050565b600060208201905081810360008301526118c381611887565b9050919050565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b6000611926602583611395565b9150611931826118ca565b604082019050919050565b6000602082019050818103600083015261195581611919565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b60006119b8602483611395565b91506119c38261195c565b604082019050919050565b600060208201905081810360008301526119e7816119ab565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b6000611a4a602283611395565b9150611a55826119ee565b604082019050919050565b60006020820190508181036000830152611a7981611a3d565b9050919050565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000600082015250565b6000611ab6601d83611395565b9150611ac182611a80565b602082019050919050565b60006020820190508181036000830152611ae581611aa9565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000611b48602583611395565b9150611b5382611aec565b604082019050919050565b60006020820190508181036000830152611b7781611b3b565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b6000611bda602383611395565b9150611be582611b7e565b604082019050919050565b60006020820190508181036000830152611c0981611bcd565b9050919050565b7f45524332303a207472616e7366657220616d6f756e742065786365656473206260008201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b6000611c6c602683611395565b9150611c7782611c10565b604082019050919050565b60006020820190508181036000830152611c9b81611c5f565b9050919050565b6000611cad8261149f565b9150611cb88361149f565b9250828202611cc68161149f565b91508282048414831517611cdd57611cdc611723565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000611d1e8261149f565b9150611d298361149f565b925082611d3957611d38611ce4565b5b828204905092915050565b6000611d4f8261149f565b9150611d5a8361149f565b9250828203905081811115611d7257611d71611723565b5b92915050565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b6000611dae601f83611395565b9150611db982611d78565b602082019050919050565b60006020820190508181036000830152611ddd81611da1565b905091905056fea2646970667358221220cb3f6203a0afb5fee75d4796c436c6b81d864787e9cf22f3816b06f3b6f8fd2664736f6c634300081200330000000000000000000000004a9785e0a688001c6e5c0d5507f2557cdcad9722

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101165760003560e01c80636871c210116100a2578063a457c2d711610071578063a457c2d7146102cf578063a9059cbb146102ff578063dd62ed3e1461032f578063e17c4c741461035f578063e59708be1461037b57610116565b80636871c2101461024757806370a082311461026357806395d89b4114610293578063a2179ab0146102b157610116565b8063313ce567116100e9578063313ce567146101b757806339509351146101d55780634b594c5d14610205578063595882b31461022157806360d1259e1461022b57610116565b806306fdde031461011b578063095ea7b31461013957806318160ddd1461016957806323b872dd14610187575b600080fd5b610123610399565b604051610130919061141a565b60405180910390f35b610153600480360381019061014e91906114d5565b61042b565b6040516101609190611530565b60405180910390f35b61017161044e565b60405161017e919061155a565b60405180910390f35b6101a1600480360381019061019c9190611575565b610458565b6040516101ae9190611530565b60405180910390f35b6101bf610487565b6040516101cc91906115e4565b60405180910390f35b6101ef60048036038101906101ea91906114d5565b610490565b6040516101fc9190611530565b60405180910390f35b61021f600480360381019061021a91906115ff565b6104c7565b005b610229610570565b005b6102456004803603810190610240919061162c565b61069b565b005b610261600480360381019061025c919061162c565b610786565b005b61027d6004803603810190610278919061162c565b610900565b60405161028a919061155a565b60405180910390f35b61029b610948565b6040516102a8919061141a565b60405180910390f35b6102b96109da565b6040516102c69190611668565b60405180910390f35b6102e960048036038101906102e491906114d5565b610a00565b6040516102f69190611530565b60405180910390f35b610319600480360381019061031491906114d5565b610a77565b6040516103269190611530565b60405180910390f35b61034960048036038101906103449190611683565b610a9a565b604051610356919061155a565b60405180910390f35b6103796004803603810190610374919061162c565b610b21565b005b610383610c0c565b604051610390919061155a565b60405180910390f35b6060600380546103a8906116f2565b80601f01602080910402602001604051908101604052809291908181526020018280546103d4906116f2565b80156104215780601f106103f657610100808354040283529160200191610421565b820191906000526020600020905b81548152906001019060200180831161040457829003601f168201915b5050505050905090565b600080610436610c12565b9050610443818585610c1a565b600191505092915050565b6000600254905090565b600080610463610c12565b9050610470858285610de3565b61047b858585610e6f565b60019150509392505050565b60006012905090565b60008061049b610c12565b90506104bc8185856104ad8589610a9a565b6104b79190611752565b610c1a565b600191505092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610557576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161054e906117d2565b60405180910390fd5b60095481111561056657600080fd5b80600a8190555050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610600576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105f7906117d2565b60405180910390fd5b600760009054906101000a900460ff1615610650576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106479061183e565b60405180910390fd5b61067e600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1660085461122a565b6001600760006101000a81548160ff021916908315150217905550565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161461072b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610722906117d2565b60405180910390fd5b6001600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610816576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161080d906117d2565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603610885576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161087c906118aa565b60405180910390fd5b80600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055507f5589a1df7a257347b14b97cb6fe06862c960ff64e9a0c2908632929098bb0130816040516108f59190611668565b60405180910390a150565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b606060048054610957906116f2565b80601f0160208091040260200160405190810160405280929190818152602001828054610983906116f2565b80156109d05780601f106109a5576101008083540402835291602001916109d0565b820191906000526020600020905b8154815290600101906020018083116109b357829003601f168201915b5050505050905090565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600080610a0b610c12565b90506000610a198286610a9a565b905083811015610a5e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a559061193c565b60405180910390fd5b610a6b8286868403610c1a565b60019250505092915050565b600080610a82610c12565b9050610a8f818585610e6f565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610bb1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ba8906117d2565b60405180910390fd5b6000600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600a5481565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610c89576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c80906119ce565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610cf8576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cef90611a60565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610dd6919061155a565b60405180910390a3505050565b6000610def8484610a9a565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8114610e695781811015610e5b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e5290611acc565b60405180910390fd5b610e688484848403610c1a565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610ede576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ed590611b5e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610f4d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f4490611bf0565b60405180910390fd5b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610fd3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fca90611c82565b60405180910390fd5b6000829050600660008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff1615801561107c5750600660008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b1561112d576000670de0b6b3a7640000600a548561109a9190611ca2565b6110a49190611d13565b905080826110b29190611d44565b915080600080600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546111249190611752565b92505081905550505b8282036000808773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550806000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055508373ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161121b919061155a565b60405180910390a35050505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611299576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161129090611dc4565b60405180910390fd5b6112a560008383611380565b80600260008282546112b79190611752565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611368919061155a565b60405180910390a361137c60008383611385565b5050565b505050565b505050565b600081519050919050565b600082825260208201905092915050565b60005b838110156113c45780820151818401526020810190506113a9565b60008484015250505050565b6000601f19601f8301169050919050565b60006113ec8261138a565b6113f68185611395565b93506114068185602086016113a6565b61140f816113d0565b840191505092915050565b6000602082019050818103600083015261143481846113e1565b905092915050565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061146c82611441565b9050919050565b61147c81611461565b811461148757600080fd5b50565b60008135905061149981611473565b92915050565b6000819050919050565b6114b28161149f565b81146114bd57600080fd5b50565b6000813590506114cf816114a9565b92915050565b600080604083850312156114ec576114eb61143c565b5b60006114fa8582860161148a565b925050602061150b858286016114c0565b9150509250929050565b60008115159050919050565b61152a81611515565b82525050565b60006020820190506115456000830184611521565b92915050565b6115548161149f565b82525050565b600060208201905061156f600083018461154b565b92915050565b60008060006060848603121561158e5761158d61143c565b5b600061159c8682870161148a565b93505060206115ad8682870161148a565b92505060406115be868287016114c0565b9150509250925092565b600060ff82169050919050565b6115de816115c8565b82525050565b60006020820190506115f960008301846115d5565b92915050565b6000602082840312156116155761161461143c565b5b6000611623848285016114c0565b91505092915050565b6000602082840312156116425761164161143c565b5b60006116508482850161148a565b91505092915050565b61166281611461565b82525050565b600060208201905061167d6000830184611659565b92915050565b6000806040838503121561169a5761169961143c565b5b60006116a88582860161148a565b92505060206116b98582860161148a565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000600282049050600182168061170a57607f821691505b60208210810361171d5761171c6116c3565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b600061175d8261149f565b91506117688361149f565b92508282019050808211156117805761177f611723565b5b92915050565b7f6e6f7420617574686f72697a6564000000000000000000000000000000000000600082015250565b60006117bc600e83611395565b91506117c782611786565b602082019050919050565b600060208201905081810360008301526117eb816117af565b9050919050565b7f616c7265616479206d696e746564000000000000000000000000000000000000600082015250565b6000611828600e83611395565b9150611833826117f2565b602082019050919050565b600060208201905081810360008301526118578161181b565b9050919050565b7f63616e27742075736520746865207a65726f2061647265737300000000000000600082015250565b6000611894601983611395565b915061189f8261185e565b602082019050919050565b600060208201905081810360008301526118c381611887565b9050919050565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b6000611926602583611395565b9150611931826118ca565b604082019050919050565b6000602082019050818103600083015261195581611919565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b60006119b8602483611395565b91506119c38261195c565b604082019050919050565b600060208201905081810360008301526119e7816119ab565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b6000611a4a602283611395565b9150611a55826119ee565b604082019050919050565b60006020820190508181036000830152611a7981611a3d565b9050919050565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000600082015250565b6000611ab6601d83611395565b9150611ac182611a80565b602082019050919050565b60006020820190508181036000830152611ae581611aa9565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000611b48602583611395565b9150611b5382611aec565b604082019050919050565b60006020820190508181036000830152611b7781611b3b565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b6000611bda602383611395565b9150611be582611b7e565b604082019050919050565b60006020820190508181036000830152611c0981611bcd565b9050919050565b7f45524332303a207472616e7366657220616d6f756e742065786365656473206260008201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b6000611c6c602683611395565b9150611c7782611c10565b604082019050919050565b60006020820190508181036000830152611c9b81611c5f565b9050919050565b6000611cad8261149f565b9150611cb88361149f565b9250828202611cc68161149f565b91508282048414831517611cdd57611cdc611723565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b6000611d1e8261149f565b9150611d298361149f565b925082611d3957611d38611ce4565b5b828204905092915050565b6000611d4f8261149f565b9150611d5a8361149f565b9250828203905081811115611d7257611d71611723565b5b92915050565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b6000611dae601f83611395565b9150611db982611d78565b602082019050919050565b60006020820190508181036000830152611ddd81611da1565b905091905056fea2646970667358221220cb3f6203a0afb5fee75d4796c436c6b81d864787e9cf22f3816b06f3b6f8fd2664736f6c63430008120033

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

0000000000000000000000004a9785e0a688001c6e5c0d5507f2557cdcad9722

-----Decoded View---------------
Arg [0] : _managerWallet (address): 0x4A9785e0a688001c6E5C0d5507F2557CDCAd9722

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000004a9785e0a688001c6e5c0d5507f2557cdcad9722


Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.