UbuntuToken

Description:

ERC20 token contract with Factory capabilities. Standard implementation for fungible tokens on Ethereum.

Blockchain: Ethereum

Source Code: View Code On The Blockchain

Solidity Source Code:

{{
  "language": "Solidity",
  "sources": {
    "contracts/Context.sol": {
      "content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
/**\r
 * @dev Provides information about the current execution context.\r
 */\r
abstract contract Context {\r
    function _msgSender() internal view virtual returns (address) {\r
        return msg.sender;\r
    }\r
\r
    function _msgData() internal view virtual returns (bytes calldata) {\r
        return msg.data;\r
    }\r
}"
    },
    "contracts/ERC20.sol": {
      "content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
import "./Context.sol";\r
import "./IERC20Metadata.sol";\r
\r
/**\r
 * @dev Implementation of the ERC20 interface.\r
 */\r
contract ERC20 is Context, IERC20Metadata {\r
    mapping(address => uint256) private _balances;\r
    mapping(address => mapping(address => uint256)) private _allowances;\r
\r
    uint256 private _totalSupply;\r
    string private _name;\r
    string private _symbol;\r
\r
    constructor(string memory name_, string memory symbol_) {\r
        _name = name_;\r
        _symbol = symbol_;\r
    }\r
\r
    function name() public view virtual override returns (string memory) {\r
        return _name;\r
    }\r
\r
    function symbol() public view virtual override returns (string memory) {\r
        return _symbol;\r
    }\r
\r
    function decimals() public view virtual override returns (uint8) {\r
        return 18;\r
    }\r
\r
    function totalSupply() public view virtual override returns (uint256) {\r
        return _totalSupply;\r
    }\r
\r
    function balanceOf(address account) public view virtual override returns (uint256) {\r
        return _balances[account];\r
    }\r
\r
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {\r
        address sender = _msgSender();\r
        _transfer(sender, recipient, amount);\r
        return true;\r
    }\r
\r
    function allowance(address owner, address spender) public view virtual override returns (uint256) {\r
        return _allowances[owner][spender];\r
    }\r
\r
    function approve(address spender, uint256 amount) public virtual override returns (bool) {\r
        address sender = _msgSender();\r
        _approve(sender, spender, amount);\r
        return true;\r
    }\r
\r
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {\r
        address caller = _msgSender();\r
        _spendAllowance(sender, caller, amount);\r
        _transfer(sender, recipient, amount);\r
        return true;\r
    }\r
\r
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\r
        address sender = _msgSender();\r
        _approve(sender, spender, _allowances[sender][spender] + addedValue);\r
        return true;\r
    }\r
\r
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\r
        address sender = _msgSender();\r
        uint256 currentAllowance = _allowances[sender][spender];\r
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");\r
        _approve(sender, spender, currentAllowance - subtractedValue);\r
        return true;\r
    }\r
\r
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {\r
        require(sender != address(0), "ERC20: transfer from zero address");\r
        require(recipient != address(0), "ERC20: transfer to zero address");\r
\r
        uint256 senderBalance = _balances[sender];\r
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");\r
\r
        unchecked {\r
            _balances[sender] = senderBalance - amount;\r
        }\r
\r
        _balances[recipient] += amount;\r
        emit Transfer(sender, recipient, amount);\r
    }\r
\r
    function _mint(address account, uint256 amount) internal virtual {\r
        require(account != address(0), "ERC20: mint to zero address");\r
\r
        _totalSupply += amount;\r
        _balances[account] += amount;\r
        emit Transfer(address(0), account, amount);\r
    }\r
\r
    function _approve(address owner, address spender, uint256 amount) internal virtual {\r
        require(owner != address(0), "ERC20: approve from zero address");\r
        require(spender != address(0), "ERC20: approve to zero address");\r
\r
        _allowances[owner][spender] = amount;\r
        emit Approval(owner, spender, amount);\r
    }\r
\r
    function _spendAllowance(address owner, address spender, uint256 amount) internal virtual {\r
        uint256 currentAllowance = allowance(owner, spender);\r
        if (currentAllowance != type(uint256).max) {\r
            require(currentAllowance >= amount, "ERC20: insufficient allowance");\r
            unchecked {\r
                _approve(owner, spender, currentAllowance - amount);\r
            }\r
        }\r
    }\r
}"
    },
    "contracts/IERC20.sol": {
      "content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
/**\r
 * @dev Interface of the ERC20 standard as defined in the EIP.\r
 */\r
interface IERC20 {\r
    function totalSupply() external view returns (uint256);\r
    function balanceOf(address account) external view returns (uint256);\r
    function transfer(address recipient, uint256 amount) external returns (bool);\r
    function allowance(address owner, address spender) external view returns (uint256);\r
    function approve(address spender, uint256 amount) external returns (bool);\r
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);\r
\r
    event Transfer(address indexed from, address indexed to, uint256 value);\r
    event Approval(address indexed owner, address indexed spender, uint256 value);\r
}"
    },
    "contracts/IERC20Metadata.sol": {
      "content": "// SPDX-License-Identifier: MIT\r
\r
pragma solidity ^0.8.19;\r
\r
import "./IERC20.sol";\r
\r
/**\r
 * @dev Interface for the optional metadata functions from the ERC20 standard.\r
 */\r
interface IERC20Metadata is IERC20 {\r
    function name() external view returns (string memory);\r
    function symbol() external view returns (string memory);\r
    function decimals() external view returns (uint8);\r
}"
    },
    "contracts/UbuntuToken.sol": {
      "content": "// SPDX-License-Identifier: MIT

pragma solidity ^0.8.19;

import "./ERC20.sol";

/**
 * @dev Ubuntu Token Contract
 */
contract UbuntuToken is ERC20 {
    constructor() ERC20("Ubuntu", "Ubuntu") {
        _mint(msg.sender, 10_000_000_000 * 10 ** decimals());
    }

    function decimals() public view virtual override returns (uint8) {
        return 6;
    }
}"
    }
  },
  "settings": {
    "optimizer": {
      "enabled": true,
      "runs": 200
    },
    "outputSelection": {
      "*": {
        "*": [
          "evm.bytecode",
          "evm.deployedBytecode",
          "devdoc",
          "userdoc",
          "metadata",
          "abi"
        ]
      }
    }
  }
}}

Tags:
ERC20, Token, Factory|addr:0x3350821f4badba0e3f24a83b87fafe9ae889de0f|verified:true|block:23670247|tx:0xe7304cba76d7924c28d4b4d23f242180b226054b03b7405849ba5277d4426ce8|first_check:1761589460

Submitted on: 2025-10-27 19:24:21

Comments

Log in to comment.

No comments yet.