Address Contract Partially Verified
Address
0xfdc0BD44AE733a50a2333A52df5C324c0A6D36f3
Balance
0.037814 ETH
Nonce
1
Code Size
8296 bytes
Creator
0x9f44283D...69B3 at tx 0x9c024945...11119f
Indexed Transactions
0
Contract Bytecode
8296 bytes
0x608060405260043610610215575f3560e01c806377b54bad1161011e578063a8aa1b31116100a8578063ded1e4381161006d578063ded1e43814610627578063df20fd4914610646578063f2fde38b14610665578063f429389014610684578063f887ea4014610698575f80fd5b8063a8aa1b3114610568578063a9059cbb14610587578063b2bdfa7b146105a6578063c0cbdea4146105c4578063dd62ed3e146105e3575f80fd5b8063893d20e8116100ee578063893d20e8146104bb5780638da5cb5b146104eb5780638f3daa9e1461050757806395d89b4114610526578063a70419d214610554575f80fd5b806377b54bad1461045357806378109e54146104725780637d1db4a514610487578063825287911461049c575f80fd5b806330c9a6a01161019f5780635d83e1d51161016f5780635d83e1d5146103b85780636ddd1713146103d757806370a08231146103f7578063715018a61461042b578063751039fc1461043f575f80fd5b806330c9a6a01461034b578063313ce5671461036a5780635526566914610385578063571ac8b014610399575f80fd5b806318160ddd116101e557806318160ddd146102ce5780631df4ccfc146102e257806323b872dd146102f7578063282c874914610316578063293230b814610337575f80fd5b80630445b6671461022057806306fdde031461024857806308fd3d051461027f578063095ea7b3146102af575f80fd5b3661021c57005b5f80fd5b34801561022b575f80fd5b50610235601e5481565b6040519081526020015b60405180910390f35b348015610253575f80fd5b50604080518082019091526006815265506f6761694360d01b60208201525b60405161023f9190611c1e565b34801561028a575f80fd5b50601d5461029f90600160a01b900460ff1681565b604051901515815260200161023f565b3480156102ba575f80fd5b5061029f6102c9366004611c84565b6106b7565b3480156102d9575f80fd5b50600354610235565b3480156102ed575f80fd5b50610235600f5481565b348015610302575f80fd5b5061029f610311366004611cac565b610723565b348015610321575f80fd5b50610335610330366004611ce5565b6107e1565b005b348015610342575f80fd5b506103356108b7565b348015610356575f80fd5b50610235610365366004611d24565b610906565b348015610375575f80fd5b506040516012815260200161023f565b348015610390575f80fd5b5061023561094b565b3480156103a4575f80fd5b5061029f6103b3366004611d3b565b6109bb565b3480156103c3575f80fd5b506103356103d2366004611d24565b6109c7565b3480156103e2575f80fd5b50601d5461029f90600160a81b900460ff1681565b348015610402575f80fd5b50610235610411366004611d3b565b6001600160a01b03165f9081526006602052604090205490565b348015610436575f80fd5b50610335610a53565b34801561044a575f80fd5b50610335610ac4565b34801561045e575f80fd5b5061029f61046d366004611c84565b610afa565b34801561047d575f80fd5b5061023560055481565b348015610492575f80fd5b5061023560045481565b3480156104a7575f80fd5b506103356104b6366004611d54565b610c21565b3480156104c6575f80fd5b505f546001600160a01b03165b6040516001600160a01b03909116815260200161023f565b3480156104f6575f80fd5b505f546001600160a01b03166104d3565b348015610512575f80fd5b50610335610521366004611dc2565b610cf8565b348015610531575f80fd5b50604080518082019091526006815265504f4741494360d01b6020820152610272565b34801561055f575f80fd5b50610335610d4b565b348015610573575f80fd5b50601d546104d3906001600160a01b031681565b348015610592575f80fd5b5061029f6105a1366004611c84565b610d88565b3480156105b1575f80fd5b505f546104d3906001600160a01b031681565b3480156105cf575f80fd5b506103356105de366004611df7565b610d94565b3480156105ee575f80fd5b506102356105fd366004611e20565b6001600160a01b039182165f90815260076020908152604080832093909416825291909152205490565b348015610632575f80fd5b5061029f610641366004611e51565b610dce565b348015610651575f80fd5b50610335610660366004611e71565b610de1565b348015610670575f80fd5b5061033561067f366004611d3b565b610e73565b34801561068f575f80fd5b50610335610f5a565b3480156106a3575f80fd5b50601b546104d3906001600160a01b031681565b335f8181526007602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906107119086815260200190565b60405180910390a35060015b92915050565b6001600160a01b0383165f9081526007602090815260408083203384529091528120545f19146107cc576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387165f9081526007825283812033825290915291909120546107a8918490610f93565b6001600160a01b0385165f9081526007602090815260408083203384529091529020555b6107d7848484610fcb565b90505b9392505050565b5f546001600160a01b031633146108135760405162461bcd60e51b815260040161080a90611e8d565b60405180910390fd5b600a869055600d859055600b849055600c839055600e8290556108448261083e858188818c8c611322565b90611322565b600f556010819055610857600282611ed6565b600f54106108a75760405162461bcd60e51b815260206004820152601d60248201527f466565732063616e206e6f74206265206d6f7265207468616e20353025000000604482015260640161080a565b6108af611380565b505050505050565b5f546001600160a01b031633146108e05760405162461bcd60e51b815260040161080a90611e8d565b601d805460ff60a01b1916600160a01b179055610fa060128190556011556103e8601355565b5f61071d61091261094b565b601d546001600160a01b03165f908152600660205260409020546109459061093e906002905b9061141b565b859061141b565b90611499565b60066020527f54cdd369e4e8a8515e52ca72ec816c2101831ad1f18bf44102ed171459c9b4f85461dead5f9081527f1aecba4ebe7a4e0673e4891b2b092b2228e4322380b579fb494fad3da8586e225460035491926109b69290916109b091906114da565b906114da565b905090565b5f61071d825f196106b7565b5f546001600160a01b031633146109f05760405162461bcd60e51b815260040161080a90611e8d565b60018110156109fd575f80fd5b6103e881600354610a0e9190611ef5565b610a189190611ed6565b60058190556040519081527f1273be876d6df5e39545188e5f5d2d930e30e383f2fb2dc9dfaae2643901be519060200160405180910390a150565b5f546001600160a01b03163314610a7c5760405162461bcd60e51b815260040161080a90611e8d565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b03163314610aed5760405162461bcd60e51b815260040161080a90611e8d565b6003546004819055600555565b5f815f03610b6b576040516370a0823160e01b81523060048201526001600160a01b038416906370a0823190602401602060405180830381865afa158015610b44573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b689190611f0c565b91505b604080516001600160a01b0385168152602081018490527fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f910160405180910390a160145460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018490529084169063a9059cbb906044016020604051808303815f875af1158015610bfd573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107da9190611f23565b5f546001600160a01b03163314610c4a5760405162461bcd60e51b815260040161080a90611e8d565b601480546001600160a01b038781166001600160a01b031992831617909255601580548784169083168117909155601680548785169084168117909155601880548786169085168117909155601780549587169590941685179093556040805192835260208301949094529281019190915260608101919091527f06cd79b5e338fdebb51e28f829f3333e4fda9663d4732f262d97dbbacf748b159060800160405180910390a15050505050565b5f546001600160a01b03163314610d215760405162461bcd60e51b815260040161080a90611e8d565b6001600160a01b03919091165f908152600860205260409020805460ff1916911515919091179055565b5f546001600160a01b03163314610d745760405162461bcd60e51b815260040161080a90611e8d565b6101906012556102bc6011556101f4601355565b5f6107da338484610fcb565b5f546001600160a01b03163314610dbd5760405162461bcd60e51b815260040161080a90611e8d565b601191909155601291909155601355565b5f82610dd983610906565b119392505050565b5f546001600160a01b03163314610e0a5760405162461bcd60e51b815260040161080a90611e8d565b601d805460ff60a81b1916600160a81b84151581029190911791829055601e8390556040805184815260ff9290930491909116151560208301527f519582fd959400ab5e398f78c2768dea99251e8e26aed5578213b059ce4cee60910160405180910390a15050565b5f546001600160a01b03163314610e9c5760405162461bcd60e51b815260040161080a90611e8d565b6001600160a01b038116610f015760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161080a565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6014546040516001600160a01b03909116904780156108fc02915f818181858888f19350505050158015610f90573d5f803e3d5ffd5b50565b5f8184841115610fb65760405162461bcd60e51b815260040161080a9190611c1e565b505f610fc28486611f3e565b95945050505050565b601f545f9060ff1615610fea57610fe384848461151b565b90506107da565b6001600160a01b0384165f9081526001602052604090205460ff1615801561102a57506001600160a01b0383165f9081526001602052604090205460ff16155b1561107f57601d54600160a01b900460ff1661107f5760405162461bcd60e51b8152602060048201526014602482015273151c98591a5b99c81b9bdd081bdc195b881e595d60621b604482015260640161080a565b6001600160a01b0384165f9081526001602052604090205460ff161580156110b057506001600160a01b0383163014155b80156110c757506001600160a01b03831661dead14155b80156110e15750601d546001600160a01b03848116911614155b80156110fb57506018546001600160a01b03848116911614155b801561111557506015546001600160a01b03848116911614155b801561113957506001600160a01b0383165f9081526009602052604090205460ff16155b156111d9576001600160a01b0383165f908152600660205260409020546005546111638483611f51565b11156111d75760405162461bcd60e51b815260206004820152603e60248201527f546f74616c20486f6c64696e672069732063757272656e746c79206c696d697460448201527f65642c20796f752063616e206e6f74206275792074686174206d7563682e0000606482015260840161080a565b505b6111e384836115eb565b6111eb611657565b156111f8576111f86116ab565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0387165f90815260069091529190912054611249918490610f93565b6001600160a01b0385165f90815260066020908152604080832093909355600890529081205460ff168061129457506001600160a01b0384165f9081526008602052604090205460ff165b6112a8576112a3858486611a73565b6112aa565b825b6001600160a01b0385165f908152600660205260409020549091506112cf9082611322565b6001600160a01b038086165f8181526006602052604090819020939093559151908716905f805160206120138339815191529061130f9085815260200190565b60405180910390a3506001949350505050565b5f8061132e8385611f51565b9050838110156107da5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161080a565b7f8cc651ceed4360bdb07d4dfc17daa4a6fa17092a313d2464a582a73e9b9328006113bd6064610945601254600f5461141b90919063ffffffff16565b6113d96064610945601154600f5461141b90919063ffffffff16565b6113f56064610945601354600f5461141b90919063ffffffff16565b6040805160ff9485168152928416602084015292168183015290519081900360600190a1565b5f825f0361142a57505f61071d565b5f6114358385611ef5565b9050826114428583611ed6565b146107da5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161080a565b5f6107da83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611bf2565b5f6107da83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610f93565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386165f90815260069091529182205461156b918490610f93565b6001600160a01b038086165f9081526006602052604080822093909355908516815220546115999083611322565b6001600160a01b038085165f8181526006602052604090819020939093559151908616905f80516020612013833981519152906115d99086815260200190565b60405180910390a35060019392505050565b6004548111158061161357506001600160a01b0382165f9081526009602052604090205460ff165b6116535760405162461bcd60e51b8152602060048201526011602482015270151608131a5b5a5d08115e18d959591959607a1b604482015260640161080a565b5050565b601d545f906001600160a01b031633148015906116775750601f5460ff16155b801561168c5750601d54600160a81b900460ff165b80156109b6575050601e54305f90815260066020526040902054101590565b601f805460ff19166001179055601954601a545f916116c991610dce565b6116d557600a546116d7565b5f5b90505f6116fa6002610945600f5461094586601e5461141b90919063ffffffff16565b90505f61171282601e546114da90919063ffffffff16565b6040805160028082526060820183529293505f92909160208301908036833701905050905030815f8151811061174a5761174a611f64565b6001600160a01b03928316602091820292909201015260025482519116908290600190811061177b5761177b611f64565b6001600160a01b039283166020918202929092010152601b5460405163791ac94760e01b81524792919091169063791ac947906117c49086905f90879030904290600401611f78565b5f604051808303815f87803b1580156117db575f80fd5b505af11580156117ed573d5f803e3d5ffd5b505050505f61180582476114da90919063ffffffff16565b90505f61181f611816886002611499565b600f54906114da565b90505f61183360026109458481878d61141b565b90505f61184f83610945600b548761141b90919063ffffffff16565b90505f61186b84610945600d548861141b90919063ffffffff16565b90505f61188785610945600c548961141b90919063ffffffff16565b6015546040519192505f916001600160a01b039091169085908381818185875af1925050503d805f81146118d6576040519150601f19603f3d011682016040523d82523d5f602084013e6118db565b606091505b50506016546040519192506001600160a01b03169083905f81818185875af1925050503d805f8114611928576040519150601f19603f3d011682016040523d82523d5f602084013e61192d565b606091505b50506017546040519192506001600160a01b03169084905f81818185875af1925050503d805f811461197a576040519150601f19603f3d011682016040523d82523d5f602084013e61197f565b606091505b505f9250508b159050611a5b57601b5460145460405163f305d71960e01b8152306004820152602481018e90525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990879060c40160606040518083038185885af11580156119f9573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611a1e9190611fe7565b505060408051878152602081018e90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b5050601f805460ff1916905550505050505050505050565b601354601d545f91906001600160a01b0390811690841603611a985750601154611ab3565b601d546001600160a01b0390811690861603611ab357506012545b5f611adf6010546064611ac69190611ef5565b61094584610938600f548a61141b90919063ffffffff16565b90505f611afd600f54610945600e548561141b90919063ffffffff16565b90505f611b0a83836114da565b305f90815260066020526040902054909150611b269082611322565b305f90815260066020526040808220929092556018546001600160a01b031681522054611b539083611322565b6018546001600160a01b039081165f9081526006602090815260409182902093909355518381523092918b16915f80516020612013833981519152910160405180910390a38115611bdc57600354611bab90836114da565b6003556040518281525f906001600160a01b038a16905f805160206120138339815191529060200160405180910390a35b611be687846114da565b98975050505050505050565b5f8183611c125760405162461bcd60e51b815260040161080a9190611c1e565b505f610fc28486611ed6565b5f6020808352835180828501525f5b81811015611c4957858101830151858201604001528201611c2d565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114611c7f575f80fd5b919050565b5f8060408385031215611c95575f80fd5b611c9e83611c69565b946020939093013593505050565b5f805f60608486031215611cbe575f80fd5b611cc784611c69565b9250611cd560208501611c69565b9150604084013590509250925092565b5f805f805f8060c08789031215611cfa575f80fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b5f60208284031215611d34575f80fd5b5035919050565b5f60208284031215611d4b575f80fd5b6107da82611c69565b5f805f805f60a08688031215611d68575f80fd5b611d7186611c69565b9450611d7f60208701611c69565b9350611d8d60408701611c69565b9250611d9b60608701611c69565b9150611da960808701611c69565b90509295509295909350565b8015158114610f90575f80fd5b5f8060408385031215611dd3575f80fd5b611ddc83611c69565b91506020830135611dec81611db5565b809150509250929050565b5f805f60608486031215611e09575f80fd5b505081359360208301359350604090920135919050565b5f8060408385031215611e31575f80fd5b611e3a83611c69565b9150611e4860208401611c69565b90509250929050565b5f8060408385031215611e62575f80fd5b50508035926020909101359150565b5f8060408385031215611e82575f80fd5b8235611c9e81611db5565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b5f82611ef057634e487b7160e01b5f52601260045260245ffd5b500490565b808202811582820484141761071d5761071d611ec2565b5f60208284031215611f1c575f80fd5b5051919050565b5f60208284031215611f33575f80fd5b81516107da81611db5565b8181038181111561071d5761071d611ec2565b8082018082111561071d5761071d611ec2565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015611fc65784516001600160a01b031683529383019391830191600101611fa1565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215611ff9575f80fd5b835192506020840151915060408401519050925092509256feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220490ea7a0cc616600eb53767bdd9b8261d7009a6bb8ee841db80646e977d51ea864736f6c63430008140033
Verified Source Code Partial Match
Compiler: v0.8.20+commit.a1b79de6
EVM: shanghai
Optimization: Yes (200 runs)
POGAIC.sol 526 lines
/**
*Submitted for verification at Etherscan.io on 2023-06-27
*/
// https://twitter.com/pepe2coineth
// https://t.me/Pepe2Portal
// https://pepe20.vip
// SPDX-License-Identifier: MIT
pragma solidity 0.8.20;
interface ERC20 {
function totalSupply() external view returns (uint256);
function decimals() external view returns (uint8);
function symbol() external view returns (string memory);
function name() external view returns (string memory);
function getOwner() external view returns (address);
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);
}
abstract contract Context {
function _msgSender() internal view virtual returns (address payable) {
return payable(msg.sender);
}
function _msgData() internal view virtual returns (bytes memory) {
this;
return msg.data;
}
}
contract Ownable is Context {
address public _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor () {
address msgSender = _msgSender();
_owner = msgSender;
authorizations[_owner] = true;
emit OwnershipTransferred(address(0), msgSender);
}
mapping (address => bool) internal authorizations;
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
interface IDEXFactory {
function createPair(address tokenA, address tokenB) external returns (address pair);
}
interface IDEXRouter {
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 swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external payable;
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
}
interface InterfaceLP {
function sync() 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;
}
}
contract POGAIC is Ownable, ERC20 {
using SafeMath for uint256;
address WETH;
address constant DEAD = 0x000000000000000000000000000000000000dEaD;
address constant ZERO = 0x0000000000000000000000000000000000000000;
string constant _name = "PogaiC";
string constant _symbol = "POGAIC";
uint8 constant _decimals = 18;
event AutoLiquify(uint256 amountETH, uint256 amountTokens);
event EditTax(uint8 Buy, uint8 Sell, uint8 Transfer);
event user_exemptfromfees(address Wallet, bool Exempt);
event user_TxExempt(address Wallet, bool Exempt);
event ClearStuck(uint256 amount);
event ClearToken(address TokenAddressCleared, uint256 Amount);
event set_Receivers(address marketingFeeReceiver, address buybackFeeReceiver,address burnFeeReceiver,address devFeeReceiver);
event set_MaxWallet(uint256 maxWallet);
event set_MaxTX(uint256 maxTX);
event set_SwapBack(uint256 Amount, bool Enabled);
uint256 _totalSupply = 100000000000 * 10**_decimals;
uint256 public _maxTxAmount = _totalSupply.mul(1).div(100);
uint256 public _maxWalletToken = _totalSupply.mul(1).div(100);
mapping (address => uint256) _balances;
mapping (address => mapping (address => uint256)) _allowances;
mapping (address => bool) isexemptfromfees;
mapping (address => bool) isexemptfrommaxTX;
uint256 private liquidityFee = 1;
uint256 private marketingFee = 3;
uint256 private devFee = 0;
uint256 private buybackFee = 1;
uint256 private burnFee = 0;
uint256 public totalFee = buybackFee + marketingFee + liquidityFee + devFee + burnFee;
uint256 private feeDenominator = 100;
uint256 sellpercent = 100;
uint256 buypercent = 100;
uint256 transferpercent = 100;
address private autoLiquidityReceiver;
address private marketingFeeReceiver;
address private devFeeReceiver;
address private buybackFeeReceiver;
address private burnFeeReceiver;
uint256 setRatio = 30;
uint256 setRatioDenominator = 100;
IDEXRouter public router;
InterfaceLP private pairContract;
address public pair;
bool public TradingOpen = false;
bool public swapEnabled = true;
uint256 public swapThreshold = _totalSupply * 70 / 1000;
bool inSwap;
modifier swapping() { inSwap = true; _; inSwap = false; }
constructor () {
router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
WETH = router.WETH();
pair = IDEXFactory(router.factory()).createPair(WETH, address(this));
pairContract = InterfaceLP(pair);
_allowances[address(this)][address(router)] = type(uint256).max;
isexemptfromfees[msg.sender] = true;
isexemptfrommaxTX[msg.sender] = true;
isexemptfrommaxTX[pair] = true;
isexemptfrommaxTX[marketingFeeReceiver] = true;
isexemptfrommaxTX[address(this)] = true;
autoLiquidityReceiver = msg.sender;
marketingFeeReceiver = 0xF2e142801C18cB08dDCfda036Db5ef0f36a8760D;
devFeeReceiver = msg.sender;
buybackFeeReceiver = msg.sender;
burnFeeReceiver = DEAD;
_balances[msg.sender] = _totalSupply;
emit Transfer(address(0), msg.sender, _totalSupply);
}
receive() external payable { }
function totalSupply() external view override returns (uint256) { return _totalSupply; }
function decimals() external pure override returns (uint8) { return _decimals; }
function symbol() external pure override returns (string memory) { return _symbol; }
function name() external pure override returns (string memory) { return _name; }
function getOwner() external view override returns (address) {return owner();}
function balanceOf(address account) public view override returns (uint256) { return _balances[account]; }
function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; }
function approve(address spender, uint256 amount) public override returns (bool) {
_allowances[msg.sender][spender] = amount;
emit Approval(msg.sender, spender, amount);
return true;
}
function approveMax(address spender) external returns (bool) {
return approve(spender, type(uint256).max);
}
function transfer(address recipient, uint256 amount) external override returns (bool) {
return _transferFrom(msg.sender, recipient, amount);
}
function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) {
if(_allowances[sender][msg.sender] != type(uint256).max){
_allowances[sender][msg.sender] = _allowances[sender][msg.sender].sub(amount, "Insufficient Allowance");
}
return _transferFrom(sender, recipient, amount);
}
function maxWalletRule(uint256 maxWallPercent) external onlyOwner {
require(maxWallPercent >= 1);
_maxWalletToken = (_totalSupply * maxWallPercent ) / 1000;
emit set_MaxWallet(_maxWalletToken);
}
function removeLimits () external onlyOwner {
_maxTxAmount = _totalSupply;
_maxWalletToken = _totalSupply;
}
function _transferFrom(address sender, address recipient, uint256 amount) internal returns (bool) {
if(inSwap){ return _basicTransfer(sender, recipient, amount); }
if(!authorizations[sender] && !authorizations[recipient]){
require(TradingOpen,"Trading not open yet");
}
if (!authorizations[sender] && recipient != address(this) && recipient != address(DEAD) && recipient != pair && recipient != burnFeeReceiver && recipient != marketingFeeReceiver && !isexemptfrommaxTX[recipient]){
uint256 heldTokens = balanceOf(recipient);
require((heldTokens + amount) <= _maxWalletToken,"Total Holding is currently limited, you can not buy that much.");}
checkTxLimit(sender, amount);
if(shouldSwapBack()){ swapBack(); }
_balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
uint256 amountReceived = (isexemptfromfees[sender] || isexemptfromfees[recipient]) ? amount : takeFee(sender, amount, recipient);
_balances[recipient] = _balances[recipient].add(amountReceived);
emit Transfer(sender, recipient, amountReceived);
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 checkTxLimit(address sender, uint256 amount) internal view {
require(amount <= _maxTxAmount || isexemptfrommaxTX[sender], "TX Limit Exceeded");
}
function shouldTakeFee(address sender) internal view returns (bool) {
return !isexemptfromfees[sender];
}
function takeFee(address sender, uint256 amount, address recipient) internal returns (uint256) {
uint256 percent = transferpercent;
if(recipient == pair) {
percent = sellpercent;
} else if(sender == pair) {
percent = buypercent;
}
uint256 feeAmount = amount.mul(totalFee).mul(percent).div(feeDenominator * 100);
uint256 burnTokens = feeAmount.mul(burnFee).div(totalFee);
uint256 contractTokens = feeAmount.sub(burnTokens);
_balances[address(this)] = _balances[address(this)].add(contractTokens);
_balances[burnFeeReceiver] = _balances[burnFeeReceiver].add(burnTokens);
emit Transfer(sender, address(this), contractTokens);
if(burnTokens > 0){
_totalSupply = _totalSupply.sub(burnTokens);
emit Transfer(sender, ZERO, burnTokens);
}
return amount.sub(feeAmount);
}
function shouldSwapBack() internal view returns (bool) {
return msg.sender != pair
&& !inSwap
&& swapEnabled
&& _balances[address(this)] >= swapThreshold;
}
function manualSend() external {
payable(autoLiquidityReceiver).transfer(address(this).balance);
}
function clearStuckToken(address tokenAddress, uint256 tokens) external returns (bool success) {
if(tokens == 0){
tokens = ERC20(tokenAddress).balanceOf(address(this));
}
emit ClearToken(tokenAddress, tokens);
return ERC20(tokenAddress).transfer(autoLiquidityReceiver, tokens);
}
function setStructure(uint256 _percentonbuy, uint256 _percentonsell, uint256 _wallettransfer) external onlyOwner {
sellpercent = _percentonsell;
buypercent = _percentonbuy;
transferpercent = _wallettransfer;
}
function startTrading() public onlyOwner {
TradingOpen = true;
buypercent = 4000;
sellpercent = 4000;
transferpercent = 1000;
}
function reduceFee() public onlyOwner {
buypercent = 400;
sellpercent = 700;
transferpercent = 500;
}
function setExemptfromfees(address _account, bool _bool) public onlyOwner {
isexemptfromfees[_account] = _bool;
}
function swapBack() internal swapping {
uint256 dynamicLiquidityFee = checkRatio(setRatio, setRatioDenominator) ? 0 : liquidityFee;
uint256 amountToLiquify = swapThreshold.mul(dynamicLiquidityFee).div(totalFee).div(2);
uint256 amountToSwap = swapThreshold.sub(amountToLiquify);
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = WETH;
uint256 balanceBefore = address(this).balance;
router.swapExactTokensForETHSupportingFeeOnTransferTokens(
amountToSwap,
0,
path,
address(this),
block.timestamp
);
uint256 amountETH = address(this).balance.sub(balanceBefore);
uint256 totalETHFee = totalFee.sub(dynamicLiquidityFee.div(2));
uint256 amountETHLiquidity = amountETH.mul(dynamicLiquidityFee).div(totalETHFee).div(2);
uint256 amountETHMarketing = amountETH.mul(marketingFee).div(totalETHFee);
uint256 amountETHbuyback = amountETH.mul(buybackFee).div(totalETHFee);
uint256 amountETHdev = amountETH.mul(devFee).div(totalETHFee);
(bool tmpSuccess,) = payable(marketingFeeReceiver).call{value: amountETHMarketing}("");
(tmpSuccess,) = payable(devFeeReceiver).call{value: amountETHdev}("");
(tmpSuccess,) = payable(buybackFeeReceiver).call{value: amountETHbuyback}("");
tmpSuccess = false;
if(amountToLiquify > 0){
router.addLiquidityETH{value: amountETHLiquidity}(
address(this),
amountToLiquify,
0,
0,
autoLiquidityReceiver,
block.timestamp
);
emit AutoLiquify(amountETHLiquidity, amountToLiquify);
}
}
function set_fees() internal {
emit EditTax( uint8(totalFee.mul(buypercent).div(100)),
uint8(totalFee.mul(sellpercent).div(100)),
uint8(totalFee.mul(transferpercent).div(100))
);
}
function setParameters(uint256 _liquidityFee, uint256 _buybackFee, uint256 _marketingFee, uint256 _devFee, uint256 _burnFee, uint256 _feeDenominator) external onlyOwner {
liquidityFee = _liquidityFee;
buybackFee = _buybackFee;
marketingFee = _marketingFee;
devFee = _devFee;
burnFee = _burnFee;
totalFee = _liquidityFee.add(_buybackFee).add(_marketingFee).add(_devFee).add(_burnFee);
feeDenominator = _feeDenominator;
require(totalFee < feeDenominator / 2, "Fees can not be more than 50%");
set_fees();
}
function setWallets(address _autoLiquidityReceiver, address _marketingFeeReceiver, address _devFeeReceiver, address _burnFeeReceiver, address _buybackFeeReceiver) external onlyOwner {
autoLiquidityReceiver = _autoLiquidityReceiver;
marketingFeeReceiver = _marketingFeeReceiver;
devFeeReceiver = _devFeeReceiver;
burnFeeReceiver = _burnFeeReceiver;
buybackFeeReceiver = _buybackFeeReceiver;
emit set_Receivers(marketingFeeReceiver, buybackFeeReceiver, burnFeeReceiver, devFeeReceiver);
}
function setSwapBackSettings(bool _enabled, uint256 _amount) external onlyOwner {
swapEnabled = _enabled;
swapThreshold = _amount;
emit set_SwapBack(swapThreshold, swapEnabled);
}
function checkRatio(uint256 ratio, uint256 accuracy) public view returns (bool) {
return showBacking(accuracy) > ratio;
}
function showBacking(uint256 accuracy) public view returns (uint256) {
return accuracy.mul(balanceOf(pair).mul(2)).div(showSupply());
}
function showSupply() public view returns (uint256) {
return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(ZERO));
}
}
Read Contract
TradingOpen 0x08fd3d05 → bool
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletToken 0x78109e54 → uint256
_owner 0xb2bdfa7b → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
checkRatio 0xded1e438 → bool
decimals 0x313ce567 → uint8
getOwner 0x893d20e8 → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
showBacking 0x30c9a6a0 → uint256
showSupply 0x55265669 → uint256
swapEnabled 0x6ddd1713 → bool
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
totalFee 0x1df4ccfc → uint256
totalSupply 0x18160ddd → uint256
Write Contract 17 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approveMax 0x571ac8b0
address spender
returns: bool
clearStuckToken 0x77b54bad
address tokenAddress
uint256 tokens
returns: bool
manualSend 0xf4293890
No parameters
maxWalletRule 0x5d83e1d5
uint256 maxWallPercent
reduceFee 0xa70419d2
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setExemptfromfees 0x8f3daa9e
address _account
bool _bool
setParameters 0x282c8749
uint256 _liquidityFee
uint256 _buybackFee
uint256 _marketingFee
uint256 _devFee
uint256 _burnFee
uint256 _feeDenominator
setStructure 0xc0cbdea4
uint256 _percentonbuy
uint256 _percentonsell
uint256 _wallettransfer
setSwapBackSettings 0xdf20fd49
bool _enabled
uint256 _amount
setWallets 0x82528791
address _autoLiquidityReceiver
address _marketingFeeReceiver
address _devFeeReceiver
address _burnFeeReceiver
address _buybackFeeReceiver
startTrading 0x293230b8
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address