Address Contract Verified
Address
0x7aE146EcC092318A6e2035B596e08cAf3a988A87
Balance
0 ETH
Nonce
1
Code Size
12213 bytes
Creator
0xAfC40505...5254 at tx 0x6a378148...71fbee
Indexed Transactions
0
Contract Bytecode
12213 bytes
0x608060405260043610610117575f3560e01c8063715018a61161009f57806395d89b411161006357806395d89b4114610354578063a9059cbb1461037e578063c9567bf9146103ba578063dd62ed3e146103d0578063f3200c911461040c5761011e565b8063715018a6146102aa578063751039fc146102c05780637d1db4a5146102d65780638da5cb5b146103005780638f9a55c01461032a5761011e565b8063313ce567116100e6578063313ce567146101ee57806351bc3c851461021857806369153b351461022e5780636fc3eaec1461025857806370a082311461026e5761011e565b806306fdde0314610122578063095ea7b31461014c57806318160ddd1461018857806323b872dd146101b25761011e565b3661011e57005b5f5ffd5b34801561012d575f5ffd5b50610136610436565b60405161014391906120f3565b60405180910390f35b348015610157575f5ffd5b50610172600480360381019061016d91906121a4565b610473565b60405161017f91906121fc565b60405180910390f35b348015610193575f5ffd5b5061019c610490565b6040516101a99190612224565b60405180910390f35b3480156101bd575f5ffd5b506101d860048036038101906101d3919061223d565b6104b3565b6040516101e591906121fc565b60405180910390f35b3480156101f9575f5ffd5b50610202610587565b60405161020f91906122a8565b60405180910390f35b348015610223575f5ffd5b5061022c61058f565b005b348015610239575f5ffd5b50610242610626565b60405161024f9190612224565b60405180910390f35b348015610263575f5ffd5b5061026c61062c565b005b348015610279575f5ffd5b50610294600480360381019061028f91906122c1565b61069b565b6040516102a19190612224565b60405180910390f35b3480156102b5575f5ffd5b506102be6106e1565b005b3480156102cb575f5ffd5b506102d4610831565b005b3480156102e1575f5ffd5b506102ea610961565b6040516102f79190612224565b60405180910390f35b34801561030b575f5ffd5b50610314610967565b60405161032191906122fb565b60405180910390f35b348015610335575f5ffd5b5061033e61098e565b60405161034b9190612224565b60405180910390f35b34801561035f575f5ffd5b50610368610994565b60405161037591906120f3565b60405180910390f35b348015610389575f5ffd5b506103a4600480360381019061039f91906121a4565b6109d1565b6040516103b191906121fc565b60405180910390f35b3480156103c5575f5ffd5b506103ce6109ee565b005b3480156103db575f5ffd5b506103f660048036038101906103f19190612314565b610f93565b6040516104039190612224565b60405180910390f35b348015610417575f5ffd5b50610420611015565b60405161042d9190612224565b60405180910390f35b60606040518060400160405280600b81526020017f536f7572636520446f6765000000000000000000000000000000000000000000815250905090565b5f61048661047f61101b565b8484611022565b6001905092915050565b5f6009600a61049f91906124ae565b6305f5e1006104ae91906124f8565b905090565b5f6104bf8484846111e5565b61057c846104cb61101b565b61057785604051806060016040528060288152602001612f586028913960025f8b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f61052e61101b565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611b6f9092919063ffffffff16565b611022565b600190509392505050565b5f6009905090565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166105cf61101b565b73ffffffffffffffffffffffffffffffffffffffff16146105ee575f5ffd5b5f6105f83061069b565b90505f81111561060c5761060b81611bd1565b5b5f4790505f8111156106225761062181611e3c565b5b5050565b60125481565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1661066c61101b565b73ffffffffffffffffffffffffffffffffffffffff161461068b575f5ffd5b5f47905061069881611e3c565b50565b5f60015f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20549050919050565b6106e961101b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610776576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161076d90612583565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35f5f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b61083961101b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146108c6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108bd90612583565b60405180910390fd5b6009600a6108d491906124ae565b6305f5e1006108e391906124f8565b600f819055506009600a6108f791906124ae565b6305f5e10061090691906124f8565b6010819055507f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6009600a61093b91906124ae565b6305f5e10061094a91906124f8565b6040516109579190612224565b60405180910390a1565b600f5481565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60105481565b60606040518060400160405280600581526020017f53444f4745000000000000000000000000000000000000000000000000000000815250905090565b5f6109e46109dd61101b565b84846111e5565b6001905092915050565b6109f661101b565b73ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a83576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a7a90612583565b60405180910390fd5b60148054906101000a900460ff1615610ad1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ac8906125eb565b60405180910390fd5b737a250d5630b4cf539739df2c5dacb4c659f2488d60135f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610b6d3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff166009600a610b5991906124ae565b6305f5e100610b6891906124f8565b611022565b610ba530610ba06064610b92604b610b843361069b565b611ea490919063ffffffff16565b611f1b90919063ffffffff16565b6109d1565b5060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c10573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c34919061261d565b73ffffffffffffffffffffffffffffffffffffffff1663c9c653963060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cba573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610cde919061261d565b6040518363ffffffff1660e01b8152600401610cfb929190612648565b6020604051808303815f875af1158015610d17573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d3b919061261d565b60145f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550610dc63060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff611022565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663f305d7194730610e0e3061069b565b5f5f610e18610967565b426040518863ffffffff1660e01b8152600401610e3a969594939291906126b1565b60606040518083038185885af1158015610e56573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610e7b9190612724565b50505060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663095ea7b360135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff167fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff6040518363ffffffff1660e01b8152600401610f1b929190612774565b6020604051808303815f875af1158015610f37573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610f5b91906127c5565b506001601460166101000a81548160ff02191690831515021790555060016014806101000a81548160ff021916908315150217905550565b5f60025f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054905092915050565b60115481565b5f33905090565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611090576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161108790612860565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036110fe576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110f5906128ee565b60405180910390fd5b8060025f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516111d89190612224565b60405180910390a3505050565b5f73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603611253576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161124a9061297c565b60405180910390fd5b5f73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036112c1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112b890612a0a565b60405180910390fd5b5f8111611303576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112fa90612a98565b60405180910390fd5b5f5f905061130f610967565b73ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff161415801561137d575061134d610967565b73ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b156118bf5760045f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16158015611420575060045f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b611428575f5ffd5b5f600e54036114705761146d606461145f600a54600e541161144c57600654611450565b6008545b85611ea490919063ffffffff16565b611f1b90919063ffffffff16565b90505b5f600e5411156114a5576114a26064611494600d5485611ea490919063ffffffff16565b611f1b90919063ffffffff16565b90505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614801561154e575060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614155b80156115a1575060035f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16155b1561169957600f548211156115eb576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115e290612b00565b60405180910390fd5b601054826115f88561069b565b6116029190612b1e565b1115611643576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161163a90612b9b565b60405180910390fd5b61167f6064611671600a54600e541161165e57600654611662565b6008545b85611ea490919063ffffffff16565b611f1b90919063ffffffff16565b9050600e5f81548092919061169390612bb9565b91905055505b60145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614801561172157503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614155b15611765576117626064611754600b54600e541161174157600754611745565b6009545b85611ea490919063ffffffff16565b611f1b90919063ffffffff16565b90505b5f61176f3061069b565b9050601460159054906101000a900460ff161580156117da575060145f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16145b80156117f25750601460169054906101000a900460ff165b80156117ff575060115481115b801561180e5750600c54600e54115b156118bd57601654431115611825575f6015819055505b60036015541061186a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161186190612c4a565b60405180910390fd5b6118876118828461187d84601254611f64565b611f64565b611bd1565b5f4790505f81111561189d5761189c47611e3c565b5b60155f8154809291906118af90612bb9565b919050555043601681905550505b505b5f8111156119be576119178160015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611f7c90919063ffffffff16565b60015f3073ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055503073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516119b59190612224565b60405180910390a35b611a0e8260015f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611fd990919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2081905550611ab1611a658284611fd990919063ffffffff16565b60015f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054611f7c90919063ffffffff16565b60015f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f20819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611b548486611fd990919063ffffffff16565b604051611b619190612224565b60405180910390a350505050565b5f838311158290611bb6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611bad91906120f3565b60405180910390fd5b505f8385611bc49190612c68565b9050809150509392505050565b6001601460156101000a81548160ff0219169083151502179055505f600267ffffffffffffffff811115611c0857611c07612c9b565b5b604051908082528060200260200182016040528015611c365781602001602082028036833780820191505090505b50905030815f81518110611c4d57611c4c612cc8565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff168152505060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611cf1573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190611d15919061261d565b81600181518110611d2957611d28612cc8565b5b602002602001019073ffffffffffffffffffffffffffffffffffffffff16908173ffffffffffffffffffffffffffffffffffffffff1681525050611d8f3060135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684611022565b60135f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663791ac947835f8430426040518663ffffffff1660e01b8152600401611df1959493929190612dac565b5f604051808303815f87803b158015611e08575f5ffd5b505af1158015611e1a573d5f5f3e3d5ffd5b50505050505f601460156101000a81548160ff02191690831515021790555050565b60055f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015611ea0573d5f5f3e3d5ffd5b5050565b5f5f8303611eb4575f9050611f15565b5f8284611ec191906124f8565b9050828482611ed09190612e31565b14611f10576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f0790612ed1565b60405180910390fd5b809150505b92915050565b5f611f5c83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612022565b905092915050565b5f818311611f725782611f74565b815b905092915050565b5f5f8284611f8a9190612b1e565b905083811015611fcf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fc690612f39565b60405180910390fd5b8091505092915050565b5f61201a83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611b6f565b905092915050565b5f5f83118290612068576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161205f91906120f3565b60405180910390fd5b505f83856120769190612e31565b9050809150509392505050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f6120c582612083565b6120cf818561208d565b93506120df81856020860161209d565b6120e8816120ab565b840191505092915050565b5f6020820190508181035f83015261210b81846120bb565b905092915050565b5f5ffd5b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61214082612117565b9050919050565b61215081612136565b811461215a575f5ffd5b50565b5f8135905061216b81612147565b92915050565b5f819050919050565b61218381612171565b811461218d575f5ffd5b50565b5f8135905061219e8161217a565b92915050565b5f5f604083850312156121ba576121b9612113565b5b5f6121c78582860161215d565b92505060206121d885828601612190565b9150509250929050565b5f8115159050919050565b6121f6816121e2565b82525050565b5f60208201905061220f5f8301846121ed565b92915050565b61221e81612171565b82525050565b5f6020820190506122375f830184612215565b92915050565b5f5f5f6060848603121561225457612253612113565b5b5f6122618682870161215d565b93505060206122728682870161215d565b925050604061228386828701612190565b9150509250925092565b5f60ff82169050919050565b6122a28161228d565b82525050565b5f6020820190506122bb5f830184612299565b92915050565b5f602082840312156122d6576122d5612113565b5b5f6122e38482850161215d565b91505092915050565b6122f581612136565b82525050565b5f60208201905061230e5f8301846122ec565b92915050565b5f5f6040838503121561232a57612329612113565b5b5f6123378582860161215d565b92505060206123488582860161215d565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f8160011c9050919050565b5f5f8291508390505b60018511156123d4578086048111156123b0576123af612352565b5b60018516156123bf5780820291505b80810290506123cd8561237f565b9450612394565b94509492505050565b5f826123ec57600190506124a7565b816123f9575f90506124a7565b816001811461240f576002811461241957612448565b60019150506124a7565b60ff84111561242b5761242a612352565b5b8360020a91508482111561244257612441612352565b5b506124a7565b5060208310610133831016604e8410600b841016171561247d5782820a90508381111561247857612477612352565b5b6124a7565b61248a848484600161238b565b925090508184048111156124a1576124a0612352565b5b81810290505b9392505050565b5f6124b882612171565b91506124c38361228d565b92506124f07fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff84846123dd565b905092915050565b5f61250282612171565b915061250d83612171565b925082820261251b81612171565b9150828204841483151761253257612531612352565b5b5092915050565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65725f82015250565b5f61256d60208361208d565b915061257882612539565b602082019050919050565b5f6020820190508181035f83015261259a81612561565b9050919050565b7f74726164696e6720697320616c7265616479206f70656e0000000000000000005f82015250565b5f6125d560178361208d565b91506125e0826125a1565b602082019050919050565b5f6020820190508181035f830152612602816125c9565b9050919050565b5f8151905061261781612147565b92915050565b5f6020828403121561263257612631612113565b5b5f61263f84828501612609565b91505092915050565b5f60408201905061265b5f8301856122ec565b61266860208301846122ec565b9392505050565b5f819050919050565b5f819050919050565b5f61269b6126966126918461266f565b612678565b612171565b9050919050565b6126ab81612681565b82525050565b5f60c0820190506126c45f8301896122ec565b6126d16020830188612215565b6126de60408301876126a2565b6126eb60608301866126a2565b6126f860808301856122ec565b61270560a0830184612215565b979650505050505050565b5f8151905061271e8161217a565b92915050565b5f5f5f6060848603121561273b5761273a612113565b5b5f61274886828701612710565b935050602061275986828701612710565b925050604061276a86828701612710565b9150509250925092565b5f6040820190506127875f8301856122ec565b6127946020830184612215565b9392505050565b6127a4816121e2565b81146127ae575f5ffd5b50565b5f815190506127bf8161279b565b92915050565b5f602082840312156127da576127d9612113565b5b5f6127e7848285016127b1565b91505092915050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f206164645f8201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b5f61284a60248361208d565b9150612855826127f0565b604082019050919050565b5f6020820190508181035f8301526128778161283e565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f2061646472655f8201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b5f6128d860228361208d565b91506128e38261287e565b604082019050919050565b5f6020820190508181035f830152612905816128cc565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f2061645f8201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b5f61296660258361208d565b91506129718261290c565b604082019050919050565b5f6020820190508181035f8301526129938161295a565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f20616464725f8201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b5f6129f460238361208d565b91506129ff8261299a565b604082019050919050565b5f6020820190508181035f830152612a21816129e8565b9050919050565b7f5472616e7366657220616d6f756e74206d7573742062652067726561746572205f8201527f7468616e207a65726f0000000000000000000000000000000000000000000000602082015250565b5f612a8260298361208d565b9150612a8d82612a28565b604082019050919050565b5f6020820190508181035f830152612aaf81612a76565b9050919050565b7f4578636565647320746865205f6d61785478416d6f756e742e000000000000005f82015250565b5f612aea60198361208d565b9150612af582612ab6565b602082019050919050565b5f6020820190508181035f830152612b1781612ade565b9050919050565b5f612b2882612171565b9150612b3383612171565b9250828201905080821115612b4b57612b4a612352565b5b92915050565b7f4578636565647320746865206d617857616c6c657453697a652e0000000000005f82015250565b5f612b85601a8361208d565b9150612b9082612b51565b602082019050919050565b5f6020820190508181035f830152612bb281612b79565b9050919050565b5f612bc382612171565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203612bf557612bf4612352565b5b600182019050919050565b7f4f6e6c7920332073656c6c732070657220626c6f636b210000000000000000005f82015250565b5f612c3460178361208d565b9150612c3f82612c00565b602082019050919050565b5f6020820190508181035f830152612c6181612c28565b9050919050565b5f612c7282612171565b9150612c7d83612171565b9250828203905081811115612c9557612c94612352565b5b92915050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52603260045260245ffd5b5f81519050919050565b5f82825260208201905092915050565b5f819050602082019050919050565b612d2781612136565b82525050565b5f612d388383612d1e565b60208301905092915050565b5f602082019050919050565b5f612d5a82612cf5565b612d648185612cff565b9350612d6f83612d0f565b805f5b83811015612d9f578151612d868882612d2d565b9750612d9183612d44565b925050600181019050612d72565b5085935050505092915050565b5f60a082019050612dbf5f830188612215565b612dcc60208301876126a2565b8181036040830152612dde8186612d50565b9050612ded60608301856122ec565b612dfa6080830184612215565b9695505050505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612e3b82612171565b9150612e4683612171565b925082612e5657612e55612e04565b5b828204905092915050565b7f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f5f8201527f7700000000000000000000000000000000000000000000000000000000000000602082015250565b5f612ebb60218361208d565b9150612ec682612e61565b604082019050919050565b5f6020820190508181035f830152612ee881612eaf565b9050919050565b7f536166654d6174683a206164646974696f6e206f766572666c6f7700000000005f82015250565b5f612f23601b8361208d565b9150612f2e82612eef565b602082019050919050565b5f6020820190508181035f830152612f5081612f17565b905091905056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220435bfc09d1aa355dc4c1130d41519d8e665fe53d561b4c75ab90969fee5d748964736f6c634300081e0033
Verified Source Code Full Match
Compiler: v0.8.30+commit.73712a01
EVM: prague
Optimization: No
SourceDoge.sol 349 lines
// SPDX-License-Identifier: MIT
/*
// ▄ ▄
// ▌▒█ ▄▀▒▌
// ▌▒▒█ ▄▀▒▒▒▐
// ▐▄█▒▒▀▀▀▀▄▄▄▀▒▒▒▒▒▐
// ▄▄▀▒▒▒▒▒▒▒▒▒▒▒█▒▒▄█▒▐
// ▄▀▒▒▒░░░▒▒▒░░░▒▒▒▀██▀▒▌
// ▐▒▒▒▄▄▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▀▄▒▌
// ▌░░▌█▀▒▒▒▒▒▄▀█▄▒▒▒▒▒▒▒█▒▐
// ▐░░░▒▒▒▒▒▒▒▒▌██▀▒▒░░░▒▒▒▀▄▌
// ▌░▒▒▒▒▒▒▒▒▒▒▒▒▒▒░░░░░░▒▒▒▒▌
//▌▒▒▒▄██▄▒▒▒▒▒▒▒▒░░░░░░░░▒▒▒▐
//▐▒▒▐▄█▄█▌▒▒▒▒▒▒▒▒▒▒░▒░▒░▒▒▒▒▌
//▐▒▒▐▀▐▀▒▒▒▒▒▒▒▒▒▒▒▒▒░▒░▒░▒▒▐
// ▌▒▒▀▄▄▄▄▄▄▒▒▒▒▒▒▒▒░▒░▒░▒▒▒▌
// ▐▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░▒░▒▒▄▒▒▐
// ▀▄▒▒▒▒▒▒▒▒▒▒▒▒▒░▒░▒▄▒▒▒▒▌
// ▀▄▒▒▒▒▒▒▒▒▒▒▄▄▄▀▒▒▒▒▄▀
// ▀▄▄▄▄▄▄▀▀▀▒▒▒▒▒▄▄▀
// ▀▀▀▀▀▀▀▀▀▀▀▀
// Elon Musk added a Doge in the source code of the Department of Government Efficiency website
// https://x.com/dogeofficialceo/status/1938071299877966218
// https://t.me/SourceDogeETH
*/
pragma solidity >=0.8.30;
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 SourceDoge is Context, IERC20, Ownable {
using SafeMath for uint256;
mapping (address => uint256) private _balances;
mapping (address => mapping (address => uint256)) private _allowances;
mapping (address => bool) private _isExcludedFromFee;
mapping (address => bool) private bots;
address payable private _taxWallet;
uint256 private _initialBuyTax=15;
uint256 private _initialSellTax=15;
uint256 private _finalBuyTax=0;
uint256 private _finalSellTax=0;
uint256 private _reduceBuyTaxAt=15;
uint256 private _reduceSellTaxAt=15;
uint256 private _preventSwapBefore=15;
uint256 private _transferTax=0;
uint256 private _buyCount=0;
uint8 private constant _decimals = 9;
uint256 private constant _tTotal = 100_000_000 * 10**_decimals;
string private constant _name = "Source Doge";
string private constant _symbol = "SDOGE";
uint256 public _maxTxAmount = 2 * (_tTotal/100);
uint256 public _maxWalletSize = 2 * (_tTotal/100);
uint256 public _taxSwapLimit = 2 * (_tTotal/1000);
uint256 public _maxSwapLimitX = 2 * (_tTotal/100);
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;
event MaxTxAmountUpdated(uint _maxTxAmount);
event TransferTaxUpdated(uint _tax);
modifier lockTheSwap {
inSwap = true;
_;
inSwap = false;
}
constructor () payable {
_taxWallet = payable(_msgSender());
_balances[_msgSender()] = _tTotal;
_isExcludedFromFee[owner()] = true;
_isExcludedFromFee[address(this)] = true;
_isExcludedFromFee[_taxWallet] = 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()) {
require(!bots[from] && !bots[to]);
if(_buyCount==0){
taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
}
if(_buyCount>0){
taxAmount = amount.mul(_transferTax).div(100);
}
if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] ) {
require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
_buyCount++;
}
if(to == uniswapV2Pair && from!= address(this) ){
taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
}
uint256 contractTokenBalance = balanceOf(address(this));
if (!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _taxSwapLimit && _buyCount > _preventSwapBefore) {
if (block.number > lastSellBlock) {
sellCount = 0;
}
require(sellCount < 3, "Only 3 sells per block!");
swapTokensForEth(min(amount, min(contractTokenBalance, _maxSwapLimitX)));
uint256 contractETHBalance = address(this).balance;
if (contractETHBalance > 0) {
sendETHToFee(address(this).balance);
}
sellCount++;
lastSellBlock = block.number;
}
}
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 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 removeLimits() external onlyOwner{
_maxTxAmount = _tTotal;
_maxWalletSize=_tTotal;
emit MaxTxAmountUpdated(_tTotal);
}
function sendETHToFee(uint256 amount) private {
_taxWallet.transfer(amount);
}
function openTrading() external onlyOwner() {
require(!tradingOpen,"trading is already open");
uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
_approve(address(this), address(uniswapV2Router), _tTotal);
transfer(address(this), balanceOf(msg.sender).mul(75).div(100));
uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
_approve(address(this), address(uniswapV2Router), type(uint256).max);
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;
}
receive() external payable {}
function manualSwap() external {
require(_msgSender()==_taxWallet);
uint256 tokenBalance=balanceOf(address(this));
if(tokenBalance>0){
swapTokensForEth(tokenBalance);
}
uint256 ethBalance=address(this).balance;
if(ethBalance>0){
sendETHToFee(ethBalance);
}
}
function manualsend() external {
require(_msgSender()==_taxWallet);
uint256 contractETHBalance = address(this).balance;
sendETHToFee(contractETHBalance);
}
}
Read Contract
_maxSwapLimitX 0x69153b35 → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapLimit 0xf3200c91 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 8 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSwap 0x51bc3c85
No parameters
manualsend 0x6fc3eaec
No parameters
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
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