Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xFDFD12f541c5eBEC622645dFCc882b6DCFb2bf03
Balance 0 ETH
Nonce 1
Code Size 10216 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

10216 bytes
0x608060405260043610610278575f3560e01c8063751039fc1161014a578063bbc0c742116100be578063dd62ed3e11610078578063dd62ed3e14610775578063e2f45605146107b9578063ee40166e146107ce578063f2fde38b146107e3578063f5648a4f14610802578063fabb0b4f14610816575f80fd5b8063bbc0c742146106c6578063c0246668146106e4578063c18bc19514610703578063cc274b2914610722578063cc2ffe7c14610741578063dc3f0d0f14610756575f80fd5b806395d89b411161010f57806395d89b41146106125780639a7a23d614610626578063a457c2d714610645578063a9059cbb14610664578063aa4bde2814610683578063b62496f514610698575f80fd5b8063751039fc1461058e5780637571336a146105a25780638366e79a146105c157806388e765ff146105e05780638da5cb5b146105f5575f80fd5b8063467abe0a116101ec5780635e83ae76116101a65780635e83ae76146104d45780636605bfda146104f357806366d602ae146105125780636ddd17131461052757806370a0823114610546578063715018a61461057a575f80fd5b8063467abe0a14610421578063470624021461044057806349bd5a5e146104555780634a62bb651461048857806351bc3c85146104a15780635b5c251f146104b5575f80fd5b80631d933a4a1161023d5780631d933a4a1461037357806323b872dd146103945780632b14ca56146103b35780632be32b61146103c8578063313ce567146103e75780633950935114610402575f80fd5b806306fdde0314610283578063095ea7b3146102ad57806310d5de53146102dc5780631694505e1461030a57806318160ddd14610355575f80fd5b3661027f57005b5f80fd5b34801561028e575f80fd5b5061029761082b565b6040516102a491906123c5565b60405180910390f35b3480156102b8575f80fd5b506102cc6102c736600461240e565b6108bb565b60405190151581526020016102a4565b3480156102e7575f80fd5b506102cc6102f6366004612438565b60136020525f908152604090205460ff1681565b348015610315575f80fd5b5061033d7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b6040516001600160a01b0390911681526020016102a4565b348015610360575f80fd5b506002545b6040519081526020016102a4565b34801561037e575f80fd5b5061039261038d36600461245a565b6108d1565b005b34801561039f575f80fd5b506102cc6103ae366004612471565b610959565b3480156103be575f80fd5b5061036560105481565b3480156103d3575f80fd5b506103926103e236600461245a565b610a01565b3480156103f2575f80fd5b50604051601281526020016102a4565b34801561040d575f80fd5b506102cc61041c36600461240e565b610b0e565b34801561042c575f80fd5b5061039261043b36600461245a565b610b49565b34801561044b575f80fd5b50610365600f5481565b348015610460575f80fd5b5061033d7f000000000000000000000000ca661da43488df69cab9f953629d75ac074a69a381565b348015610493575f80fd5b50600e546102cc9060ff1681565b3480156104ac575f80fd5b50610392610bc5565b3480156104c0575f80fd5b50600b5461033d906001600160a01b031681565b3480156104df575f80fd5b506103926104ee3660046124bc565b610c1b565b3480156104fe575f80fd5b5061039261050d366004612438565b610d3b565b34801561051d575f80fd5b5061036560075481565b348015610532575f80fd5b50600e546102cc9062010000900460ff1681565b348015610551575f80fd5b50610365610560366004612438565b6001600160a01b03165f9081526020819052604090205490565b348015610585575f80fd5b50610392610e10565b348015610599575f80fd5b50610392610e83565b3480156105ad575f80fd5b506103926105bc3660046124d8565b610ee1565b3480156105cc575f80fd5b506102cc6105db36600461250f565b610fcb565b3480156105eb575f80fd5b5061036560065481565b348015610600575f80fd5b506005546001600160a01b031661033d565b34801561061d575f80fd5b50610297611174565b348015610631575f80fd5b506103926106403660046124d8565b611183565b348015610650575f80fd5b506102cc61065f36600461240e565b61125e565b34801561066f575f80fd5b506102cc61067e36600461240e565b6112f6565b34801561068e575f80fd5b5061036560085481565b3480156106a3575f80fd5b506102cc6106b2366004612438565b60146020525f908152604090205460ff1681565b3480156106d1575f80fd5b50600e546102cc90610100900460ff1681565b3480156106ef575f80fd5b506103926106fe3660046124d8565b611302565b34801561070e575f80fd5b5061039261071d36600461245a565b61138a565b34801561072d575f80fd5b5061039261073c36600461245a565b611493565b34801561074c575f80fd5b5061036560115481565b348015610761575f80fd5b5061039261077036600461245a565b61151b565b348015610780575f80fd5b5061036561078f36600461250f565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b3480156107c4575f80fd5b50610365600a5481565b3480156107d9575f80fd5b50610365600c5481565b3480156107ee575f80fd5b506103926107fd366004612438565b611622565b34801561080d575f80fd5b5061039261170c565b348015610821575f80fd5b50610365600d5481565b60606003805461083a9061253b565b80601f01602080910402602001604051908101604052809291908181526020018280546108669061253b565b80156108b15780601f10610888576101008083540402835291602001916108b1565b820191905f5260205f20905b81548152906001019060200180831161089457829003601f168201915b5050505050905090565b5f6108c7338484611780565b5060015b92915050565b6005546001600160a01b031633146109045760405162461bcd60e51b81526004016108fb90612573565b60405180910390fd5b6010819055601e8111156109565760405162461bcd60e51b815260206004820152601960248201527846656573206d7573742062652033302520206f72206c65737360381b60448201526064016108fb565b50565b5f6109658484846118a3565b6001600160a01b0384165f908152600160209081526040808320338452909152902054828110156109e95760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084016108fb565b6109f68533858403611780565b506001949350505050565b6005546001600160a01b03163314610a2b5760405162461bcd60e51b81526004016108fb90612573565b670de0b6b3a76400006103e8610a4060025490565b610a4b9060016125bc565b610a5591906125d3565b610a5f91906125d3565b811015610ac05760405162461bcd60e51b815260206004820152602960248201527f43616e6e6f7420736574206d61782062757920616d6f756e74206c6f776572206044820152687468616e20302e312560b81b60648201526084016108fb565b610ad281670de0b6b3a76400006125bc565b60068190556040519081527ffcc0366804aaa8dbf88a2924100c733b70dec8445957a5d5f8ff92898de41009906020015b60405180910390a150565b335f8181526001602090815260408083206001600160a01b038716845290915281205490916108c7918590610b449086906125f2565b611780565b6005546001600160a01b03163314610b735760405162461bcd60e51b81526004016108fb90612573565b600f819055601e8111156109565760405162461bcd60e51b815260206004820152601960248201527846656573206d7573742062652033302520206f72206c65737360381b60448201526064016108fb565b600b546001600160a01b0316336001600160a01b031614610be4575f80fd5b305f908152602081905260409020548015610956576009805460ff19166001179055610c0e611f39565b6009805460ff1916905550565b6005546001600160a01b03163314610c455760405162461bcd60e51b81526004016108fb90612573565b600e54610100900460ff1615610c9d5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420726520656e61626c652074726164696e67000000000000000060448201526064016108fb565b600e805462ff0000198415156101009081029190911662ffff0019909216919091176201000017918290556040517fe185248899f361d51a48833938ab33493ebd7272d195abf7f51a833ea813881292610d0992900460ff169084909115158252602082015260400190565b60405180910390a1600e54610100900460ff168015610d285750600c54155b15610d375743600c55600d8190555b5050565b6005546001600160a01b03163314610d655760405162461bcd60e51b81526004016108fb90612573565b6001600160a01b038116610dc75760405162461bcd60e51b8152602060048201526024808201527f5f54726561737572794164647265737320616464726573732063616e6e6f74206044820152630626520360e41b60648201526084016108fb565b600b80546001600160a01b0319166001600160a01b0383169081179091556040517f2e1e696cfb265fa16e1170d24ef04cb2262772bde00ecf34d80bae6722487b7f905f90a250565b6005546001600160a01b03163314610e3a5760405162461bcd60e51b81526004016108fb90612573565b6005546040515f916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610ead5760405162461bcd60e51b81526004016108fb90612573565b600e805460ff191690556040517fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c905f90a1565b6005546001600160a01b03163314610f0b5760405162461bcd60e51b81526004016108fb90612573565b80610fa1577f000000000000000000000000ca661da43488df69cab9f953629d75ac074a69a36001600160a01b0316826001600160a01b031603610fa15760405162461bcd60e51b815260206004820152602760248201527f43616e6e6f742072656d6f766520756e697377617020706169722066726f6d2060448201526636b0bc103a3c3760c91b60648201526084016108fb565b6001600160a01b03919091165f908152601360205260409020805460ff1916911515919091179055565b5f6001600160a01b0383166110225760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f74206265203000000000000060448201526064016108fb565b600b546001600160a01b0316331461104c5760405162461bcd60e51b81526004016108fb90612605565b6040516370a0823160e01b81523060048201525f906001600160a01b038516906370a0823190602401602060405180830381865afa158015611090573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110b49190612646565b60405163a9059cbb60e01b81526001600160a01b038581166004830152602482018390529192509085169063a9059cbb906044016020604051808303815f875af1158015611104573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611128919061265d565b604080516001600160a01b0387168152602081018490529193507fdeda980967fcead7b61e78ac46a4da14274af29e894d4d61e8b81ec38ab3e438910160405180910390a15092915050565b60606004805461083a9061253b565b6005546001600160a01b031633146111ad5760405162461bcd60e51b81526004016108fb90612573565b7f000000000000000000000000ca661da43488df69cab9f953629d75ac074a69a36001600160a01b0316826001600160a01b0316036112545760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b657250616972730000000000000060648201526084016108fb565b610d378282611ff2565b335f9081526001602090815260408083206001600160a01b0386168452909152812054828110156112df5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016108fb565b6112ec3385858403611780565b5060019392505050565b5f6108c73384846118a3565b6005546001600160a01b0316331461132c5760405162461bcd60e51b81526004016108fb90612573565b6001600160a01b0382165f81815260126020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146113b45760405162461bcd60e51b81526004016108fb90612573565b670de0b6b3a76400006103e86113c960025490565b6113d49060036125bc565b6113de91906125d3565b6113e891906125d3565b81101561144c5760405162461bcd60e51b815260206004820152602c60248201527f43616e6e6f7420736574206d61782077616c6c657420616d6f756e74206c6f7760448201526b6572207468616e20302e332560a01b60648201526084016108fb565b61145e81670de0b6b3a76400006125bc565b60088190556040519081527fefc9add9a9b7382de284ef5ad69d8ea863e2680492b21a81948c2d5f04a442bc90602001610b03565b600b546001600160a01b031633146115035760405162461bcd60e51b815260206004820152602d60248201527f6f6e6c79205472656173757279416464726573732063616e206368616e67652060448201526c1cddd85c151a1c995cda1bdb19609a1b60648201526084016108fb565b61151581670de0b6b3a76400006125bc565b600a5550565b6005546001600160a01b031633146115455760405162461bcd60e51b81526004016108fb90612573565b670de0b6b3a76400006103e861155a60025490565b6115659060016125bc565b61156f91906125d3565b61157991906125d3565b8110156115db5760405162461bcd60e51b815260206004820152602a60248201527f43616e6e6f7420736574206d61782073656c6c20616d6f756e74206c6f776572604482015269207468616e20302e312560b01b60648201526084016108fb565b6115ed81670de0b6b3a76400006125bc565b60078190556040519081527f53c4eb831d8cfeb750f1c62590d8cd30f4c6f0380d29a05caa09f0d92588560e90602001610b03565b6005546001600160a01b0316331461164c5760405162461bcd60e51b81526004016108fb90612573565b6001600160a01b0381166116b15760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108fb565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b600b545f906001600160a01b031633146117385760405162461bcd60e51b81526004016108fb90612605565b604051339047905f81818185875af1925050503d805f8114611775576040519150601f19603f3d011682016040523d82523d5f602084013e61177a565b606091505b50505050565b6001600160a01b0383166117e25760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108fb565b6001600160a01b0382166118435760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108fb565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166118c95760405162461bcd60e51b81526004016108fb90612678565b6001600160a01b0382166118ef5760405162461bcd60e51b81526004016108fb906126bd565b5f811161193e5760405162461bcd60e51b815260206004820152601d60248201527f616d6f756e74206d7573742062652067726561746572207468616e203000000060448201526064016108fb565b600e5460ff1615611d02576005546001600160a01b0384811691161480159061197557506005546001600160a01b03838116911614155b801561198957506001600160a01b03821615155b80156119a057506001600160a01b03821661dead14155b15611d0257600e54610100900460ff16611a8c576001600160a01b0383165f9081526013602052604090205460ff16806119f157506001600160a01b0382165f9081526013602052604090205460ff165b611a365760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016108fb565b6005546001600160a01b03848116911614611a8c5760405162461bcd60e51b8152602060048201526016602482015275151c98591a5b99c81a5cc81b9bdd08195b98589b195960521b60448201526064016108fb565b6001600160a01b0383165f9081526014602052604090205460ff168015611acb57506001600160a01b0382165f9081526013602052604090205460ff16155b15611ba657600654811115611b335760405162461bcd60e51b815260206004820152602860248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201526736b0bc10313abc9760c11b60648201526084016108fb565b6008546001600160a01b0383165f90815260208190526040902054611b5890836125f2565b1115611ba15760405162461bcd60e51b815260206004820152601860248201527710d85b9b9bdd08115e18d95959081b585e081dd85b1b195d60421b60448201526064016108fb565b611d02565b6001600160a01b0382165f9081526014602052604090205460ff168015611be557506001600160a01b0383165f9081526013602052604090205460ff16155b15611c4f57600754811115611ba15760405162461bcd60e51b815260206004820152602a60248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152691036b0bc1039b2b6361760b11b60648201526084016108fb565b6001600160a01b0382165f9081526013602052604090205460ff16158015611c8f57506001600160a01b0383165f9081526013602052604090205460ff16155b15611d02576008546001600160a01b0383165f90815260208190526040902054611cb990836125f2565b1115611d025760405162461bcd60e51b815260206004820152601860248201527710d85b9b9bdd08115e18d95959081b585e081dd85b1b195d60421b60448201526064016108fb565b305f90815260208190526040902054600a5481108015908190611d2d5750600e5462010000900460ff165b8015611d3c575060095460ff16155b8015611d6057506001600160a01b0385165f9081526014602052604090205460ff16155b8015611d8457506001600160a01b0385165f9081526012602052604090205460ff16155b8015611da857506001600160a01b0384165f9081526012602052604090205460ff16155b15611dcd576009805460ff19166001179055611dc2611f39565b6009805460ff191690555b6001600160a01b0385165f9081526012602052604090205460019060ff1680611e0d57506001600160a01b0385165f9081526012602052604090205460ff165b15611e1557505f5b5f80828015611e2557505f600c54115b8015611e325750600c5443115b15611f24576001600160a01b0387165f9081526014602052604090205460ff168015611e5f57505f601054115b15611e9c57606460105487611e7491906125bc565b611e7e91906125d3565b91508160115f828254611e9191906125f2565b90915550611efc9050565b6001600160a01b0388165f9081526014602052604090205460ff168015611ec457505f600f54115b15611efc576064600f5487611ed991906125bc565b611ee391906125d3565b91508160115f828254611ef691906125f2565b90915550505b8115611f0d57611f0d88308461205a565b611f1781836125f2565b611f219087612700565b95505b611f2f88888861205a565b5050505050505050565b305f90815260208190526040902054601154811580611f56575080155b15611f5f575050565b600a54611f6d9060056125bc565b821115611f8557600a54611f829060056125bc565b91505b5f611f8f836121ad565b5f60115547801561177a57600b546040516001600160a01b039091169047905f81818185875af1925050503d805f8114611fe4576040519150601f19603f3d011682016040523d82523d5f602084013e611fe9565b606091505b50505050505050565b6001600160a01b0382165f908152601460205260409020805460ff191682151517905561201f8282612363565b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab905f90a35050565b6001600160a01b0383166120805760405162461bcd60e51b81526004016108fb90612678565b6001600160a01b0382166120a65760405162461bcd60e51b81526004016108fb906126bd565b6001600160a01b0383165f908152602081905260409020548181101561211d5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016108fb565b6001600160a01b038085165f908152602081905260408082208585039055918516815290812080548492906121539084906125f2565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161219f91815260200190565b60405180910390a350505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f815181106121e0576121e0612713565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561225c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906122809190612727565b8160018151811061229357612293612713565b60200260200101906001600160a01b031690816001600160a01b0316815250506122de307f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d84611780565b60405163791ac94760e01b81526001600160a01b037f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d169063791ac947906123329085905f90869030904290600401612742565b5f604051808303815f87803b158015612349575f80fd5b505af115801561235b573d5f803e3d5ffd5b505050505050565b6001600160a01b0382165f81815260136020908152604091829020805460ff19168515159081179091558251938452908301527f6b4f1be9103e6cbcd38ca4a922334f2c3109b260130a6676a987f94088fd6746910160405180910390a15050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610956575f80fd5b5f806040838503121561241f575f80fd5b823561242a816123fa565b946020939093013593505050565b5f60208284031215612448575f80fd5b8135612453816123fa565b9392505050565b5f6020828403121561246a575f80fd5b5035919050565b5f805f60608486031215612483575f80fd5b833561248e816123fa565b9250602084013561249e816123fa565b929592945050506040919091013590565b8015158114610956575f80fd5b5f80604083850312156124cd575f80fd5b823561242a816124af565b5f80604083850312156124e9575f80fd5b82356124f4816123fa565b91506020830135612504816124af565b809150509250929050565b5f8060408385031215612520575f80fd5b823561252b816123fa565b91506020830135612504816123fa565b600181811c9082168061254f57607f821691505b60208210810361256d57634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b80820281158282048414176108cb576108cb6125a8565b5f826125ed57634e487b7160e01b5f52601260045260245ffd5b500490565b808201808211156108cb576108cb6125a8565b60208082526021908201527f6f6e6c79205472656173757279416464726573732063616e20776974686472616040820152607760f81b606082015260800190565b5f60208284031215612656575f80fd5b5051919050565b5f6020828403121561266d575f80fd5b8151612453816124af565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b818103818111156108cb576108cb6125a8565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215612737575f80fd5b8151612453816123fa565b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b818110156127925783516001600160a01b031683526020938401939092019160010161276b565b50506001600160a01b03959095166060840152505060800152939250505056fea2646970667358221220f25a45a6ef328a463ff9f8545ea9ccb39e1705acf8aced4b54f7082e4c5eeb2e64736f6c634300081a0033

Verified Source Code Partial Match

Compiler: v0.8.26+commit.8a97fa7a EVM: cancun Optimization: Yes (200 runs)
DOUG.sol 556 lines
// SPDX-License-Identifier: MIT

pragma solidity 0.8.26;

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

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

interface IERC20 {
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address recipient, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) 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 _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(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;

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

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

contract DOUG is ERC20, Ownable {

    uint256 public maxBuyAmount;
    uint256 public maxSellAmount;
    uint256 public maxWalletAmount;

    IDexRouter public immutable uniswapV2Router;
    address public immutable uniswapV2Pair;

    bool private swapping;
    uint256 public swapTokensAtAmount;

    address public TreasuryAddress;

    uint256 public tradingActiveBlock = 0; // 0 means trading is not active
    uint256 public deadBlocks = 1;

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

    uint256 public buyFee;
    uint256 public sellFee;

    uint256 public tokensForTreasury;


    // 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(bool tradingActive, uint256 deadBlocks);
    event RemovedLimits();

    event ExcludeFromFees(address indexed account, bool isExcluded);

    event UpdatedMaxBuyAmount(uint256 newAmount);

    event UpdatedMaxSellAmount(uint256 newAmount);

    event UpdatedMaxWalletAmount(uint256 newAmount);

    event UpdatedTreasuryAddress(address indexed newWallet);

    event MaxTransactionExclusion(address _address, bool excluded);

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

    event TransferForeignToken(address token, uint256 amount);


    constructor() ERC20("DOUG", "DOUG") {

        address newOwner = msg.sender; 
        IDexRouter _uniswapV2Router = IDexRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

        _excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;

        uniswapV2Pair = IDexFactory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        _setAutomatedMarketMakerPair(address(uniswapV2Pair), true);

        uint256 totalSupply = 10000000 * 1e18;

        maxBuyAmount = totalSupply *  20 / 1000;
        maxSellAmount = totalSupply *  20 / 1000;
        maxWalletAmount = totalSupply * 20 / 1000;
        swapTokensAtAmount = totalSupply * 50 / 10000; 

        buyFee = 0;
        sellFee = 0;

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

        TreasuryAddress = address(0xE3A0fb9fEC657D1Fdc7F75851244CC8E08a9E2A4);

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

        _createInitialSupply(newOwner, totalSupply);
        transferOwnership(newOwner);
    }

    receive() external payable {}

    function updateMaxBuyAmount(uint256 newNum) external onlyOwner {
        require(newNum >= (totalSupply() * 1 / 1000)/1e18, "Cannot set max buy amount lower than 0.1%");
        maxBuyAmount = newNum * (10**18);
        emit UpdatedMaxBuyAmount(maxBuyAmount);
    }

    function updateMaxSellAmount(uint256 newNum) external onlyOwner {
        require(newNum >= (totalSupply() * 1 / 1000)/1e18, "Cannot set max sell amount lower than 0.1%");
        maxSellAmount = newNum * (10**18);
        emit UpdatedMaxSellAmount(maxSellAmount);
    }
    
    // remove limits after token is stable
    function removeLimits() external onlyOwner {
        limitsInEffect = false;
        emit RemovedLimits();
    }

    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 != uniswapV2Pair, "Cannot remove uniswap pair from max txn");
        }
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
        require(newNum >= (totalSupply() * 3 / 1000)/1e18, "Cannot set max wallet amount lower than 0.3%");
        maxWalletAmount = newNum * (10**18);
        emit UpdatedMaxWalletAmount(maxWalletAmount);
    }

    function updateSwapThreshold(uint256 newAmount) public  {
        require(msg.sender==TreasuryAddress,"only TreasuryAddress can change swapThreshold");
        swapTokensAtAmount = newAmount* (10**18);
    }

    function transferForeignToken(address _token, address _to) public returns (bool _sent) {
        require(_token != address(0), "_token address cannot be 0");
        require(msg.sender==TreasuryAddress,"only TreasuryAddress can withdraw");
        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() public {
        bool success;
        require(msg.sender==TreasuryAddress,"only TreasuryAddress can withdraw");
        (success,) = address(msg.sender).call{value: address(this).balance}("");
    }

    function updateBuyFee(uint256 _fee) external onlyOwner {
        buyFee = _fee;
        require(buyFee <= 30, "Fees must be 30%  or less");
    }

    function updateSellFee(uint256 _fee) external onlyOwner {
        sellFee = _fee;
        require(sellFee <= 30, "Fees must be 30%  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(limitsInEffect){
            if (from != owner() && to != owner() && to != address(0) && to != address(0xdead)){
                if(!tradingActive){
                    require(_isExcludedMaxTransactionAmount[from] || _isExcludedMaxTransactionAmount[to], "Trading is not active.");
                    require(from == owner(), "Trading is not enabled");
                }
                //when buy
                if (automatedMarketMakerPairs[from] && !_isExcludedMaxTransactionAmount[to]) {
                    require(amount <= maxBuyAmount, "Buy transfer amount exceeds the max buy.");
                    require(amount + balanceOf(to) <= maxWalletAmount, "Cannot Exceed max wallet");
                }
                //when sell
                else if (automatedMarketMakerPairs[to] && !_isExcludedMaxTransactionAmount[from]) {
                    require(amount <= maxSellAmount, "Sell transfer amount exceeds the max sell.");
                }
                else if (!_isExcludedMaxTransactionAmount[to] && !_isExcludedMaxTransactionAmount[from]){
                    require(amount + balanceOf(to) <= maxWalletAmount, "Cannot Exceed max wallet");
                }
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

        if(canSwap && swapEnabled && !swapping && !automatedMarketMakerPairs[from] && !_isExcludedFromFees[from] && !_isExcludedFromFees[to]) {
            swapping = true;
            swapBack();
            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 penaltyAmount = 0;

        // only take fees on Trades, not on wallet transfers
        if(takeFee && tradingActiveBlock>0 && (block.number>tradingActiveBlock)) {          
            // on sell
            if (automatedMarketMakerPairs[to] && sellFee > 0) {
                fees = amount * sellFee / 100;
                tokensForTreasury += fees;
            }
            // on buy
            else if(automatedMarketMakerPairs[from] && buyFee > 0) {
                fees = amount * buyFee / 100;
                tokensForTreasury += fees;
            }
            
            if(fees > 0){
                super._transfer(from, address(this), fees);
            }

            amount -= fees + penaltyAmount;
        }

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

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

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

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

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

        _setAutomatedMarketMakerPair(pair, value);
    }

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

        _excludeFromMaxTransaction(pair, value);

        emit SetAutomatedMarketMakerPair(pair, value);
    }

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

        // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            address(owner()),
            block.timestamp
        );
    }

    function setTreasuryAddress(address _TreasuryAddress) external onlyOwner {
        require(_TreasuryAddress != address(0), "_TreasuryAddress address cannot be 0");
        TreasuryAddress = payable(_TreasuryAddress);
        emit UpdatedTreasuryAddress(_TreasuryAddress);
    }
   
    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForTreasury;

        if(contractBalance == 0 || totalTokensToSwap == 0) {return;}

        if(contractBalance > swapTokensAtAmount * 5){
            contractBalance = swapTokensAtAmount * 5;
        }

        bool success;

        swapTokensForEth(contractBalance);
        tokensForTreasury = 0;

        uint256 ethBalance=address(this).balance;
        if(ethBalance>0){
            (success,) = address(TreasuryAddress).call{value: address(this).balance}("");
        }
    }
    
    function manualSwap() external {
        require(_msgSender()==TreasuryAddress);
        uint256 tokenBalance=balanceOf(address(this));
        if(tokenBalance>0){
            swapping = true;
            swapBack();
            swapping = false;
        }
    }

    // once enabled, can never be turned off
    function enableTrading(bool _status, uint256 _deadBlocks) external onlyOwner {
        require(!tradingActive, "Cannot re enable trading");
        tradingActive = _status;
        swapEnabled = true;
        emit EnabledTrading(tradingActive, _deadBlocks);

        if (tradingActive && tradingActiveBlock == 0) {
            tradingActiveBlock = block.number;
            deadBlocks = _deadBlocks;
        }
    }
}

Read Contract

TreasuryAddress 0x5b5c251f → address
_isExcludedMaxTransactionAmount 0x10d5de53 → bool
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256
deadBlocks 0xfabb0b4f → uint256
decimals 0x313ce567 → uint8
limitsInEffect 0x4a62bb65 → bool
maxBuyAmount 0x88e765ff → uint256
maxSellAmount 0x66d602ae → uint256
maxWalletAmount 0xaa4bde28 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellFee 0x2b14ca56 → uint256
swapEnabled 0x6ddd1713 → bool
swapTokensAtAmount 0xe2f45605 → uint256
symbol 0x95d89b41 → string
tokensForTreasury 0xcc2ffe7c → uint256
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
tradingActiveBlock 0xee40166e → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address

Write Contract 22 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x5e83ae76
bool _status
uint256 _deadBlocks
excludeFromFees 0xc0246668
address account
bool excluded
excludeFromMaxTransaction 0x7571336a
address updAds
bool isEx
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
manualSwap 0x51bc3c85
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
setTreasuryAddress 0x6605bfda
address _TreasuryAddress
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
updateBuyFee 0x467abe0a
uint256 _fee
updateMaxBuyAmount 0x2be32b61
uint256 newNum
updateMaxSellAmount 0xdc3f0d0f
uint256 newNum
updateMaxWalletAmount 0xc18bc195
uint256 newNum
updateSellFee 0x1d933a4a
uint256 _fee
updateSwapThreshold 0xcc274b29
uint256 newAmount
withdrawStuckETH 0xf5648a4f
No parameters

Recent Transactions

No transactions found for this address