Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x2925E289cbc1c5fdBa34B62148FB540B5bA14A90
Balance 0 ETH
Nonce 1
Code Size 6606 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6606 bytes
0x6080604052600436106101fd5760003560e01c8063844d591c1161010d578063b2bdfa7b116100a0578063da00097d1161006f578063da00097d146105d6578063dd62ed3e146105f7578063f0cd1dac1461063d578063f2fde38b14610653578063fae926121461067357600080fd5b8063b2bdfa7b14610551578063c49b9a8014610571578063c816841b14610591578063d158272d146105b157600080fd5b8063a073d37f116100dc578063a073d37f146104dc578063a457c2d7146104f1578063a5d69d1f14610511578063a9059cbb1461053157600080fd5b8063844d591c146104745780638da5cb5b14610494578063914eb66a146104b257806395d89b41146104c757600080fd5b8063395093511161019057806352f7c9881161015f57806352f7c988146103c55780635342acb4146103e5578063557ed1ba1461041557806370a082311461042857806382eefb431461045e57600080fd5b806339509351146103325780633b97084a146103525780633ecad271146103745780634a74bb02146103a457600080fd5b806323b872dd116101cc57806323b872dd146102bb57806327c8f835146102db5780632b112e49146102fb578063313ce5671461031057600080fd5b806306fdde0314610209578063095ea7b3146102345780631694505e1461026457806318160ddd1461029c57600080fd5b3661020457005b600080fd5b34801561021557600080fd5b5061021e610693565b60405161022b91906115ca565b60405180910390f35b34801561024057600080fd5b5061025461024f366004611630565b610725565b604051901515815260200161022b565b34801561027057600080fd5b50600d54610284906001600160a01b031681565b6040516001600160a01b03909116815260200161022b565b3480156102a857600080fd5b50600b545b60405190815260200161022b565b3480156102c757600080fd5b506102546102d636600461165c565b61073c565b3480156102e757600080fd5b50600454610284906001600160a01b031681565b34801561030757600080fd5b506102ad6107a7565b34801561031c57600080fd5b5060035460405160ff909116815260200161022b565b34801561033e57600080fd5b5061025461034d366004611630565b6107d3565b34801561035e57600080fd5b5061037261036d36600461169d565b610809565b005b34801561038057600080fd5b5061025461038f3660046116b6565b60086020526000908152604090205460ff1681565b3480156103b057600080fd5b50600e5461025490600160a81b900460ff1681565b3480156103d157600080fd5b506103726103e03660046116d3565b610841565b3480156103f157600080fd5b506102546104003660046116b6565b60076020526000908152604090205460ff1681565b34801561042157600080fd5b50426102ad565b34801561043457600080fd5b506102ad6104433660046116b6565b6001600160a01b031660009081526005602052604090205490565b34801561046a57600080fd5b506102ad600a5481565b34801561048057600080fd5b5061037261048f36600461170a565b610876565b3480156104a057600080fd5b506000546001600160a01b0316610284565b3480156104be57600080fd5b506103726108cb565b3480156104d357600080fd5b5061021e61093f565b3480156104e857600080fd5b50600c546102ad565b3480156104fd57600080fd5b5061025461050c366004611630565b61094e565b34801561051d57600080fd5b5061037261052c36600461173f565b61099d565b34801561053d57600080fd5b5061025461054c366004611630565b6109e5565b34801561055d57600080fd5b50600054610284906001600160a01b031681565b34801561057d57600080fd5b5061037261058c36600461173f565b6109f2565b34801561059d57600080fd5b50600e54610284906001600160a01b031681565b3480156105bd57600080fd5b506003546102849061010090046001600160a01b031681565b3480156105e257600080fd5b50600e5461025490600160b01b900460ff1681565b34801561060357600080fd5b506102ad61061236600461175a565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b34801561064957600080fd5b506102ad60095481565b34801561065f57600080fd5b5061037261066e3660046116b6565b610a74565b34801561067f57600080fd5b5061037261068e3660046116b6565b610b5e565b6060600180546106a290611793565b80601f01602080910402602001604051908101604052809291908181526020018280546106ce90611793565b801561071b5780601f106106f05761010080835404028352916020019161071b565b820191906000526020600020905b8154815290600101906020018083116106fe57829003601f168201915b5050505050905090565b6000610732338484610bb0565b5060015b92915050565b6000610749848484610cd4565b5061079c84336107978560405180606001604052806028815260200161194c602891396001600160a01b038a1660009081526006602090815260408083203384529091529020549190610ff3565b610bb0565b5060015b9392505050565b6004546001600160a01b0316600090815260056020526040812054600b546107ce9161102d565b905090565b3360008181526006602090815260408083206001600160a01b03871684529091528120549091610732918590610797908661106f565b6000546001600160a01b0316331461083c5760405162461bcd60e51b8152600401610833906117cd565b60405180910390fd5b600c55565b6000546001600160a01b0316331461086b5760405162461bcd60e51b8152600401610833906117cd565b600991909155600a55565b6000546001600160a01b031633146108a05760405162461bcd60e51b8152600401610833906117cd565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146108f55760405162461bcd60e51b8152600401610833906117cd565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600280546106a290611793565b6000610732338461079785604051806060016040528060258152602001611974602591393360009081526006602090815260408083206001600160a01b038d1684529091529020549190610ff3565b6000546001600160a01b031633146109c75760405162461bcd60e51b8152600401610833906117cd565b600e8054911515600160b01b0260ff60b01b19909216919091179055565b600061079c338484610cd4565b6000546001600160a01b03163314610a1c5760405162461bcd60e51b8152600401610833906117cd565b600e8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc15990610a6990831515815260200190565b60405180910390a150565b6000546001600160a01b03163314610a9e5760405162461bcd60e51b8152600401610833906117cd565b6001600160a01b038116610b035760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610833565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314610b885760405162461bcd60e51b8152600401610833906117cd565b600380546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b6001600160a01b038316610c125760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610833565b6001600160a01b038216610c735760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610833565b6001600160a01b0383811660008181526006602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416610d3a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610833565b6001600160a01b038316610d9c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610833565b60008211610dfe5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610833565b600e54600160a01b900460ff1615610e2257610e1b8484846110ce565b90506107a0565b30600090815260056020526040902054600c5481108015908190610e505750600e54600160a01b900460ff16155b8015610e7557506001600160a01b03861660009081526008602052604090205460ff16155b8015610e8a5750600e54600160a81b900460ff165b15610eb057600e54600160b01b900460ff1615610ea757600c5491505b610eb0826111b4565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260059091529190912054610f02918690610ff3565b6001600160a01b038716600090815260056020908152604080832093909355600790529081205460ff1680610f4f57506001600160a01b03861660009081526007602052604090205460ff165b610f6357610f5e878787611203565b610f65565b845b6001600160a01b038716600090815260056020526040902054909150610f8b908261106f565b6001600160a01b0380881660008181526005602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fdf9085815260200190565b60405180910390a3600193505050506107a0565b600081848411156110175760405162461bcd60e51b815260040161083391906115ca565b5060006110248486611818565b95945050505050565b60006107a083836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610ff3565b60008061107c838561182b565b9050838110156107a05760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610833565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038616600090815260059091529182205461111f918490610ff3565b6001600160a01b03808616600090815260056020526040808220939093559085168152205461114e908361106f565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111a29086815260200190565b60405180910390a35060019392505050565b600e805460ff60a01b1916600160a01b1790556111d08161130f565b4780156111f2576003546111f29061010090046001600160a01b0316826114a2565b5050600e805460ff60a01b19169055565b6001600160a01b038316600090815260086020526040812054819060ff161561124d576112466064611240600954866114dd90919063ffffffff16565b9061155f565b905061128b565b6001600160a01b03841660009081526008602052604090205460ff161561128b576112886064611240600a54866114dd90919063ffffffff16565b90505b801561130557306000908152600560205260409020546112ab908261106f565b30600081815260056020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112fc9085815260200190565b60405180910390a35b611024838261102d565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106113445761134461183e565b6001600160a01b03928316602091820292909201810191909152600d54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa15801561139d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113c19190611854565b816001815181106113d4576113d461183e565b6001600160a01b039283166020918202929092010152600d546113fa9130911684610bb0565b600d5460405163791ac94760e01b81526001600160a01b039091169063791ac947906114339085906000908690309042906004016118b5565b600060405180830381600087803b15801561144d57600080fd5b505af1158015611461573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a782826040516114969291906118f1565b60405180910390a15050565b6040516001600160a01b0383169082156108fc029083906000818181858888f193505050501580156114d8573d6000803e3d6000fd5b505050565b6000826000036114ef57506000610736565b60006114fb8385611912565b9050826115088583611929565b146107a05760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610833565b60006107a083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250600081836115bd5760405162461bcd60e51b815260040161083391906115ca565b5060006110248486611929565b600060208083528351808285015260005b818110156115f7578581018301518582016040015282016115db565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461162d57600080fd5b50565b6000806040838503121561164357600080fd5b823561164e81611618565b946020939093013593505050565b60008060006060848603121561167157600080fd5b833561167c81611618565b9250602084013561168c81611618565b929592945050506040919091013590565b6000602082840312156116af57600080fd5b5035919050565b6000602082840312156116c857600080fd5b81356107a081611618565b600080604083850312156116e657600080fd5b50508035926020909101359150565b8035801515811461170557600080fd5b919050565b6000806040838503121561171d57600080fd5b823561172881611618565b9150611736602084016116f5565b90509250929050565b60006020828403121561175157600080fd5b6107a0826116f5565b6000806040838503121561176d57600080fd5b823561177881611618565b9150602083013561178881611618565b809150509250929050565b600181811c908216806117a757607f821691505b6020821081036117c757634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b8181038181111561073657610736611802565b8082018082111561073657610736611802565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561186657600080fd5b81516107a081611618565b600081518084526020808501945080840160005b838110156118aa5781516001600160a01b031687529582019590820190600101611885565b509495945050505050565b85815284602082015260a0604082015260006118d460a0830186611871565b6001600160a01b0394909416606083015250608001529392505050565b82815260406020820152600061190a6040830184611871565b949350505050565b808202811582820484141761073657610736611802565b60008261194657634e487b7160e01b600052601260045260246000fd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212208828841ae0b3c3ab5a07dc5a86d5febb5f9a6834a0cb22a388f48dbf2c77408264736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: Yes (200 runs)
Bitcoin.sol 526 lines
// SPDX-License-Identifier: Unlicensed
pragma solidity ^0.8.4;

abstract contract Context {

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

    function _msgData() internal view virtual returns (bytes memory) {
        this;
        // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

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;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

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

    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

library Address {

    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly {codehash := extcodehash(account)}
        return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success,) = recipient.call{ value : amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{ value : weiValue}(data);
        if (success) {
            return returndata;
        } else {

            if (returndata.length > 0) {
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

contract Ownable is Context {
    address public _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);


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

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

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

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }

    function getTime() public view returns (uint256) {
        return block.timestamp;
    }

}

interface IUniswapV2Factory {

    function getPair(address tokenA, address tokenB) external view returns (address pair);

    function createPair(address tokenA, address tokenB) external returns (address pair);

}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);

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

    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);


}

interface IUniswapV2Router02 is IUniswapV2Router01 {

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}


contract Bitcoin is Context, IERC20, Ownable {

    using SafeMath for uint256;
    using Address for address;

    string private _name;
    string private _symbol;
    uint8 private _decimals;
    address payable public marketingWalletAddress = payable(0xB30a8b68A0d545B30d5058bC6Ae8383010FC5a49);
    address public deadAddress = 0x000000000000000000000000000000000000dEaD;

    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) private _allowances;

    mapping (address => bool) public isExcludedFromFee;
    mapping (address => bool) public isMarketPair;


    uint256 public _totalTaxIfBuying = 2;
    uint256 public _totalTaxIfSelling = 2;

    uint256 private _totalSupply;
    uint256 private _minimumTokensBeforeSwap = 0;



    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapPair;

    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = true;
    bool public swapAndLiquifyByLimitOnly = false;

    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );

    event SwapETHForTokens(
        uint256 amountIn,
        address[] path
    );

    event SwapTokensForETH(
        uint256 amountIn,
        address[] path
    );

    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }


    constructor (
        string memory coinName,
        string memory coinSymbol
    ) payable {

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

        uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());
        _name = coinName;
        _symbol = coinSymbol;
        _decimals = 0;
        _owner = 0xFB23Cb0Be6c825FACC01462cf72cF1794BBd82F0;
        _totalSupply = 100000000000000000000000000000000;
        _minimumTokensBeforeSwap = 1000000000000000000000000000;
        uniswapV2Router = _uniswapV2Router;
        _allowances[address(this)][address(uniswapV2Router)] = _totalSupply;
        isExcludedFromFee[msg.sender] = true;
        isExcludedFromFee[_owner] = true;
        isExcludedFromFee[address(this)] = true;
        isExcludedFromFee[marketingWalletAddress] = true;

        isMarketPair[address(uniswapPair)] = true;

        _balances[_owner] = _totalSupply;
        emit Transfer(address(0), _owner, _totalSupply);
    }


    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 totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }

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

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

    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }

    function minimumTokensBeforeSwapAmount() public view returns (uint256) {
        return _minimumTokensBeforeSwap;
    }

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

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function setMarketPairStatus(address account, bool newValue) public onlyOwner {
        isMarketPair[account] = newValue;
    }

    function setNumTokensBeforeSwap(uint256 newLimit) external onlyOwner() {
        _minimumTokensBeforeSwap = newLimit;
    }

    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }

    function setSwapAndLiquifyByLimitOnly(bool newValue) public onlyOwner {
        swapAndLiquifyByLimitOnly = newValue;
    }

    function setFee(uint256 buy,uint256 sell) public onlyOwner {
        _totalTaxIfBuying = buy;
        _totalTaxIfSelling = sell;
    }

    function setMarketAddress(address addr) public onlyOwner {
        marketingWalletAddress = payable(addr);
    }

    function getCirculatingSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(deadAddress));
    }

    function transferToAddressETH(address payable recipient, uint256 amount) private {
        recipient.transfer(amount);
    }
    
     //to recieve ETH from uniswapV2Router when swaping
    receive() external payable {}

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, 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 _transfer(address sender, address recipient, uint256 amount) private returns (bool) {

        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        

        if(inSwapAndLiquify)
        {
            return _basicTransfer(sender, recipient, amount);
        }
        else
        {

            uint256 contractTokenBalance = balanceOf(address(this));
            bool overMinimumTokenBalance = contractTokenBalance >= _minimumTokensBeforeSwap;

            if (overMinimumTokenBalance && !inSwapAndLiquify && !isMarketPair[sender] && swapAndLiquifyEnabled)
            {
                if(swapAndLiquifyByLimitOnly)
                    contractTokenBalance = _minimumTokensBeforeSwap;
                swapAndLiquify(contractTokenBalance);
            }

            _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");

            uint256 finalAmount = (isExcludedFromFee[sender] || isExcludedFromFee[recipient]) ?
                                         amount : takeFee(sender, recipient, amount);


            _balances[recipient] = _balances[recipient].add(finalAmount);

            emit Transfer(sender, recipient, finalAmount);
            return true;
        }
    }

    function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }


    function swapAndLiquify(uint256 tAmount) private lockTheSwap {

        // swap token -> eth
        swapTokensForEth(tAmount);
        uint256 amountReceived = address(this).balance;
         
        if(amountReceived > 0)
            transferToAddressETH(marketingWalletAddress, amountReceived);

    }

    function swapTokensForEth(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this), // The contract
            block.timestamp
        );

        emit SwapTokensForETH(tokenAmount, path);
    }



    function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) {

        uint256 feeAmount = 0;
        if(isMarketPair[sender]) {
            feeAmount = amount.mul(_totalTaxIfBuying).div(100);
        }
        else if(isMarketPair[recipient]) {
            feeAmount = amount.mul(_totalTaxIfSelling).div(100);
        }
        if(feeAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(feeAmount);
            emit Transfer(sender, address(this), feeAmount);
        }

        return amount.sub(feeAmount);
    }

   
}

Read Contract

_owner 0xb2bdfa7b → address
_totalTaxIfBuying 0xf0cd1dac → uint256
_totalTaxIfSelling 0x82eefb43 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
getCirculatingSupply 0x2b112e49 → uint256
getTime 0x557ed1ba → uint256
isExcludedFromFee 0x5342acb4 → bool
isMarketPair 0x3ecad271 → bool
marketingWalletAddress 0xd158272d → address
minimumTokensBeforeSwapAmount 0xa073d37f → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapAndLiquifyByLimitOnly 0xda00097d → bool
swapAndLiquifyEnabled 0x4a74bb02 → bool
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapPair 0xc816841b → address
uniswapV2Router 0x1694505e → address

Write Contract 13 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
setFee 0x52f7c988
uint256 buy
uint256 sell
setMarketAddress 0xfae92612
address addr
setMarketPairStatus 0x844d591c
address account
bool newValue
setNumTokensBeforeSwap 0x3b97084a
uint256 newLimit
setSwapAndLiquifyByLimitOnly 0xa5d69d1f
bool newValue
setSwapAndLiquifyEnabled 0xc49b9a80
bool _enabled
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
waiveOwnership 0x914eb66a
No parameters

Recent Transactions

No transactions found for this address