Address Contract Partially Verified
Address
0xFDFD12f541c5eBEC622645dFCc882b6DCFb2bf03
Balance
0 ETH
Nonce
1
Code Size
10216 bytes
Creator
0x9F559871...aB09 at tx 0x5dc185dc...df7174
Indexed Transactions
0
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