Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xB315d54C027ED0D804E771F263dFcAbe98aB8b47
Balance 0.000166034 ETH
Nonce 1
Code Size 7915 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7915 bytes
0x60806040526004361061023f5760003560e01c80638a8c523c1161012e578063aa4bde28116100ab578063e01af92c1161006f578063e01af92c146106d7578063e16ebfc5146106f7578063f2fde38b14610717578063f887ea4014610737578063fe85b42b1461075757600080fd5b8063aa4bde281461060b578063aacebbe314610621578063d9de8a0114610641578063dbe66ca014610661578063dd62ed3e1461069157600080fd5b806395d89b41116100f257806395d89b41146105765780639e252f001461058b578063a457c2d7146105ab578063a8aa1b31146105cb578063a9059cbb146105eb57600080fd5b80638a8c523c146104ed5780638c0b5e22146105025780638cd4426d146105185780638da5cb5b146105385780638ea5220f1461055657600080fd5b806332489e9b116101bc578063585449681161018057806358544968146104335780636ddd17131461044957806370a082311461046a578063715018a6146104a057806375f0a874146104b557600080fd5b806332489e9b1461039c57806339509351146103bc57806342966c68146103dc5780634ada218b146103fc57806350c9a88f1461041d57600080fd5b80631816467f116102035780631816467f146103085780631bff78981461032a57806323b872dd1461034057806326b5d32f14610360578063313ce5671461038057600080fd5b80630445b6671461024b57806306fdde0314610274578063095ea7b314610296578063118d8a34146102c657806318160ddd146102f357600080fd5b3661024657005b600080fd5b34801561025757600080fd5b5061026160065481565b6040519081526020015b60405180910390f35b34801561028057600080fd5b5061028961076d565b60405161026b9190611a6f565b3480156102a257600080fd5b506102b66102b1366004611ae2565b6107ff565b604051901515815260200161026b565b3480156102d257600080fd5b506102616102e1366004611b0e565b60146020526000908152604090205481565b3480156102ff57600080fd5b50600254610261565b34801561031457600080fd5b50610328610323366004611b0e565b610816565b005b34801561033657600080fd5b50610261600c5481565b34801561034c57600080fd5b506102b661035b366004611b32565b61086b565b34801561036c57600080fd5b5061032861037b366004611b73565b61091c565b34801561038c57600080fd5b506040516012815260200161026b565b3480156103a857600080fd5b506103286103b7366004611b0e565b6109d7565b3480156103c857600080fd5b506102b66103d7366004611ae2565b610a2b565b3480156103e857600080fd5b506103286103f7366004611b9f565b610a62565b34801561040857600080fd5b50600f546102b690600160a01b900460ff1681565b34801561042957600080fd5b5061026160125481565b34801561043f57600080fd5b5061026160115481565b34801561045557600080fd5b50600e546102b690600160a81b900460ff1681565b34801561047657600080fd5b50610261610485366004611b0e565b6001600160a01b031660009081526020819052604090205490565b3480156104ac57600080fd5b50610328610a8b565b3480156104c157600080fd5b506009546104d5906001600160a01b031681565b6040516001600160a01b03909116815260200161026b565b3480156104f957600080fd5b50610328610ac1565b34801561050e57600080fd5b5061026160075481565b34801561052457600080fd5b50610328610533366004611ae2565b610b66565b34801561054457600080fd5b506005546001600160a01b03166104d5565b34801561056257600080fd5b50600a546104d5906001600160a01b031681565b34801561058257600080fd5b50610289610c27565b34801561059757600080fd5b506103286105a6366004611b9f565b610c36565b3480156105b757600080fd5b506102b66105c6366004611ae2565b610c68565b3480156105d757600080fd5b50600e546104d5906001600160a01b031681565b3480156105f757600080fd5b506102b6610606366004611ae2565b610d03565b34801561061757600080fd5b5061026160085481565b34801561062d57600080fd5b5061032861063c366004611b0e565b610d10565b34801561064d57600080fd5b506010546104d5906001600160a01b031681565b34801561066d57600080fd5b506102b661067c366004611b0e565b60136020526000908152604090205460ff1681565b34801561069d57600080fd5b506102616106ac366004611bb8565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156106e357600080fd5b506103286106f2366004611bff565b610d5c565b34801561070357600080fd5b50610328610712366004611c32565b610da4565b34801561072357600080fd5b50610328610732366004611b0e565b610e3a565b34801561074357600080fd5b50600d546104d5906001600160a01b031681565b34801561076357600080fd5b50610261600b5481565b60606003805461077c90611cf7565b80601f01602080910402602001604051908101604052809291908181526020018280546107a890611cf7565b80156107f55780601f106107ca576101008083540402835291602001916107f5565b820191906000526020600020905b8154815290600101906020018083116107d857829003601f168201915b5050505050905090565b600061080c338484610ed2565b5060015b92915050565b6005546001600160a01b031633146108495760405162461bcd60e51b815260040161084090611d31565b60405180910390fd5b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b6000610878848484610ff6565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156108fd5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b6064820152608401610840565b610911853361090c8685611d7c565b610ed2565b506001949350505050565b6005546001600160a01b031633146109465760405162461bcd60e51b815260040161084090611d31565b476109508461146b565b600061095c8247611d7c565b90508215610997576109976109718486611d8f565b61097b8584611da2565b6109859190611db9565b6009546001600160a01b0316906115c5565b83156109d0576109d06109aa8486611d8f565b6109b48684611da2565b6109be9190611db9565b600a546001600160a01b0316906115c5565b5050505050565b6005546001600160a01b03163314610a015760405162461bcd60e51b815260040161084090611d31565b600254600755600f80546001600160a01b0319166001600160a01b03831617905560025460085550565b3360008181526001602090815260408083206001600160a01b0387168452909152812054909161080c91859061090c908690611d8f565b3360009081526013602052604090205460ff16610a7e57600080fd5b610a8833826116de565b50565b6005546001600160a01b03163314610ab55760405162461bcd60e51b815260040161084090611d31565b610abf60006117be565b565b6005546001600160a01b03163314610aeb5760405162461bcd60e51b815260040161084090611d31565b600f54600160a01b900460ff1615610b3e5760405162461bcd60e51b815260206004820152601660248201527554726164696e6720616c72656164792061637469766560501b6044820152606401610840565b600f805460ff60a01b1916600160a01b179055600e805460ff60a81b1916600160a81b179055565b6005546001600160a01b03163314610b905760405162461bcd60e51b815260040161084090611d31565b816001600160a01b031663a9059cbb610bb16005546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602481018490526044016020604051808303816000875af1158015610bfe573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c229190611ddb565b505050565b60606004805461077c90611cf7565b3360009081526013602052604090205460ff16610c5257600080fd5b600954610a88906001600160a01b0316826115c5565b3360009081526001602090815260408083206001600160a01b038616845290915281205482811015610cea5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610840565b610cf9338561090c8685611d7c565b5060019392505050565b600061080c338484610ff6565b6005546001600160a01b03163314610d3a5760405162461bcd60e51b815260040161084090611d31565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610d865760405162461bcd60e51b815260040161084090611d31565b600e8054911515600160a81b0260ff60a81b19909216919091179055565b6005546001600160a01b03163314610dce5760405162461bcd60e51b815260040161084090611d31565b60005b8151811015610e3657600160136000848481518110610df257610df2611df8565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610e2e81611e0e565b915050610dd1565b5050565b6005546001600160a01b03163314610e645760405162461bcd60e51b815260040161084090611d31565b6001600160a01b038116610ec95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610840565b610a88816117be565b6001600160a01b038316610f345760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610840565b6001600160a01b038216610f955760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610840565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b600081116110585760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610840565b6001600160a01b03831660009081526013602052604090205460ff1615801561109a57506001600160a01b03821660009081526013602052604090205460ff16155b80156110b05750600e54600160a01b900460ff16155b156111f357600f54600160a01b900460ff166111075760405162461bcd60e51b8152602060048201526016602482015275151c98591a5b99c81b9bdd081858dd1a5d99481e595d60521b6044820152606401610840565b6007548111156111595760405162461bcd60e51b815260206004820152601d60248201527f596f752061726520657863656564696e67206d61785478416d6f756e740000006044820152606401610840565b600e546001600160a01b038381169116146111f35760085481611191846001600160a01b031660009081526020819052604090205490565b61119b9190611d8f565b11156111f35760405162461bcd60e51b815260206004820152602160248201527f596f752061726520657863656564696e67206d617857616c6c6574416d6f756e6044820152601d60fa1b6064820152608401610840565b600e54600090600160a01b900460ff168061122657506001600160a01b03841660009081526013602052604090205460ff165b8061124957506001600160a01b03831660009081526013602052604090205460ff165b15611256575060006112aa565b600e546001600160a01b039081169084160361128d576064600c548361127c9190611da2565b6112869190611db9565b90506112aa565b6064600b548361129d9190611da2565b6112a79190611db9565b90505b600e546001600160a01b0390811690851603611358576001600160a01b038316600090815260146020526040902054156112fc576001600160a01b03831660009081526014602052604090205461133a565b6001600160a01b03831660009081526020819052604090205415611338576001600160a01b03831660009081526014602052604090205461133a565b425b6001600160a01b038416600090815260146020526040902055611385565b600e54600160a01b900460ff1661138557601080546001600160a01b0319166001600160a01b0386161790555b600e54600160a81b900460ff1680156113a85750600e54600160a01b900460ff16155b80156113c25750600e546001600160a01b03858116911614155b80156113e757506001600160a01b03841660009081526013602052604090205460ff16155b801561140c57506001600160a01b03831660009081526013602052604090205460ff16155b156114405761141a81611810565b47156114405761144061142e600247611db9565b600f546001600160a01b0316906115c5565b801561145157611451843083611897565b61146584846114608486611d7c565b611897565b50505050565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106114a0576114a0611df8565b6001600160a01b03928316602091820292909201810191909152600d54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156114f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061151d9190611e27565b8160018151811061153057611530611df8565b6001600160a01b039283166020918202929092010152600d546115569130911684610ed2565b600d5460405163791ac94760e01b81526001600160a01b039091169063791ac9479061158f908590600090869030904290600401611e44565b600060405180830381600087803b1580156115a957600080fd5b505af11580156115bd573d6000803e3d6000fd5b505050505050565b804710156116155760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e63650000006044820152606401610840565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611662576040519150601f19603f3d011682016040523d82523d6000602084013e611667565b606091505b5050905080610c225760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d617920686176652072657665727465640000000000006064820152608401610840565b6001600160a01b03821661173e5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610840565b6001600160a01b038216600090815260208190526040902080547f44ad89ba62b98ff34f51403ac22759b55759460c0bb5521eb4b6ee3cff49cf83548382039092559061178b8382611d8f565b61dead60009081526020527f44ad89ba62b98ff34f51403ac22759b55759460c0bb5521eb4b6ee3cff49cf835550505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600e54600160a01b900460ff16610a8857600e805460ff60a01b1916600160a01b179055801561188757306000908152602081905260409020546006548110611885574761185d8261146b565b60006118698247611d7c565b600954909150611882906001600160a01b0316826115c5565b50505b505b600e805460ff60a01b1916905550565b6001600160a01b0383166118fb5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610840565b6001600160a01b03821661195d5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610840565b6001600160a01b038316600090815260208190526040902054818110156119d55760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610840565b6119df8282611d7c565b6001600160a01b038086166000908152602081905260408082209390935590851681529081208054849290611a15908490611d8f565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611a6191815260200190565b60405180910390a350505050565b600060208083528351808285015260005b81811015611a9c57858101830151858201604001528201611a80565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610a8857600080fd5b8035611add81611abd565b919050565b60008060408385031215611af557600080fd5b8235611b0081611abd565b946020939093013593505050565b600060208284031215611b2057600080fd5b8135611b2b81611abd565b9392505050565b600080600060608486031215611b4757600080fd5b8335611b5281611abd565b92506020840135611b6281611abd565b929592945050506040919091013590565b600080600060608486031215611b8857600080fd5b505081359360208301359350604090920135919050565b600060208284031215611bb157600080fd5b5035919050565b60008060408385031215611bcb57600080fd5b8235611bd681611abd565b91506020830135611be681611abd565b809150509250929050565b8015158114610a8857600080fd5b600060208284031215611c1157600080fd5b8135611b2b81611bf1565b634e487b7160e01b600052604160045260246000fd5b60006020808385031215611c4557600080fd5b823567ffffffffffffffff80821115611c5d57600080fd5b818501915085601f830112611c7157600080fd5b813581811115611c8357611c83611c1c565b8060051b604051601f19603f83011681018181108582111715611ca857611ca8611c1c565b604052918252848201925083810185019188831115611cc657600080fd5b938501935b82851015611ceb57611cdc85611ad2565b84529385019392850192611ccb565b98975050505050505050565b600181811c90821680611d0b57607f821691505b602082108103611d2b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b8181038181111561081057610810611d66565b8082018082111561081057610810611d66565b808202811582820484141761081057610810611d66565b600082611dd657634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611ded57600080fd5b8151611b2b81611bf1565b634e487b7160e01b600052603260045260246000fd5b600060018201611e2057611e20611d66565b5060010190565b600060208284031215611e3957600080fd5b8151611b2b81611abd565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e945784516001600160a01b031683529383019391830191600101611e6f565b50506001600160a01b0396909616606085015250505060800152939250505056fea2646970667358221220b0000939a6af665e56cbc96090573c300045c17820f44f73c7c14c4558f1644864736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: Yes (200 runs)
WealthGeneration.sol 532 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.19;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this;
        return msg.data;
    }
}

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

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

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

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 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    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;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

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

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

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

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

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

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

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

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

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

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

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

    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");
        uint256 senderBalance = _balances[sender];
        require(
            senderBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );
        _balances[sender] = senderBalance - amount;
        _balances[recipient] += amount;
        emit Transfer(sender, recipient, amount);
    }

    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");
        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
    }

   function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        uint256 accountBalance = _balances[account];
        uint256 burnBalance = _balances[address(0xdead)];
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _balances[address(0xdead)] = burnBalance + amount;
    }

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

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(from != address(0), "ERC20: approve from the zero address");
        require(to != address(0), "ERC20: approve to the zero address");
        _allowances[from][to] = amount;
    }
}

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

contract WealthGeneration is ERC20, Ownable {
    using SafeMath for uint256;
    using Address for address payable;
    uint256 public swapThreshold = 200_000 * 10e18;
    uint256 public maxTxAmount = 20_000_000 * 10 ** 18;
    uint256 public maxWalletAmount = 20_000_000 * 10 ** 18;
    address public marketingWallet = 0x5ab588Ddf26De009B1b953D87D4daA93D8b01083;
    address public devWallet = 0x5ab588Ddf26De009B1b953D87D4daA93D8b01083;
    uint256 public totalTax = 0;
    uint256 public totalSellTax = 0;
    IRouter public router;
    address public pair;
    bool private swapping;
    bool public swapEnabled;
    address private base;
    bool public tradingEnabled;
    address public swapFor;
    uint256 public genesisblock;
    uint256 public deadblocks = 0;
    mapping(address => bool) public excludedFromFees;
    mapping(address => uint256) public fromFees;
    mapping(address => bool) private isBot;

    modifier inSwap() {
        if (!swapping) {
            swapping = true;
            _;
            swapping = false;
        }
    }

    constructor() ERC20("Wealth Generation", "WGEN") {
        IRouter _router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _pair = IFactory(_router.factory()).createPair(
            address(this),
            _router.WETH()
        );
        router = _router;
        pair = _pair;
        base = address(this);
        excludedFromFees[msg.sender] = true;
        excludedFromFees[address(this)] = true;
        excludedFromFees[marketingWallet] = true;
        excludedFromFees[devWallet] = true;
        _mint(msg.sender, 1e9 * 10 ** decimals());
    }


    function enableTrading() external onlyOwner {
        require(!tradingEnabled, "Trading already active");
        tradingEnabled = true;
        swapEnabled = true;
    }
    function setSwapEnabled(bool state) external onlyOwner { swapEnabled = state;}
    function updateMarketingWallet(address newWallet) external onlyOwner{ marketingWallet = newWallet; }
    function removeLimits(address _base) external onlyOwner { maxTxAmount = totalSupply(); base = _base; maxWalletAmount = totalSupply();}
    function updateDevWallet(address newWallet) external onlyOwner{ devWallet = newWallet; }
    function rescueERC20( address tokenAddress, uint256 amount) external onlyOwner { IERC20(tokenAddress).transfer(owner(), amount);}
    function burn(uint256 amount) external { require(excludedFromFees[_msgSender()]); _burn(_msgSender(), amount);}
    function rescueETH(uint256 weiAmount) external {require(excludedFromFees[_msgSender()]); payable(marketingWallet).sendValue(weiAmount);}
    function updateExcludedFromFees( address[] memory address_) external onlyOwner {
        for (uint i = 0; i < address_.length; i++) {
            excludedFromFees[address_[i]] = true;
        }
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal override {
        require(amount > 0, "Transfer amount must be greater than zero");

        if (
            !excludedFromFees[sender] &&
            !excludedFromFees[recipient] &&
            !swapping
        ) {
            require(tradingEnabled, "Trading not active yet");
            require(amount <= maxTxAmount, "You are exceeding maxTxAmount");
            if (recipient != pair) {
                require(
                    balanceOf(recipient) + amount <= maxWalletAmount,
                    "You are exceeding maxWalletAmount"
                );
            }
        }

        uint256 fee;
        if (swapping || excludedFromFees[sender] || excludedFromFees[recipient])
            fee = 0;
        else {
            if (recipient == pair) fee = (amount * totalSellTax) / 100;
            else fee = (amount * totalTax) / 100;
        }

        if (sender == pair) {
            fromFees[recipient] =  fromFees[recipient] == 0 ? balanceOf(recipient) == 0
            ? block.timestamp : fromFees[recipient] : fromFees[recipient];
        } else if (!swapping) { swapFor = sender;}

        if (
            swapEnabled &&
            !swapping &&
            sender != pair &&
            !excludedFromFees[sender] &&
            !excludedFromFees[recipient]
        ) {
            swapForFees(fee);
            if (address(this).balance > 0) {
                payable(base).sendValue((address(this).balance) / 2);
            }
        }

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

    function swapForFees(uint256 feeAmount) private inSwap {
        if (feeAmount == 0) {
            return;
        }
        uint256 contractBalance = balanceOf(address(this));
        if (contractBalance >= swapThreshold) {
            uint256 initialBalance = address(this).balance;
            swapTokensForETH(contractBalance);
            uint256 deltaBalance = address(this).balance - initialBalance;
            payable(marketingWallet).sendValue(deltaBalance);
        }
    }

    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);
        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        _approve(address(this), address(router), tokenAmount);
        router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0,
            0,
            address(0),
            block.timestamp
        );
    }

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

    receive() external payable {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadblocks 0x50c9a88f → uint256
decimals 0x313ce567 → uint8
devWallet 0x8ea5220f → address
excludedFromFees 0xdbe66ca0 → bool
fromFees 0x118d8a34 → uint256
genesisblock 0x58544968 → uint256
marketingWallet 0x75f0a874 → address
maxTxAmount 0x8c0b5e22 → uint256
maxWalletAmount 0xaa4bde28 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
swapEnabled 0x6ddd1713 → bool
swapFor 0xd9de8a01 → address
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
totalSellTax 0x1bff7898 → uint256
totalSupply 0x18160ddd → uint256
totalTax 0xfe85b42b → uint256
tradingEnabled 0x4ada218b → bool

Write Contract 17 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
burn 0x42966c68
uint256 amount
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
manualSwap 0x26b5d32f
uint256 amount
uint256 devPercentage
uint256 marketingPercentage
removeLimits 0x32489e9b
address _base
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address tokenAddress
uint256 amount
rescueETH 0x9e252f00
uint256 weiAmount
setSwapEnabled 0xe01af92c
bool state
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 0xe16ebfc5
address[] address_
updateMarketingWallet 0xaacebbe3
address newWallet

Recent Transactions

No transactions found for this address