Address Contract Partially Verified
Address
0xC8209F77150258360C538D8E80a8deAABd69Bb80
Balance
0 ETH
Nonce
1
Code Size
9986 bytes
Creator
0xC357CF60...141f at tx 0xe5bdc8f2...392da2
Indexed Transactions
0
Contract Bytecode
9986 bytes
0x6080604052600436106102765760003560e01c8063658d4b7f1161014f578063b0f7ec38116100c1578063d7c010321161007a578063d7c0103214610805578063d85a282814610825578063dd62ed3e1461083a578063df20fd4914610880578063f2fde38b146108a0578063f40acc3d146108c057600080fd5b8063b0f7ec381461073b578063b62496f51461075c578063bbc0c7421461078c578063c18bc195146107a6578063c38a31de146107c6578063c876d0b9146107e657600080fd5b80638a8c523c116101135780638a8c523c146106775780638da5cb5b1461068c57806395d89b41146106be5780639a7a23d6146106d3578063a82ed9ec146106f3578063a9059cbb1461071b57600080fd5b8063658d4b7f146105f65780636c0a24eb1461061657806370a082311461062c578063715018a61461064c5780637d1db4a51461066157600080fd5b80632b14ca56116101e8578063364333f4116101ac578063364333f41461050f578063404e51291461052457806341aea9de1461054457806345ce5365146105645780634706240214610584578063571ac8b0146105d657600080fd5b80632b14ca56146103fc5780632d83811914610493578063313ce567146104b357806334b86560146104cf5780633582ad23146104ef57600080fd5b8063178002871161023a578063178002871461035a57806318160ddd14610370578063203e727e1461038557806323b872dd146103a757806324c39023146103c75780632b112e49146103e757600080fd5b80630445b6671461028257806306fdde03146102ab578063095ea7b3146102cd5780630cfc15f9146102fd57806316c021291461032a57600080fd5b3661027d57005b600080fd5b34801561028e57600080fd5b5061029860125481565b6040519081526020015b60405180910390f35b3480156102b757600080fd5b506102c06108f4565b6040516102a29190612220565b3480156102d957600080fd5b506102ed6102e8366004612283565b610986565b60405190151581526020016102a2565b34801561030957600080fd5b506102986103183660046122af565b60076020526000908152604090205481565b34801561033657600080fd5b506102ed6103453660046122af565b60146020526000908152604090205460ff1681565b34801561036657600080fd5b5061029860085481565b34801561037c57600080fd5b50600454610298565b34801561039157600080fd5b506103a56103a03660046122cc565b6109f3565b005b3480156103b357600080fd5b506102ed6103c23660046122e5565b610aae565b3480156103d357600080fd5b506103a56103e2366004612336565b610bb6565b3480156103f357600080fd5b50610298610be9565b34801561040857600080fd5b50600e5461044e9060ff8082169161010081048216916201000082048116916301000000810482169164010000000082041690600160281b90046001600160801b031686565b6040805160ff9788168152958716602087015293861693850193909352908416606084015290921660808201526001600160801b0390911660a082015260c0016102a2565b34801561049f57600080fd5b506102986104ae3660046122cc565b610c1c565b3480156104bf57600080fd5b50604051601281526020016102a2565b3480156104db57600080fd5b506102ed6104ea36600461236b565b610c39565b3480156104fb57600080fd5b50600a546102ed9062010000900460ff1681565b34801561051b57600080fd5b506103a5610c5f565b34801561053057600080fd5b506103a561053f366004612336565b610cbf565b34801561055057600080fd5b506103a561055f36600461236b565b610cf2565b34801561057057600080fd5b5061029861057f3660046122cc565b610d16565b34801561059057600080fd5b50600d5461044e9060ff8082169161010081048216916201000082048116916301000000810482169164010000000082041690600160281b90046001600160801b031686565b3480156105e257600080fd5b506102ed6105f13660046122af565b610d29565b34801561060257600080fd5b506103a5610611366004612336565b610d37565b34801561062257600080fd5b5061029860065481565b34801561063857600080fd5b506102986106473660046122af565b610d6a565b34801561065857600080fd5b506103a5610d8c565b34801561066d57600080fd5b5061029860055481565b34801561068357600080fd5b506103a5610da0565b34801561069857600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016102a2565b3480156106ca57600080fd5b506102c0610dca565b3480156106df57600080fd5b506103a56106ee366004612336565b610dd9565b3480156106ff57600080fd5b506106a6737a250d5630b4cf539739df2c5dacb4c659f2488d81565b34801561072757600080fd5b506102ed610736366004612283565b610e96565b34801561074757600080fd5b506011546102ed90600160a01b900460ff1681565b34801561076857600080fd5b506102ed6107773660046122af565b60016020526000908152604090205460ff1681565b34801561079857600080fd5b50600a546102ed9060ff1681565b3480156107b257600080fd5b506103a56107c13660046122cc565b610ea3565b3480156107d257600080fd5b506103a56107e1366004612397565b610f4d565b3480156107f257600080fd5b50600a546102ed90610100900460ff1681565b34801561081157600080fd5b506103a5610820366004612451565b6111ff565b34801561083157600080fd5b506103a5611246565b34801561084657600080fd5b5061029861085536600461249c565b6001600160a01b03918216600090815260096020908152604080832093909416825291909152205490565b34801561088c57600080fd5b506103a561089b3660046124d5565b611261565b3480156108ac57600080fd5b506103a56108bb3660046122af565b61128b565b3480156108cc57600080fd5b506106a67f000000000000000000000000b8d5ddb2dd2bb298f7bcdfa567ac0eec91a44b6181565b606060028054610903906124f1565b80601f016020809104026020016040519081016040528092919081815260200182805461092f906124f1565b801561097c5780601f106109515761010080835404028352916020019161097c565b820191906000526020600020905b81548152906001019060200180831161095f57829003601f168201915b5050505050905090565b3360008181526009602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906109e19086815260200190565b60405180910390a35060015b92915050565b6109fb611301565b670de0b6b3a76400006103e86004546001610a169190612541565b610a209190612558565b610a2a9190612558565b811015610a965760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e312560881b60648201526084015b60405180910390fd5b610aa881670de0b6b3a7640000612541565b60055550565b6001600160a01b038316600090815260096020908152604080832033845290915281205460001914610ba1576001600160a01b0384166000908152600960209081526040808320338452909152902054821115610b4d5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a8d565b6001600160a01b0384166000908152600960209081526040808320338452909152902054610b7c90839061257a565b6001600160a01b03851660009081526009602090815260408083203384529091529020555b610bac84848461135b565b90505b9392505050565b610bbe611301565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000610bf56000610d6a565b610c0061dead610d6a565b600454610c0d919061257a565b610c17919061257a565b905090565b600060085460045483610c2f9190612541565b6109ed9190612558565b6000610c43611301565b50600a805461ff0019166101008315150217905560015b919050565b610c67611301565b604051600090339047908381818185875af1925050503d8060008114610ca9576040519150601f19603f3d011682016040523d82523d6000602084013e610cae565b606091505b5050905080610cbc57600080fd5b50565b610cc7611301565b6001600160a01b03919091166000908152601460205260409020805460ff1916911515919091179055565b610cfa611301565b600a8054911515620100000262ff000019909216919091179055565b600060045460085483610c2f9190612541565b60006109ed82600019610986565b610d3f611301565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6001600160a01b0381166000908152600760205260408120546109ed90610c1c565b610d94611301565b610d9e6000611934565b565b610da8611301565b600a805460ff191660011790556011805460ff60a01b1916600160a01b179055565b606060038054610903906124f1565b610de1611301565b7f000000000000000000000000b8d5ddb2dd2bb298f7bcdfa567ac0eec91a44b616001600160a01b0316826001600160a01b031603610e885760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610a8d565b610e928282611984565b5050565b6000610baf33848461135b565b610eab611301565b670de0b6b3a76400006103e86004546005610ec69190612541565b610ed09190612558565b610eda9190612558565b811015610f355760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263302e352560e01b6064820152608401610a8d565b610f4781670de0b6b3a7640000612541565b60065550565b610f55611301565b600086888a610f648d8f61258d565b610f6e919061258d565b610f78919061258d565b610f82919061258d565b60ff1690506000828486610f96898b61258d565b610fa0919061258d565b610faa919061258d565b610fb4919061258d565b60ff1690506040518060c001604052808d60ff1681526020018c60ff1681526020018b60ff1681526020018a60ff1681526020018960ff168152602001836001600160801b0316815250600d60008201518160000160006101000a81548160ff021916908360ff16021790555060208201518160000160016101000a81548160ff021916908360ff16021790555060408201518160000160026101000a81548160ff021916908360ff16021790555060608201518160000160036101000a81548160ff021916908360ff16021790555060808201518160000160046101000a81548160ff021916908360ff16021790555060a08201518160000160056101000a8154816001600160801b0302191690836001600160801b031602179055509050506040518060c001604052808860ff1681526020018760ff1681526020018660ff1681526020018560ff1681526020018460ff168152602001826001600160801b0316815250600e60008201518160000160006101000a81548160ff021916908360ff16021790555060208201518160000160016101000a81548160ff021916908360ff16021790555060408201518160000160026101000a81548160ff021916908360ff16021790555060608201518160000160036101000a81548160ff021916908360ff16021790555060808201518160000160046101000a81548160ff021916908360ff16021790555060a08201518160000160056101000a8154816001600160801b0302191690836001600160801b03160217905550905050505050505050505050505050565b611207611301565b600f80546001600160a01b039485166001600160a01b031991821617909155601080549385169382169390931790925560118054919093169116179055565b61124e611301565b610cbc303361125c30610d6a565b61135b565b611269611301565b60118054921515600160a01b0260ff60a01b1990931692909217909155601255565b611293611301565b6001600160a01b0381166112f85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a8d565b610cbc81611934565b6000546001600160a01b03163314610d9e5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610a8d565b6001600160a01b03821660009081526014602052604081205460ff1615801561139d57506001600160a01b03841660009081526014602052604090205460ff16155b6113d75760405162461bcd60e51b815260206004820152600b60248201526a109b1858dadb1a5cdd195960aa1b6044820152606401610a8d565b60135460ff16156113f4576113ed8484846119d8565b9050610baf565b600a5462010000900460ff161561178457600a5460ff16611493576001600160a01b0384166000908152600b602052604090205460ff168061144e57506001600160a01b0383166000908152600b602052604090205460ff165b6114935760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610a8d565b6001600160a01b03841660009081526001602052604090205460ff1680156114d457506001600160a01b0383166000908152600c602052604090205460ff16155b1561155a576005548211156114fb5760405162461bcd60e51b8152600401610a8d906125a6565b60065461150784610d6a565b61151190846125ee565b11156115555760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a8d565b61163c565b6001600160a01b03831660009081526001602052604090205460ff16801561159b57506001600160a01b0384166000908152600c602052604090205460ff16155b156115c2576005548211156115555760405162461bcd60e51b8152600401610a8d906125a6565b6001600160a01b0383166000908152600c602052604090205460ff1661163c576006546115ee84610d6a565b6115f890846125ee565b111561163c5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a8d565b600a54610100900460ff1615611784576000546001600160a01b0384811691161480159061168757506001600160a01b038316737a250d5630b4cf539739df2c5dacb4c659f2488d14155b80156116c557507f000000000000000000000000b8d5ddb2dd2bb298f7bcdfa567ac0eec91a44b616001600160a01b0316836001600160a01b031614155b15611784573260009081526015602052604090205443906116e79060016125ee565b106117715760405162461bcd60e51b815260206004820152604e60248201527f5f7472616e736665723a3a205472616e736665722044656c617920656e61626c60448201527f65642e20204f6e6c79206f6e65207075726368617365207065722074776f206260648201526d3637b1b5b99030b63637bbb2b21760911b608482015260a401610a8d565b3260009081526015602052604090204390555b61178c611b01565b1561179957611799611b6e565b60006117a483610d16565b6001600160a01b0386166000908152600760205260409020549091508111156118065760405162461bcd60e51b8152602060048201526014602482015273496e73756666696369656e742042616c616e636560601b6044820152606401610a8d565b6001600160a01b03851660009081526007602052604090205461182a90829061257a565b6001600160a01b0386166000908152600760205260408120919091556118508686611f67565b61185a57816118a7565b6118a77f000000000000000000000000b8d5ddb2dd2bb298f7bcdfa567ac0eec91a44b616001600160a01b0316876001600160a01b03161461189d5760006118a0565b60015b8784611fad565b6001600160a01b0386166000908152600760205260409020549091506118ce9082906125ee565b6001600160a01b0380871660008181526007602052604090209290925587167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61191784610c1c565b60405190815260200160405180910390a350600195945050505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b038216600081815260016020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6000806119e483610d16565b6001600160a01b038616600090815260076020526040902054909150811115611a465760405162461bcd60e51b8152602060048201526014602482015273496e73756666696369656e742042616c616e636560601b6044820152606401610a8d565b6001600160a01b038516600090815260076020526040902054611a6a90829061257a565b6001600160a01b038087166000908152600760205260408082209390935590861681522054611a9a9082906125ee565b6001600160a01b0380861660008181526007602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611aee9087815260200190565b60405180910390a3506001949350505050565b6000336001600160a01b037f000000000000000000000000b8d5ddb2dd2bb298f7bcdfa567ac0eec91a44b611614801590611b3f575060135460ff16155b8015611b545750601154600160a01b900460ff165b8015610c175750601254611b6730610d6a565b1015905090565b60138054600160ff199091161790556040805160c081018252600e5460ff80821683526101008204811660208401526201000082048116938301939093526301000000810483166060830152640100000000810490921660808201819052600160281b9092046001600160801b031660a08201819052601254919260009190611bf79084612541565b611c019190612558565b90506000611c0f828461257a565b9050611c2f737a250d5630b4cf539739df2c5dacb4c659f2488d82610986565b508115611c4557611c433061dead8461135b565b505b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611c7a57611c7a612601565b60200260200101906001600160a01b031690816001600160a01b031681525050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611cec573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d109190612617565b81600181518110611d2357611d23612601565b6001600160a01b039092166020928302919091019091015260405163791ac94760e01b8152737a250d5630b4cf539739df2c5dacb4c659f2488d9063791ac94790611d7b908590600090869030904290600401612634565b600060405180830381600087803b158015611d9557600080fd5b505af1158015611da9573d6000803e3d6000fd5b5050505060004790506000866080015160ff16876000015160ff168860a00151611dd391906126a5565b611ddd91906126a5565b6001600160801b03169050600081886020015160ff1684611dfe9190612541565b611e089190612558565b9050600082896040015160ff1685611e209190612541565b611e2a9190612558565b90506000838a6060015160ff1686611e429190612541565b611e4c9190612558565b6010546040519192506000916001600160a01b039091169084908381818185875af1925050503d8060008114611e9e576040519150601f19603f3d011682016040523d82523d6000602084013e611ea3565b606091505b50506011546040519192506001600160a01b0316908390600081818185875af1925050503d8060008114611ef3576040519150601f19603f3d011682016040523d82523d6000602084013e611ef8565b606091505b5050600f546040519192506001600160a01b0316904790600081818185875af1925050503d8060008114611f48576040519150601f19603f3d011682016040523d82523d6000602084013e611f4d565b606091505b50506013805460ff19169055505050505050505050505050565b6001600160a01b0382166000908152600b602052604081205460ff16158015610baf5750506001600160a01b03166000908152600b602052604090205460ff1615919050565b6040805160c08082018352600d5460ff8082168452610100808304821660208087019190915262010000808504841687890152630100000080860485166060808a019190915264010000000080880487166080808c01919091526001600160801b03600160281b998a9004811660a0808e01919091528d519b8c018e52600e54808b168d529889048a16978c019790975294870488169b8a019b909b52918504861690880152830490931696850196909652919091041692810192909252600091828615156001146120a35760648260a001516001600160801b0316866120949190612541565b61209e9190612558565b6120c8565b60648360a001516001600160801b0316866120be9190612541565b6120c89190612558565b90506000600188151514612106578260a001516001600160801b0316836000015160ff16836120f79190612541565b6121019190612558565b612131565b8360a001516001600160801b0316846000015160ff16836121279190612541565b6121319190612558565b905080600854612141919061257a565b6008556000612150828461257a565b905080156121cc57306000908152600760205260409020546121739082906125ee565b306000818152600760205260409020919091556001600160a01b0389167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6121ba84610c1c565b60405190815260200160405180910390a35b6008546040805184815260208101929092527fc3b3cc73ac1faef58c428c22be6cb344acfd92a699c8cd758c753af27071b5ac910160405180910390a1612213838861257a565b9998505050505050505050565b600060208083528351808285015260005b8181101561224d57858101830151858201604001528201612231565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610cbc57600080fd5b6000806040838503121561229657600080fd5b82356122a18161226e565b946020939093013593505050565b6000602082840312156122c157600080fd5b8135610baf8161226e565b6000602082840312156122de57600080fd5b5035919050565b6000806000606084860312156122fa57600080fd5b83356123058161226e565b925060208401356123158161226e565b929592945050506040919091013590565b80358015158114610c5a57600080fd5b6000806040838503121561234957600080fd5b82356123548161226e565b915061236260208401612326565b90509250929050565b60006020828403121561237d57600080fd5b610baf82612326565b803560ff81168114610c5a57600080fd5b6000806000806000806000806000806101408b8d0312156123b757600080fd5b6123c08b612386565b99506123ce60208c01612386565b98506123dc60408c01612386565b97506123ea60608c01612386565b96506123f860808c01612386565b955061240660a08c01612386565b945061241460c08c01612386565b935061242260e08c01612386565b92506124316101008c01612386565b91506124406101208c01612386565b90509295989b9194979a5092959850565b60008060006060848603121561246657600080fd5b83356124718161226e565b925060208401356124818161226e565b915060408401356124918161226e565b809150509250925092565b600080604083850312156124af57600080fd5b82356124ba8161226e565b915060208301356124ca8161226e565b809150509250929050565b600080604083850312156124e857600080fd5b6122a183612326565b600181811c9082168061250557607f821691505b60208210810361252557634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b80820281158282048414176109ed576109ed61252b565b60008261257557634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156109ed576109ed61252b565b60ff81811683821601908111156109ed576109ed61252b565b60208082526028908201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546040820152673c20b6b7bab73a1760c11b606082015260800190565b808201808211156109ed576109ed61252b565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561262957600080fd5b8151610baf8161226e565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156126845784516001600160a01b03168352938301939183019160010161265f565b50506001600160a01b03969096166060850152505050608001529392505050565b6001600160801b038281168282160390808211156126c5576126c561252b565b509291505056fea2646970667358221220cf64fca79caaf5b42515d6db65e3b910c744c65f5f8f54640ddb6c825b12f72464736f6c63430008130033
Verified Source Code Partial Match
Compiler: v0.8.19+commit.7dd6d404
EVM: paris
Optimization: Yes (200 runs)
PEPIO.sol 625 lines
/**
TG - https://t.me/SuperPepio
Web - http://superpepio.com
Twitter - https://twitter.com/PepioETH
*/
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
pragma solidity ^0.8.0;
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)
pragma solidity ^0.8.0;
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* By default, the owner account will be the one that deploys the contract. This
* can later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
/**
* @dev Initializes the contract setting the deployer as the initial owner.
*/
constructor() {
_transferOwnership(_msgSender());
}
/**
* @dev Throws if called by any account other than the owner.
*/
modifier onlyOwner() {
_checkOwner();
_;
}
/**
* @dev Returns the address of the current owner.
*/
function owner() public view virtual returns (address) {
return _owner;
}
/**
* @dev Throws if the sender is not the owner.
*/
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
/**
* @dev Leaves the contract without owner. It will not be possible to call
* `onlyOwner` functions anymore. Can only be called by the current owner.
*
* NOTE: Renouncing ownership will leave the contract without an owner,
* thereby removing any functionality that is only available to the owner.
*/
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Can only be called by the current owner.
*/
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Internal function without access restriction.
*/
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)
pragma solidity ^0.8.0;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @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);
/**
* @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 `to`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address to, 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 `from` to `to` 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 from,
address to,
uint256 amount
) external returns (bool);
}
pragma solidity ^0.8.19;
interface IUniswapV2Router02 {
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;
}
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB) external returns (address UNISWAP_V2_PAIR);
}
contract PEPIO is IERC20, Ownable {
event Reflect(uint256 amountReflected, uint256 newTotalProportion);
event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
address constant DEAD = 0x000000000000000000000000000000000000dEaD;
address constant ZERO = 0x0000000000000000000000000000000000000000;
uint256 constant MAX_FEE = 10;
IUniswapV2Router02 public constant UNISWAP_V2_ROUTER =
IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
address public immutable UNISWAP_V2_PAIR;
mapping(address => bool) public automatedMarketMakerPairs;
struct Fee {
uint8 reflection;
uint8 marketing;
uint8 lp;
uint8 buyback;
uint8 burn;
uint128 total;
}
string _name = "Super Pepio";
string _symbol = "PEPIO";
uint256 _totalSupply = 420_690_000_000 ether;
uint256 public _maxTxAmount = _totalSupply * 1 / 100;
uint256 public _maxWalletAmount = _totalSupply * 2 / 100;
/* rOwned = ratio of tokens owned relative to circulating supply (NOT total supply, since circulating <= total) */
mapping(address => uint256) public _rOwned;
uint256 public _totalProportion = _totalSupply;
mapping(address => mapping(address => uint256)) _allowances;
bool public tradingActive = false;
bool public transferDelayEnabled = false;
bool public limitsEnabled = true;
mapping(address => bool) isFeeExempt;
mapping(address => bool) isLimitExempt;
Fee public buyFee = Fee({reflection: 0, marketing: 27, lp: 3, buyback: 0, burn: 0, total: 30});
Fee public sellFee = Fee({reflection: 0, marketing: 27, lp: 3, buyback: 0, burn: 0, total: 40});
address private marketingFeeReceiver;
address private lpFeeReceiver;
address private buybackFeeReceiver;
bool public claimingFees = false;
uint256 public swapThreshold = (_totalSupply * 12) / 1000;
bool inSwap;
mapping(address => bool) public blacklists;
mapping(address => uint256) private _holderLastTransferTimestamp;
modifier swapping() {
inSwap = true;
_;
inSwap = false;
}
constructor() {
// create uniswap pair
address _uniswapPair =
IUniswapV2Factory(UNISWAP_V2_ROUTER.factory()).createPair(address(this), UNISWAP_V2_ROUTER.WETH());
UNISWAP_V2_PAIR = _uniswapPair;
_setAutomatedMarketMakerPair(address(_uniswapPair), true);
_allowances[address(this)][address(UNISWAP_V2_ROUTER)] = type(uint256).max;
_allowances[address(this)][owner()] = type(uint256).max;
isLimitExempt[address(this)] = true;
isLimitExempt[DEAD] = true;
isLimitExempt[owner()] = true;
isLimitExempt[UNISWAP_V2_PAIR] = true;
isFeeExempt[address(this)] = true;
isFeeExempt[DEAD] = true;
isFeeExempt[owner()] = true;
marketingFeeReceiver = 0x952b21397A99645099Ed4Dc66573D81BfDAC67a2;
lpFeeReceiver = 0xC357CF60beDdEBCD37CcfB3a8B7bEf5B24a0141f;
buybackFeeReceiver = 0x952b21397A99645099Ed4Dc66573D81BfDAC67a2;
_rOwned[tx.origin] = _totalSupply;
emit Transfer(address(0), tx.origin, _totalSupply);
}
receive() external payable {}
function approve(address spender, uint256 amount) public override returns (bool) {
_allowances[msg.sender][spender] = amount;
emit Approval(msg.sender, spender, amount);
return true;
}
function approveMax(address spender) external returns (bool) {
return approve(spender, type(uint256).max);
}
function transfer(address recipient, uint256 amount) external override returns (bool) {
return _transferFrom(msg.sender, recipient, amount);
}
function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) {
if (_allowances[sender][msg.sender] != type(uint256).max) {
require(_allowances[sender][msg.sender] >= amount, "ERC20: insufficient allowance");
_allowances[sender][msg.sender] = _allowances[sender][msg.sender] - amount;
}
return _transferFrom(sender, recipient, amount);
}
function totalSupply() external view override returns (uint256) {
return _totalSupply;
}
function decimals() external pure returns (uint8) {
return 18;
}
function name() external view returns (string memory) {
return _name;
}
function symbol() external view returns (string memory) {
return _symbol;
}
function balanceOf(address account) public view override returns (uint256) {
return tokenFromReflection(_rOwned[account]);
}
function allowance(address holder, address spender) external view override returns (uint256) {
return _allowances[holder][spender];
}
function tokensToProportion(uint256 tokens) public view returns (uint256) {
return tokens * _totalProportion / _totalSupply;
}
function tokenFromReflection(uint256 proportion) public view returns (uint256) {
return proportion * _totalSupply / _totalProportion;
}
function getCirculatingSupply() public view returns (uint256) {
return _totalSupply - balanceOf(DEAD) - balanceOf(ZERO);
}
function enableTrading() external onlyOwner {
tradingActive = true;
claimingFees = true;
}
function setAutomatedMarketMakerPair(address pair, bool value)
public
onlyOwner
{
require(
pair != UNISWAP_V2_PAIR,
"The pair cannot be removed from automatedMarketMakerPairs"
);
_setAutomatedMarketMakerPair(pair, value);
}
function _setAutomatedMarketMakerPair(address pair, bool value) private {
automatedMarketMakerPairs[pair] = value;
emit SetAutomatedMarketMakerPair(pair, value);
}
function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
require(
newNum >= ((_totalSupply * 1) / 1000) / 1e18,
"Cannot set maxTransactionAmount lower than 0.1%"
);
_maxTxAmount = newNum * (10**18);
}
function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
require(
newNum >= ((_totalSupply * 5) / 1000) / 1e18,
"Cannot set maxWallet lower than 0.5%"
);
_maxWalletAmount = newNum * (10**18);
}
function clearStuckBalance() external onlyOwner {
(bool success,) = payable(msg.sender).call{value: address(this).balance}("");
require(success);
}
function clearStuckToken() external onlyOwner {
_transferFrom(address(this), msg.sender, balanceOf(address(this)));
}
function setSwapBackSettings(bool _enabled, uint256 _amount) external onlyOwner {
claimingFees = _enabled;
swapThreshold = _amount;
}
function changeFees(
uint8 reflectionFeeBuy,
uint8 marketingFeeBuy,
uint8 lpFeeBuy,
uint8 buybackFeeBuy,
uint8 burnFeeBuy,
uint8 reflectionFeeSell,
uint8 marketingFeeSell,
uint8 lpFeeSell,
uint8 buybackFeeSell,
uint8 burnFeeSell
) external onlyOwner {
uint128 __totalBuyFee = reflectionFeeBuy + marketingFeeBuy + lpFeeBuy + buybackFeeBuy + burnFeeBuy;
uint128 __totalSellFee = reflectionFeeSell + marketingFeeSell + lpFeeSell + buybackFeeSell + burnFeeSell;
buyFee = Fee({
reflection: reflectionFeeBuy,
marketing: marketingFeeBuy,
lp: lpFeeBuy,
buyback: buybackFeeBuy,
burn: burnFeeBuy,
total: __totalBuyFee
});
sellFee = Fee({
reflection: reflectionFeeSell,
marketing: marketingFeeSell,
lp: lpFeeSell,
buyback: buybackFeeSell,
burn: burnFeeSell,
total: __totalSellFee
});
}
function setIsFeeExempt(address holder, bool exempt) external onlyOwner {
isFeeExempt[holder] = exempt;
}
function setisLimitExempt(address holder, bool exempt) external onlyOwner {
isLimitExempt[holder] = exempt;
}
function setFeeReceivers(address m_, address lp_, address b_) external onlyOwner {
marketingFeeReceiver = m_;
lpFeeReceiver = lp_;
buybackFeeReceiver = b_;
}
function setLimitsEnabled(bool e_) external onlyOwner {
limitsEnabled = e_;
}
// Set Transfer delay
function disableTransferDelay(bool e_) external onlyOwner returns (bool) {
transferDelayEnabled = e_;
return true;
}
function blacklist(address _address, bool _isBlacklisting) external onlyOwner {
blacklists[_address] = _isBlacklisting;
}
function _transferFrom(address sender, address recipient, uint256 amount) internal returns (bool) {
require(!blacklists[recipient] && !blacklists[sender], "Blacklisted");
if (inSwap) {
return _basicTransfer(sender, recipient, amount);
}
if (limitsEnabled) {
if (!tradingActive)
{
require(
isFeeExempt[sender] || isFeeExempt[recipient],
"Trading is not active."
);
}
//when buy
if (automatedMarketMakerPairs[sender] && !isLimitExempt[recipient])
{
require(amount <= _maxTxAmount, "Transfer amount exceeds the maxTxAmount.");
require(amount + balanceOf(recipient) <= _maxWalletAmount, "Max wallet exceeded");
}
//when sell
else if (automatedMarketMakerPairs[recipient] && !isLimitExempt[sender])
{
require(amount <= _maxTxAmount, "Transfer amount exceeds the maxTxAmount.");
}
else if (!isLimitExempt[recipient])
{
require(amount + balanceOf(recipient) <= _maxWalletAmount, "Max wallet exceeded");
}
// at launch if the transfer delay is enabled, ensure the block timestamps for purchasers is set -- during launch.
if (transferDelayEnabled) {
if (
recipient != owner() &&
recipient != address(UNISWAP_V2_ROUTER) &&
recipient != UNISWAP_V2_PAIR
) {
require(
_holderLastTransferTimestamp[tx.origin] + 1 <
block.number,
"_transfer:: Transfer Delay enabled. Only one purchase per two blocks allowed."
);
_holderLastTransferTimestamp[tx.origin] = block.number;
}
}
}
if (_shouldSwapBack()) {
_swapBack();
}
uint256 proportionAmount = tokensToProportion(amount);
require(_rOwned[sender] >= proportionAmount, "Insufficient Balance");
_rOwned[sender] = _rOwned[sender] - proportionAmount;
uint256 proportionReceived = _shouldTakeFee(sender, recipient)
? _takeFeeInProportions(sender == UNISWAP_V2_PAIR ? true : false, sender, proportionAmount)
: proportionAmount;
_rOwned[recipient] = _rOwned[recipient] + proportionReceived;
emit Transfer(sender, recipient, tokenFromReflection(proportionReceived));
return true;
}
function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
uint256 proportionAmount = tokensToProportion(amount);
require(_rOwned[sender] >= proportionAmount, "Insufficient Balance");
_rOwned[sender] = _rOwned[sender] - proportionAmount;
_rOwned[recipient] = _rOwned[recipient] + proportionAmount;
emit Transfer(sender, recipient, amount);
return true;
}
function _takeFeeInProportions(bool buying, address sender, uint256 proportionAmount) internal returns (uint256) {
Fee memory __buyFee = buyFee;
Fee memory __sellFee = sellFee;
uint256 proportionFeeAmount =
buying == true ? proportionAmount * __buyFee.total / 100 : proportionAmount * __sellFee.total / 100;
// reflect
uint256 proportionReflected = buying == true
? proportionFeeAmount * __buyFee.reflection / __buyFee.total
: proportionFeeAmount * __sellFee.reflection / __sellFee.total;
_totalProportion = _totalProportion - proportionReflected;
// take fees
uint256 _proportionToContract = proportionFeeAmount - proportionReflected;
if (_proportionToContract > 0) {
_rOwned[address(this)] = _rOwned[address(this)] + _proportionToContract;
emit Transfer(sender, address(this), tokenFromReflection(_proportionToContract));
}
emit Reflect(proportionReflected, _totalProportion);
return proportionAmount - proportionFeeAmount;
}
function _shouldSwapBack() internal view returns (bool) {
return msg.sender != UNISWAP_V2_PAIR && !inSwap && claimingFees && balanceOf(address(this)) >= swapThreshold;
}
function _swapBack() internal swapping {
Fee memory __sellFee = sellFee;
uint256 __swapThreshold = swapThreshold;
uint256 amountToBurn = __swapThreshold * __sellFee.burn / __sellFee.total;
uint256 amountToSwap = __swapThreshold - amountToBurn;
approve(address(UNISWAP_V2_ROUTER), amountToSwap);
if(amountToBurn > 0)
{
// burn
_transferFrom(address(this), DEAD, amountToBurn);
}
// swap
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = UNISWAP_V2_ROUTER.WETH();
UNISWAP_V2_ROUTER.swapExactTokensForETHSupportingFeeOnTransferTokens(
amountToSwap, 0, path, address(this), block.timestamp
);
uint256 amountETH = address(this).balance;
uint256 totalSwapFee = __sellFee.total - __sellFee.reflection - __sellFee.burn;
uint256 amountETHMarketing = amountETH * __sellFee.marketing / totalSwapFee;
uint256 amountETHLP = amountETH * __sellFee.lp / totalSwapFee;
uint256 amountETHBuyback = amountETH * __sellFee.buyback / totalSwapFee;
// send
(bool tmpSuccess,) = payable(lpFeeReceiver).call{value: amountETHLP}("");
(tmpSuccess,) = payable(buybackFeeReceiver).call{value: amountETHBuyback}("");
(tmpSuccess,) = address(marketingFeeReceiver).call{value: address(this).balance}("");
}
function _shouldTakeFee(address sender, address recipient) internal view returns (bool) {
return !isFeeExempt[sender] && !isFeeExempt[recipient];
}
}
Read Contract
UNISWAP_V2_PAIR 0xf40acc3d → address
UNISWAP_V2_ROUTER 0xa82ed9ec → address
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletAmount 0x6c0a24eb → uint256
_rOwned 0x0cfc15f9 → uint256
_totalProportion 0x17800287 → uint256
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
blacklists 0x16c02129 → bool
buyFee 0x47062402 → uint8, uint8, uint8, uint8, uint8, uint128
claimingFees 0xb0f7ec38 → bool
decimals 0x313ce567 → uint8
getCirculatingSupply 0x2b112e49 → uint256
limitsEnabled 0x3582ad23 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellFee 0x2b14ca56 → uint8, uint8, uint8, uint8, uint8, uint128
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
tokenFromReflection 0x2d838119 → uint256
tokensToProportion 0x45ce5365 → uint256
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
transferDelayEnabled 0xc876d0b9 → bool
Write Contract 20 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approveMax 0x571ac8b0
address spender
returns: bool
blacklist 0x404e5129
address _address
bool _isBlacklisting
changeFees 0xc38a31de
uint8 reflectionFeeBuy
uint8 marketingFeeBuy
uint8 lpFeeBuy
uint8 buybackFeeBuy
uint8 burnFeeBuy
uint8 reflectionFeeSell
uint8 marketingFeeSell
uint8 lpFeeSell
uint8 buybackFeeSell
uint8 burnFeeSell
clearStuckBalance 0x364333f4
No parameters
clearStuckToken 0xd85a2828
No parameters
disableTransferDelay 0x34b86560
bool e_
returns: bool
enableTrading 0x8a8c523c
No parameters
renounceOwnership 0x715018a6
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
setFeeReceivers 0xd7c01032
address m_
address lp_
address b_
setIsFeeExempt 0x658d4b7f
address holder
bool exempt
setLimitsEnabled 0x41aea9de
bool e_
setSwapBackSettings 0xdf20fd49
bool _enabled
uint256 _amount
setisLimitExempt 0x24c39023
address holder
bool exempt
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateMaxTxnAmount 0x203e727e
uint256 newNum
updateMaxWalletAmount 0xc18bc195
uint256 newNum
Recent Transactions
No transactions found for this address