Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x4cfE14CED8272E3f19b48B1BE02e28119a841EA1
Balance 0 ETH
Nonce 1
Code Size 13906 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13906 bytes
0x60806040526004361061014e575f3560e01c80637d1db4a5116100b5578063a9dd22b21161006e578063a9dd22b214610469578063bf474bed1461047f578063c2773d4e146104a9578063cee3e84d146104bf578063dd62ed3e146104e9578063f5b3c3bf1461052557610155565b80637d1db4a51461035b57806383aa6290146103855780638da5cb5b146103af5780638f9a55c0146103d957806395d89b4114610403578063a9059cbb1461042d57610155565b80632c65469e116101075780632c65469e14610265578063313ce5671461028d578063331221d5146102b757806349bd5a5e146102df57806370a0823114610309578063715018a61461034557610155565b80630150fe4c1461015957806306fdde031461016f578063095ea7b3146101995780630faee56f146101d557806318160ddd146101ff57806323b872dd1461022957610155565b3661015557005b5f5ffd5b348015610164575f5ffd5b5061016d610561565b005b34801561017a575f5ffd5b5061018361065d565b60405161019091906126a0565b60405180910390f35b3480156101a4575f5ffd5b506101bf60048036038101906101ba9190612751565b61069a565b6040516101cc91906127a9565b60405180910390f35b3480156101e0575f5ffd5b506101e96106b7565b6040516101f691906127d1565b60405180910390f35b34801561020a575f5ffd5b506102136106bd565b60405161022091906127d1565b60405180910390f35b348015610234575f5ffd5b5061024f600480360381019061024a91906127ea565b6106e0565b60405161025c91906127a9565b60405180910390f35b348015610270575f5ffd5b5061028b60048036038101906102869190612751565b6107b4565b005b348015610298575f5ffd5b506102a16108ea565b6040516102ae9190612855565b60405180910390f35b3480156102c2575f5ffd5b506102dd60048036038101906102d8919061286e565b6108f2565b005b3480156102ea575f5ffd5b506102f36109b1565b60405161030091906128f4565b60405180910390f35b348015610314575f5ffd5b5061032f600480360381019061032a919061290d565b6109d6565b60405161033c91906127d1565b60405180910390f35b348015610350575f5ffd5b50610359610a1c565b005b348015610366575f5ffd5b5061036f610b6c565b60405161037c91906127d1565b60405180910390f35b348015610390575f5ffd5b50610399610b72565b6040516103a691906127d1565b60405180910390f35b3480156103ba575f5ffd5b506103c3610b78565b6040516103d091906128f4565b60405180910390f35b3480156103e4575f5ffd5b506103ed610b9f565b6040516103fa91906127d1565b60405180910390f35b34801561040e575f5ffd5b50610417610ba5565b60405161042491906126a0565b60405180910390f35b348015610438575f5ffd5b50610453600480360381019061044e9190612751565b610be2565b60405161046091906127a9565b60405180910390f35b348015610474575f5ffd5b5061047d610bff565b005b34801561048a575f5ffd5b50610493611215565b6040516104a091906127d1565b60405180910390f35b3480156104b4575f5ffd5b506104bd61121b565b005b3480156104ca575f5ffd5b506104d361134b565b6040516104e091906127a9565b60405180910390f35b3480156104f4575f5ffd5b5061050f600480360381019061050a9190612938565b61135e565b60405161051c91906127d1565b60405180910390f35b348015610530575f5ffd5b5061054b6004803603810190610546919061290d565b6113e0565b60405161055891906127a9565b60405180910390f35b6105696113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146105f6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105ed906129c0565b60405180910390fd5b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f1935050505015801561065a573d5f5f3e3d5ffd5b50565b60606040518060400160405280600781526020017f4369766120414900000000000000000000000000000000000000000000000000815250905090565b5f6106ad6106a66113fd565b8484611404565b6001905092915050565b60145481565b5f6009600a6106cc9190612b3a565b6305f5e1006106db9190612b84565b905090565b5f6106ec8484846115c7565b6107a9846106f86113fd565b6107a4856040518060600160405280602881526020016135f56028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61075b6113fd565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461210d9092919063ffffffff16565b611404565b600190509392505050565b6107bc6113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610849576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610840906129c0565b60405180910390fd5b8173ffffffffffffffffffffffffffffffffffffffff1663a9059cbb60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b81526004016108a5929190612c20565b6020604051808303815f875af11580156108c1573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108e59190612c71565b505050565b5f6009905090565b6108fa6113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610987576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161097e906129c0565b60405180910390fd5b846007819055508360088190555082600b8190555081600c8190555080600d819055505050505050565b60165f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b610a246113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610ab1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610aa8906129c0565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f5f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b60115481565b60175481565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60125481565b60606040518060400160405280600481526020017f4349564100000000000000000000000000000000000000000000000000000000815250905090565b5f610bf5610bee6113fd565b84846115c7565b6001905092915050565b610c076113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c94576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c8b906129c0565b60405180910390fd5b601660149054906101000a900460ff1615610ce4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610cdb90612ce6565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60155f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610d803060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610d6c9190612b3a565b6305f5e100610d7b9190612b84565b611404565b60155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610dea573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610e0e9190612d18565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610e94573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610eb89190612d18565b6040518363ffffffff1660e01b8152600401610ed5929190612d43565b6020604051808303815f875af1158015610ef1573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f159190612d18565b60165f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600160045f60165f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff021916908315150217905550600160035f60165f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff02191690831515021790555060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730611088306109d6565b5f5f611092610b78565b426040518863ffffffff1660e01b81526004016110b496959493929190612da3565b60606040518083038185885af11580156110d0573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110f59190612e16565b50505060165f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401611195929190612e66565b6020604051808303815f875af11580156111b1573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111d59190612c71565b506001601860016101000a81548160ff0219169083151502179055506001601660146101000a81548160ff02191690831515021790555043600681905550565b60135481565b6112236113fd565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146112b0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112a7906129c0565b60405180910390fd5b6009600a6112be9190612b3a565b6305f5e1006112cd9190612b84565b6011819055506009600a6112e19190612b3a565b6305f5e1006112f09190612b84565b6012819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a6113259190612b3a565b6305f5e1006113349190612b84565b60405161134191906127d1565b60405180910390a1565b601860029054906101000a900460ff1681565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b6004602052805f5260405f205f915054906101000a900460ff1681565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611472576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161146990612efd565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036114e0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114d790612f8b565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516115ba91906127d1565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611635576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161162c90613019565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036116a3576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161169a906130a7565b60405180910390fd5b5f81116116e5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116dc90613135565b60405180910390fd5b5f5f90506116f1610b78565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561175f575061172f610b78565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b15611e5d576117a06064611792600b54600e541161177f57600754611783565b6009545b8561216f90919063ffffffff16565b6121e690919063ffffffff16565b905060045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff168015611845575060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b8015611898575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561197b576011548211156118e2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118d99061319d565b60405180910390fd5b601254826118ef856109d6565b6118f991906131bb565b111561193a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161193190613238565b60405180910390fd5b43600160065461194a91906131bb565b1115611963576119598361222f565b15611962575f5ffd5b5b600e5f81548092919061197590613256565b91905055505b60045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611a19575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15611a775760125482611a2b856109d6565b611a3591906131bb565b1115611a76576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a6d90613238565b60405180910390fd5b5b60045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff168015611af957503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611b3d57611b3a6064611b2c600c54600e5411611b1957600854611b1d565b600a545b8561216f90919063ffffffff16565b6121e690919063ffffffff16565b90505b60045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611bdb575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b8015611c1357503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611c1c575f90505b5f611c26306109d6565b9050601860029054906101000a900460ff168015611c50575060185f9054906101000a900460ff16155b8015611ca2575060045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b8015611cba5750601860019054906101000a900460ff165b8015611cc7575060135481115b8015611cd65750600d54600e54115b15611d8a57601054431115611ced575f600f819055505b601754600f5410611d33576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611d2a906132e7565b60405180910390fd5b611d50611d4b84611d4684601454612240565b612240565b612258565b5f4790505f811115611d6657611d65476124c1565b5b600f5f815480929190611d7890613256565b91905055504360108190555050611e5b565b60185f9054906101000a900460ff16158015611dec575060045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b8015611e045750601860019054906101000a900460ff165b8015611e11575060135481115b8015611e205750600d54600e54115b15611e5a57611e42611e3d84611e3884601454612240565b612240565b612258565b5f4790505f811115611e5857611e57476124c1565b5b505b5b505b5f811115611f5c57611eb58160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461252990919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611f5391906127d1565b60405180910390a35b611fac8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461258690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f208190555061204f612003828461258690919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461252990919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6120f2848661258690919063ffffffff16565b6040516120ff91906127d1565b60405180910390a350505050565b5f838311158290612154576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161214b91906126a0565b60405180910390fd5b505f83856121629190613305565b9050809150509392505050565b5f5f830361217f575f90506121e0565b5f828461218c9190612b84565b905082848261219b9190613365565b146121db576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016121d290613405565b60405180910390fd5b809150505b92915050565b5f61222783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506125cf565b905092915050565b5f5f823b90505f8111915050919050565b5f81831161224e5782612250565b815b905092915050565b600160185f6101000a81548160ff0219169083151502179055505f600267ffffffffffffffff81111561228e5761228d613423565b5b6040519080825280602002602001820160405280156122bc5781602001602082028036833780820191505090505b50905030815f815181106122d3576122d2613450565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015612377573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061239b9190612d18565b816001815181106123af576123ae613450565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250506124153060155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611404565b60155f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401612477959493929190613534565b5f604051808303815f87803b15801561248e575f5ffd5b505af11580156124a0573d5f5f3e3d5ffd5b50505050505f60185f6101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612525573d5f5f3e3d5ffd5b5050565b5f5f828461253791906131bb565b90508381101561257c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612573906135d6565b60405180910390fd5b8091505092915050565b5f6125c783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061210d565b905092915050565b5f5f83118290612615576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161260c91906126a0565b60405180910390fd5b505f83856126239190613365565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61267282612630565b61267c818561263a565b935061268c81856020860161264a565b61269581612658565b840191505092915050565b5f6020820190508181035f8301526126b88184612668565b905092915050565b5f5ffd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f6126ed826126c4565b9050919050565b6126fd816126e3565b8114612707575f5ffd5b50565b5f81359050612718816126f4565b92915050565b5f819050919050565b6127308161271e565b811461273a575f5ffd5b50565b5f8135905061274b81612727565b92915050565b5f5f60408385031215612767576127666126c0565b5b5f6127748582860161270a565b92505060206127858582860161273d565b9150509250929050565b5f8115159050919050565b6127a38161278f565b82525050565b5f6020820190506127bc5f83018461279a565b92915050565b6127cb8161271e565b82525050565b5f6020820190506127e45f8301846127c2565b92915050565b5f5f5f60608486031215612801576128006126c0565b5b5f61280e8682870161270a565b935050602061281f8682870161270a565b92505060406128308682870161273d565b9150509250925092565b5f60ff82169050919050565b61284f8161283a565b82525050565b5f6020820190506128685f830184612846565b92915050565b5f5f5f5f5f60a08688031215612887576128866126c0565b5b5f6128948882890161273d565b95505060206128a58882890161273d565b94505060406128b68882890161273d565b93505060606128c78882890161273d565b92505060806128d88882890161273d565b9150509295509295909350565b6128ee816126e3565b82525050565b5f6020820190506129075f8301846128e5565b92915050565b5f60208284031215612922576129216126c0565b5b5f61292f8482850161270a565b91505092915050565b5f5f6040838503121561294e5761294d6126c0565b5b5f61295b8582860161270a565b925050602061296c8582860161270a565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6129aa60208361263a565b91506129b582612976565b602082019050919050565b5f6020820190508181035f8301526129d78161299e565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f5f8291508390505b6001851115612a6057808604811115612a3c57612a3b6129de565b5b6001851615612a4b5780820291505b8081029050612a5985612a0b565b9450612a20565b94509492505050565b5f82612a785760019050612b33565b81612a85575f9050612b33565b8160018114612a9b5760028114612aa557612ad4565b6001915050612b33565b60ff841115612ab757612ab66129de565b5b8360020a915084821115612ace57612acd6129de565b5b50612b33565b5060208310610133831016604e8410600b8410161715612b095782820a905083811115612b0457612b036129de565b5b612b33565b612b168484846001612a17565b92509050818404811115612b2d57612b2c6129de565b5b81810290505b9392505050565b5f612b448261271e565b9150612b4f8361283a565b9250612b7c7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612a69565b905092915050565b5f612b8e8261271e565b9150612b998361271e565b9250828202612ba78161271e565b91508282048414831517612bbe57612bbd6129de565b5b5092915050565b5f819050919050565b5f612be8612be3612bde846126c4565b612bc5565b6126c4565b9050919050565b5f612bf982612bce565b9050919050565b5f612c0a82612bef565b9050919050565b612c1a81612c00565b82525050565b5f604082019050612c335f830185612c11565b612c4060208301846127c2565b9392505050565b612c508161278f565b8114612c5a575f5ffd5b50565b5f81519050612c6b81612c47565b92915050565b5f60208284031215612c8657612c856126c0565b5b5f612c9384828501612c5d565b91505092915050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f612cd060178361263a565b9150612cdb82612c9c565b602082019050919050565b5f6020820190508181035f830152612cfd81612cc4565b9050919050565b5f81519050612d12816126f4565b92915050565b5f60208284031215612d2d57612d2c6126c0565b5b5f612d3a84828501612d04565b91505092915050565b5f604082019050612d565f8301856128e5565b612d6360208301846128e5565b9392505050565b5f819050919050565b5f612d8d612d88612d8384612d6a565b612bc5565b61271e565b9050919050565b612d9d81612d73565b82525050565b5f60c082019050612db65f8301896128e5565b612dc360208301886127c2565b612dd06040830187612d94565b612ddd6060830186612d94565b612dea60808301856128e5565b612df760a08301846127c2565b979650505050505050565b5f81519050612e1081612727565b92915050565b5f5f5f60608486031215612e2d57612e2c6126c0565b5b5f612e3a86828701612e02565b9350506020612e4b86828701612e02565b9250506040612e5c86828701612e02565b9150509250925092565b5f604082019050612e795f8301856128e5565b612e8660208301846127c2565b9392505050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f612ee760248361263a565b9150612ef282612e8d565b604082019050919050565b5f6020820190508181035f830152612f1481612edb565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612f7560228361263a565b9150612f8082612f1b565b604082019050919050565b5f6020820190508181035f830152612fa281612f69565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f61300360258361263a565b915061300e82612fa9565b604082019050919050565b5f6020820190508181035f83015261303081612ff7565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f61309160238361263a565b915061309c82613037565b604082019050919050565b5f6020820190508181035f8301526130be81613085565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f61311f60298361263a565b915061312a826130c5565b604082019050919050565b5f6020820190508181035f83015261314c81613113565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f61318760198361263a565b915061319282613153565b602082019050919050565b5f6020820190508181035f8301526131b48161317b565b9050919050565b5f6131c58261271e565b91506131d08361271e565b92508282019050808211156131e8576131e76129de565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f613222601a8361263a565b915061322d826131ee565b602082019050919050565b5f6020820190508181035f83015261324f81613216565b9050919050565b5f6132608261271e565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203613292576132916129de565b5b600182019050919050565b7f43412062616c616e63652073656c6c00000000000000000000000000000000005f82015250565b5f6132d1600f8361263a565b91506132dc8261329d565b602082019050919050565b5f6020820190508181035f8301526132fe816132c5565b9050919050565b5f61330f8261271e565b915061331a8361271e565b9250828203905081811115613332576133316129de565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f61336f8261271e565b915061337a8361271e565b92508261338a57613389613338565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f6133ef60218361263a565b91506133fa82613395565b604082019050919050565b5f6020820190508181035f83015261341c816133e3565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6134af816126e3565b82525050565b5f6134c083836134a6565b60208301905092915050565b5f602082019050919050565b5f6134e28261347d565b6134ec8185613487565b93506134f783613497565b805f5b8381101561352757815161350e88826134b5565b9750613519836134cc565b9250506001810190506134fa565b5085935050505092915050565b5f60a0820190506135475f8301886127c2565b6135546020830187612d94565b818103604083015261356681866134d8565b905061357560608301856128e5565b61358260808301846127c2565b9695505050505050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f6135c0601b8361263a565b91506135cb8261358c565b602082019050919050565b5f6020820190508181035f8301526135ed816135b4565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220ec3c91b87f71323a2e2995fae76600d394c98354c52fa0e003448565e133b37b64736f6c634300081d0033

Verified Source Code Partial Match

Compiler: v0.8.29+commit.ab55807c EVM: cancun Optimization: No
CivaAI.sol 348 lines
/**
Website:  https://civavault.app/
Telegram:  https://t.me/Civavault
Twitter:  https://x.com/CivaVault_/
**/

//SPDX-License-Identifier: UNLICENSE
pragma solidity 0.8.29;

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

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

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

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

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

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

}

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
}

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

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    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);
}

contract CivaAI is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private isExile;
    mapping (address => bool) public marketPair;
    address payable private _taxWallet;
    uint256 firstBlock;

    uint256 private _firstBuyTax=15;
    uint256 private _firstSellTax=15;
    uint256 private _finalBuyTax=5;
    uint256 private _finalSellTax=5;
    uint256 private _reduceBuyTaxAt=12;
    uint256 private _reduceSellTaxAt=12;
    uint256 private _preventSwapBefore=2;
    uint256 private _buyCount= 0;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 100000000 * 10**_decimals;
    string private constant _name = unicode"Civa AI";
    string private constant _symbol = unicode"CIVA";
    uint256 public _maxTxAmount =   2000000 * 10**_decimals;
    uint256 public _maxWalletSize = 2000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 200000 * 10**_decimals;
    uint256 public _maxTaxSwap= 2000000 * 10**_decimals;

    IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;
    bool private tradingOpen;
    uint256 public caBlockLimit = 3;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool public caLimit = true;

    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {

        _taxWallet = payable(0x3DF0401947e3C41D6c21D4868B69e84A4740FA1d);
        _balances[_msgSender()] = _tTotal;
        isExile[owner()] = true;
        isExile[address(this)] = true;
        isExile[address(uniswapV2Pair)] = true;
        
        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    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 totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].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);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount=0;

        if (from != owner() && to != owner()) {
            taxAmount = amount.mul((_buyCount> _reduceBuyTaxAt)? _finalBuyTax: _firstBuyTax).div(100);

            if (marketPair[from] && to != address(uniswapV2Router) && ! isExile[to] ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");

                if (firstBlock + 1  > block.number) {
                    require(!isContract(to));
                }
                _buyCount++;
            }

            if (!marketPair[to] && ! isExile[to]) {
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
            }

            if(marketPair[to] && from!= address(this) ){
                taxAmount = amount.mul((_buyCount> _reduceSellTaxAt)? _finalSellTax: _firstSellTax).div(100);
            }

	    if (!marketPair[from] && !marketPair[to] && from!= address(this) ) {
                taxAmount = 0;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (caLimit && !inSwap && marketPair[to] && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < caBlockLimit, "CA balance sell");
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            }

            else if(!inSwap && marketPair[to] && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore) {
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if(taxAmount>0){
          _balances[address(this)]=_balances[address(this)].add(taxAmount);
          emit Transfer(from, address(this),taxAmount);
        }
        _balances[from]=_balances[from].sub(amount);
        _balances[to]=_balances[to].add(amount.sub(taxAmount));
        emit Transfer(from, to, amount.sub(taxAmount));
    }


    function min(uint256 a, uint256 b) private pure returns (uint256){
      return (a>b)?b:a;
    }

    function isContract(address account) private view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

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

    function rescueStuckETH() external onlyOwner {
        payable(_taxWallet).transfer(address(this).balance);
    }

    function updateSwapSettings(uint256 newinitialBuyTax, uint256 newinitialSellTax, uint256 newReduBTax, uint256 newReduSTax, uint256 newPrevSwapBef) external onlyOwner {
        _firstBuyTax = newinitialBuyTax;
        _firstSellTax = newinitialSellTax;
        _reduceBuyTaxAt = newReduBTax;
        _reduceSellTaxAt = newReduSTax;
        _preventSwapBefore = newPrevSwapBef;
    }

    function rescueStuckERC20Tokens(address _tokenAddr, uint _amount) external onlyOwner {
        IERC20(_tokenAddr).transfer(_taxWallet, _amount);
    }

    function openMax() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function startTradE() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        marketPair[address(uniswapV2Pair)] = true;
        isExile[address(uniswapV2Pair)] = true;
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
        firstBlock = block.number;
    }

    receive() external payable {}
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
caBlockLimit 0x83aa6290 → uint256
caLimit 0xcee3e84d → bool
decimals 0x313ce567 → uint8
marketPair 0xf5b3c3bf → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address

Write Contract 9 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
openMax 0xc2773d4e
No parameters
renounceOwnership 0x715018a6
No parameters
rescueStuckERC20Tokens 0x2c65469e
address _tokenAddr
uint256 _amount
rescueStuckETH 0x0150fe4c
No parameters
startTradE 0xa9dd22b2
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
updateSwapSettings 0x331221d5
uint256 newinitialBuyTax
uint256 newinitialSellTax
uint256 newReduBTax
uint256 newReduSTax
uint256 newPrevSwapBef

Recent Transactions

No transactions found for this address