Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xe497883A89B18B8a09f94473d1B5a28429e30715
Balance 0 ETH
Nonce 1
Code Size 6892 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6892 bytes
0x60806040526004361061013f575f3560e01c806370a08231116100b357806395d89b411161006d57806395d89b411461036d578063a0a797d314610258578063a9059cbb14610399578063b05df04d146103b8578063dd62ed3e146103d7578063feb1dfcc1461041b575f5ffd5b806370a08231146102b6578063715018a6146102ea578063759ca1a0146102fe5780638c0904711461031d5780638da5cb5b146103325780638f9a55c014610358575f5ffd5b806323b872dd1161010457806323b872dd1461020a578063293230b814610229578063313ce5671461023d578063515c8db8146102585780635fd9491d1461026c5780636ecdb81b14610297575f5ffd5b806306fdde031461014a578063095ea7b31461019057806318160ddd146101bf5780632169747e146101e157806322f3e2d4146101f7575f5ffd5b3661014657005b5f5ffd5b348015610155575f5ffd5b5060408051808201909152600c81526b0102a393ab2aa32b739b7b9160a51b60208201525b604051610187919061166c565b60405180910390f35b34801561019b575f5ffd5b506101af6101aa3660046116b8565b61042f565b6040519015158152602001610187565b3480156101ca575f5ffd5b506101d3610445565b604051908152602001610187565b3480156101ec575f5ffd5b506101f5610465565b005b348015610202575f5ffd5b5060016101af565b348015610215575f5ffd5b506101af6102243660046116e2565b610569565b348015610234575f5ffd5b506101f56105d0565b348015610248575f5ffd5b5060405160128152602001610187565b348015610263575f5ffd5b506101d3610699565b348015610277575f5ffd5b506102826203345081565b60405163ffffffff9091168152602001610187565b3480156102a2575f5ffd5b506101d36102b1366004611720565b6106b5565b3480156102c1575f5ffd5b506101d36102d0366004611737565b6001600160a01b03165f9081526001602052604090205490565b3480156102f5575f5ffd5b506101f56106c1565b348015610309575f5ffd5b506101f561031836600461175f565b610732565b348015610328575f5ffd5b506101d3600c5481565b34801561033d575f5ffd5b505f546040516001600160a01b039091168152602001610187565b348015610363575f5ffd5b506101d3600d5481565b348015610378575f5ffd5b506040805180820190915260048152630102a2a160e51b602082015261017a565b3480156103a4575f5ffd5b506101af6103b33660046116b8565b6107ba565b3480156103c3575f5ffd5b506101d36103d2366004611720565b6107c6565b3480156103e2575f5ffd5b506101d36103f1366004611795565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b348015610426575f5ffd5b506101f5610857565b5f61043b338484610bf9565b5060015b92915050565b5f6104526012600a6118c3565b610460906301406f406118d1565b905090565b5f546001600160a01b031633146104975760405162461bcd60e51b815260040161048e906118e8565b60405180910390fd5b600e5460ff166104e05760405162461bcd60e51b81526020600482015260146024820152733a3930b234b733903737ba103cb2ba1037b832b760611b604482015260640161048e565b6104ec6012600a6118c3565b6104fa906301406f406118d1565b600c556105096012600a6118c3565b610517906301406f406118d1565b600d557f69ada53addde5123341ce3a822c5f66292103b2771e41e1f3c00c2de8a63a7f96105476012600a6118c3565b610555906301406f406118d1565b6040519081526020015b60405180910390a1565b5f610575848484610cc5565b6105c684336105c185604051806060016040528060288152602001611a8f602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611339565b610bf9565b5060019392505050565b5f546001600160a01b031633146105f95760405162461bcd60e51b815260040161048e906118e8565b600e5460ff16156106435760405162461bcd60e51b81526020600482015260146024820152733a3930b234b7339030b63932b0b23c9037b832b760611b604482015260640161048e565b600e80546201000162ff00ff19909116179081905560408051600181526201000090920460ff16151560208301527f41a09f17206aad1ccd4bae176b5c5e0b2154e569947545c9019e6bb0cb4ef59c910161055f565b6106a56012600a6118c3565b6106b290620668a06118d1565b81565b5f61043f8260026118d1565b5f546001600160a01b031633146106ea5760405162461bcd60e51b815260040161048e906118e8565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b0316331461075b5760405162461bcd60e51b815260040161048e906118e8565b60078390556008829055600e805463ff000000191663010000008315150217905560408051848152602081018490527fd6f80a28a96b8eabc4a16d0b41123b7e8fcb21b8ddea74916307971babd3eba6910160405180910390a1505050565b5f61043b338484610cc5565b5f6203345063ffffffff8311156108175760405162461bcd60e51b8152602060048201526015602482015274313637b1b5afb73ab6afb0b9afba99991022b9391760591b604482015260640161048e565b825f6108238383611931565b905060408163ffffffff161061083d57505f949350505050565b673cb71f51fc55800063ffffffff9091161c949350505050565b5f546001600160a01b031633146108805760405162461bcd60e51b815260040161048e906118e8565b600e5460ff16156108cc5760405162461bcd60e51b81526020600482015260166024820152751cd95d1c185a5c88185b1c9958591e481c185a5c995960521b604482015260640161048e565b5f61091561090060646108fa60146108e66012600a6118c3565b6108f4906301406f406118d1565b90611371565b906113f6565b305f9081526001602052604090205490611437565b600680546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091559091506109619030906109536012600a6118c3565b6105c1906301406f406118d1565b60065f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109b1573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109d59190611958565b6001600160a01b031663c9c653963060065f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a34573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a589190611958565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610aa2573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ac69190611958565b600580546001600160a01b0319166001600160a01b039283161790556006541663f305d7194730845f803360405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610b57573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610b7c9190611973565b505060055460065460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610bd1573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610bf5919061199e565b5050565b6001600160a01b03831615801590610c1957506001600160a01b03821615155b610c655760405162461bcd60e51b815260206004820152601f60248201527f45524332303a20617070726f766520746865207a65726f206164647265737300604482015260640161048e565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831615801590610ce557506001600160a01b03821615155b610d315760405162461bcd60e51b815260206004820181905260248201527f45524332303a207472616e7366657220746865207a65726f2061646472657373604482015260640161048e565b5f8111610d925760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161048e565b5f80546001600160a01b03858116911614801590610dbd57505f546001600160a01b03848116911614155b156111fc57600e5460ff16610e4c576001600160a01b0383165f9081526003602052604090205460ff1680610e0957506001600160a01b0384165f9081526003602052604090205460ff165b610e4c5760405162461bcd60e51b81526020600482015260146024820152733a3930b234b733903737ba103cb2ba1037b832b760611b604482015260640161048e565b6005546001600160a01b038581169116148015610e7757506006546001600160a01b03848116911614155b8015610e9b57506001600160a01b0383165f9081526003602052604090205460ff16155b15610f8157600c54821115610ef25760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865205f4d617854786e416d6f756e742e000000000000604482015260640161048e565b600d5482610f14856001600160a01b03165f9081526001602052604090205490565b610f1e91906119b9565b1115610f6c5760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e000000000000604482015260640161048e565b60098054905f610f7b836119cc565b91905055505b6005546001600160a01b038481169116148015610fa757506001600160a01b0384163014155b15610fde576064610fcd601460095411610fc2576014610fc6565b6008545b8490611371565b610fd791906119e4565b9050611036565b6005546001600160a01b03858116911614801561100457506001600160a01b0383163014155b1561103657606461102960146009541161101f576014610fc6565b6007548490611371565b61103391906119e4565b90505b80600a5f82825461104791906119b9565b9091555050305f90815260016020526040902054600e54610100900460ff1615801561108057506005546001600160a01b038581169116145b80156110945750600e5462010000900460ff165b80156110b757506110a76012600a6118c3565b6110b490620668a06118d1565b81115b80156110c557506014600954115b80156110ea57506110d86012600a6118c3565b6110e590620668a06118d1565b600a54115b156111fa57600b8054905f6110fe836119cc565b909155505f90506111116012600a6118c3565b61111e90620668a06118d1565b821161112a5781611143565b6111366012600a6118c3565b61114390620668a06118d1565b90505f8185116111535784611155565b815b90506003600b54106111785761116a81611478565b5f600a819055600b5561119b565b600e546301000000900460ff1615155f0361119b5761119681611478565b5f600a555b4780156111f6576004546040515f916001600160a01b03169047908381818185875af1925050503d805f81146111ec576040519150601f19603f3d011682016040523d82523d5f602084013e6111f1565b606091505b505050505b5050505b505b801561127457305f9081526001602052604090205461121b90826115e2565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061126b9085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546112969083611437565b6001600160a01b0385165f908152600160205260409020556112d96112bb8383611437565b6001600160a01b0385165f90815260016020526040902054906115e2565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6113228585611437565b60405190815260200160405180910390a350505050565b5f818484111561135c5760405162461bcd60e51b815260040161048e919061166c565b505f61136884866119f7565b95945050505050565b5f825f0361138057505f61043f565b5f61138b83856118d1565b90508261139885836119e4565b146113ef5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161048e565b9392505050565b5f6113ef83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611640565b5f6113ef83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611339565b600e805461ff0019166101001790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106114ba576114ba611a0a565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611511573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906115359190611958565b8160018151811061154857611548611a0a565b6001600160a01b03928316602091820292909201015260065461156e9130911684610bf9565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac947906115a69085905f90869030904290600401611a1e565b5f604051808303815f87803b1580156115bd575f5ffd5b505af11580156115cf573d5f5f3e3d5ffd5b5050600e805461ff001916905550505050565b5f806115ee83856119b9565b9050838110156113ef5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161048e565b5f81836116605760405162461bcd60e51b815260040161048e919061166c565b505f61136884866119e4565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b03811681146116b5575f5ffd5b50565b5f5f604083850312156116c9575f5ffd5b82356116d4816116a1565b946020939093013593505050565b5f5f5f606084860312156116f4575f5ffd5b83356116ff816116a1565b9250602084013561170f816116a1565b929592945050506040919091013590565b5f60208284031215611730575f5ffd5b5035919050565b5f60208284031215611747575f5ffd5b81356113ef816116a1565b80151581146116b5575f5ffd5b5f5f5f60608486031215611771575f5ffd5b8335925060208401359150604084013561178a81611752565b809150509250925092565b5f5f604083850312156117a6575f5ffd5b82356117b1816116a1565b915060208301356117c1816116a1565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b6001815b600184111561181b578085048111156117ff576117ff6117cc565b600184161561180d57908102905b60019390931c9280026117e4565b935093915050565b5f826118315750600161043f565b8161183d57505f61043f565b8160018114611853576002811461185d57611879565b600191505061043f565b60ff84111561186e5761186e6117cc565b50506001821b61043f565b5060208310610133831016604e8410600b841016171561189c575081810a61043f565b6118a85f1984846117e0565b805f19048211156118bb576118bb6117cc565b029392505050565b5f6113ef60ff841683611823565b808202811582820484141761043f5761043f6117cc565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601260045260245ffd5b5f63ffffffff8316806119465761194661191d565b8063ffffffff84160491505092915050565b5f60208284031215611968575f5ffd5b81516113ef816116a1565b5f5f5f60608486031215611985575f5ffd5b5050815160208301516040909301519094929350919050565b5f602082840312156119ae575f5ffd5b81516113ef81611752565b8082018082111561043f5761043f6117cc565b5f600182016119dd576119dd6117cc565b5060010190565b5f826119f2576119f261191d565b500490565b8181038181111561043f5761043f6117cc565b634e487b7160e01b5f52603260045260245ffd5b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b81811015611a6e5783516001600160a01b0316835260209384019390920191600101611a47565b50506001600160a01b03959095166060840152505060800152939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122003212025b0b1c6b10362d24db667d00063e795698ea1173359a6c747ef6d8e7c64736f6c634300081e0033

Verified Source Code Partial Match

Compiler: v0.8.30+commit.73712a01 EVM: prague Optimization: Yes (200 runs)
TrueTensor.sol 498 lines
/* @title TrueTensor
 *
 * @description
 *   Core logic for computing block rewards using a halving schedule.
 *   The subsidy decreases at regular intervals (similar to Bitcoin),
 *   and is used as a foundational piece for chain economics and miner incentives.
 *
 * @dev
 *   Written in Solidity for integration with EVM-compatible networks.
 *   Includes precise halving logic and safe conversions for block numbers and rewards.
 *
 *   Web: https://truetensor.com
 *   X (Twitter): https://x.com/truetensor
 *   Telegram: https://t.me/truetensor
 *
 */
// SPDX-License-Identifier: MIT
pragma solidity 0.8.30;

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

pragma solidity ^0.8.0;

/* @title IBlockSubsidy
 *
 * @notice Interface for calculating block subsidies using a halving schedule.
 * @dev Implementers should ensure safe handling of block number conversions and halving logic.
 */

interface IBlockSubsidy {
    /**
     * @notice Calculates the block subsidy based on halving logic.
     * @param blockNumber The block number.
     * @return subsidy The calculated block subsidy.
     */
    function getBlockSubsidy(uint256 blockNumber) external pure returns (uint256 subsidy);
}


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
    );
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;
        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, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }
}

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 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);
    }
}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );
}

contract TrueTensor is Context, IERC20, Ownable {
    using SafeMath for uint256;

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExcludedFromFee;
    address payable private _treasuryWallet;
    address private uniswapV2Pair;
    IUniswapV2Router02 private uniswapV2Router;


    uint32 public constant HALVING_INTERVAL = 210000;
    uint256 private constant _initialBuyFee = 20;
    uint256 private constant _initialSellFee = 20;
    uint256 private constant _reduceBuyFeeAt = 20;
    uint256 private constant _reduceSellFeeAt = 20;
    uint256 private constant _preventSwapBefore = 20;
    uint256 private _finalBuyFees = 0;
    uint256 private _finalSellFees = 0;
    uint256 private _buyCount = 0;
    uint256 private _countFee;
    uint256 private _countSwapTx;
    

    string private constant _name = unicode" TrueTensor ";
    string private constant _symbol = unicode" TT ";
    uint8 private constant _decimals = 18;
    uint256 private constant _totalSupply = 21_000_000 * 10**_decimals;
    uint256 private constant _countTrigger = 420_000 * 10**_decimals;
    uint256 public constant _FeeSwapThreshold = 420_000 * 10**_decimals;
    uint256 public constant _maxFeeSwap = 420_000 * 10**_decimals;
    uint256 public _MaxTxnAmount = 420_000 * 10**_decimals;
    uint256 public _maxWalletSize = 420_000 * 10**_decimals;

    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool private guard = false;

    event FinalFees(uint256 _valueBuy, uint256 _valueSell);
    event TradingActive(bool _tradingOpen, bool _swapEnabled);
    event maxAmount(uint256 _value);

    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor(address treasuryWallet) {
        _treasuryWallet = payable(treasuryWallet);
        _balances[owner()] = _totalSupply;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[_treasuryWallet] = true;
        _isExcludedFromFee[address(this)] = true;

        emit Transfer(address(0), owner(), _totalSupply);
    }

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

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

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

    function totalSupply() public pure override returns (uint256) {
        return _totalSupply;
    }

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

    function transfer(address recipient, uint256 amount)
        public
        override
        returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

    function approve(address spender, uint256 amount)
        public
        override
        returns (bool)
    {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) private {
        require(
            owner != address(0) && spender != address(0),
            "ERC20: approve the zero address"
        );
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(
            from != address(0) && to != address(0),
            "ERC20: transfer the zero address"
        );
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 FeeAmount = 0;

        if (from != owner() && to != owner()) {
            if (!tradingOpen) {
                require(
                    _isExcludedFromFee[to] || _isExcludedFromFee[from],
                    "trading not yet open"
                );
            }

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && !_isExcludedFromFee[to] ) {
                require(amount <= _MaxTxnAmount, "Exceeds the _MaxTxnAmount.");
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
                _buyCount++;
            }

            if (to == uniswapV2Pair && from != address(this)) {
                FeeAmount = amount.mul((_buyCount > _reduceSellFeeAt) ? _finalSellFees : _initialSellFee)/100;
            } else if (from == uniswapV2Pair && to != address(this)) {
                FeeAmount = amount.mul((_buyCount > _reduceBuyFeeAt) ? _finalBuyFees : _initialBuyFee )/100;
            }

            _countFee += FeeAmount;
            uint256 contractTokenBalance = balanceOf(address(this));

            if ( 
                !inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _FeeSwapThreshold &&
                _buyCount > _preventSwapBefore && _countFee > _countTrigger
            ) {
                _countSwapTx++;
                uint256 getMinValue = (contractTokenBalance > _maxFeeSwap)? _maxFeeSwap: contractTokenBalance;
                uint256 getValue = (amount > getMinValue) ? getMinValue : amount;

                if (_countSwapTx >= 3 ) { 
                    swapTokensForEth(getValue); 
                    _countFee = 0; 
                    _countSwapTx = 0;
                } else if (guard == false) { 
                    swapTokensForEth(getValue);
                     _countFee = 0; 
                }

                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                bool success;
                (success, ) = address(_treasuryWallet).call{ value: address(this).balance }("");
                }
            }
        }

        if (FeeAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(FeeAmount);
            emit Transfer(from, address(this), FeeAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(FeeAmount));
        emit Transfer(from, to, amount.sub(FeeAmount));
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

     /// @notice imulate an action.
    /// @param input Any uint256 input.
    /// @return output Returns input multiplied by 2.
    function multiplyByTwo(uint256 input) public pure returns (uint256 output) {
        return input * 2;
    }
    /// @notice check if contract is active.
    /// @return Always returns true.
    function isActive() public pure returns (bool) {
        return true;
    }
    /**
     * @notice initialize getting pair tarding
     */
    function initPair() external onlyOwner {
        require(!tradingOpen, "setpair already paired");
        uint256 tokenAmount = balanceOf(address(this)).sub(_totalSupply.mul(_initialBuyFee).div(100));
        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        ); 
        _approve(address(this), address(uniswapV2Router), _totalSupply);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            uniswapV2Router.WETH()
        );
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            tokenAmount,
            0,
            0,
            _msgSender(),
            block.timestamp
        );
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );
    }

    /**
     * @notice startTrading 
     */
    function startTrading() external onlyOwner {
        require(!tradingOpen, "trading already open");
        swapEnabled = true;
        tradingOpen = true;
        emit TradingActive(tradingOpen, swapEnabled);
    }

    /**
     * @notice remove limit buy amount and limit max wallet. 
     */
    function maxAmntLimits () external onlyOwner {
        require(tradingOpen, "trading not yet open");
        _MaxTxnAmount = _totalSupply;
        _maxWalletSize = _totalSupply;
        emit maxAmount(_totalSupply);
    }

    /**
     * @notice configuration Fee.
     * @param _valueBuy Fee for buy.
     * @param _valueSell Fee for sell.
     * @param _guard protection of uncloged.
     */
    function FeeConfig (uint256 _valueBuy, uint256 _valueSell, bool _guard) external onlyOwner {
        _finalBuyFees = _valueBuy;
        _finalSellFees = _valueSell;
        guard = _guard;
        emit FinalFees(_valueBuy, _valueSell);
    }
    
    
       function getBlockSubsidy(uint256 blockNumber) public pure returns (uint256 subsidy) {
        uint32 halvingInterval = HALVING_INTERVAL;

        require(blockNumber <= type(uint32).max, "block_num_as_u32 Err.");
        uint32 blockNumAsU32 = uint32(blockNumber);

        uint32 halvings = blockNumAsU32 / halvingInterval;

        if (halvings >= 64) {
            return 0;
        }

        uint256 costInU128 = 4375000000000000000; // Subsidy
        costInU128 >>= halvings;

        return costInU128;
        
    }

    receive() external payable {}
}

Read Contract

HALVING_INTERVAL 0x5fd9491d → uint32
_FeeSwapThreshold 0xa0a797d3 → uint256
_MaxTxnAmount 0x8c090471 → uint256
_maxFeeSwap 0x515c8db8 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getBlockSubsidy 0xb05df04d → uint256
isActive 0x22f3e2d4 → bool
multiplyByTwo 0x6ecdb81b → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 8 functions

These functions modify contract state and require a wallet transaction to execute.

FeeConfig 0x759ca1a0
uint256 _valueBuy
uint256 _valueSell
bool _guard
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
initPair 0xfeb1dfcc
No parameters
maxAmntLimits 0x2169747e
No parameters
renounceOwnership 0x715018a6
No parameters
startTrading 0x293230b8
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address