Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x35e445da0C9f6eceA6d95726DF6f325Bfa902456
Balance 0 ETH
Nonce 1
Code Size 13826 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13826 bytes
0x6080604052600436106101d0575f3560e01c80638a8c523c116100f6578063c4918b4e11610094578063f2fde38b11610063578063f2fde38b14610647578063f442d3fb1461066f578063f5648a4f14610697578063f928364c146106ad576101d7565b8063c4918b4e1461058f578063cb4e162b146105b9578063d18afa85146105e3578063dd62ed3e1461060b576101d7565b806395d89b41116100d057806395d89b41146104c3578063a457c2d7146104ed578063a9059cbb14610529578063aa4bde2814610565576101d7565b80638a8c523c146104595780638bcea9391461046f5780638da5cb5b14610499576101d7565b8063395093511161016e57806354cf2aeb1161013d57806354cf2aeb146103c7578063697cfc19146103f157806370a0823114610407578063715018a614610443576101d7565b8063395093511461030f5780633963510b1461034b57806339e7fddc1461037357806354c35c281461039d576101d7565b80630b78f9c0116101aa5780630b78f9c01461025757806318160ddd1461027f57806323b872dd146102a9578063313ce567146102e5576101d7565b8063063be69e146101db57806306fdde03146101f1578063095ea7b31461021b576101d7565b366101d757005b5f80fd5b3480156101e6575f80fd5b506101ef6106c3565b005b3480156101fc575f80fd5b50610205610748565b6040516102129190612427565b60405180910390f35b348015610226575f80fd5b50610241600480360381019061023c91906124d8565b6107d8565b60405161024e9190612530565b60405180910390f35b348015610262575f80fd5b5061027d60048036038101906102789190612549565b6107fa565b005b34801561028a575f80fd5b506102936108d9565b6040516102a09190612596565b60405180910390f35b3480156102b4575f80fd5b506102cf60048036038101906102ca91906125af565b6108e2565b6040516102dc9190612530565b60405180910390f35b3480156102f0575f80fd5b506102f9610910565b604051610306919061261a565b60405180910390f35b34801561031a575f80fd5b50610335600480360381019061033091906124d8565b610918565b6040516103429190612530565b60405180910390f35b348015610356575f80fd5b50610371600480360381019061036c919061266e565b6109bd565b005b34801561037e575f80fd5b50610387610b47565b60405161039491906126a8565b60405180910390f35b3480156103a8575f80fd5b506103b1610b6b565b6040516103be9190612596565b60405180910390f35b3480156103d2575f80fd5b506103db610b71565b6040516103e89190612596565b60405180910390f35b3480156103fc575f80fd5b50610405610b77565b005b348015610412575f80fd5b5061042d600480360381019061042891906126c1565b610bfc565b60405161043a9190612596565b60405180910390f35b34801561044e575f80fd5b50610457610c41565b005b348015610464575f80fd5b5061046d610cc8565b005b34801561047a575f80fd5b50610483610eff565b60405161049091906126a8565b60405180910390f35b3480156104a4575f80fd5b506104ad610f24565b6040516104ba91906126a8565b60405180910390f35b3480156104ce575f80fd5b506104d7610f4c565b6040516104e49190612427565b60405180910390f35b3480156104f8575f80fd5b50610513600480360381019061050e91906124d8565b610fdc565b6040516105209190612530565b60405180910390f35b348015610534575f80fd5b5061054f600480360381019061054a91906124d8565b6110c0565b60405161055c9190612530565b60405180910390f35b348015610570575f80fd5b506105796110e2565b6040516105869190612596565b60405180910390f35b34801561059a575f80fd5b506105a36110e8565b6040516105b09190612596565b60405180910390f35b3480156105c4575f80fd5b506105cd6110ee565b6040516105da9190612596565b60405180910390f35b3480156105ee575f80fd5b5061060960048036038101906106049190612549565b6110f4565b005b348015610616575f80fd5b50610631600480360381019061062c91906126ec565b6111b3565b60405161063e9190612596565b60405180910390f35b348015610652575f80fd5b5061066d600480360381019061066891906126c1565b611235565b005b34801561067a575f80fd5b506106956004803603810190610690919061272a565b61132b565b005b3480156106a2575f80fd5b506106ab6114ab565b005b3480156106b8575f80fd5b506106c1611585565b005b6106cb611611565b73ffffffffffffffffffffffffffffffffffffffff166106e9610f24565b73ffffffffffffffffffffffffffffffffffffffff161461073f576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107369061279f565b60405180910390fd5b5f600781905550565b606060038054610757906127ea565b80601f0160208091040260200160405190810160405280929190818152602001828054610783906127ea565b80156107ce5780601f106107a5576101008083540402835291602001916107ce565b820191905f5260205f20905b8154815290600101906020018083116107b157829003601f168201915b5050505050905090565b5f806107e2611611565b90506107ef818585611618565b600191505092915050565b610802611611565b73ffffffffffffffffffffffffffffffffffffffff16610820610f24565b73ffffffffffffffffffffffffffffffffffffffff1614610876576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161086d9061279f565b60405180910390fd5b60198211158015610888575060198111155b6108c7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108be9061288a565b60405180910390fd5b81600d8190555080600e819055505050565b5f600254905090565b5f806108ec611611565b90506108f98582856117db565b610904858585611866565b60019150509392505050565b5f6012905090565b5f80610922611611565b90506109b281858560015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546109ad91906128d5565b611618565b600191505092915050565b7f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd9573ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161480610a495750610a1a610f24565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b610a51575f80fd5b8073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb338373ffffffffffffffffffffffffffffffffffffffff166370a08231306040518263ffffffff1660e01b8152600401610aa791906126a8565b602060405180830381865afa158015610ac2573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ae6919061291c565b6040518363ffffffff1660e01b8152600401610b03929190612947565b6020604051808303815f875af1158015610b1f573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b439190612998565b5050565b7f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd9581565b600e5481565b600d5481565b610b7f611611565b73ffffffffffffffffffffffffffffffffffffffff16610b9d610f24565b73ffffffffffffffffffffffffffffffffffffffff1614610bf3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bea9061279f565b60405180910390fd5b5f600881905550565b5f805f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610c49611611565b73ffffffffffffffffffffffffffffffffffffffff16610c67610f24565b73ffffffffffffffffffffffffffffffffffffffff1614610cbd576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cb49061279f565b60405180910390fd5b610cc65f611d82565b565b610cd0611611565b73ffffffffffffffffffffffffffffffffffffffff16610cee610f24565b73ffffffffffffffffffffffffffffffffffffffff1614610d44576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d3b9061279f565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610da1573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610dc591906129d7565b73ffffffffffffffffffffffffffffffffffffffff1663e6a4390530737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e3e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e6291906129d7565b6040518363ffffffff1660e01b8152600401610e7f929190612a02565b602060405180830381865afa158015610e9a573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ebe91906129d7565b60065f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b606060048054610f5b906127ea565b80601f0160208091040260200160405190810160405280929190818152602001828054610f87906127ea565b8015610fd25780601f10610fa957610100808354040283529160200191610fd2565b820191905f5260205f20905b815481529060010190602001808311610fb557829003601f168201915b5050505050905090565b5f80610fe6611611565b90505f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050838110156110a7576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161109e90612a99565b60405180910390fd5b6110b48286868403611618565b60019250505092915050565b5f806110ca611611565b90506110d7818585611866565b600191505092915050565b60085481565b60075481565b60095481565b7f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd9573ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806111805750611151610f24565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b611188575f80fd5b6004821115801561119957505f8114155b6111a1575f80fd5b81600a8190555080600b819055505050565b5f60015f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b61123d611611565b73ffffffffffffffffffffffffffffffffffffffff1661125b610f24565b73ffffffffffffffffffffffffffffffffffffffff16146112b1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a89061279f565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff160361131f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161131690612b27565b60405180910390fd5b61132881611d82565b50565b7f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd9573ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806113b75750611388610f24565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b6113bf575f80fd5b6113ef620186a06113e160016113d36108d9565b611e4590919063ffffffff16565b611e5a90919063ffffffff16565b811015611431576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161142890612bb5565b60405180910390fd5b61145f606461145160026114436108d9565b611e4590919063ffffffff16565b611e5a90919063ffffffff16565b8111156114a1576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161149890612c43565b60405180910390fd5b8060098190555050565b7f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd9573ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614806115375750611508610f24565b73ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16145b61153f575f80fd5b3373ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f19350505050158015611582573d5f803e3d5ffd5b50565b61158d611611565b73ffffffffffffffffffffffffffffffffffffffff166115ab610f24565b73ffffffffffffffffffffffffffffffffffffffff1614611601576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115f89061279f565b60405180910390fd5b5f6008819055505f600781905550565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611686576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161167d90612cd1565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036116f4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116eb90612d5f565b60405180910390fd5b8060015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516117ce9190612596565b60405180910390a3505050565b5f6117e684846111b3565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146118605781811015611852576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161184990612dc7565b60405180910390fd5b61185f8484848403611618565b5b50505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036118d4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118cb90612e55565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611942576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161193990612ee3565b60405180910390fd5b5f8111611984576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161197b90612f71565b60405180910390fd5b5f60105f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff1680611a20575060105f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b90505f73ffffffffffffffffffffffffffffffffffffffff1660065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16141580611a7b5750805b611aba576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611ab190612fd9565b60405180910390fd5b5f60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161490505f60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff161490508080611b695750815b8015611b7657505f600754115b8015611b80575082155b15611bcb57600754841115611bca576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bc19061308d565b60405180910390fd5b5b81158015611bda57505f600854115b8015611be4575082155b15611c425760085484611bf687610bfc565b611c0091906128d5565b1115611c41576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611c3890613141565b60405180910390fd5b5b600954611c4e30610bfc565b10158015611c685750600f5f9054906101000a900460ff16155b8015611c715750815b8015611c7b575082155b8015611c8c5750611c8b84611e6f565b5b15611ccd576001600f5f6101000a81548160ff021916908315150217905550611cb3611eca565b5f600f5f6101000a81548160ff0219169083151502179055505b5f81611cdb57600e54611cdf565b600d545b90505f811115611d6e5783158015611d035750600f5f9054906101000a900460ff16155b8015611d1457508180611d135750825b5b15611d6d575f611d406064611d328489611e4590919063ffffffff16565b611e5a90919063ffffffff16565b90505f811115611d5657611d55883083612123565b5b611d69818761239890919063ffffffff16565b9550505b5b611d79878787612123565b50505050505050565b5f60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690508160055f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b5f8183611e52919061315f565b905092915050565b5f8183611e6791906131cd565b905092915050565b5f80600b5414611e8e57600b54600954611e8991906131cd565b611e90565b5f5b8210158015611ec357506002600c5f4381526020019081526020015f205f815480929190611ebd906131fd565b91905055105b9050919050565b5f611ed430610bfc565b90505f8103611ee35750612121565b600954811115611ef35760095490505b5f600267ffffffffffffffff811115611f0f57611f0e613244565b5b604051908082528060200260200182016040528015611f3d5781602001602082028036833780820191505090505b50905030815f81518110611f5457611f53613271565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611feb573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061200f91906129d7565b8160018151811061202357612022613271565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505061207c30737a250d5630b4cf539739df2c5dacb4c659f2488d84611618565b737a250d5630b4cf539739df2c5dacb4c659f2488d73ffffffffffffffffffffffffffffffffffffffff1663791ac947835f847f000000000000000000000000a368f9789c1f9040f8243ccb29636c21a53cbd95426040518663ffffffff1660e01b81526004016120f1959493929190613397565b5f604051808303815f87803b158015612108575f80fd5b505af115801561211a573d5f803e3d5ffd5b5050505050505b565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603612191576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121889061345f565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036121ff576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121f6906134ed565b60405180910390fd5b61220a8383836123ad565b5f805f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205490508181101561228d576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016122849061357b565b60405180910390fd5b8181035f808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550815f808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f82825461231b91906128d5565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161237f9190612596565b60405180910390a36123928484846123b2565b50505050565b5f81836123a59190613599565b905092915050565b505050565b505050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f6123f9826123b7565b61240381856123c1565b93506124138185602086016123d1565b61241c816123df565b840191505092915050565b5f6020820190508181035f83015261243f81846123ef565b905092915050565b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6124748261244b565b9050919050565b6124848161246a565b811461248e575f80fd5b50565b5f8135905061249f8161247b565b92915050565b5f819050919050565b6124b7816124a5565b81146124c1575f80fd5b50565b5f813590506124d2816124ae565b92915050565b5f80604083850312156124ee576124ed612447565b5b5f6124fb85828601612491565b925050602061250c858286016124c4565b9150509250929050565b5f8115159050919050565b61252a81612516565b82525050565b5f6020820190506125435f830184612521565b92915050565b5f806040838503121561255f5761255e612447565b5b5f61256c858286016124c4565b925050602061257d858286016124c4565b9150509250929050565b612590816124a5565b82525050565b5f6020820190506125a95f830184612587565b92915050565b5f805f606084860312156125c6576125c5612447565b5b5f6125d386828701612491565b93505060206125e486828701612491565b92505060406125f5868287016124c4565b9150509250925092565b5f60ff82169050919050565b612614816125ff565b82525050565b5f60208201905061262d5f83018461260b565b92915050565b5f61263d8261246a565b9050919050565b61264d81612633565b8114612657575f80fd5b50565b5f8135905061266881612644565b92915050565b5f6020828403121561268357612682612447565b5b5f6126908482850161265a565b91505092915050565b6126a28161246a565b82525050565b5f6020820190506126bb5f830184612699565b92915050565b5f602082840312156126d6576126d5612447565b5b5f6126e384828501612491565b91505092915050565b5f806040838503121561270257612701612447565b5b5f61270f85828601612491565b925050602061272085828601612491565b9150509250929050565b5f6020828403121561273f5761273e612447565b5b5f61274c848285016124c4565b91505092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6127896020836123c1565b915061279482612755565b602082019050919050565b5f6020820190508181035f8301526127b68161277d565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52602260045260245ffd5b5f600282049050600182168061280157607f821691505b602082108103612814576128136127bd565b5b50919050565b7f417474656d7074696e6720746f207365742066656520686967686572207468615f8201527f6e20696e697469616c206665652e000000000000000000000000000000000000602082015250565b5f612874602e836123c1565b915061287f8261281a565b604082019050919050565b5f6020820190508181035f8301526128a181612868565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f6128df826124a5565b91506128ea836124a5565b9250828201905080821115612902576129016128a8565b5b92915050565b5f81519050612916816124ae565b92915050565b5f6020828403121561293157612930612447565b5b5f61293e84828501612908565b91505092915050565b5f60408201905061295a5f830185612699565b6129676020830184612587565b9392505050565b61297781612516565b8114612981575f80fd5b50565b5f815190506129928161296e565b92915050565b5f602082840312156129ad576129ac612447565b5b5f6129ba84828501612984565b91505092915050565b5f815190506129d18161247b565b92915050565b5f602082840312156129ec576129eb612447565b5b5f6129f9848285016129c3565b91505092915050565b5f604082019050612a155f830185612699565b612a226020830184612699565b9392505050565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f775f8201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b5f612a836025836123c1565b9150612a8e82612a29565b604082019050919050565b5f6020820190508181035f830152612ab081612a77565b9050919050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f612b116026836123c1565b9150612b1c82612ab7565b604082019050919050565b5f6020820190508181035f830152612b3e81612b05565b9050919050565b7f53776170207468726573686f6c642063616e6e6f74206265206c6f77657220745f8201527f68616e20302e3030312520746f74616c20737570706c792e0000000000000000602082015250565b5f612b9f6038836123c1565b9150612baa82612b45565b604082019050919050565b5f6020820190508181035f830152612bcc81612b93565b9050919050565b7f53776170207468726573686f6c642063616e6e6f7420626520686967686572205f8201527f7468616e20322520746f74616c20737570706c792e0000000000000000000000602082015250565b5f612c2d6035836123c1565b9150612c3882612bd3565b604082019050919050565b5f6020820190508181035f830152612c5a81612c21565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612cbb6024836123c1565b9150612cc682612c61565b604082019050919050565b5f6020820190508181035f830152612ce881612caf565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612d496022836123c1565b9150612d5482612cef565b604082019050919050565b5f6020820190508181035f830152612d7681612d3d565b9050919050565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000005f82015250565b5f612db1601d836123c1565b9150612dbc82612d7d565b602082019050919050565b5f6020820190508181035f830152612dde81612da5565b9050919050565b7f5472616e736665722066726f6d20746865207a65726f2061646472657373206e5f8201527f6f7420616c6c6f7765642e000000000000000000000000000000000000000000602082015250565b5f612e3f602b836123c1565b9150612e4a82612de5565b604082019050919050565b5f6020820190508181035f830152612e6c81612e33565b9050919050565b7f5472616e7366657220746f20746865207a65726f2061646472657373206e6f745f8201527f20616c6c6f7765642e0000000000000000000000000000000000000000000000602082015250565b5f612ecd6029836123c1565b9150612ed882612e73565b604082019050919050565b5f6020820190508181035f830152612efa81612ec1565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f2e00000000000000000000000000000000000000000000602082015250565b5f612f5b602a836123c1565b9150612f6682612f01565b604082019050919050565b5f6020820190508181035f830152612f8881612f4f565b9050919050565b7f4c69717569646974792070616972206e6f742079657420637265617465642e005f82015250565b5f612fc3601f836123c1565b9150612fce82612f8f565b602082019050919050565b5f6020820190508181035f830152612ff081612fb7565b9050919050565b7f537761702076616c75652065786365656473206d6178207377617020616d6f755f8201527f6e742c2074727920616761696e2077697468206c65737320737761702076616c60208201527f75652e0000000000000000000000000000000000000000000000000000000000604082015250565b5f6130776043836123c1565b915061308282612ff7565b606082019050919050565b5f6020820190508181035f8301526130a48161306b565b9050919050565b7f42616c616e63652065786365656473206d617820686f6c64696e677320616d6f5f8201527f756e742c20636f6e7369646572207573696e672061207365636f6e642077616c60208201527f6c65742e00000000000000000000000000000000000000000000000000000000604082015250565b5f61312b6044836123c1565b9150613136826130ab565b606082019050919050565b5f6020820190508181035f8301526131588161311f565b9050919050565b5f613169826124a5565b9150613174836124a5565b9250828202613182816124a5565b91508282048414831517613199576131986128a8565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6131d7826124a5565b91506131e2836124a5565b9250826131f2576131f16131a0565b5b828204905092915050565b5f613207826124a5565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203613239576132386128a8565b5b600182019050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f819050919050565b5f819050919050565b5f6132ca6132c56132c08461329e565b6132a7565b6124a5565b9050919050565b6132da816132b0565b82525050565b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6133128161246a565b82525050565b5f6133238383613309565b60208301905092915050565b5f602082019050919050565b5f613345826132e0565b61334f81856132ea565b935061335a836132fa565b805f5b8381101561338a5781516133718882613318565b975061337c8361332f565b92505060018101905061335d565b5085935050505092915050565b5f60a0820190506133aa5f830188612587565b6133b760208301876132d1565b81810360408301526133c9818661333b565b90506133d86060830185612699565b6133e56080830184612587565b9695505050505050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f6134496025836123c1565b9150613454826133ef565b604082019050919050565b5f6020820190508181035f8301526134768161343d565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6134d76023836123c1565b91506134e28261347d565b604082019050919050565b5f6020820190508181035f830152613504816134cb565b9050919050565b7f45524332303a207472616e7366657220616d6f756e74206578636565647320625f8201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b5f6135656026836123c1565b91506135708261350b565b604082019050919050565b5f6020820190508181035f83015261359281613559565b9050919050565b5f6135a3826124a5565b91506135ae836124a5565b92508282039050818111156135c6576135c56128a8565b5b9291505056fea264697066735822122028903bfed05e422cd2dd6e4c267f1730a05cb611ce55ea9010bf76abf1ae45c064736f6c634300081a0033

Verified Source Code Partial Match

Compiler: v0.8.26+commit.8a97fa7a EVM: cancun Optimization: No
INFI.sol 479 lines
// SPDX-License-Identifier: MIT

  /*
    Website: www.incognifi.io
    X/Twitter: x.com/incognifi
    Telegram: t.me/incognifi

    Product Docs: https://incognifi-or-product-docs.gitbook.io/incognifi-or-product-docs
    Github: https://github.com/incognifi-dev/incognifi
  */
  
  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) {
          return msg.data;
      }
  }

  interface IERC20 {
      function totalSupply() external view returns (uint256);
      function balanceOf(address account) external view returns (uint256);
      function transfer(address to, 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 from,
          address to,
          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 to, uint256 amount) public virtual override returns (bool) {
          address owner = _msgSender();
          _transfer(owner, to, 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) {
          address owner = _msgSender();
          _approve(owner, spender, amount);
          return true;
      }

      function transferFrom(
          address from,
          address to,
          uint256 amount
      ) public virtual override returns (bool) {
          address spender = _msgSender();
          _spendAllowance(from, spender, amount);
          _transfer(from, to, amount);
          return true;
      }

      function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
          address owner = _msgSender();
          _approve(owner, spender, _allowances[owner][spender] + addedValue);
          return true;
      }

      function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
          address owner = _msgSender();
          uint256 currentAllowance = _allowances[owner][spender];
          require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
          unchecked {
              _approve(owner, spender, currentAllowance - subtractedValue);
          }

          return true;
      }

      function _transfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {
          require(from != address(0), "ERC20: transfer from the zero address");
          require(to != address(0), "ERC20: transfer to the zero address");

          _beforeTokenTransfer(from, to, amount);

          uint256 fromBalance = _balances[from];
          require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
          unchecked {
              _balances[from] = fromBalance - amount;
          }
          _balances[to] += amount;

          emit Transfer(from, to, amount);

          _afterTokenTransfer(from, to, amount);
      }

      function _mint(address account, uint256 amount) internal virtual {
          require(account != address(0), "ERC20: mint to the zero address");

          _beforeTokenTransfer(address(0), account, amount);

          _totalSupply += amount;
          _balances[account] += amount;
          emit Transfer(address(0), account, amount);

          _afterTokenTransfer(address(0), account, amount);
      }

      function _burn(address account, uint256 amount) internal virtual {
          require(account != address(0), "ERC20: burn from the zero address");

          _beforeTokenTransfer(account, address(0), amount);

          uint256 accountBalance = _balances[account];
          require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
          unchecked {
              _balances[account] = accountBalance - amount;
          }
          _totalSupply -= amount;

          emit Transfer(account, address(0), amount);

          _afterTokenTransfer(account, address(0), amount);
      }

      function _approve(
          address owner,
          address spender,
          uint256 amount
      ) internal virtual {
          require(owner != address(0), "ERC20: approve from the zero address");
          require(spender != address(0), "ERC20: approve to the zero address");

          _allowances[owner][spender] = amount;
          emit Approval(owner, spender, amount);
      }

      function _spendAllowance(
          address owner,
          address spender,
          uint256 amount
      ) internal virtual {
          uint256 currentAllowance = allowance(owner, spender);
          if (currentAllowance != type(uint256).max) {
              require(currentAllowance >= amount, "ERC20: insufficient allowance");
              unchecked {
                  _approve(owner, spender, currentAllowance - amount);
              }
          }
      }

      function _beforeTokenTransfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {}

      function _afterTokenTransfer(
          address from,
          address to,
          uint256 amount
      ) internal virtual {}
  }

  abstract contract Ownable is Context {
      address private _owner;

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

      constructor() {
          _transferOwnership(_msgSender());
      }

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

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

      function renounceOwnership() public virtual onlyOwner {
          _transferOwnership(address(0));
      }

      function transferOwnership(address newOwner) public virtual onlyOwner {
          require(newOwner != address(0), "Ownable: new owner is the zero address");
          _transferOwnership(newOwner);
      }

      function _transferOwnership(address newOwner) internal virtual {
          address oldOwner = _owner;
          _owner = newOwner;
          emit OwnershipTransferred(oldOwner, newOwner);
      }
  }

  library SafeMath {
      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 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;
          }
      }
  }

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

  interface IUniswapV2Router02 {
      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 INFI is ERC20, Ownable {
    using SafeMath for uint256;

    IUniswapV2Router02 private constant _router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    address public uniV2Pair;
    address public immutable feeAddr;

    uint256 public maxSwap;
    uint256 public maxWalletAmount;
    uint256 public feeThreshold;
    uint256 private _contractSwapMax = 3;
    uint256 private _contractSwapMin = 7;
    mapping(uint256 => uint256) private _swapBlocks;

    uint256 public swapFee;
    uint256 public swapBackFee;

    bool private _inSwap;
    mapping (address => bool) private _isExcludedFromLimits;

    constructor() ERC20(unicode"IncogniFi", unicode"INFI") payable {
        uint256 totalSupply = 1000000 * 1e18;

        uint256 caSupply = totalSupply.mul(1).div(10000);

        maxSwap = totalSupply.mul(15).div(1000);
        maxWalletAmount = totalSupply.mul(15).div(1000);
        feeThreshold = totalSupply.mul(5).div(1000);

        feeAddr = 0xa368F9789c1F9040f8243ccB29636C21A53cBd95;

        swapFee = 0;
        swapBackFee = 0;

        _isExcludedFromLimits[feeAddr] = true;
        _isExcludedFromLimits[msg.sender] = true;
        _isExcludedFromLimits[tx.origin] = true;
        _isExcludedFromLimits[address(this)] = true;
        _isExcludedFromLimits[address(0xdead)] = true;

        _mint(address(this), caSupply);

        _mint(tx.origin, totalSupply.sub(caSupply));

    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "Transfer from the zero address not allowed.");
        require(to != address(0), "Transfer to the zero address not allowed.");
        require(amount > 0, 'Transfer amount must be greater than zero.');

        bool excluded = _isExcludedFromLimits[from] || _isExcludedFromLimits[to];
        require(uniV2Pair != address(0) || excluded, "Liquidity pair not yet created.");

        bool isSell = to == uniV2Pair;
        bool isBuy = from == uniV2Pair;

        if ((isBuy || isSell) && maxSwap > 0 && !excluded)
            require(amount <= maxSwap, "Swap value exceeds max swap amount, try again with less swap value.");

        if (!isSell && maxWalletAmount > 0 && !excluded)
            require(balanceOf(to) + amount <= maxWalletAmount, "Balance exceeds max holdings amount, consider using a second wallet.");

        if (
          balanceOf(address(this)) >= feeThreshold &&
          !_inSwap && isSell &&
          !excluded && shouldSwapBack(amount)
        ) {
            _inSwap = true;
            _swapBackTokenFees();
            _inSwap = false;
        }

        uint256 fee = isBuy ? swapFee : swapBackFee;

        if (fee > 0) {
            if (!excluded && !_inSwap && (isBuy || isSell)) {
                uint256 fees = amount.mul(fee).div(100);

                if (fees > 0)
                    super._transfer(from, address(this), fees);

                amount = amount.sub(fees);
            }
        }

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

    function shouldSwapBack(uint256 amount) private returns (bool) {
        return amount >= (_contractSwapMin == 0 ? 0 : feeThreshold / _contractSwapMin) && _swapBlocks[block.number]++ < 2;
      }

    function _swapBackTokenFees() private {
        uint256 contractBalance = balanceOf(address(this));
        if (contractBalance == 0) return;
        if (contractBalance > feeThreshold) contractBalance = feeThreshold;

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = _router.WETH();

        _approve(address(this), address(_router), contractBalance);

        _router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            contractBalance,
            0,
            path,
            feeAddr,
            block.timestamp
        );
    }

    function enableTrading() external onlyOwner {
        uniV2Pair = IUniswapV2Factory(_router.factory()).getPair(address(this), _router.WETH());
    }

    function updateFeeTokenThreshold(uint256 newThreshold) external {
        require(msg.sender == feeAddr || msg.sender == owner());
        require(newThreshold >= totalSupply().mul(1).div(100000), "Swap threshold cannot be lower than 0.001% total supply.");
        require(newThreshold <= totalSupply().mul(2).div(100), "Swap threshold cannot be higher than 2% total supply.");
        feeThreshold = newThreshold;
    }

    function setFees(uint256 newBuyFee, uint256 newSellFee) external onlyOwner {
        require(newBuyFee <= 25 && newSellFee <= 25, 'Attempting to set fee higher than initial fee.');
        swapFee = newBuyFee;
        swapBackFee = newSellFee;
    }

    function disableLimits() external onlyOwner {
        maxWalletAmount = 0;
        maxSwap = 0;
    }

    function disableWalletLimit() external onlyOwner {
        maxWalletAmount = 0;
    }

    function disableSwapLimit() external onlyOwner {
        maxSwap = 0;
    }

    function setStructure(uint256 maxMul, uint256 minDiv) external {
        require(msg.sender == feeAddr || msg.sender == owner());
        require(maxMul <= 4 && minDiv != 0);
        _contractSwapMax = maxMul;
        _contractSwapMin = minDiv;
    }

    function withdrawStuckETH() external  {
        require(msg.sender == feeAddr || msg.sender == owner());
        payable(msg.sender).transfer(address(this).balance);
    }

    function withdrawStuckERC20(IERC20 token) external  {
      require(msg.sender == feeAddr || msg.sender == owner());
        token.transfer(msg.sender, token.balanceOf(address(this)));
    }

    receive() external payable {}
  }

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
feeAddr 0x39e7fddc → address
feeThreshold 0xcb4e162b → uint256
maxSwap 0xc4918b4e → uint256
maxWalletAmount 0xaa4bde28 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapBackFee 0x54c35c28 → uint256
swapFee 0x54cf2aeb → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniV2Pair 0x8bcea939 → address

Write Contract 16 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
disableLimits 0xf928364c
No parameters
disableSwapLimit 0x063be69e
No parameters
disableWalletLimit 0x697cfc19
No parameters
enableTrading 0x8a8c523c
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
renounceOwnership 0x715018a6
No parameters
setFees 0x0b78f9c0
uint256 newBuyFee
uint256 newSellFee
setStructure 0xd18afa85
uint256 maxMul
uint256 minDiv
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateFeeTokenThreshold 0xf442d3fb
uint256 newThreshold
withdrawStuckERC20 0x3963510b
address token
withdrawStuckETH 0xf5648a4f
No parameters

Recent Transactions

No transactions found for this address