Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x3477c6074bEe6842dE7c8337206b739ECd851fce
Balance 0 ETH
Nonce 1
Code Size 8601 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8601 bytes
0x6080604052600436106102815760003560e01c806375f0a8741161014f578063a9059cbb116100c1578063e01af92c1161007a578063e01af92c146107d7578063e545fd6d146107f7578063e9dae5ed14610817578063f2fde38b14610837578063f66895a314610857578063f887ea401461087657600080fd5b8063a9059cbb146106eb578063aa4bde281461070b578063aacebbe314610721578063c18bc19514610741578063dbe66ca014610761578063dd62ed3e1461079157600080fd5b80638ea5220f116101135780638ea5220f1461063657806395d89b41146106565780639d0014b11461066b5780639e252f001461068b578063a457c2d7146106ab578063a8aa1b31146106cb57600080fd5b806375f0a8741461058a57806382aa7c68146105c25780638c0b5e22146105e25780638cd4426d146105f85780638da5cb5b1461061857600080fd5b8063293b7ef4116101f357806350c9a88f116101ac57806350c9a88f146104ae5780636256d181146104c45780636ddd1713146104e457806370a0823114610505578063715018a61461053b578063728f8eea1461055057600080fd5b8063293b7ef4146103eb578063313ce56714610401578063395093511461041d5780633bbac5791461043d57806340b28c2f1461046d5780634ada218b1461048d57600080fd5b806318160ddd1161024557806318160ddd1461034a5780631816467f1461035f5780632253163d1461037f57806323b872dd1461039557806326b5d32f146103b5578063274a533c146103d557600080fd5b806303c0f5d41461028d5780630445b667146102af57806306fdde03146102d857806308733214146102fa578063095ea7b31461031a57600080fd5b3661028857005b600080fd5b34801561029957600080fd5b506102ad6102a8366004611dcf565b610896565b005b3480156102bb57600080fd5b506102c5600a5481565b6040519081526020015b60405180910390f35b3480156102e457600080fd5b506102ed6108f4565b6040516102cf9190611e08565b34801561030657600080fd5b506102ad610315366004611e5d565b610986565b34801561032657600080fd5b5061033a610335366004611e89565b6109f4565b60405190151581526020016102cf565b34801561035657600080fd5b506002546102c5565b34801561036b57600080fd5b506102ad61037a366004611eb5565b610a0a565b34801561038b57600080fd5b506102c560165481565b3480156103a157600080fd5b5061033a6103b0366004611ed9565b610a56565b3480156103c157600080fd5b506102ad6103d0366004611e5d565b610b07565b3480156103e157600080fd5b506102c560085481565b3480156103f757600080fd5b506102c560155481565b34801561040d57600080fd5b50604051601281526020016102cf565b34801561042957600080fd5b5061033a610438366004611e89565b610bc2565b34801561044957600080fd5b5061033a610458366004611eb5565b60186020526000908152604090205460ff1681565b34801561047957600080fd5b506102ad610488366004611f1a565b610bf9565b34801561049957600080fd5b5060075461033a90600160b01b900460ff1681565b3480156104ba57600080fd5b506102c560095481565b3480156104d057600080fd5b506102ad6104df366004611f48565b610c51565b3480156104f057600080fd5b5060075461033a90600160a81b900460ff1681565b34801561051157600080fd5b506102c5610520366004611eb5565b6001600160a01b031660009081526020819052604090205490565b34801561054757600080fd5b506102ad610c93565b34801561055c57600080fd5b50600f5460105460115461056f92919083565b604080519384526020840192909252908201526060016102cf565b34801561059657600080fd5b50600d546105aa906001600160a01b031681565b6040516001600160a01b0390911681526020016102cf565b3480156105ce57600080fd5b506102ad6105dd366004611f48565b610cc9565b3480156105ee57600080fd5b506102c5600b5481565b34801561060457600080fd5b506102ad610613366004611e89565b610d64565b34801561062457600080fd5b506005546001600160a01b03166105aa565b34801561064257600080fd5b50600e546105aa906001600160a01b031681565b34801561066257600080fd5b506102ed610e25565b34801561067757600080fd5b506102ad610686366004611f48565b610e34565b34801561069757600080fd5b506102ad6106a6366004611f48565b610e63565b3480156106b757600080fd5b5061033a6106c6366004611e89565b610eb5565b3480156106d757600080fd5b506007546105aa906001600160a01b031681565b3480156106f757600080fd5b5061033a610706366004611e89565b610f50565b34801561071757600080fd5b506102c5600c5481565b34801561072d57600080fd5b506102ad61073c366004611eb5565b610f5d565b34801561074d57600080fd5b506102ad61075c366004611f48565b610fa9565b34801561076d57600080fd5b5061033a61077c366004611eb5565b60176020526000908152604090205460ff1681565b34801561079d57600080fd5b506102c56107ac366004611f1a565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156107e357600080fd5b506102ad6107f2366004611f61565b610feb565b34801561080357600080fd5b506102ad610812366004611dcf565b611033565b34801561082357600080fd5b506102ad610832366004611e5d565b611088565b34801561084357600080fd5b506102ad610852366004611eb5565b6110f6565b34801561086357600080fd5b5060125460135460145461056f92919083565b34801561088257600080fd5b506006546105aa906001600160a01b031681565b6005546001600160a01b031633146108c95760405162461bcd60e51b81526004016108c090611f7e565b60405180910390fd5b6001600160a01b03919091166000908152601860205260409020805460ff1916911515919091179055565b60606003805461090390611fb3565b80601f016020809104026020016040519081016040528092919081815260200182805461092f90611fb3565b801561097c5780601f106109515761010080835404028352916020019161097c565b820191906000526020600020905b81548152906001019060200180831161095f57829003601f168201915b5050505050905090565b6005546001600160a01b031633146109b05760405162461bcd60e51b81526004016108c090611f7e565b604080516060810182528481526020810184905201819052601283905560138290556014819055806109e28385612004565b6109ec9190612004565b601655505050565b6000610a0133848461118e565b50600192915050565b6005546001600160a01b03163314610a345760405162461bcd60e51b81526004016108c090611f7e565b600e80546001600160a01b0319166001600160a01b0392909216919091179055565b6000610a638484846112b2565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610ae85760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084016108c0565b610afc8533610af7868561201c565b61118e565b506001949350505050565b6005546001600160a01b03163314610b315760405162461bcd60e51b81526004016108c090611f7e565b47610b3b846116fe565b6000610b47824761201c565b90508215610b8257610b82610b5c8486612004565b610b668584612033565b610b709190612052565b600d546001600160a01b031690611858565b8315610bbb57610bbb610b958486612004565b610b9f8684612033565b610ba99190612052565b600e546001600160a01b031690611858565b5050505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610a01918590610af7908690612004565b6005546001600160a01b03163314610c235760405162461bcd60e51b81526004016108c090611f7e565b600680546001600160a01b039384166001600160a01b03199182161790915560078054929093169116179055565b6005546001600160a01b03163314610c7b5760405162461bcd60e51b81526004016108c090611f7e565b610c8d81670de0b6b3a7640000612033565b600b5550565b6005546001600160a01b03163314610cbd5760405162461bcd60e51b81526004016108c090611f7e565b610cc76000611971565b565b6005546001600160a01b03163314610cf35760405162461bcd60e51b81526004016108c090611f7e565b600754600160b01b900460ff1615610d465760405162461bcd60e51b815260206004820152601660248201527554726164696e6720616c72656164792061637469766560501b60448201526064016108c0565b6007805461ffff60a81b191661010160a81b17905543600855600955565b6005546001600160a01b03163314610d8e5760405162461bcd60e51b81526004016108c090611f7e565b816001600160a01b031663a9059cbb610daf6005546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602481018490526044016020604051808303816000875af1158015610dfc573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e209190612074565b505050565b60606004805461090390611fb3565b6005546001600160a01b03163314610e5e5760405162461bcd60e51b81526004016108c090611f7e565b600a55565b6005546001600160a01b03163314610e8d5760405162461bcd60e51b81526004016108c090611f7e565b610eb281610ea36005546001600160a01b031690565b6001600160a01b031690611858565b50565b3360009081526001602090815260408083206001600160a01b038616845290915281205482811015610f375760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016108c0565b610f463385610af7868561201c565b5060019392505050565b6000610a013384846112b2565b6005546001600160a01b03163314610f875760405162461bcd60e51b81526004016108c090611f7e565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610fd35760405162461bcd60e51b81526004016108c090611f7e565b610fe581670de0b6b3a7640000612033565b600c5550565b6005546001600160a01b031633146110155760405162461bcd60e51b81526004016108c090611f7e565b60078054911515600160a81b0260ff60a81b19909216919091179055565b6005546001600160a01b0316331461105d5760405162461bcd60e51b81526004016108c090611f7e565b6001600160a01b03919091166000908152601760205260409020805460ff1916911515919091179055565b6005546001600160a01b031633146110b25760405162461bcd60e51b81526004016108c090611f7e565b604080516060810182528481526020810184905201819052600f83905560108290556011819055806110e48385612004565b6110ee9190612004565b601555505050565b6005546001600160a01b031633146111205760405162461bcd60e51b81526004016108c090611f7e565b6001600160a01b0381166111855760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108c0565b610eb281611971565b6001600160a01b0383166111f05760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108c0565b6001600160a01b0382166112515760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108c0565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b600081116113145760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016108c0565b6001600160a01b03831660009081526018602052604090205460ff1615801561135657506001600160a01b03821660009081526018602052604090205460ff16155b6113a25760405162461bcd60e51b815260206004820152601960248201527f596f752063616e2774207472616e7366657220746f6b656e730000000000000060448201526064016108c0565b6001600160a01b03831660009081526017602052604090205460ff161580156113e457506001600160a01b03821660009081526017602052604090205460ff16155b80156113fa5750600754600160a01b900460ff16155b156115c657600754600160b01b900460ff166114515760405162461bcd60e51b8152602060048201526016602482015275151c98591a5b99c81b9bdd081858dd1a5d99481e595d60521b60448201526064016108c0565b436009546008546114629190612004565b11156114da576007546001600160a01b038381169116146114a1576001600160a01b0382166000908152601860205260409020805460ff191660011790555b6007546001600160a01b038481169116146114da576001600160a01b0383166000908152601860205260409020805460ff191660011790555b600b5481111561152c5760405162461bcd60e51b815260206004820152601d60248201527f596f752061726520657863656564696e67206d61785478416d6f756e7400000060448201526064016108c0565b6007546001600160a01b038381169116146115c657600c5481611564846001600160a01b031660009081526020819052604090205490565b61156e9190612004565b11156115c65760405162461bcd60e51b815260206004820152602160248201527f596f752061726520657863656564696e67206d617857616c6c6574416d6f756e6044820152601d60fa1b60648201526084016108c0565b600754600090600160a01b900460ff16806115f957506001600160a01b03841660009081526017602052604090205460ff165b8061161c57506001600160a01b03831660009081526017602052604090205460ff165b156116295750600061167d565b6007546001600160a01b03848116911614156116605760646016548361164f9190612033565b6116599190612052565b905061167d565b6064601554836116709190612033565b61167a9190612052565b90505b600754600160a81b900460ff1680156116a05750600754600160a01b900460ff16155b80156116ba57506007546001600160a01b03858116911614155b80156116c65750600081115b156116d3576116d36119c3565b6116e784846116e2848661201c565b611b27565b80156116f8576116f8843083611b27565b50505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061173357611733612091565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa15801561178c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117b091906120a7565b816001815181106117c3576117c3612091565b6001600160a01b0392831660209182029290920101526006546117e9913091168461118e565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac947906118229085906000908690309042906004016120c4565b600060405180830381600087803b15801561183c57600080fd5b505af1158015611850573d6000803e3d6000fd5b505050505050565b804710156118a85760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e636500000060448201526064016108c0565b6000826001600160a01b03168260405160006040518083038185875af1925050503d80600081146118f5576040519150601f19603f3d011682016040523d82523d6000602084013e6118fa565b606091505b5050905080610e205760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d6179206861766520726576657274656400000000000060648201526084016108c0565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600754600160a01b900460ff16610cc7576007805460ff60a01b1916600160a01b179055306000908152602081905260408120549050600a548110611b175760006016546002611a139190612033565b905060008160126001015484611a299190612033565b611a339190612052565b90506000611a41828561201c565b905047611a4d826116fe565b6000611a59824761201c565b601354909150600090611a6c908761201c565b611a769083612052565b601354909150600090611a899083612033565b90508015611a9b57611a9b8682611cff565b601254600090611aac846002612033565b611ab69190612033565b90508015611ad457600d54611ad4906001600160a01b031682611858565b601454600090611ae5856002612033565b611aef9190612033565b90508015611b0d57600e54611b0d906001600160a01b031682611858565b5050505050505050505b506007805460ff60a01b19169055565b6001600160a01b038316611b8b5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016108c0565b6001600160a01b038216611bed5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016108c0565b6001600160a01b03831660009081526020819052604090205481811015611c655760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016108c0565b611c6f828261201c565b6001600160a01b038086166000908152602081905260408082209390935590851681529081208054849290611ca5908490612004565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611cf191815260200190565b60405180910390a350505050565b600654611d179030906001600160a01b03168461118e565b600654600e5460405163f305d71960e01b81523060048201526024810185905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af1158015611d87573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610bbb9190612135565b6001600160a01b0381168114610eb257600080fd5b8015158114610eb257600080fd5b60008060408385031215611de257600080fd5b8235611ded81611dac565b91506020830135611dfd81611dc1565b809150509250929050565b600060208083528351808285015260005b81811015611e3557858101830151858201604001528201611e19565b81811115611e47576000604083870101525b50601f01601f1916929092016040019392505050565b600080600060608486031215611e7257600080fd5b505081359360208301359350604090920135919050565b60008060408385031215611e9c57600080fd5b8235611ea781611dac565b946020939093013593505050565b600060208284031215611ec757600080fd5b8135611ed281611dac565b9392505050565b600080600060608486031215611eee57600080fd5b8335611ef981611dac565b92506020840135611f0981611dac565b929592945050506040919091013590565b60008060408385031215611f2d57600080fd5b8235611f3881611dac565b91506020830135611dfd81611dac565b600060208284031215611f5a57600080fd5b5035919050565b600060208284031215611f7357600080fd5b8135611ed281611dc1565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600181811c90821680611fc757607f821691505b60208210811415611fe857634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b6000821982111561201757612017611fee565b500190565b60008282101561202e5761202e611fee565b500390565b600081600019048311821515161561204d5761204d611fee565b500290565b60008261206f57634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561208657600080fd5b8151611ed281611dc1565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156120b957600080fd5b8151611ed281611dac565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156121145784516001600160a01b0316835293830193918301916001016120ef565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561214a57600080fd5b835192506020840151915060408401519050925092509256fea26469706673582212203c1e0ef9b72bf24aa3f8e8d830a1d912308605bde3da3d18c3d4dfddf0837a9364736f6c634300080c0033

Verified Source Code Partial Match

Compiler: v0.8.12+commit.f00d7308 EVM: london Optimization: Yes (200 runs)
PULSETH.sol 642 lines
/**
 *Submitted for verification at Etherscan.io on 2022-08-10
*/

//SPDX-License-Identifier: MIT

/*
PULSETH ($PLSE)

TOKENOMICS

3% Tax
Liquidity Locked for 1 Month 
Ownership Renounced

Telegram: t.me/pulseth
*/

pragma solidity 0.8.12;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        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);
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}


contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping (address => uint256) internal _balances;

    mapping (address => mapping (address => uint256)) internal _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The defaut value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor (string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        _approve(sender, _msgSender(), currentAllowance - amount);

        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);

        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        _balances[sender] = senderBalance - amount;
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

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

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        _balances[account] = accountBalance - amount;
        _totalSupply -= amount;

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

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(address owner, address spender, uint256 amount) internal virtual {
        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);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { }
}

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

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _setOwner(_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 {
        _setOwner(address(0));
    }

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

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

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

interface IRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);

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

contract PULSETH is ERC20, Ownable{
    using Address for address payable;
    
    IRouter public router;
    address public pair;
    
    bool private swapping;
    bool public swapEnabled;
    bool public tradingEnabled;

    uint256 public genesis_block;
    uint256 public deadblocks = 0;
    
    uint256 public swapThreshold = 10_000 * 10e18;
    uint256 public maxTxAmount = 10_000_000 * 10**18;
    uint256 public maxWalletAmount = 200_000 * 10**18;
    
    address public marketingWallet = 0x10679C9C4eB77BC129947AB952e29d069B0bF4f2;
    address public devWallet = 0x10679C9C4eB77BC129947AB952e29d069B0bF4f2;
    
    struct Taxes {
        uint256 marketing;
        uint256 liquidity; 
        uint256 dev;
    }
    
    Taxes public taxes = Taxes(3,0,0);
    Taxes public sellTaxes = Taxes(99,0,0);
    uint256 public totTax = 3;
    uint256 public totSellTax = 99;
    
    mapping (address => bool) public excludedFromFees;
    mapping (address => bool) public isBot;
    
    modifier inSwap() {
        if (!swapping) {
            swapping = true;
            _;
            swapping = false;
        }
    }
        
    constructor() ERC20("PULSETH", "PULSETH") {
        _mint(msg.sender, 1e7 * 10 ** decimals());
        excludedFromFees[msg.sender] = true;

        IRouter _router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _pair = IFactory(_router.factory())
            .createPair(address(this), _router.WETH());

        router = _router;
        pair = _pair;
        excludedFromFees[address(this)] = true;
        excludedFromFees[marketingWallet] = true;
        excludedFromFees[devWallet] = true;
    }
    
    function _transfer(address sender, address recipient, uint256 amount) internal override {
        require(amount > 0, "Transfer amount must be greater than zero");
        require(!isBot[sender] && !isBot[recipient], "You can't transfer tokens");
                
        
        if(!excludedFromFees[sender] && !excludedFromFees[recipient] && !swapping){
            require(tradingEnabled, "Trading not active yet");
            if(genesis_block + deadblocks > block.number){
                if(recipient != pair) isBot[recipient] = true;
                if(sender != pair) isBot[sender] = true;
            }
            require(amount <= maxTxAmount, "You are exceeding maxTxAmount");
            if(recipient != pair){
                require(balanceOf(recipient) + amount <= maxWalletAmount, "You are exceeding maxWalletAmount");
            }
        }

        uint256 fee;
        
        //set fee to zero if fees in contract are handled or exempted
        if (swapping || excludedFromFees[sender] || excludedFromFees[recipient]) fee = 0;
        
        //calculate fee
        else{
            if(recipient == pair) fee = amount * totSellTax / 100;
            else fee = amount * totTax / 100;
        }
        
        //send fees if threshold has been reached
        //don't do this on buys, breaks swap
        if (swapEnabled && !swapping && sender != pair && fee > 0) swapForFees();

        super._transfer(sender, recipient, amount - fee);
        if(fee > 0) super._transfer(sender, address(this) ,fee);

    }

    function swapForFees() private inSwap {
        uint256 contractBalance = balanceOf(address(this));
        if (contractBalance >= swapThreshold) {

            // Split the contract balance into halves
            uint256 denominator = totSellTax * 2;
            uint256 tokensToAddLiquidityWith = contractBalance * sellTaxes.liquidity / denominator;
            uint256 toSwap = contractBalance - tokensToAddLiquidityWith;
    
            uint256 initialBalance = address(this).balance;
    
            swapTokensForETH(toSwap);
    
            uint256 deltaBalance = address(this).balance - initialBalance;
            uint256 unitBalance= deltaBalance / (denominator - sellTaxes.liquidity);
            uint256 ethToAddLiquidityWith = unitBalance * sellTaxes.liquidity;
    
            if(ethToAddLiquidityWith > 0){
                // Add liquidity to Uniswap
                addLiquidity(tokensToAddLiquidityWith, ethToAddLiquidityWith);
            }
    
            uint256 marketingAmt = unitBalance * 2 * sellTaxes.marketing;
            if(marketingAmt > 0){
                payable(marketingWallet).sendValue(marketingAmt);
            }
            
            uint256 devAmt = unitBalance * 2 * sellTaxes.dev;
            if(devAmt > 0){
                payable(devWallet).sendValue(devAmt);
            }
        }
    }


    function swapTokensForETH(uint256 tokenAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.WETH();

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

        // make the swap
        router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount, 0, path, address(this), block.timestamp);

    }

    function addLiquidity(uint256 tokenAmount, uint256 bnbAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(router), tokenAmount);

        // add the liquidity
        router.addLiquidityETH{value: bnbAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            devWallet,
            block.timestamp
        );
    }

    function setSwapEnabled(bool state) external onlyOwner {
        swapEnabled = state;
    }

    function setSwapThreshold(uint256 new_amount) external onlyOwner {
        swapThreshold = new_amount;
    }

    function enableTrading(uint256 numOfDeadBlocks) external onlyOwner{
        require(!tradingEnabled, "Trading already active");
        tradingEnabled = true;
        swapEnabled = true;
        genesis_block = block.number;
        deadblocks = numOfDeadBlocks;
    }

    function setTaxes(uint256 _marketing, uint256 _liquidity, uint256 _dev) external onlyOwner{
        taxes = Taxes(_marketing, _liquidity, _dev);
        totTax = _marketing + _liquidity + _dev;
    }

    function setSellTaxes(uint256 _marketing, uint256 _liquidity, uint256 _dev) external onlyOwner{
        sellTaxes = Taxes(_marketing, _liquidity, _dev);
        totSellTax = _marketing + _liquidity + _dev;
    }
    
    function updateMarketingWallet(address newWallet) external onlyOwner{
        marketingWallet = newWallet;
    }
    
    function updateDevWallet(address newWallet) external onlyOwner{
        devWallet = newWallet;
    }

    function updateRouterAndPair(IRouter _router, address _pair) external onlyOwner{
        router = _router;
        pair = _pair;
    }
    
    function setIsBot(address account, bool state) external onlyOwner{
        isBot[account] = state;
    }

    function updateExcludedFromFees(address _address, bool state) external onlyOwner {
        excludedFromFees[_address] = state;
    }
    
    function updateMaxTxAmount(uint256 amount) external onlyOwner{
        maxTxAmount = amount * 10**18;
    }
    
    function updateMaxWalletAmount(uint256 amount) external onlyOwner{
        maxWalletAmount = amount * 10**18;
    }

    function rescueERC20(address tokenAddress, uint256 amount) external onlyOwner{
        IERC20(tokenAddress).transfer(owner(), amount);
    }

    function rescueETH(uint256 weiAmount) external onlyOwner{
        payable(owner()).sendValue(weiAmount);
    }

    function manualSwap(uint256 amount, uint256 devPercentage, uint256 marketingPercentage) external onlyOwner{
        uint256 initBalance = address(this).balance;
        swapTokensForETH(amount);
        uint256 newBalance = address(this).balance - initBalance;
        if(marketingPercentage > 0) payable(marketingWallet).sendValue(newBalance * marketingPercentage / (devPercentage + marketingPercentage));
        if(devPercentage > 0) payable(devWallet).sendValue(newBalance * devPercentage / (devPercentage + marketingPercentage));
    }

    // fallbacks
    receive() external payable {}
    
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadblocks 0x50c9a88f → uint256
decimals 0x313ce567 → uint8
devWallet 0x8ea5220f → address
excludedFromFees 0xdbe66ca0 → bool
genesis_block 0x274a533c → uint256
isBot 0x3bbac579 → bool
marketingWallet 0x75f0a874 → address
maxTxAmount 0x8c0b5e22 → uint256
maxWalletAmount 0xaa4bde28 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
sellTaxes 0xf66895a3 → uint256, uint256, uint256
swapEnabled 0x6ddd1713 → bool
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
taxes 0x728f8eea → uint256, uint256, uint256
totSellTax 0x2253163d → uint256
totTax 0x293b7ef4 → uint256
totalSupply 0x18160ddd → uint256
tradingEnabled 0x4ada218b → bool

Write Contract 22 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
enableTrading 0x82aa7c68
uint256 numOfDeadBlocks
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
manualSwap 0x26b5d32f
uint256 amount
uint256 devPercentage
uint256 marketingPercentage
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address tokenAddress
uint256 amount
rescueETH 0x9e252f00
uint256 weiAmount
setIsBot 0x03c0f5d4
address account
bool state
setSellTaxes 0x08733214
uint256 _marketing
uint256 _liquidity
uint256 _dev
setSwapEnabled 0xe01af92c
bool state
setSwapThreshold 0x9d0014b1
uint256 new_amount
setTaxes 0xe9dae5ed
uint256 _marketing
uint256 _liquidity
uint256 _dev
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateDevWallet 0x1816467f
address newWallet
updateExcludedFromFees 0xe545fd6d
address _address
bool state
updateMarketingWallet 0xaacebbe3
address newWallet
updateMaxTxAmount 0x6256d181
uint256 amount
updateMaxWalletAmount 0xc18bc195
uint256 amount
updateRouterAndPair 0x40b28c2f
address _router
address _pair

Recent Transactions

No transactions found for this address