Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x9c4dD0762fa527c4EE3C225861122B09614AeC12
Balance 0 ETH
Nonce 1
Code Size 14040 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14040 bytes
0x60806040526004361061039b5760003560e01c80639a7a23d6116101dc578063d257b34f11610102578063e884f260116100a0578063f2fde38b1161006f578063f2fde38b14610a51578063f5648a4f14610a71578063f637434214610a86578063f8b45b0514610a9c57600080fd5b8063e884f260146109f0578063ee40166e14610a05578063efda116514610a1b578063f11a24d314610a3b57600080fd5b8063e2f45605116100dc578063e2f456051461098f578063e71dc3f5146109a5578063e7b71ce2146109bb578063e800dff7146109d057600080fd5b8063d257b34f14610913578063d85ba06314610933578063dd62ed3e1461094957600080fd5b8063b62496f51161017a578063c17b5b8c11610149578063c17b5b8c146108a3578063c18bc195146108c3578063c876d0b9146108e3578063cf46f24c146108fd57600080fd5b8063b62496f514610814578063b987553914610844578063bbc0c74214610864578063c02466681461088357600080fd5b8063a457c2d7116101b6578063a457c2d7146107a8578063a62068ce146107c8578063a9059cbb146107de578063adb873bd146107fe57600080fd5b80639a7a23d61461075d5780639e93ad8e1461077d578063a28e86d31461079357600080fd5b80635a139dd4116102c15780637571336a1161025f57806385b12c7c1161022e57806385b12c7c146106da57806385ecfd28146106fa5780638da5cb5b1461072a57806395d89b411461074857600080fd5b80637571336a1461065a5780638095d5641461067a57806382aa7c681461069a5780638366e79a146106ba57600080fd5b80636ddd17131161029b5780636ddd1713146105f057806370a0823114610610578063715018a614610630578063751039fc1461064557600080fd5b80635a139dd4146105ae5780636a486a8e146105c45780636b0a894c146105da57600080fd5b806323b872dd11610339578063499b839411610308578063499b8394146105475780634a62bb65146105675780634f77f6c01461058157806358a6d5311461059757600080fd5b806323b872dd146104cb578063313ce567146104eb5780633950935114610507578063452ed4f11461052757600080fd5b806310d5de531161037557806310d5de531461043a578063130a2c3c1461046a57806318160ddd1461048c578063203e727e146104ab57600080fd5b806306fdde03146103a75780630758d924146103d2578063095ea7b31461040a57600080fd5b366103a257005b600080fd5b3480156103b357600080fd5b506103bc610ab2565b6040516103c99190612f98565b60405180910390f35b3480156103de57600080fd5b506008546103f2906001600160a01b031681565b6040516001600160a01b0390911681526020016103c9565b34801561041657600080fd5b5061042a610425366004612ffe565b610b44565b60405190151581526020016103c9565b34801561044657600080fd5b5061042a61045536600461302a565b601c6020526000908152604090205460ff1681565b34801561047657600080fd5b5061048a61048536600461305c565b610b5b565b005b34801561049857600080fd5b506002545b6040519081526020016103c9565b3480156104b757600080fd5b5061048a6104c63660046130e2565b610c05565b3480156104d757600080fd5b5061042a6104e63660046130fb565b610cd7565b3480156104f757600080fd5b50604051601281526020016103c9565b34801561051357600080fd5b5061042a610522366004612ffe565b610d81565b34801561053357600080fd5b506009546103f2906001600160a01b031681565b34801561055357600080fd5b5061048a61056236600461302a565b610dbd565b34801561057357600080fd5b5060105461042a9060ff1681565b34801561058d57600080fd5b5061049d60185481565b3480156105a357600080fd5b50600d54431061042a565b3480156105ba57600080fd5b5061049d60145481565b3480156105d057600080fd5b5061049d60175481565b3480156105e657600080fd5b5061049d600f5481565b3480156105fc57600080fd5b5060105461042a9062010000900460ff1681565b34801561061c57600080fd5b5061049d61062b36600461302a565b610e6e565b34801561063c57600080fd5b5061048a610e89565b34801561065157600080fd5b5061048a610efd565b34801561066657600080fd5b5061048a61067536600461313c565b610f68565b34801561068657600080fd5b5061048a610695366004613175565b611030565b3480156106a657600080fd5b5061048a6106b53660046130e2565b6110d9565b3480156106c657600080fd5b5061042a6106d53660046131a1565b6111ac565b3480156106e657600080fd5b5061048a6106f53660046130e2565b6113b5565b34801561070657600080fd5b5061042a61071536600461302a565b600e6020526000908152604090205460ff1681565b34801561073657600080fd5b506005546001600160a01b03166103f2565b34801561075457600080fd5b506103bc6115dc565b34801561076957600080fd5b5061048a61077836600461313c565b6115eb565b34801561078957600080fd5b5061049d61271081565b34801561079f57600080fd5b5061048a6116df565b3480156107b457600080fd5b5061042a6107c3366004612ffe565b611718565b3480156107d457600080fd5b5061049d600d5481565b3480156107ea57600080fd5b5061042a6107f9366004612ffe565b6117b1565b34801561080a57600080fd5b5061049d601a5481565b34801561082057600080fd5b5061042a61082f36600461302a565b601d6020526000908152604090205460ff1681565b34801561085057600080fd5b5061048a61085f3660046131cf565b6117be565b34801561087057600080fd5b5060105461042a90610100900460ff1681565b34801561088f57600080fd5b5061048a61089e36600461313c565b61187d565b3480156108af57600080fd5b5061048a6108be366004613175565b611906565b3480156108cf57600080fd5b5061048a6108de3660046130e2565b6119aa565b3480156108ef57600080fd5b5060125461042a9060ff1681565b34801561090957600080fd5b5061049d60065481565b34801561091f57600080fd5b5061048a61092e3660046130e2565b611a74565b34801561093f57600080fd5b5061049d60135481565b34801561095557600080fd5b5061049d6109643660046131a1565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561099b57600080fd5b5061049d600a5481565b3480156109b157600080fd5b5061049d60165481565b3480156109c757600080fd5b5061048a611bbf565b3480156109dc57600080fd5b5061048a6109eb36600461313c565b611c1f565b3480156109fc57600080fd5b5061048a611c74565b348015610a1157600080fd5b5061049d600c5481565b348015610a2757600080fd5b5061048a610a363660046130e2565b611caa565b348015610a4757600080fd5b5061049d60155481565b348015610a5d57600080fd5b5061048a610a6c36600461302a565b611eab565b348015610a7d57600080fd5b5061048a611f96565b348015610a9257600080fd5b5061049d60195481565b348015610aa857600080fd5b5061049d60075481565b606060038054610ac1906131ec565b80601f0160208091040260200160405190810160405280929190818152602001828054610aed906131ec565b8015610b3a5780601f10610b0f57610100808354040283529160200191610b3a565b820191906000526020600020905b815481529060010190602001808311610b1d57829003601f168201915b5050505050905090565b6000610b51338484612002565b5060015b92915050565b6005546001600160a01b03163314610b8e5760405162461bcd60e51b8152600401610b8590613226565b60405180910390fd5b60005b82811015610bff5781600e6000868685818110610bb057610bb061325b565b9050602002016020810190610bc5919061302a565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610bf781613287565b915050610b91565b50505050565b6005546001600160a01b03163314610c2f5760405162461bcd60e51b8152600401610b8590613226565b610c3b6012600a613384565b6103e8610c4760025490565b610c52906002613393565b610c5c91906133aa565b610c6691906133aa565b811015610c855760405162461bcd60e51b8152600401610b85906133cc565b610c916012600a613384565b610c9b9082613393565b60068190556040519081527f89c099a4e6d77f9ed9839689924c080dcc270b4bc837e2d8979544f19df27d78906020015b60405180910390a150565b6000610ce4848484612127565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610d695760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b6064820152608401610b85565b610d768533858403612002565b506001949350505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610b51918590610db8908690613415565b612002565b6005546001600160a01b03163314610de75760405162461bcd60e51b8152600401610b8590613226565b6001600160a01b038116610e4c5760405162461bcd60e51b815260206004820152602660248201527f5f6f7065726174696f6e734164647265737320616464726573732063616e6e6f60448201526507420626520360d41b6064820152608401610b85565b600b80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b031660009081526020819052604090205490565b6005546001600160a01b03163314610eb35760405162461bcd60e51b8152600401610b8590613226565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610f275760405162461bcd60e51b8152600401610b8590613226565b6010805460ff199081169091556012805490911690556040517fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c90600090a1565b6005546001600160a01b03163314610f925760405162461bcd60e51b8152600401610b8590613226565b80611005576009546001600160a01b03908116908316036110055760405162461bcd60e51b815260206004820152602760248201527f43616e6e6f742072656d6f766520756e697377617020706169722066726f6d2060448201526636b0bc103a3c3760c91b6064820152608401610b85565b6001600160a01b03919091166000908152601c60205260409020805460ff1916911515919091179055565b6005546001600160a01b0316331461105a5760405162461bcd60e51b8152600401610b8590613226565b601483905560158290556016819055806110748385613415565b61107e9190613415565b60138190556105dc10156110d45760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610b85565b505050565b6005546001600160a01b031633146111035760405162461bcd60e51b8152600401610b8590613226565b601054610100900460ff161561115b5760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207265656e61626c652074726164696e670000000000000000006044820152606401610b85565b6010805462ffff0019166201010017905543600c81905561117d908290613415565b600d556040517fa56feb2d31b9a7424db0be063fd450863979c9e2382cf5110f869bd1ad361bb790600090a150565b6005546000906001600160a01b031633146111d95760405162461bcd60e51b8152600401610b8590613226565b6001600160a01b03831661122f5760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f7420626520300000000000006044820152606401610b85565b306001600160a01b038416036112875760405162461bcd60e51b815260206004820152601c60248201527f43616e2774207769746864726177206e617469766520746f6b656e73000000006044820152606401610b85565b6040516370a0823160e01b81523060048201526000906001600160a01b038516906370a0823190602401602060405180830381865afa1580156112ce573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112f29190613428565b60405163a9059cbb60e01b81526001600160a01b038581166004830152602482018390529192509085169063a9059cbb906044016020604051808303816000875af1158015611345573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113699190613441565b604080516001600160a01b0387168152602081018490529193507fdeda980967fcead7b61e78ac46a4da14274af29e894d4d61e8b81ec38ab3e438910160405180910390a15092915050565b6005546001600160a01b031633146113df5760405162461bcd60e51b8152600401610b8590613226565b601054610100900460ff16156114075760405162461bcd60e51b8152600401610b859061345e565b600a81106114675760405162461bcd60e51b815260206004820152602760248201527f43616e6e6f74206d616b652070656e616c747920626c6f636b73206d6f72652060448201526607468616e2031360cc1b6064820152608401610b85565b6010805462ffff0019166201010017905543600c819055611489908290613415565b600d556040517fa56feb2d31b9a7424db0be063fd450863979c9e2382cf5110f869bd1ad361bb790600090a1600047116114d55760405162461bcd60e51b8152600401610b85906134a9565b60006114e030610e6e565b1161153c5760405162461bcd60e51b815260206004820152602660248201527f4d757374206861766520546f6b656e73206f6e20636f6e747261637420746f206044820152650d8c2eadcc6d60d31b6064820152608401610b85565b6008546115579030906001600160a01b0316610db882610e6e565b6008546001600160a01b031663f305d719473061157381610e6e565b60008030426040518863ffffffff1660e01b8152600401611599969594939291906134ec565b60606040518083038185885af11580156115b7573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610bff9190613527565b606060048054610ac1906131ec565b6005546001600160a01b031633146116155760405162461bcd60e51b8152600401610b8590613226565b6009546001600160a01b03908116908316036116995760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610b85565b6116a38282612b2a565b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b6005546001600160a01b031633146117095760405162461bcd60e51b8152600401610b8590613226565b6010805460ff19166001179055565b3360009081526001602090815260408083206001600160a01b03861684529091528120548281101561179a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610b85565b6117a73385858403612002565b5060019392505050565b6000610b51338484612127565b6005546001600160a01b031633146117e85760405162461bcd60e51b8152600401610b8590613226565b806118355760405162461bcd60e51b815260206004820152601f60248201527f506c6561736520636f6e6669726d20616464696e67206f6620746865204c50006044820152606401610b85565b601054610100900460ff161561185d5760405162461bcd60e51b8152600401610b859061345e565b600047116114d55760405162461bcd60e51b8152600401610b85906134a9565b6005546001600160a01b031633146118a75760405162461bcd60e51b8152600401610b8590613226565b6001600160a01b0382166000818152601b6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146119305760405162461bcd60e51b8152600401610b8590613226565b60188390556019829055601a8190558061194a8385613415565b6119549190613415565b60178190556105dc10156110d45760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610b85565b6005546001600160a01b031633146119d45760405162461bcd60e51b8152600401610b8590613226565b6119e06012600a613384565b60646119eb60025490565b6119f6906001613393565b611a0091906133aa565b611a0a91906133aa565b811015611a295760405162461bcd60e51b8152600401610b85906133cc565b611a356012600a613384565b611a3f9082613393565b60078190556040519081527f3046ad62de8b70d396246aaed19ff2559ff20df8706520cbde58320766c4276290602001610ccc565b6005546001600160a01b03163314611a9e5760405162461bcd60e51b8152600401610b8590613226565b620186a0611aab60025490565b611ab6906001613393565b611ac091906133aa565b811015611b2d5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610b85565b6103e8611b3960025490565b611b44906001613393565b611b4e91906133aa565b811115611bba5760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171892903a37ba30b61039bab838363c9760611b6064820152608401610b85565b600a55565b6005546001600160a01b03163314611be95760405162461bcd60e51b8152600401610b8590613226565b6032601481905560006015819055611c0091613415565b6013556032601881905560006019819055611c1a91613415565b601755565b6005546001600160a01b03163314611c495760405162461bcd60e51b8152600401610b8590613226565b6001600160a01b03919091166000908152600e60205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314611c9e5760405162461bcd60e51b8152600401610b8590613226565b6012805460ff19169055565b6005546001600160a01b03163314611cd45760405162461bcd60e51b8152600401610b8590613226565b6009546040516370a0823160e01b81523060048201526000916001600160a01b0316906370a0823190602401602060405180830381865afa158015611d1d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d419190613428565b905060008111611d935760405162461bcd60e51b815260206004820152601860248201527f4e6f204c5020746f6b656e7320696e20636f6e747261637400000000000000006044820152606401610b85565b6000612710611da28484613393565b611dac91906133aa565b60095460085460405163095ea7b360e01b81526001600160a01b03918216600482015260248101849052929350169063095ea7b3906044016020604051808303816000875af1158015611e03573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e279190613441565b50600854604051629d473b60e21b81526001600160a01b03909116906302751cec90611e6290309085906001908190339042906004016134ec565b60408051808303816000875af1158015611e80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ea49190613555565b5050505050565b6005546001600160a01b03163314611ed55760405162461bcd60e51b8152600401610b8590613226565b6001600160a01b038116611f3a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610b85565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314611fc05760405162461bcd60e51b8152600401610b8590613226565b604051600090339047908381818185875af1925050503d8060008114610bff576040519150601f19603f3d011682016040523d82523d6000602084013e610bff565b6001600160a01b0383166120645760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610b85565b6001600160a01b0382166120c55760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610b85565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661214d5760405162461bcd60e51b8152600401610b8590613579565b6001600160a01b0382166121735760405162461bcd60e51b8152600401610b85906135be565b600081116121c35760405162461bcd60e51b815260206004820152601d60248201527f616d6f756e74206d7573742062652067726561746572207468616e20300000006044820152606401610b85565b601054610100900460ff16612256576001600160a01b0383166000908152601b602052604090205460ff168061221157506001600160a01b0382166000908152601b602052604090205460ff165b6122565760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610b85565b600d5415612329576001600160a01b0383166000908152600e602052604090205460ff16158061229357506005546001600160a01b038381169116145b806122a857506001600160a01b03821661dead145b6123295760405162461bcd60e51b815260206004820152604660248201527f426f74732063616e6e6f74207472616e7366657220746f6b656e7320696e206f60448201527f72206f75742065786365707420746f206f776e6572206f722064656164206164606482015265323932b9b99760d11b608482015260a401610b85565b60105460ff161561271c576005546001600160a01b0384811691161480159061236057506005546001600160a01b03838116911614155b801561237457506001600160a01b03821615155b801561238b57506001600160a01b03821661dead14155b80156123b057506001600160a01b0383166000908152601b602052604090205460ff16155b80156123d557506001600160a01b0382166000908152601b602052604090205460ff16155b1561271c5760125460ff16156124ee576008546001600160a01b0383811691161480159061241157506009546001600160a01b03838116911614155b156124ee57612421600243613601565b3260009081526011602052604090205410801561245f5750612444600243613601565b6001600160a01b038316600090815260116020526040902054105b6124c95760405162461bcd60e51b815260206004820152603560248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527432b21710102a393c9030b3b0b4b7103630ba32b91760591b6064820152608401610b85565b3260009081526011602052604080822043908190556001600160a01b03851683529120555b6001600160a01b0383166000908152601d602052604090205460ff16801561252f57506001600160a01b0382166000908152601c602052604090205460ff16155b156125f7576006548111156125975760405162461bcd60e51b815260206004820152602860248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201526736b0bc103a3c371760c11b6064820152608401610b85565b600754816125a484610e6e565b6125ae9190613415565b11156125f25760405162461bcd60e51b815260206004820152601360248201527213585e0815d85b1b195d08115e18d959591959606a1b6044820152606401610b85565b61271c565b6001600160a01b0382166000908152601d602052604090205460ff16801561263857506001600160a01b0383166000908152601c602052604090205460ff16155b156126a1576006548111156125f25760405162461bcd60e51b815260206004820152602960248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152681036b0bc103a3c371760b91b6064820152608401610b85565b6001600160a01b0382166000908152601c602052604090205460ff1661271c57600754816126ce84610e6e565b6126d89190613415565b111561271c5760405162461bcd60e51b815260206004820152601360248201527213585e0815d85b1b195d08115e18d959591959606a1b6044820152606401610b85565b600061272730610e6e565b600a5490915081108015908190612746575060105462010000900460ff165b801561275c5750600954600160a01b900460ff16155b801561278157506001600160a01b0385166000908152601d602052604090205460ff16155b80156127a657506001600160a01b0385166000908152601b602052604090205460ff16155b80156127cb57506001600160a01b0384166000908152601b602052604090205460ff16155b15612820576009805460ff60a01b1916600160a01b179055600a546127f1906014613393565b82111561280957600a54612806906014613393565b91505b61281282612b58565b6009805460ff60a01b191690555b6001600160a01b0385166000908152601b602052604090205460019060ff168061286257506001600160a01b0385166000908152601b602052604090205460ff165b1561286b575060005b6000806000808415612b1357600d54431080156128a057506001600160a01b038a166000908152601d602052604090205460ff165b80156128c557506001600160a01b0389166000908152601d602052604090205460ff16155b80156128d357506000601354115b156129cd576001600160a01b0389166000908152600e602052604090205460ff16612973576001600160a01b0389166000908152600e60205260408120805460ff19166001908117909155600f805491929091612931908490613415565b90915550506040516001600160a01b038a1681527f55678e47d0a699d3ab99b0184c4ff14f2246ba80522deb921aa0c8823578c44a9060200160405180910390a15b50886064612982896063613393565b61298c91906133aa565b93506013546015548561299f9190613393565b6129a991906133aa565b9150601354601654856129bc9190613393565b6129c691906133aa565b9250612ad4565b6001600160a01b0389166000908152601d602052604090205460ff1680156129f757506000601754115b15612a4a5788905061271060175489612a109190613393565b612a1a91906133aa565b935060175460195485612a2d9190613393565b612a3791906133aa565b9150601754601a54856129bc9190613393565b6001600160a01b038a166000908152601d602052604090205460ff168015612a7457506000601354115b15612ad45789905061271060135489612a8d9190613393565b612a9791906133aa565b935060135460155485612aaa9190613393565b612ab491906133aa565b915060135460165485612ac79190613393565b612ad191906133aa565b92505b8315612b0657612ae58a3086612cb6565b8215612af557612af53084612e0b565b8115612b0657612b06308284612cb6565b612b108489613601565b97505b612b1e8a8a8a612cb6565b50505050505050505050565b6001600160a01b0382166000908152601d60205260409020805460ff19168215151790556116a38282612f35565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110612b8d57612b8d61325b565b6001600160a01b03928316602091820292909201810191909152600854604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612be6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612c0a9190613614565b81600181518110612c1d57612c1d61325b565b6001600160a01b039283166020918202929092010152600854612c439130911684612002565b600854600b5460405163791ac94760e01b81526001600160a01b039283169263791ac94792612c8092879260009288929116904290600401613631565b600060405180830381600087803b158015612c9a57600080fd5b505af1158015612cae573d6000803e3d6000fd5b505050505050565b6001600160a01b038316612cdc5760405162461bcd60e51b8152600401610b8590613579565b6001600160a01b038216612d025760405162461bcd60e51b8152600401610b85906135be565b6001600160a01b03831660009081526020819052604090205481811015612d7a5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610b85565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290612db1908490613415565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051612dfd91815260200190565b60405180910390a350505050565b6001600160a01b038216612e6b5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610b85565b6001600160a01b03821660009081526020819052604090205481811015612edf5760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b6064820152608401610b85565b6001600160a01b0383166000818152602081815260408083208686039055600280548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910161211a565b6001600160a01b0382166000818152601c6020908152604091829020805460ff19168515159081179091558251938452908301527f6b4f1be9103e6cbcd38ca4a922334f2c3109b260130a6676a987f94088fd6746910160405180910390a15050565b600060208083528351808285015260005b81811015612fc557858101830151858201604001528201612fa9565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114612ffb57600080fd5b50565b6000806040838503121561301157600080fd5b823561301c81612fe6565b946020939093013593505050565b60006020828403121561303c57600080fd5b813561304781612fe6565b9392505050565b8015158114612ffb57600080fd5b60008060006040848603121561307157600080fd5b833567ffffffffffffffff8082111561308957600080fd5b818601915086601f83011261309d57600080fd5b8135818111156130ac57600080fd5b8760208260051b85010111156130c157600080fd5b602092830195509350508401356130d78161304e565b809150509250925092565b6000602082840312156130f457600080fd5b5035919050565b60008060006060848603121561311057600080fd5b833561311b81612fe6565b9250602084013561312b81612fe6565b929592945050506040919091013590565b6000806040838503121561314f57600080fd5b823561315a81612fe6565b9150602083013561316a8161304e565b809150509250929050565b60008060006060848603121561318a57600080fd5b505081359360208301359350604090920135919050565b600080604083850312156131b457600080fd5b82356131bf81612fe6565b9150602083013561316a81612fe6565b6000602082840312156131e157600080fd5b81356130478161304e565b600181811c9082168061320057607f821691505b60208210810361322057634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006001820161329957613299613271565b5060010190565b600181815b808511156132db5781600019048211156132c1576132c1613271565b808516156132ce57918102915b93841c93908002906132a5565b509250929050565b6000826132f257506001610b55565b816132ff57506000610b55565b8160018114613315576002811461331f5761333b565b6001915050610b55565b60ff84111561333057613330613271565b50506001821b610b55565b5060208310610133831016604e8410600b841016171561335e575081810a610b55565b61336883836132a0565b806000190482111561337c5761337c613271565b029392505050565b600061304760ff8416836132e3565b8082028115828204841417610b5557610b55613271565b6000826133c757634e487b7160e01b600052601260045260246000fd5b500490565b60208082526029908201527f43616e6e6f7420736574206d61782062757920616d6f756e74206c6f776572206040820152687468616e20302e322560b81b606082015260800190565b80820180821115610b5557610b55613271565b60006020828403121561343a57600080fd5b5051919050565b60006020828403121561345357600080fd5b81516130478161304e565b6020808252602b908201527f54726164696e6720697320616c7265616479206163746976652c2063616e6e6f60408201526a3a103932b630bab731b41760a91b606082015260800190565b60208082526023908201527f4d757374206861766520455448206f6e20636f6e747261637420746f206c61756040820152620dcc6d60eb1b606082015260800190565b6001600160a01b039687168152602081019590955260408501939093526060840191909152909216608082015260a081019190915260c00190565b60008060006060848603121561353c57600080fd5b8351925060208401519150604084015190509250925092565b6000806040838503121561356857600080fd5b505080516020909101519092909150565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b81810381811115610b5557610b55613271565b60006020828403121561362657600080fd5b815161304781612fe6565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156136815784516001600160a01b03168352938301939183019160010161365c565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212203c1e39a06b0ebba5090d349c1339f0749737af43edfb80b71cae59c8b7440c0964736f6c63430008110033

Verified Source Code Partial Match

Compiler: v0.8.17+commit.8df45f5f EVM: london Optimization: Yes (200 runs)
PedoBear.sol 963 lines
// SPDX-License-Identifier: MIT

/**
 * https://t.me/PedoBear_ERC20
 *
 * ~ 31TB
 *
 */

pragma solidity 0.8.17;

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 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    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) private _balances;

    mapping(address => mapping(address => uint256)) private _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"
        );
        unchecked {
            _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"
        );
        unchecked {
            _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"
        );
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);
    }

    function _createInitialSupply(
        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];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
            // Overflow not possible: amount <= accountBalance <= totalSupply.
            _totalSupply -= amount;
        }

        emit Transfer(account, address(0), 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);
    }
}

contract Ownable is Context {
    address private _owner;

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

    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

    function renounceOwnership() external 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 IDexRouter {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

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

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

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

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

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

contract PedoBear is ERC20, Ownable {
    uint256 public maxTxnAmount;
    uint256 public maxWallet;

    IDexRouter public dexRouter;
    address public lpPair;

    bool private swapping;
    uint256 public swapTokensAtAmount;

    address operationsAddress;

    uint256 public tradingActiveBlock = 0; // 0 means trading is not active
    uint256 public blockForPenaltyEnd;
    mapping(address => bool) public boughtEarly;
    uint256 public botsCaught;

    bool public limitsInEffect = true;
    bool public tradingActive = false;
    bool public swapEnabled = false;

    // Anti-bot and anti-whale mappings and variables
    mapping(address => uint256) private _holderLastTransferTimestamp; // to hold last Transfers temporarily during launch
    bool public transferDelayEnabled = true;

    uint256 public buyTotalFees;
    uint256 public buyOperationsFee;
    uint256 public buyLiquidityFee;
    uint256 public buyBurnFee;

    uint256 public sellTotalFees;
    uint256 public sellOperationsFee;
    uint256 public sellLiquidityFee;
    uint256 public sellBurnFee;

    uint256 public constant FEE_DIVISOR = 10000;

    /******************/

    // exlcude from fees and max transaction amount
    mapping(address => bool) private _isExcludedFromFees;
    mapping(address => bool) public _isExcludedMaxTransactionAmount;

    // store addresses that a automatic market maker pairs. Any transfer *to* these addresses
    // could be subject to a maximum transfer amount
    mapping(address => bool) public automatedMarketMakerPairs;

    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);

    event EnabledTrading();

    event RemovedLimits();

    event ExcludeFromFees(address indexed account, bool isExcluded);

    event UpdatedMaxTxnAmount(uint256 newAmount);
    event UpdatedMaxWallet(uint256 newAmount);

    event UpdatedOperationsAddress(address indexed newWallet);

    event MaxTransactionExclusion(address _address, bool excluded);

    event OwnerForcedSwapBack(uint256 timestamp);

    event CaughtEarlyBuyer(address sniper);

    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );

    event TransferForeignToken(address token, uint256 amount);

    constructor() payable ERC20("PedoBear", "PEDO") {
        address newOwner = msg.sender; // can leave alone if owner is deployer.

        address _dexRouter;

        if (block.chainid == 1) {
            _dexRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; // ETH: Uniswap V2
        } else if (block.chainid == 4) {
            _dexRouter = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D; // ETH: Rinkeby
        } else {
            revert("Chain not configured");
        }

        // initialize router
        dexRouter = IDexRouter(_dexRouter);

        // create pair
        lpPair = IDexFactory(dexRouter.factory()).createPair(
            address(this),
            dexRouter.WETH()
        );
        _excludeFromMaxTransaction(address(lpPair), true);
        _setAutomatedMarketMakerPair(address(lpPair), true);

        uint256 totalSupply = 31 * 1e12 * 1e18;

        maxTxnAmount = (totalSupply * 15) / 1000; // 1.5%
        maxWallet = (totalSupply * 15) / 1000; // 1.5%
        swapTokensAtAmount = (totalSupply * 1) / 10000; // 0.01%

        buyOperationsFee = 50;
        buyLiquidityFee = 0;
        buyBurnFee = 0;
        buyTotalFees = buyOperationsFee + buyLiquidityFee + buyBurnFee;

        sellOperationsFee = 50;
        sellLiquidityFee = 0;
        sellBurnFee = 0;
        sellTotalFees = sellOperationsFee + sellLiquidityFee + sellBurnFee;

        _excludeFromMaxTransaction(newOwner, true);
        _excludeFromMaxTransaction(address(this), true);
        _excludeFromMaxTransaction(address(0xdead), true);
        _excludeFromMaxTransaction(address(dexRouter), true);

        excludeFromFees(newOwner, true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        excludeFromFees(address(dexRouter), true);

        operationsAddress = address(msg.sender);

        _createInitialSupply(address(this), (totalSupply * 88) / 100);
        _createInitialSupply(newOwner, (totalSupply * 12) / 100);
        transferOwnership(newOwner);
    }

    receive() external payable {}

    // only enable if no plan to airdrop

    function enableTrading(uint256 deadBlocks) external onlyOwner {
        require(!tradingActive, "Cannot reenable trading");
        tradingActive = true;
        swapEnabled = true;
        tradingActiveBlock = block.number;
        blockForPenaltyEnd = tradingActiveBlock + deadBlocks;
        emit EnabledTrading();
    }

    // remove limits after token is stable
    function removeLimits() external onlyOwner {
        limitsInEffect = false;
        transferDelayEnabled = false;
        emit RemovedLimits();
    }

    function restoreLimits() external onlyOwner {
        limitsInEffect = true;
    }

    function manageBoughtEarly(address wallet, bool flag) external onlyOwner {
        boughtEarly[wallet] = flag;
    }

    function massManageBoughtEarly(
        address[] calldata wallets,
        bool flag
    ) external onlyOwner {
        for (uint256 i = 0; i < wallets.length; i++) {
            boughtEarly[wallets[i]] = flag;
        }
    }

    // disable Transfer delay - cannot be reenabled
    function disableTransferDelay() external onlyOwner {
        transferDelayEnabled = false;
    }

    function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 2) / 1000) / (10 ** decimals()),
            "Cannot set max buy amount lower than 0.2%"
        );
        maxTxnAmount = newNum * (10 ** decimals());
        emit UpdatedMaxTxnAmount(maxTxnAmount);
    }

    function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 1) / 100) / (10 ** decimals()),
            "Cannot set max buy amount lower than 0.2%"
        );
        maxWallet = newNum * (10 ** decimals());
        emit UpdatedMaxWallet(maxWallet);
    }

    // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner {
        require(
            newAmount >= (totalSupply() * 1) / 100000,
            "Swap amount cannot be lower than 0.001% total supply."
        );
        require(
            newAmount <= (totalSupply() * 1) / 1000,
            "Swap amount cannot be higher than 0.1% total supply."
        );
        swapTokensAtAmount = newAmount;
    }

    function _excludeFromMaxTransaction(
        address updAds,
        bool isExcluded
    ) private {
        _isExcludedMaxTransactionAmount[updAds] = isExcluded;
        emit MaxTransactionExclusion(updAds, isExcluded);
    }

    function excludeFromMaxTransaction(
        address updAds,
        bool isEx
    ) external onlyOwner {
        if (!isEx) {
            require(
                updAds != lpPair,
                "Cannot remove uniswap pair from max txn"
            );
        }
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    function setAutomatedMarketMakerPair(
        address pair,
        bool value
    ) external onlyOwner {
        require(
            pair != lpPair,
            "The pair cannot be removed from automatedMarketMakerPairs"
        );

        _setAutomatedMarketMakerPair(pair, value);
        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;

        _excludeFromMaxTransaction(pair, value);

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function updateBuyFees(
        uint256 _operationsFee,
        uint256 _liquidityFee,
        uint256 _burnFee
    ) external onlyOwner {
        buyOperationsFee = _operationsFee;
        buyLiquidityFee = _liquidityFee;
        buyBurnFee = _burnFee;
        buyTotalFees = buyOperationsFee + buyLiquidityFee + buyBurnFee;
        require(buyTotalFees <= 1500, "Must keep fees at 10% or less");
    }

    function updateSellFees(
        uint256 _operationsFee,
        uint256 _liquidityFee,
        uint256 _burnFee
    ) external onlyOwner {
        sellOperationsFee = _operationsFee;
        sellLiquidityFee = _liquidityFee;
        sellBurnFee = _burnFee;
        sellTotalFees = sellOperationsFee + sellLiquidityFee + sellBurnFee;
        require(sellTotalFees <= 1500, "Must keep fees at 10% or less");
    }

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }

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

        if (!tradingActive) {
            require(
                _isExcludedFromFees[from] || _isExcludedFromFees[to],
                "Trading is not active."
            );
        }

        if (blockForPenaltyEnd > 0) {
            require(
                !boughtEarly[from] || to == owner() || to == address(0xdead),
                "Bots cannot transfer tokens in or out except to owner or dead address."
            );
        }

        if (limitsInEffect) {
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !_isExcludedFromFees[from] &&
                !_isExcludedFromFees[to]
            ) {
                // at launch if the transfer delay is enabled, ensure the block timestamps for purchasers is set -- during launch.
                if (transferDelayEnabled) {
                    if (to != address(dexRouter) && to != address(lpPair)) {
                        require(
                            _holderLastTransferTimestamp[tx.origin] <
                                block.number - 2 &&
                                _holderLastTransferTimestamp[to] <
                                block.number - 2,
                            "_transfer:: Transfer Delay enabled.  Try again later."
                        );
                        _holderLastTransferTimestamp[tx.origin] = block.number;
                        _holderLastTransferTimestamp[to] = block.number;
                    }
                }

                //when buy
                if (
                    automatedMarketMakerPairs[from] &&
                    !_isExcludedMaxTransactionAmount[to]
                ) {
                    require(
                        amount <= maxTxnAmount,
                        "Buy transfer amount exceeds the max txn."
                    );
                    require(
                        balanceOf(to) + amount <= maxWallet,
                        "Max Wallet Exceeded"
                    );
                }
                //when sell
                else if (
                    automatedMarketMakerPairs[to] &&
                    !_isExcludedMaxTransactionAmount[from]
                ) {
                    require(
                        amount <= maxTxnAmount,
                        "Sell transfer amount exceeds the max txn."
                    );
                } else if (!_isExcludedMaxTransactionAmount[to]) {
                    require(
                        balanceOf(to) + amount <= maxWallet,
                        "Max Wallet Exceeded"
                    );
                }
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

        if (
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;

            if (contractTokenBalance > swapTokensAtAmount * 20) {
                contractTokenBalance = swapTokensAtAmount * 20;
            }

            swapTokensForEthAndSend(contractTokenBalance);

            swapping = false;
        }

        bool takeFee = true;
        // if any account belongs to _isExcludedFromFee account then remove the fee
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }

        uint256 fees = 0;
        uint256 burnTokens = 0;
        uint256 liquidityTokens = 0;
        address currentLiquidityAddress;
        // only take fees on buys/sells, do not take on wallet transfers

        if (takeFee) {
            // bot/sniper penalty.
            if (
                earlyBuyPenaltyInEffect() &&
                automatedMarketMakerPairs[from] &&
                !automatedMarketMakerPairs[to] &&
                buyTotalFees > 0
            ) {
                if (!boughtEarly[to]) {
                    boughtEarly[to] = true;
                    botsCaught += 1;
                    emit CaughtEarlyBuyer(to);
                }
                currentLiquidityAddress = from;
                fees = (amount * 99) / 100;
                liquidityTokens = (fees * buyLiquidityFee) / buyTotalFees;
                burnTokens = (fees * buyBurnFee) / buyTotalFees;
            }
            // on sell
            else if (automatedMarketMakerPairs[to] && sellTotalFees > 0) {
                currentLiquidityAddress = to;
                fees = (amount * sellTotalFees) / FEE_DIVISOR;
                liquidityTokens = (fees * sellLiquidityFee) / sellTotalFees;
                burnTokens = (fees * sellBurnFee) / sellTotalFees;
            }
            // on buy
            else if (automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                currentLiquidityAddress = from;
                fees = (amount * buyTotalFees) / FEE_DIVISOR;
                liquidityTokens = (fees * buyLiquidityFee) / buyTotalFees;
                burnTokens = (fees * buyBurnFee) / buyTotalFees;
            }

            if (fees > 0) {
                super._transfer(from, address(this), fees);
                if (burnTokens > 0) {
                    _burn(address(this), burnTokens);
                }
                if (liquidityTokens > 0) {
                    super._transfer(
                        address(this),
                        currentLiquidityAddress,
                        liquidityTokens
                    );
                }
            }
            amount -= fees;
        }

        super._transfer(from, to, amount);
    }

    function earlyBuyPenaltyInEffect() public view returns (bool) {
        return block.number < blockForPenaltyEnd;
    }

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

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

        // make the swap
        dexRouter.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(operationsAddress),
            block.timestamp
        );
    }

    function transferForeignToken(
        address _token,
        address _to
    ) external onlyOwner returns (bool _sent) {
        require(_token != address(0), "_token address cannot be 0");
        require(_token != address(this), "Can't withdraw native tokens");
        uint256 _contractBalance = IERC20(_token).balanceOf(address(this));
        _sent = IERC20(_token).transfer(_to, _contractBalance);
        emit TransferForeignToken(_token, _contractBalance);
    }

    // withdraw ETH if stuck or someone sends to the address
    function withdrawStuckETH() external onlyOwner {
        bool success;
        (success, ) = address(msg.sender).call{value: address(this).balance}(
            ""
        );
    }

    function setOperationsAddress(
        address _operationsAddress
    ) external onlyOwner {
        require(
            _operationsAddress != address(0),
            "_operationsAddress address cannot be 0"
        );
        operationsAddress = payable(_operationsAddress);
    }

    function resetTaxes() external onlyOwner {
        buyOperationsFee = 50;
        buyLiquidityFee = 0;
        buyTotalFees = buyOperationsFee + buyLiquidityFee;

        sellOperationsFee = 50;
        sellLiquidityFee = 0;
        sellTotalFees = sellOperationsFee + sellLiquidityFee;
    }

    function addLP(bool confirmAddLp) external onlyOwner {
        require(confirmAddLp, "Please confirm adding of the LP");
        require(!tradingActive, "Trading is already active, cannot relaunch.");

        // add the liquidity
        require(
            address(this).balance > 0,
            "Must have ETH on contract to launch"
        );
        require(
            balanceOf(address(this)) > 0,
            "Must have Tokens on contract to launch"
        );

        _approve(address(this), address(dexRouter), balanceOf(address(this)));

        dexRouter.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            address(this),
            block.timestamp
        );
    }

    function removeLP(uint256 percent) external onlyOwner {
        uint256 lpBalance = IERC20(lpPair).balanceOf(address(this));

        require(lpBalance > 0, "No LP tokens in contract");

        uint256 lpAmount = (lpBalance * percent) / 10000;

        // approve token transfer to cover all possible scenarios
        IERC20(lpPair).approve(address(dexRouter), lpAmount);

        // remove the liquidity
        dexRouter.removeLiquidityETH(
            address(this),
            lpAmount,
            1, // slippage is unavoidable
            1, // slippage is unavoidable
            msg.sender,
            block.timestamp
        );
    }

    function launch(uint256 blocksForPenalty) external onlyOwner {
        require(!tradingActive, "Trading is already active, cannot relaunch.");
        require(
            blocksForPenalty < 10,
            "Cannot make penalty blocks more than 10"
        );

        //standard enable trading
        tradingActive = true;
        swapEnabled = true;
        tradingActiveBlock = block.number;
        blockForPenaltyEnd = tradingActiveBlock + blocksForPenalty;
        emit EnabledTrading();

        // add the liquidity

        require(
            address(this).balance > 0,
            "Must have ETH on contract to launch"
        );

        require(
            balanceOf(address(this)) > 0,
            "Must have Tokens on contract to launch"
        );

        _approve(address(this), address(dexRouter), balanceOf(address(this)));

        dexRouter.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            address(this),
            block.timestamp
        );
    }
}

Read Contract

FEE_DIVISOR 0x9e93ad8e → uint256
_isExcludedMaxTransactionAmount 0x10d5de53 → bool
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
blockForPenaltyEnd 0xa62068ce → uint256
botsCaught 0x6b0a894c → uint256
boughtEarly 0x85ecfd28 → bool
buyBurnFee 0xe71dc3f5 → uint256
buyLiquidityFee 0xf11a24d3 → uint256
buyOperationsFee 0x5a139dd4 → uint256
buyTotalFees 0xd85ba063 → uint256
decimals 0x313ce567 → uint8
dexRouter 0x0758d924 → address
earlyBuyPenaltyInEffect 0x58a6d531 → bool
limitsInEffect 0x4a62bb65 → bool
lpPair 0x452ed4f1 → address
maxTxnAmount 0xcf46f24c → uint256
maxWallet 0xf8b45b05 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellBurnFee 0xadb873bd → uint256
sellLiquidityFee 0xf6374342 → uint256
sellOperationsFee 0x4f77f6c0 → uint256
sellTotalFees 0x6a486a8e → uint256
swapEnabled 0x6ddd1713 → bool
swapTokensAtAmount 0xe2f45605 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
tradingActiveBlock 0xee40166e → uint256
transferDelayEnabled 0xc876d0b9 → bool

Write Contract 28 functions

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

addLP 0xb9875539
bool confirmAddLp
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
disableTransferDelay 0xe884f260
No parameters
enableTrading 0x82aa7c68
uint256 deadBlocks
excludeFromFees 0xc0246668
address account
bool excluded
excludeFromMaxTransaction 0x7571336a
address updAds
bool isEx
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
launch 0x85b12c7c
uint256 blocksForPenalty
manageBoughtEarly 0xe800dff7
address wallet
bool flag
massManageBoughtEarly 0x130a2c3c
address[] wallets
bool flag
removeLP 0xefda1165
uint256 percent
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
resetTaxes 0xe7b71ce2
No parameters
restoreLimits 0xa28e86d3
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
setOperationsAddress 0x499b8394
address _operationsAddress
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferForeignToken 0x8366e79a
address _token
address _to
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateBuyFees 0x8095d564
uint256 _operationsFee
uint256 _liquidityFee
uint256 _burnFee
updateMaxTxnAmount 0x203e727e
uint256 newNum
updateMaxWalletAmount 0xc18bc195
uint256 newNum
updateSellFees 0xc17b5b8c
uint256 _operationsFee
uint256 _liquidityFee
uint256 _burnFee
updateSwapTokensAtAmount 0xd257b34f
uint256 newAmount
withdrawStuckETH 0xf5648a4f
No parameters

Recent Transactions

No transactions found for this address