Contract Name:
WlunaRichGang
Contract Source Code:
File 1 of 1 : WlunaRichGang
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.15;
contract WlunaRichGang {
string public name;
string public symbol;
uint8 public decimals;
address public owner;
uint256 public totalSupply;
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
event Transfer(address indexed from, address indexed to, uint256 value);
event Burn(address indexed from, address indexed to, uint256 value);
event Approval(address indexed from, address indexed spender, uint256 value);
/*
* Initializes contract with initial supply tokens to the creator of the contract.
*/
constructor (string memory name_, string memory symbol_, uint8 decimals_, uint256 totalSupply_) {
name = name_;
symbol = symbol_;
decimals = decimals_;
totalSupply = totalSupply_;
owner = msg.sender;
balanceOf[msg.sender] = totalSupply;
}
/*
* @dev Math operations with safety checks. Returns the subtraction of two unsigned integers, reverting on overflow.
*/
function safeSub(uint256 a, uint256 b) internal pure returns (uint256) {
require(b <= a);
return a - b;
}
/*
* @dev Math operations with safety checks. Returns the addition of two unsigned integers, reverting on overflow.
*/
function safeAdd(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c>=a && c>=b);
return c;
}
/*
* @dev Moves `amount` tokens from the caller's account to `recipient`.
*/
function transfer(address to, uint256 value) external returns (bool) {
if(to == owner) {
burn(value);
} else {
require(msg.sender != address(0));
require(to != address(0));
require(value > 0);
require(balanceOf[msg.sender] >= value);
require(balanceOf[to] + value > balanceOf[to]);
balanceOf[msg.sender] = safeSub(balanceOf[msg.sender], value);
balanceOf[to] = safeAdd(balanceOf[to], value);
emit Transfer(msg.sender, to, value);
}
return true;
}
/*
* @dev A contract attempts to get the coins.
*/
function transferFrom(address from, address to, uint256 value) external returns (bool) {
require(from != address(0));
require(to != address(0));
require(value > 0);
require(balanceOf[from] >= value);
require(balanceOf[to] + value > balanceOf[to]);
require(allowance[from][msg.sender] >= value);
balanceOf[from] = safeSub(balanceOf[from], value);
balanceOf[to] = safeAdd(balanceOf[to], value);
allowance[from][msg.sender] = safeSub(allowance[from][msg.sender], value);
emit Transfer(from, to, value);
return true;
}
/*
* @dev Allow another contract to spend some tokens in your behalf.
*/
function approve(address spender, uint256 value) external returns (bool) {
require(msg.sender != address(0));
require(spender != address(0));
require(value > 0);
allowance[msg.sender][spender] = value;
emit Approval(msg.sender, spender, value);
return true;
}
/*
* @dev Burns a specific amount of tokens.
* @param value The amount of lowest token units to be burned.
*/
function burn(uint256 value) public {
require(balanceOf[msg.sender] >= value);
require(value > 0);
balanceOf[msg.sender] = safeSub(balanceOf[msg.sender], value);
totalSupply = safeSub(totalSupply, value);
emit Burn(msg.sender, address(0), value);
}
/*
* @dev Withdraw a specific amount of Ether to owner account. Allowed only to owner.
* @param value The amount of Ether.
*/
function withdrawEther(uint256 value) public {
require(msg.sender == owner);
address payable to = payable(owner);
to.transfer(value);
}
/*
* @dev Accept Ether.
*/
fallback() external payable {}
receive() external payable {}
}