Contract 0x6cAcDB97e3fC8136805a9E7c342d866ab77D0957

 
 
Txn Hash Method
Block
From
To
Value
0x8cc37bb7584a7c6d3fc63a9c4b6a7ee0120626b542dcbe0dfe8487a23ba75765Approve138925672021-12-28 8:11:3025 days 6 hrs ago0xfdbbfb0fe2986672af97eca0e797d76a0bbf35c9 IN  Swapr: SWPR Token0 Ether0.003114889266 66.896232338
0x9dfda95b832d4f1349b350663af96c0f34a3f369e9d814f1c8f38a9895d367b7Approve138093942021-12-15 11:15:2638 days 3 hrs ago0x8634a0f5370bb6db934978ba52dca9f48f03ba11 IN  Swapr: SWPR Token0 Ether0.00253903422 54.529008459
0x4da71f4010370b8db67a39cd02d97e9abd31968c451b938ba0dbccc5316f9b74Transfer137936062021-12-13 0:18:4140 days 14 hrs ago0xac8e78d3afdf931514df9addb7357771a1b0c862 IN  Swapr: SWPR Token0 Ether0.002914268897 62.272033533
0x6a50f5c70f42a57da9df5cfd491323c408a006799d7768e849e08e9312ea9e95Approve137709672021-12-09 12:08:2644 days 2 hrs ago0xd00fcd747059d19d759c16a70e068cac4f065906 IN  Swapr: SWPR Token0 Ether0.002407839143 51.711426323
0x470a174259d5c9b28d967001c256e1dca2c56ba3599b6aa151365569c93cded3Transfer137031562021-11-28 15:21:1454 days 22 hrs ago0xc0a4a4c01cce8f64c8886d79bd6b2edd695f8c57 IN  Swapr: SWPR Token0 Ether0.005391539176 104.513524263
0xaee60bccdb1c64c4bf331a70c24a7ce8ec9e79b8ee5c1529f3d3122e5f902286Transfer136747352021-11-24 3:08:4859 days 11 hrs ago0xe9c62867856baf9535283c162d36383bb90a2162 IN  Swapr: SWPR Token0 Ether0.002982614589 110.881987786
0x3d6a99985adf5b256c7f170518c5808335304fb97b39c9891739dd527a2b13adApprove136743602021-11-24 1:40:1359 days 12 hrs ago0xbbd21e3bf53d6cc44efb4636f9addcb935b1172d IN  Swapr: SWPR Token0 Ether0.005055884027 108.581578228
0x459ec6b7b17ac0ad580310c7572e2e15ab0aebd92972dd6fcacba9efbbda8c49Approve136705022021-11-23 11:11:2460 days 3 hrs agoENS Name shadycrypto.eth IN  Swapr: SWPR Token0 Ether0.004023794743 86.416140353
0xa4aca8f944c7bb035f0bd81baa750c294b34d2a94a71004ac87b2c89ad766ad2Approve136703102021-11-23 10:25:3460 days 3 hrs ago0x556ba81fbfbcfa4a9563e758edd0d1967afe58e5 IN  Swapr: SWPR Token0 Ether0.00421569069 90.537351334
0x2cd62dc46df16795991beca9435744238a1a01f8a13330c147662e68e0fc3c54Approve136266302021-11-16 12:34:1567 days 1 hr ago0x644239848c7b402d813295893db428aae7cc4cb5 IN  Swapr: SWPR Token0 Ether0.004791612328 103.546457668
0x79b92764287849024f5639a51e12f51d81b80733dbc8145a68333b5f3fc8bd33Approve136230912021-11-15 22:53:3067 days 15 hrs ago0x8ce15ba7316641a01604cc842de6cd3da690a7ff IN  Swapr: SWPR Token0 Ether0.005514916171 118.439880843
0x30e0e2a3194ad63feee38a743c0aa3d7384b9788c5e0908ffc2234022086e1d5Approve136134082021-11-14 10:19:5869 days 4 hrs ago0xe9c62867856baf9535283c162d36383bb90a2162 IN  Swapr: SWPR Token0 Ether0.003916718914 84.116549924
0x782094007f6f90856b4d7235db402416a06b7cde1cc5800049612438e1e9f167Approve136035942021-11-12 21:01:4070 days 17 hrs ago0xc993c0479101654badeb161d60c04863965658b1 IN  Swapr: SWPR Token0 Ether0.010279955746 220.775202333
0x35e79084afe20addfb00c9e49b069d7c153f18785a9fd1c26c8501c9cfa14e52Transfer135984972021-11-12 1:54:3771 days 12 hrs ago0x897c67ca1f74b8a284c9f6c91a86f9238974662b IN  Swapr: SWPR Token0 Ether0.006400455164 136.764784822
0xc3c829ad728cab07ce395b93dafc6e1ce672d7188abdb5a983f471286ff25af7Approve135956602021-11-11 15:16:2471 days 23 hrs ago0xbc40846a5f29b324b5fbec903bdc9fe7be4852a0 IN  Swapr: SWPR Token0 Ether0.006827245204 146.623825879
0xd95ba05bcaeac56f62fed59a771ff310d48f5ef2d49e3bbeeccd560865bfdb6aApprove135857242021-11-10 2:02:5073 days 12 hrs ago0xf791da446d04282f921f38fbf954ad5caee899a3 IN  Swapr: SWPR Token0 Ether0.006937887149
0x0703d643824ecc38a3c0dfe58f204abf4de7ceac5bbd21235a074939c38047f3Approve135488702021-11-04 7:25:3779 days 6 hrs ago0xe9c62867856baf9535283c162d36383bb90a2162 IN  Swapr: SWPR Token0 Ether0.005153885539 110.686286092
0x0055d24828e128b4cc2871c7e51612bfeecbc8a5835538c7f44348ae5bf54c34Approve135481922021-11-04 4:50:3979 days 9 hrs ago0x64ccc3343356d28d06b4a290d4fd4d1bb3980bcd IN  Swapr: SWPR Token0 Ether0.005634123121
0x019d5d222356b0fd70a5ccc45975cebc5df70e19a480de29d890055243e74955Approve135394492021-11-02 19:44:2380 days 18 hrs ago0xc9364c9b2feaa6d3374f7362b82140a3cfcf66d9 IN  Swapr: SWPR Token0 Ether0.0067529281 145.892542185
0x1b296e25639e6c5b8ecf2c3eef88813106ccad847f2c71fc161bb36d13f2da2bApprove135386752021-11-02 16:48:2580 days 21 hrs ago0xc9364c9b2feaa6d3374f7362b82140a3cfcf66d9 IN  Swapr: SWPR Token0 Ether0.00843481475 181.148438679
0xa8fd78eebb0acbdd503b19a03f300cb821f9b1cd9c86d73e89ed532b7e352cdfApprove135359512021-11-02 6:17:0881 days 8 hrs ago0x9f1920d0cbb63ed03376a1e09fd2851d601234c8 IN  Swapr: SWPR Token0 Ether0.00498871248 107.138983316
0x48f9203fe8921f1caac63124427dbdd47476a2412fd2ac2618042a78beae2b4cApprove135111392021-10-29 8:53:3185 days 5 hrs ago0x4ffad6ac852c0af0aa301376f4c5dea3a928b120 IN  Swapr: SWPR Token0 Ether0.005698081325 122.373586873
0x38ab06d14fb5dbb9240abfbc4437ac275885c9e9d82bc3b11b9d5c48e858a75fApprove135007362021-10-27 17:27:0686 days 20 hrs ago0xc066f65bfdacaa347c907839dd389cbf4982325f IN  Swapr: SWPR Token0 Ether0.008865108276 190.389542687
0xff87166f61d5e60e8fcbc08eb27c157709e002b0a4da1a404bc6e1f7a5209a8eApprove134960732021-10-26 23:58:5887 days 14 hrs ago0xc0a4a4c01cce8f64c8886d79bd6b2edd695f8c57 IN  Swapr: SWPR Token0 Ether0.005019818456 107.807023955
0x6f1f06305e33bcd4a7950ccf4a567edc3f1cb0390f159c273899d579e696b16eTransfer134758842021-10-23 20:09:2390 days 18 hrs ago0x1a31c94f97c649bc2a8adbceb54d1f4a075be4b1 IN  Swapr: SWPR Token0 Ether0.001931215 65
[ Download CSV Export 

OVERVIEW

A governance-enabled automated market maker with adjustable fees.

View more zero value Internal Transactions in Advanced View mode
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
SWPR

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 6 : SWPR.sol
pragma solidity ^0.8.4;

import "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol";

/**
 * @title SWPR
 * @dev SWPR token contract
 * @author Federico Luzzi - <[email protected]>
 * SPDX-License-Identifier: GPL-3.0
 */
contract SWPR is ERC20Burnable {
    constructor(address _ownerAddress) ERC20("Swapr", "SWPR") {
        _mint(_ownerAddress, 100000000 ether);
    }
}

File 2 of 6 : ERC20Burnable.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

import "../ERC20.sol";
import "../../../utils/Context.sol";

/**
 * @dev Extension of {ERC20} that allows token holders to destroy both their own
 * tokens and those that they have an allowance for, in a way that can be
 * recognized off-chain (via event analysis).
 */
abstract contract ERC20Burnable is Context, ERC20 {
    /**
     * @dev Destroys `amount` tokens from the caller.
     *
     * See {ERC20-_burn}.
     */
    function burn(uint256 amount) public virtual {
        _burn(_msgSender(), amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, deducting from the caller's
     * allowance.
     *
     * See {ERC20-_burn} and {ERC20-allowance}.
     *
     * Requirements:
     *
     * - the caller must have allowance for ``accounts``'s tokens of at least
     * `amount`.
     */
    function burnFrom(address account, uint256 amount) public virtual {
        uint256 currentAllowance = allowance(account, _msgSender());
        require(currentAllowance >= amount, "ERC20: burn amount exceeds allowance");
        unchecked {
            _approve(account, _msgSender(), currentAllowance - amount);
        }
        _burn(account, amount);
    }
}

File 3 of 6 : ERC20.sol
// SPDX-License-Identifier: MIT

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.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of 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:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, 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}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), 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}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - 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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][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) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     *
     * 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:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, 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;
        _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;
        }
        _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 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 4 of 6 : Context.sol
// SPDX-License-Identifier: MIT

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 5 of 6 : IERC20.sol
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

File 6 of 6 : IERC20Metadata.sol
// SPDX-License-Identifier: MIT

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

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_ownerAddress","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","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":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","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":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b5060405162000e0e38038062000e0e833981016040819052620000349162000248565b604080518082018252600581526429bbb0b83960d91b60208083019182528351808501909452600484526329aba82960e11b9084015281519192916200007d91600391620001a2565b50805162000093906004906020840190620001a2565b505050620000b3816a52b7d2dcc80cd2e4000000620000ba60201b60201c565b50620002da565b6001600160a01b038216620001155760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640160405180910390fd5b806002600082825462000129919062000278565b90915550506001600160a01b038216600090815260208190526040812080548392906200015890849062000278565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b828054620001b0906200029d565b90600052602060002090601f016020900481019282620001d457600085556200021f565b82601f10620001ef57805160ff19168380011785556200021f565b828001600101855582156200021f579182015b828111156200021f57825182559160200191906001019062000202565b506200022d92915062000231565b5090565b5b808211156200022d576000815560010162000232565b6000602082840312156200025a578081fd5b81516001600160a01b038116811462000271578182fd5b9392505050565b600082198211156200029857634e487b7160e01b81526011600452602481fd5b500190565b600181811c90821680620002b257607f821691505b60208210811415620002d457634e487b7160e01b600052602260045260246000fd5b50919050565b610b2480620002ea6000396000f3fe608060405234801561001057600080fd5b50600436106100cf5760003560e01c806342966c681161008c57806395d89b411161006657806395d89b41146101ad578063a457c2d7146101b5578063a9059cbb146101c8578063dd62ed3e146101db57600080fd5b806342966c681461015c57806370a082311461017157806379cc67901461019a57600080fd5b806306fdde03146100d4578063095ea7b3146100f257806318160ddd1461011557806323b872dd14610127578063313ce5671461013a5780633950935114610149575b600080fd5b6100dc610214565b6040516100e99190610a1b565b60405180910390f35b6101056101003660046109da565b6102a6565b60405190151581526020016100e9565b6002545b6040519081526020016100e9565b61010561013536600461099f565b6102bc565b604051601281526020016100e9565b6101056101573660046109da565b61036b565b61016f61016a366004610a03565b6103a7565b005b61011961017f36600461094c565b6001600160a01b031660009081526020819052604090205490565b61016f6101a83660046109da565b6103b4565b6100dc61043a565b6101056101c33660046109da565b610449565b6101056101d63660046109da565b6104e2565b6101196101e936600461096d565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60606003805461022390610a9d565b80601f016020809104026020016040519081016040528092919081815260200182805461024f90610a9d565b801561029c5780601f106102715761010080835404028352916020019161029c565b820191906000526020600020905b81548152906001019060200180831161027f57829003601f168201915b5050505050905090565b60006102b33384846104ef565b50600192915050565b60006102c9848484610613565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156103535760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b61036085338584036104ef565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916102b39185906103a2908690610a6e565b6104ef565b6103b133826107e2565b50565b60006103c083336101e9565b90508181101561041e5760405162461bcd60e51b8152602060048201526024808201527f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f77604482015263616e636560e01b606482015260840161034a565b61042b83338484036104ef565b61043583836107e2565b505050565b60606004805461022390610a9d565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156104cb5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161034a565b6104d833858584036104ef565b5060019392505050565b60006102b3338484610613565b6001600160a01b0383166105515760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161034a565b6001600160a01b0382166105b25760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161034a565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166106775760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161034a565b6001600160a01b0382166106d95760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161034a565b6001600160a01b038316600090815260208190526040902054818110156107515760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161034a565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290610788908490610a6e565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516107d491815260200190565b60405180910390a350505050565b6001600160a01b0382166108425760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161034a565b6001600160a01b038216600090815260208190526040902054818110156108b65760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b606482015260840161034a565b6001600160a01b03831660009081526020819052604081208383039055600280548492906108e5908490610a86565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050565b80356001600160a01b038116811461094757600080fd5b919050565b60006020828403121561095d578081fd5b61096682610930565b9392505050565b6000806040838503121561097f578081fd5b61098883610930565b915061099660208401610930565b90509250929050565b6000806000606084860312156109b3578081fd5b6109bc84610930565b92506109ca60208501610930565b9150604084013590509250925092565b600080604083850312156109ec578182fd5b6109f583610930565b946020939093013593505050565b600060208284031215610a14578081fd5b5035919050565b6000602080835283518082850152825b81811015610a4757858101830151858201604001528201610a2b565b81811115610a585783604083870101525b50601f01601f1916929092016040019392505050565b60008219821115610a8157610a81610ad8565b500190565b600082821015610a9857610a98610ad8565b500390565b600181811c90821680610ab157607f821691505b60208210811415610ad257634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fdfea26469706673582212208d98d3063eae2d6aa3e0e772fa75d2d8356f3c80dbc6eff984753729a731344964736f6c6343000804003300000000000000000000000008eec580ad41e9994599bad7d2a74a9874a2852c

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

00000000000000000000000008eec580ad41e9994599bad7d2a74a9874a2852c

-----Decoded View---------------
Arg [0] : _ownerAddress (address): 0x08eec580ad41e9994599bad7d2a74a9874a2852c

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 00000000000000000000000008eec580ad41e9994599bad7d2a74a9874a2852c


Block Transaction Difficulty Gas Used Reward
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.