Address Contract Partially Verified
Address
0x5fCe9Fc9B5d62aF082A59D0823A062F7529eFA5a
Balance
0.784066 ETH
Nonce
1
Code Size
14900 bytes
Creator
0xE1f1dd01...B16F at tx 0xd946646e...3f1bc6
Indexed Transactions
0
Contract Bytecode
14900 bytes
0x60806040526004361061026b5760003560e01c8063781edb3c11610144578063aee50b1e116100b6578063d2d7ad831161007a578063d2d7ad83146107b7578063d3221576146107cd578063d4698016146107ed578063dd62ed3e1461080d578063f2fde38b14610853578063fe0175351461087357600080fd5b8063aee50b1e146106b6578063b1ba39ea146106d6578063b62496f5146106f6578063c024666814610726578063cd43e2281461074657600080fd5b80638ea5220f116101085780638ea5220f146105f157806395d89b41146106115780639fad968314610640578063a457c2d714610660578063a9059cbb14610680578063aa4bde28146106a057600080fd5b8063781edb3c1461055d57806383672f3e1461057d578063880bcbc11461059d5780638c0b5e22146105bd5780638da5cb5b146105d357600080fd5b806327a14fc2116101dd5780634549b039116101a15780634549b0391461049f57806349bd5a5e146104bf57806366164f6f146104f357806370a0823114610508578063715018a61461052857806375f0a8741461053d57600080fd5b806327a14fc21461040e5780632d8381191461042e578063313ce5671461044e57806334cf1fea1461046a578063395093511461047f57600080fd5b806313114a9d1161022f57806313114a9d146103355780631694505e1461035457806318160ddd1461038c5780631cd348c0146103ae5780631e293c10146103ce57806323b872dd146103ee57600080fd5b80630483f7a014610277578063064a59d01461029957806306fdde03146102c8578063095ea7b3146103005780630bd05b691461032057600080fd5b3661027257005b600080fd5b34801561028357600080fd5b5061029761029236600461347f565b6108b9565b005b3480156102a557600080fd5b506007546102b39060ff1681565b60405190151581526020015b60405180910390f35b3480156102d457600080fd5b5060408051808201909152600681526529b430b6b0b760d11b60208201525b6040516102bf91906134b4565b34801561030c57600080fd5b506102b361031b366004613509565b610b60565b34801561032c57600080fd5b50610297610b77565b34801561034157600080fd5b506006545b6040519081526020016102bf565b34801561036057600080fd5b50600154610374906001600160a01b031681565b6040516001600160a01b0390911681526020016102bf565b34801561039857600080fd5b506e09a130b963a6c115c3c7f400000000610346565b3480156103ba57600080fd5b50601054610374906001600160a01b031681565b3480156103da57600080fd5b506102976103e9366004613535565b610bb0565b3480156103fa57600080fd5b506102b361040936600461354e565b610c76565b34801561041a57600080fd5b50610297610429366004613535565b610cdf565b34801561043a57600080fd5b50610346610449366004613535565b610da9565b34801561045a57600080fd5b50604051601281526020016102bf565b34801561047657600080fd5b50610297610e35565b34801561048b57600080fd5b506102b361049a366004613509565b610e6f565b3480156104ab57600080fd5b506103466104ba36600461358f565b610ea5565b3480156104cb57600080fd5b506103747f0000000000000000000000009b4a421bdf48f44a7327dcde1dc741009e37989981565b3480156104ff57600080fd5b50610297610f8b565b34801561051457600080fd5b506103466105233660046135b2565b6110c3565b34801561053457600080fd5b50610297611122565b34801561054957600080fd5b50600f54610374906001600160a01b031681565b34801561056957600080fd5b5061029761057836600461347f565b611196565b34801561058957600080fd5b506102976105983660046135cf565b611258565b3480156105a957600080fd5b506102976105b836600461347f565b611600565b3480156105c957600080fd5b50610346600a5481565b3480156105df57600080fd5b506000546001600160a01b0316610374565b3480156105fd57600080fd5b50601154610374906001600160a01b031681565b34801561061d57600080fd5b5060408051808201909152600681526529a420a6a0a760d11b60208201526102f3565b34801561064c57600080fd5b5061029761065b36600461363c565b6116c2565b34801561066c57600080fd5b506102b361067b366004613509565b611779565b34801561068c57600080fd5b506102b361069b366004613509565b6117c8565b3480156106ac57600080fd5b5061034660095481565b3480156106c257600080fd5b506102976106d1366004613535565b6117d5565b3480156106e257600080fd5b506102976106f136600461363c565b6118a9565b34801561070257600080fd5b506102b36107113660046135b2565b60186020526000908152604090205460ff1681565b34801561073257600080fd5b5061029761074136600461347f565b611900565b34801561075257600080fd5b5060145460ff80821691620100008104821691600160201b8204811691600160301b8104821691600160401b909104165b6040805160ff968716815294861660208601529285169284019290925283166060830152909116608082015260a0016102bf565b3480156107c357600080fd5b50610346600c5481565b3480156107d957600080fd5b506102976107e836600461347f565b6119c2565b3480156107f957600080fd5b50600e54610374906001600160a01b031681565b34801561081957600080fd5b506103466108283660046136a1565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b34801561085f57600080fd5b5061029761086e3660046135b2565b611a44565b34801561087f57600080fd5b5060145460ff610100820481169163010000008104821691600160281b8204811691600160381b8104821691600160481b90910416610783565b6000546001600160a01b031633146108ec5760405162461bcd60e51b81526004016108e3906136da565b60405180910390fd5b6001600160a01b03821660009081526019602052604090205481151560ff90911615150361092c5760405162461bcd60e51b81526004016108e39061370f565b80156109f4576001600160a01b0382166000908152600260205260409020541561098c576001600160a01b03821660009081526002602052604090205461097290610da9565b6001600160a01b0383166000908152600360205260409020555b6001600160a01b0382166000818152601960205260408120805460ff1916841515179055601b805460018101825591527f3ad8aa4f87544323a9d1e5dd902f40c356527a7955687113db5f9a85ad579dc10180546001600160a01b0319169091179055610b17565b60005b601b54811015610b1557826001600160a01b0316601b8281548110610a1e57610a1e613761565b6000918252602090912001546001600160a01b031603610b0357601b8054610a489060019061378d565b81548110610a5857610a58613761565b600091825260209091200154601b80546001600160a01b039092169183908110610a8457610a84613761565b600091825260208083209190910180546001600160a01b0319166001600160a01b039485161790559185168152600382526040808220829055601990925220805460ff19169055601b805480610adc57610adc6137a4565b600082815260209020810160001990810180546001600160a01b0319169055019055610b15565b80610b0d816137ba565b9150506109f7565b505b816001600160a01b03167fcb9d59a6e9da25dee1a9ddef81481537dfd94e20b1593b58b08193bea9e9baa982604051610b54911515815260200190565b60405180910390a25050565b6000610b6d338484611b70565b5060015b92915050565b6000546001600160a01b03163314610ba15760405162461bcd60e51b81526004016108e3906136da565b6007805460ff19166001179055565b6000546001600160a01b03163314610bda5760405162461bcd60e51b81526004016108e3906136da565b600a548103610c435760405162461bcd60e51b815260206004820152602f60248201527f5368616d616e3a2043616e6e6f7420757064617465206d61785478416d6f756e60448201526e7420746f2073616d652076616c756560881b60648201526084016108e3565b600a5460405182907f75f1c17bf623f0f7a2bd91ba61e89dff216960370e3e9a46b250750d03e4215e90600090a3600a55565b6000610c83848484611c94565b610cd58433610cd085604051806060016040528060288152602001613992602891396001600160a01b038a166000908152600460209081526040808320338452909152902054919061215e565b611b70565b5060019392505050565b6000546001600160a01b03163314610d095760405162461bcd60e51b81526004016108e3906136da565b6009548103610d765760405162461bcd60e51b815260206004820152603360248201527f5368616d616e3a2043616e6e6f7420757064617465206d617857616c6c6574416044820152726d6f756e7420746f2073616d652076616c756560681b60648201526084016108e3565b60095460405182907f6d3e257c59a11116c3e97bb144abf5ba1a6a9da6bd509192ecf0d48f7be1fc7690600090a3600955565b6000600554821115610e185760405162461bcd60e51b815260206004820152603260248201527f5368616d616e3a20416d6f756e74206d757374206265206c657373207468616e60448201527120746f74616c207265666c656374696f6e7360701b60648201526084016108e3565b6000610e22612198565b9050610e2e81846137e9565b9392505050565b6000546001600160a01b03163314610e5f5760405162461bcd60e51b81526004016108e3906136da565b6007805460ff1916905542600855565b3360008181526004602090815260408083206001600160a01b03871684529091528120549091610b6d918590610cd090866121bb565b60006e09a130b963a6c115c3c7f400000000831115610f165760405162461bcd60e51b815260206004820152602760248201527f5368616d616e3a20416d6f756e74206d757374206265206c657373207468616e60448201526620737570706c7960c81b60648201526084016108e3565b6000610f20612198565b90506000610f2e82866137fd565b905083610f3e579150610b719050565b601c546000908390606490610f5d90600160281b900460ff16896137fd565b610f6791906137e9565b610f7191906137fd565b90506000610f7f828461378d565b9450610b719350505050565b6000546001600160a01b03163314610fb55760405162461bcd60e51b81526004016108e3906136da565b6000471161101c5760405162461bcd60e51b815260206004820152602e60248201527f5368616d616e3a2043616e6e6f742073656e64206d6f7265207468616e20636f60448201526d6e74726163742062616c616e636560901b60648201526084016108e3565b4760006110316000546001600160a01b031690565b6001600160a01b03168260405160006040518083038185875af1925050503d806000811461107b576040519150601f19603f3d011682016040523d82523d6000602084013e611080565b606091505b5050905080156110bf576040518281527f362ae087cf4ccfc970d45b9e8ce6520f03b4eda3f9d76a70b655dc22badcca48906020015b60405180910390a15b5050565b6001600160a01b03811660009081526019602052604081205460ff161561110057506001600160a01b031660009081526003602052604090205490565b6001600160a01b038216600090815260026020526040902054610b7190610da9565b6000546001600160a01b0316331461114c5760405162461bcd60e51b81526004016108e3906136da565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146111c05760405162461bcd60e51b81526004016108e3906136da565b6001600160a01b03821660009081526016602052604090205481151560ff9091161515036112005760405162461bcd60e51b81526004016108e39061370f565b6001600160a01b038216600081815260166020908152604091829020805460ff191685151590811790915591519182527ff5133f371b17bf21ce0df4ae2c1b6e11ca7c2f27257eb55282edb1ccfd4ecb2e9101610b54565b6000546001600160a01b031633146112825760405162461bcd60e51b81526004016108e3906136da565b600e546001600160a01b03858116911614611364576001600160a01b0384166112fd5760405162461bcd60e51b815260206004820152602760248201527f5368616d616e3a20546865206c697175696469747957616c6c65742063616e6e60448201526606f7420626520360cc1b60648201526084016108e3565b600e546040516e1b1a5c5d5a591a5d1e55d85b1b195d608a1b81526001600160a01b0391821691861690600f016040519081900381209060008051602061397283398151915290600090a4600e80546001600160a01b0319166001600160a01b0386161790555b600f546001600160a01b03848116911614611446576001600160a01b0383166113df5760405162461bcd60e51b815260206004820152602760248201527f5368616d616e3a20546865206d61726b6574696e6757616c6c65742063616e6e60448201526606f7420626520360cc1b60648201526084016108e3565b600f80546040516e1b585c9ad95d1a5b99d5d85b1b195d608a1b81526001600160a01b039182169291861691016040519081900381209060008051602061397283398151915290600090a4600f80546001600160a01b0319166001600160a01b0385161790555b6011546001600160a01b0383811691161461151c576001600160a01b0382166114bb5760405162461bcd60e51b815260206004820152602160248201527f5368616d616e3a205468652064657657616c6c65742063616e6e6f74206265206044820152600360fc1b60648201526084016108e3565b6011546040516819195d95d85b1b195d60ba1b81526001600160a01b03918216918416906009016040519081900381209060008051602061397283398151915290600090a4601180546001600160a01b0319166001600160a01b0384161790555b6010546001600160a01b038281169116146115fa576001600160a01b0381166115955760405162461bcd60e51b815260206004820152602560248201527f5368616d616e3a20546865206275794261636b57616c6c65742063616e6e6f74604482015264020626520360dc1b60648201526084016108e3565b6010546040516c189d5e509858dad5d85b1b195d609a1b81526001600160a01b0391821691831690600d016040519081900381209060008051602061397283398151915290600090a4601080546001600160a01b0319166001600160a01b0383161790555b50505050565b6000546001600160a01b0316331461162a5760405162461bcd60e51b81526004016108e3906136da565b6001600160a01b03821660009081526017602052604090205481151560ff90911615150361166a5760405162461bcd60e51b81526004016108e39061370f565b6001600160a01b038216600081815260176020908152604091829020805460ff191685151590811790915591519182527f30098fc83ab61b1a98835d32c4e611adedccfc260eeef586bd329d48e8a40a409101610b54565b6000546001600160a01b031633146116ec5760405162461bcd60e51b81526004016108e3906136da565b6116fb6012868686868661221a565b6040516b62617365466565732d42757960a01b8152600c015b6040805191829003822060ff8881168452878116602085015286811684840152858116606085015284166080840152905190917f9a3619059270a48acdf850268d8f96db29f0cfe103bc17b5b4040a05af4d4f67919081900360a00190a25050505050565b6000610b6d3384610cd0856040518060600160405280602581526020016139da602591393360009081526004602090815260408083206001600160a01b038d168452909152902054919061215e565b6000610b6d338484611c94565b6000546001600160a01b031633146117ff5760405162461bcd60e51b81526004016108e3906136da565b600c5481036118765760405162461bcd60e51b815260206004820152603b60248201527f5368616d616e3a2043616e6e6f7420757064617465206d696e696d756d546f6b60448201527f656e734265666f72655377617020746f2073616d652076616c7565000000000060648201526084016108e3565b600c5460405182907f5b0491f767c1463bea8972339f785795be1a38784cc6483cf649cdcbb28c46b090600090a3600c55565b6000546001600160a01b031633146118d35760405162461bcd60e51b81526004016108e3906136da565b6118e2601286868686866124fe565b6040516c18985cd95199595ccb54d95b1b609a1b8152600d01611714565b6000546001600160a01b0316331461192a5760405162461bcd60e51b81526004016108e3906136da565b6001600160a01b03821660009081526015602052604090205481151560ff90911615150361196a5760405162461bcd60e51b81526004016108e39061370f565b6001600160a01b038216600081815260156020908152604091829020805460ff191685151590811790915591519182527fa856ba9fdc54a5434b2359874c95612f520a2d7f858864ae98d15c1b2099ca8b9101610b54565b6000546001600160a01b031633146119ec5760405162461bcd60e51b81526004016108e3906136da565b6001600160a01b0382166000818152601a6020908152604091829020805460ff191685151590811790915591519182527fcb9f97b7b4b41413e5c8d418a8cf9a88db1cf34dee66b213d070faf881d9d3509101610b54565b6000546001600160a01b03163314611a6e5760405162461bcd60e51b81526004016108e3906136da565b6001600160a01b038116611ad35760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016108e3565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000610e2e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506127fe565b6001600160a01b038316611bd25760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016108e3565b6001600160a01b038216611c335760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016108e3565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316611cf85760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016108e3565b6001600160a01b038216611d5a5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016108e3565b60008111611dbc5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016108e3565b611dc5836110c3565b811115611e265760405162461bcd60e51b815260206004820152602960248201527f5368616d616e3a2043616e6e6f74207472616e73666572206d6f7265207468616044820152686e2062616c616e636560b81b60648201526084016108e3565b6001600160a01b03808416600081815260186020908152604080832054948716835280832054938352601a90915290205460ff928316929182169116158015611e8857506001600160a01b0384166000908152601a602052604090205460ff16155b1561204b5760075460ff16611eee5760405162461bcd60e51b815260206004820152602660248201527f5368616d616e3a2054726164696e672069732063757272656e746c792064697360448201526530b13632b21760d11b60648201526084016108e3565b6001600160a01b03841660009081526017602052604090205460ff16158015611f3057506001600160a01b03851660009081526017602052604090205460ff16155b15611fa057600a54831115611fa05760405162461bcd60e51b815260206004820152603060248201527f5368616d616e3a205472616e7366657220616d6f756e7420657863656564732060448201526f3a34329036b0bc2a3c20b6b7bab73a1760811b60648201526084016108e3565b6001600160a01b03841660009081526016602052604090205460ff1661204b5760095483611fcd866110c3565b611fd7919061381c565b111561204b5760405162461bcd60e51b815260206004820152603b60248201527f5368616d616e3a2045787065637465642077616c6c657420616d6f756e74206560448201527f78636565647320746865206d617857616c6c6574416d6f756e742e000000000060648201526084016108e3565b612055828261282c565b6000600c54612063306110c3565b600754911115915060ff1680156120775750805b80156120865750600b5460ff16155b801561209d5750601c54600160281b900460ff1615155b80156120c157506001600160a01b03851660009081526018602052604090205460ff165b156120e657600b805460ff191660011790556120db612a22565b600b805460ff191690555b600b5460009060ff161580156120fe575060075460ff165b6001600160a01b03881660009081526015602052604090205490915060ff168061214057506001600160a01b03861660009081526015602052604090205460ff165b15612149575060005b61215587878784612d14565b50505050505050565b600081848411156121825760405162461bcd60e51b81526004016108e391906134b4565b50600061218f848661378d565b95945050505050565b60008060006121a5612ee5565b90925090506121b48282611b2e565b9250505090565b6000806121c8838561381c565b905083811015610e2e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016108e3565b600286015460ff86811691161461229b57604051706c69717569646974794665654f6e42757960781b815260110160405190819003812060028801548854919260ff91821692918916916000805160206139ba833981519152916122819160481b90613834565b60405180910390a460028601805460ff191660ff87161790555b600286015460ff85811662010000909204161461232f57604051706d61726b6574696e674665654f6e42757960781b815260110160405190819003812060028801548854919260ff62010000909204821692918816916000805160206139ba8339815191529161230e9160481b90613834565b60405180910390a460028601805462ff000019166201000060ff8716021790555b600286015460ff848116600160201b90920416146123c2576040516a6465764665654f6e42757960a81b8152600b0160405190819003812060028801548854919260ff600160201b909204821692918716916000805160206139ba8339815191529161239e9160481b90613834565b60405180910390a460028601805464ff000000001916600160201b60ff8616021790555b600286015460ff838116600160301b909204161461245b576040516e6275794261636b4665654f6e42757960881b8152600f0160405190819003812060028801548854919260ff600160301b909204821692918616916000805160206139ba833981519152916124359160481b90613834565b60405180910390a460028601805466ff0000000000001916600160301b60ff8516021790555b600286015460ff828116600160401b90920416146124f6576040516e686f6c646572734665654f6e42757960881b8152600f0160405190819003812060028801548854919260ff600160401b909204821692918516916000805160206139ba833981519152916124ce9160481b90613834565b60405180910390a460028601805468ff00000000000000001916600160401b60ff8416021790555b505050505050565b600286015460ff868116610100909204161461258f57604051711b1a5c5d5a591a5d1e51995953db94d95b1b60721b815260120160405190819003812060028801548854919260ff610100909204821692918916916000805160206139ba833981519152916125709160481b90613834565b60405180910390a460028601805461ff00191661010060ff8816021790555b600286015460ff8581166301000000909204161461262857604051711b585c9ad95d1a5b99d1995953db94d95b1b60721b815260120160405190819003812060028801548854919260ff6301000000909204821692918816916000805160206139ba833981519152916126059160481b90613834565b60405180910390a460028601805463ff0000001916630100000060ff8716021790555b600286015460ff848116600160281b90920416146126bd576040516b19195d91995953db94d95b1b60a21b8152600c0160405190819003812060028801548854919260ff600160281b909204821692918716916000805160206139ba833981519152916126989160481b90613834565b60405180910390a460028601805465ff00000000001916600160281b60ff8616021790555b600286015460ff838116600160381b9092041614612758576040516f189d5e509858dad1995953db94d95b1b60821b815260100160405190819003812060028801548854919260ff600160381b909204821692918616916000805160206139ba833981519152916127319160481b90613834565b60405180910390a460028601805467ff000000000000001916600160381b60ff8516021790555b600286015460ff828116600160481b90920416146124f6576040516f1a1bdb19195c9cd1995953db94d95b1b60821b815260100160405190819003812060028801548854919260ff600160481b909204821692918516916000805160206139ba833981519152916127cc9160481b90613834565b60405180910390a460028601805460ff8316600160481b0269ff00000000000000000019909116179055505050505050565b6000818361281f5760405162461bcd60e51b81526004016108e391906134b4565b50600061218f84866137e9565b601c805464ffffffffff1916905581156128b757601454601c805460ff80841662ff00ff1990921691909117600160201b8085048316620100009081029290921763ff00ff00191661010092860484169290920263ff000000191691909117600160301b850483166301000000021764ff000000001916600160401b90940491909116029190911790555b801561293357601454601c805461010080840460ff90811662ff00ff1990931692909217600160281b8504831662010000021763ff00ff001916630100000080860484169290920263ff000000191617600160381b85048316919091021764ff000000001916600160481b90930416600160201b029190911790555b601c5460ff600160201b8204811691630100000081048216916201000082048116916129679161010082048116911661384b565b612971919061384b565b61297b919061384b565b612985919061384b565b601c805465ff0000000000198116600160281b60ff948516810291821793849055604080519386169286169290921783526101008404851660208401526201000084048516918301919091526301000000830484166060830152600160201b83048416608083015290910490911660a08201527f6c6977cb51242ec6e05aba0e2a29a5292ed1a8a5cffa3b87ff66395b7997d6d29060c0016110b6565b6000612a2d306110c3565b601c54909150479060ff600160281b820481169181811691610100820481169162010000810482169163010000008204811691600160201b9004166000600287612a77888c6137fd565b612a8191906137e9565b612a8b91906137e9565b90506000612a99828b61378d565b9050612aa48161309a565b6000612ab08a4761378d565b9050600084612ac060028b613870565b612aca908c613892565b612ad49190613892565b60ff16905060006002828b60ff1685612aed91906137fd565b612af791906137e9565b612b0191906137e9565b9050600082612b1360ff8b16866137fd565b612b1d91906137e9565b9050600083612b2f60ff8b16876137fd565b612b3991906137e9565b9050600081612b48848661381c565b612b52919061381c565b612b5c908761378d565b600f546040519192506001600160a01b03169082156108fc029083906000818181858888f19350505050158015612b97573d6000803e3d6000fd5b506011546040516001600160a01b039091169084156108fc029085906000818181858888f19350505050158015612bd2573d6000803e3d6000fd5b506010546040516001600160a01b039091169083156108fc029084906000818181858888f19350505050158015612c0d573d6000803e3d6000fd5b508715612c6057612c1e88856131ec565b60408051888152602081018690529081018990527f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619060600160405180910390a15b8d601c60056101000a81548160ff021916908360ff1602179055508c601c60006101000a81548160ff021916908360ff1602179055508b601c60016101000a81548160ff021916908360ff1602179055508a601c60026101000a81548160ff021916908360ff16021790555089601c60036101000a81548160ff021916908360ff16021790555088601c60046101000a81548160ff021916908360ff16021790555050505050505050505050505050505050565b6000806000612d2385856132a0565b925092509250600080600080612d42898787612d3d612198565b61336a565b6001600160a01b038f166000908152601960205260409020549397509195509350915060ff1615612dab576001600160a01b038b16600090815260036020526040902054612d91908a9061378d565b6001600160a01b038c166000908152600360205260409020555b6001600160a01b038a1660009081526019602052604090205460ff1615612e0a576001600160a01b038a16600090815260036020526040902054612df090889061381c565b6001600160a01b038b166000908152600360205260409020555b6001600160a01b038b16600090815260026020526040902054612e2e90859061378d565b6001600160a01b03808d1660009081526002602052604080822093909355908c1681522054612e5e90849061381c565b6001600160a01b038b16600090815260026020526040902055612e8181866133c2565b612e8b8287613427565b896001600160a01b03168b6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef89604051612ed091815260200190565b60405180910390a35050505050505050505050565b60055460009081906e09a130b963a6c115c3c7f400000000825b601b54811015613050578260026000601b8481548110612f2157612f21613761565b60009182526020808320909101546001600160a01b031683528201929092526040019020541180612f8c57508160036000601b8481548110612f6557612f65613761565b60009182526020808320909101546001600160a01b03168352820192909252604001902054115b15612fae575050600554936e09a130b963a6c115c3c7f4000000009350915050565b60026000601b8381548110612fc557612fc5613761565b60009182526020808320909101546001600160a01b03168352820192909252604001902054612ff4908461378d565b925060036000601b838154811061300d5761300d613761565b60009182526020808320909101546001600160a01b0316835282019290925260400190205461303c908361378d565b915080613048816137ba565b915050612eff565b506e09a130b963a6c115c3c7f40000000060055461306e91906137e9565b821015613091575050600554926e09a130b963a6c115c3c7f40000000092509050565b90939092509050565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106130cf576130cf613761565b6001600160a01b03928316602091820292909201810191909152600154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015613128573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061314c91906138b5565b8160018151811061315f5761315f613761565b6001600160a01b0392831660209182029290920101526001546131859130911684611b70565b60015460405163791ac94760e01b81526001600160a01b039091169063791ac947906131be9085906000908690309042906004016138d2565b600060405180830381600087803b1580156131d857600080fd5b505af11580156124f6573d6000803e3d6000fd5b6001546132049030906001600160a01b031684611b70565b600154600e5460405163f305d71960e01b81523060048201526024810185905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af1158015613274573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906132999190613943565b5050505050565b6000806000836132b857508391506000905080613363565b601c546000906064906132d590600160201b900460ff16886137fd565b6132df91906137e9565b601c5490915060009060649060ff630100000082048116916101008104821691613312916201000081048216911661384b565b61331c919061384b565b613326919061384b565b6133339060ff16896137fd565b61333d91906137e9565b9050600061334b828461381c565b613355908961378d565b955091935091506133639050565b9250925092565b60008080808061337a868a6137fd565b90506000613388878a6137fd565b90506000613396888a6137fd565b905060006133a4828461381c565b6133ae908561378d565b939c939b5091995097509095505050505050565b3060009081526019602052604090205460ff16156133ff5730600090815260036020526040812080548392906133f990849061381c565b90915550505b306000908152600260205260408120805484929061341e90849061381c565b90915550505050565b8160056000828254613439919061378d565b92505081905550806006600082825461341e919061381c565b6001600160a01b038116811461346757600080fd5b50565b8035801515811461347a57600080fd5b919050565b6000806040838503121561349257600080fd5b823561349d81613452565b91506134ab6020840161346a565b90509250929050565b600060208083528351808285015260005b818110156134e1578581018301518582016040015282016134c5565b818111156134f3576000604083870101525b50601f01601f1916929092016040019392505050565b6000806040838503121561351c57600080fd5b823561352781613452565b946020939093013593505050565b60006020828403121561354757600080fd5b5035919050565b60008060006060848603121561356357600080fd5b833561356e81613452565b9250602084013561357e81613452565b929592945050506040919091013590565b600080604083850312156135a257600080fd5b823591506134ab6020840161346a565b6000602082840312156135c457600080fd5b8135610e2e81613452565b600080600080608085870312156135e557600080fd5b84356135f081613452565b9350602085013561360081613452565b9250604085013561361081613452565b9150606085013561362081613452565b939692955090935050565b803560ff8116811461347a57600080fd5b600080600080600060a0868803121561365457600080fd5b61365d8661362b565b945061366b6020870161362b565b93506136796040870161362b565b92506136876060870161362b565b91506136956080870161362b565b90509295509295909350565b600080604083850312156136b457600080fd5b82356136bf81613452565b915060208301356136cf81613452565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526032908201527f5368616d616e3a204163636f756e7420697320616c7265616479207468652076604082015271616c7565206f6620276578636c756465642760701b606082015260800190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60008282101561379f5761379f613777565b500390565b634e487b7160e01b600052603160045260246000fd5b6000600182016137cc576137cc613777565b5060010190565b634e487b7160e01b600052601260045260246000fd5b6000826137f8576137f86137d3565b500490565b600081600019048311821515161561381757613817613777565b500290565b6000821982111561382f5761382f613777565b500190565b68ffffffffffffffffff1991909116815260200190565b600060ff821660ff84168060ff0382111561386857613868613777565b019392505050565b600060ff831680613883576138836137d3565b8060ff84160491505092915050565b600060ff821660ff8416808210156138ac576138ac613777565b90039392505050565b6000602082840312156138c757600080fd5b8151610e2e81613452565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156139225784516001600160a01b0316835293830193918301916001016138fd565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561395857600080fd5b835192506020840151915060408401519050925092509256fe4af24be54adc5e716fbcaa3fca0ad593e28dff90dffd49487c0a33b1547c6b5245524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636500edc71549f0cbe47086c2237ce0cf874d6897fd1d7ce43ee6b65c0230d7606e45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220a45651408d5c4241893b3de81f96b113421ebf00bdb90bd0f44303589311359264736f6c634300080d0033
Verified Source Code Partial Match
Compiler: v0.8.13+commit.abaa5c0e
EVM: london
Optimization: Yes (200 runs)
Shaman.sol 892 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.13;
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
);
}
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,
uint256 amountTokenDesired,
uint256 amountTokenMin,
uint256 amountETHMin,
address to,
uint256 deadline
)
external
payable
returns (
uint256 amountToken,
uint256 amountETH,
uint256 liquidity
);
function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external payable;
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
}
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) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
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;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
return mod(a, b, "SafeMath: modulo by zero");
}
function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
require(b != 0, errorMessage);
return a % b;
}
}
library Address {
function isContract(address account) internal view returns (bool) {
uint256 size;
assembly {
size := extcodesize(account)
}
return size > 0;
}
function sendValue(address payable recipient, uint256 amount) internal {
require(
address(this).balance >= amount,
"Address: insufficient balance"
);
(bool success, ) = recipient.call{value: amount}("");
require(
success,
"Address: unable to send value, recipient may have reverted"
);
}
function functionCall(address target, bytes memory data)
internal
returns (bytes memory)
{
return functionCall(target, data, "Address: low-level call failed");
}
function functionCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
return functionCallWithValue(target, data, 0, errorMessage);
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value
) internal returns (bytes memory) {
return
functionCallWithValue(
target,
data,
value,
"Address: low-level call with value failed"
);
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value,
string memory errorMessage
) internal returns (bytes memory) {
require(
address(this).balance >= value,
"Address: insufficient balance for call"
);
require(isContract(target), "Address: call to non-contract");
(bool success, bytes memory returndata) = target.call{value: value}(
data
);
return _verifyCallResult(success, returndata, errorMessage);
}
function functionStaticCall(address target, bytes memory data)
internal
view
returns (bytes memory)
{
return
functionStaticCall(
target,
data,
"Address: low-level static call failed"
);
}
function functionStaticCall(
address target,
bytes memory data,
string memory errorMessage
) internal view returns (bytes memory) {
require(isContract(target), "Address: static call to non-contract");
(bool success, bytes memory returndata) = target.staticcall(data);
return _verifyCallResult(success, returndata, errorMessage);
}
function functionDelegateCall(address target, bytes memory data)
internal
returns (bytes memory)
{
return
functionDelegateCall(
target,
data,
"Address: low-level delegate call failed"
);
}
function functionDelegateCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
require(isContract(target), "Address: delegate call to non-contract");
(bool success, bytes memory returndata) = target.delegatecall(data);
return _verifyCallResult(success, returndata, errorMessage);
}
function _verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) private pure returns (bytes memory) {
if (success) {
return returndata;
} else {
if (returndata.length > 0) {
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
return msg.data;
}
}
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);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
contract Shaman is IERC20, Ownable {
using Address for address;
using SafeMath for uint256;
IRouter public uniswapV2Router;
address public immutable uniswapV2Pair;
string private constant _name = "Shaman";
string private constant _symbol = "SHAMAN";
uint8 private constant _decimals = 18;
mapping (address => uint256) private _rOwned;
mapping (address => uint256) private _tOwned;
mapping (address => mapping (address => uint256)) private _allowances;
uint256 private constant MAX = ~uint256(0);
uint256 private constant _tTotal = 50000000000000000 * 10**18;
uint256 private _rTotal = (MAX - (MAX % _tTotal));
uint256 private _tFeeTotal;
bool public isTradingEnabled;
uint256 private _tradingPausedTimestamp;
// max wallet is 1.0% of initialSupply
uint256 public maxWalletAmount = _tTotal * 100 / 10000;
// max tx is 0.15% of initialSupply
uint256 public maxTxAmount = _tTotal * 150 / 100000;
bool private _swapping;
// max wallet is 0.025% of initialSupply
uint256 public minimumTokensBeforeSwap = _tTotal * 250 / 1000000;
address private dead = 0x000000000000000000000000000000000000dEaD;
address public liquidityWallet;
address public marketingWallet;
address public buyBackWallet;
address public devWallet;
struct CustomTaxPeriod {
bytes23 periodName;
uint8 blocksInPeriod;
uint256 timeInPeriod;
uint8 liquidityFeeOnBuy;
uint8 liquidityFeeOnSell;
uint8 marketingFeeOnBuy;
uint8 marketingFeeOnSell;
uint8 devFeeOnBuy;
uint8 devFeeOnSell;
uint8 buyBackFeeOnBuy;
uint8 buyBackFeeOnSell;
uint8 holdersFeeOnBuy;
uint8 holdersFeeOnSell;
}
// Base taxes
CustomTaxPeriod private _base = CustomTaxPeriod('base',0,0,1,1,3,3,1,1,3,3,2,2);
mapping (address => bool) private _isExcludedFromFee;
mapping (address => bool) private _isExcludedFromMaxWalletLimit;
mapping (address => bool) private _isExcludedFromMaxTransactionLimit;
mapping (address => bool) public automatedMarketMakerPairs;
mapping (address => bool) private _isExcludedFromDividends;
mapping (address => bool) private _isAllowedToTradeWhenDisabled;
address[] private _excludedFromDividends;
uint8 private _liquidityFee;
uint8 private _marketingFee;
uint8 private _devFee;
uint8 private _buyBackFee;
uint8 private _holdersFee;
uint8 private _totalFee;
event AutomatedMarketMakerPairChange(address indexed pair, bool indexed value);
event AllowedWhenTradingDisabledChange(address indexed account, bool isExcluded);
event UniswapV2RouterChange(address indexed newAddress, address indexed oldAddress);
event WalletChange(string indexed indentifier, address indexed newWallet, address indexed oldWallet);
event FeeChange(string indexed identifier, uint8 liquidityFee, uint8 marketingFee, uint8 devFee, uint8 buyBackFee, uint8 holdersFee);
event CustomTaxPeriodChange(uint256 indexed newValue, uint256 indexed oldValue, string indexed taxType, bytes23 period);
event MaxWalletAmountChange(uint256 indexed newValue, uint256 indexed oldValue);
event MaxTransactionAmountChange(uint256 indexed newValue, uint256 indexed oldValue);
event ExcludeFromDividendsChange(address indexed account, bool isExcluded);
event ExcludeFromFeesChange(address indexed account, bool isExcluded);
event ExcludeFromMaxTransferChange(address indexed account, bool isExcluded);
event ExcludeFromMaxWalletChange(address indexed account, bool isExcluded);
event MinTokenAmountBeforeSwapChange(uint256 indexed newValue, uint256 indexed oldValue);
event SwapAndLiquify(uint256 tokensSwapped, uint256 ethReceived,uint256 tokensIntoLiqudity);
event ClaimETHOverflow(uint256 amount);
event FeesApplied(uint8 liquidityFee, uint8 marketingFee, uint8 devFee, uint8 buyBackFee, uint8 holdersFee, uint8 totalFee);
constructor() {
liquidityWallet = owner();
marketingWallet = owner();
buyBackWallet = owner();
devWallet = owner();
IRouter _uniswapV2Router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
address _uniswapV2Pair = IFactory(_uniswapV2Router.factory()).createPair(
address(this),
_uniswapV2Router.WETH()
);
uniswapV2Router = _uniswapV2Router;
uniswapV2Pair = _uniswapV2Pair;
_setAutomatedMarketMakerPair(_uniswapV2Pair, true);
_isExcludedFromFee[owner()] = true;
_isExcludedFromFee[address(this)] = true;
excludeFromDividends(address(this), true);
excludeFromDividends(address(dead), true);
excludeFromDividends(address(_uniswapV2Router), true);
_isAllowedToTradeWhenDisabled[owner()] = true;
_isAllowedToTradeWhenDisabled[address(this)] = true;
_isExcludedFromMaxWalletLimit[_uniswapV2Pair] = true;
_isExcludedFromMaxWalletLimit[address(uniswapV2Router)] = true;
_isExcludedFromMaxWalletLimit[address(this)] = true;
_isExcludedFromMaxWalletLimit[owner()] = true;
_isExcludedFromMaxTransactionLimit[address(this)] = true;
_isExcludedFromMaxTransactionLimit[address(dead)] = true;
_isExcludedFromMaxTransactionLimit[owner()] = true;
_rOwned[owner()] = _rTotal;
emit Transfer(address(0), owner(), _tTotal);
}
receive() external payable {}
// Setters
function transfer(address recipient, uint256 amount) external override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function approve(address spender, uint256 amount) public override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom( address sender,address recipient,uint256 amount) external override returns (bool) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount,"ERC20: transfer amount exceeds allowance"));
return true;
}
function increaseAllowance(address spender, uint256 addedValue) external virtual returns (bool){
_approve(_msgSender(),spender,_allowances[_msgSender()][spender].add(addedValue));
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) external virtual returns (bool) {
_approve(_msgSender(),spender,_allowances[_msgSender()][spender].sub(subtractedValue,"ERC20: decreased allowance below zero"));
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 _getNow() private view returns (uint256) {
return block.timestamp;
}
function activateTrading() external onlyOwner {
isTradingEnabled = true;
}
function deactivateTrading() external onlyOwner {
isTradingEnabled = false;
_tradingPausedTimestamp = _getNow();
}
function _setAutomatedMarketMakerPair(address pair, bool value) private {
require(automatedMarketMakerPairs[pair] != value, "Shaman: Automated market maker pair is already set to that value");
automatedMarketMakerPairs[pair] = value;
emit AutomatedMarketMakerPairChange(pair, value);
}
function allowTradingWhenDisabled(address account, bool allowed) external onlyOwner {
_isAllowedToTradeWhenDisabled[account] = allowed;
emit AllowedWhenTradingDisabledChange(account, allowed);
}
function excludeFromFees(address account, bool excluded) external onlyOwner {
require(_isExcludedFromFee[account] != excluded, "Shaman: Account is already the value of 'excluded'");
_isExcludedFromFee[account] = excluded;
emit ExcludeFromFeesChange(account, excluded);
}
function excludeFromMaxWalletLimit(address account, bool excluded) external onlyOwner {
require(_isExcludedFromMaxWalletLimit[account] != excluded, "Shaman: Account is already the value of 'excluded'");
_isExcludedFromMaxWalletLimit[account] = excluded;
emit ExcludeFromMaxWalletChange(account, excluded);
}
function excludeFromMaxTransactionLimit(address account, bool excluded) external onlyOwner {
require(_isExcludedFromMaxTransactionLimit[account] != excluded, "Shaman: Account is already the value of 'excluded'");
_isExcludedFromMaxTransactionLimit[account] = excluded;
emit ExcludeFromMaxTransferChange(account, excluded);
}
function setWallets(address newLiquidityWallet, address newMarketingWallet, address newDevWallet, address newBuyBackWallet) external onlyOwner {
if(liquidityWallet != newLiquidityWallet) {
require(newLiquidityWallet != address(0), "Shaman: The liquidityWallet cannot be 0");
emit WalletChange('liquidityWallet', newLiquidityWallet, liquidityWallet);
liquidityWallet = newLiquidityWallet;
}
if(marketingWallet != newMarketingWallet) {
require(newMarketingWallet != address(0), "Shaman: The marketingWallet cannot be 0");
emit WalletChange('marketingWallet', newMarketingWallet, marketingWallet);
marketingWallet = newMarketingWallet;
}
if(devWallet != newDevWallet) {
require(newDevWallet != address(0), "Shaman: The devWallet cannot be 0");
emit WalletChange('devWallet', newDevWallet, devWallet);
devWallet = newDevWallet;
}
if(buyBackWallet != newBuyBackWallet) {
require(newBuyBackWallet != address(0), "Shaman: The buyBackWallet cannot be 0");
emit WalletChange('buyBackWallet', newBuyBackWallet, buyBackWallet);
buyBackWallet = newBuyBackWallet;
}
}
// Base fees
function setBaseFeesOnBuy(uint8 _liquidityFeeOnBuy, uint8 _marketingFeeOnBuy, uint8 _devFeeOnBuy, uint8 _buyBackFeeOnBuy, uint8 _holdersFeeOnBuy) external onlyOwner {
_setCustomBuyTaxPeriod(_base, _liquidityFeeOnBuy, _marketingFeeOnBuy, _devFeeOnBuy, _buyBackFeeOnBuy, _holdersFeeOnBuy);
emit FeeChange('baseFees-Buy', _liquidityFeeOnBuy, _marketingFeeOnBuy, _devFeeOnBuy, _buyBackFeeOnBuy, _holdersFeeOnBuy);
}
function setBaseFeesOnSell(uint8 _liquidityFeeOnSell, uint8 _marketingFeeOnSell, uint8 _devFeeOnSell, uint8 _buyBackFeeOnSell, uint8 _holdersFeeOnSell) external onlyOwner {
_setCustomSellTaxPeriod(_base, _liquidityFeeOnSell, _marketingFeeOnSell, _devFeeOnSell, _buyBackFeeOnSell, _holdersFeeOnSell);
emit FeeChange('baseFees-Sell', _liquidityFeeOnSell, _marketingFeeOnSell, _devFeeOnSell, _buyBackFeeOnSell, _holdersFeeOnSell);
}
function setMaxWalletAmount(uint256 newValue) external onlyOwner {
require(newValue != maxWalletAmount, "Shaman: Cannot update maxWalletAmount to same value");
emit MaxWalletAmountChange(newValue, maxWalletAmount);
maxWalletAmount = newValue;
}
function setMaxTransactionAmount(uint256 newValue) external onlyOwner {
require(newValue != maxTxAmount, "Shaman: Cannot update maxTxAmount to same value");
emit MaxTransactionAmountChange(newValue, maxTxAmount);
maxTxAmount = newValue;
}
function excludeFromDividends(address account, bool excluded) public onlyOwner {
require(_isExcludedFromDividends[account] != excluded, "Shaman: Account is already the value of 'excluded'");
if(excluded) {
if(_rOwned[account] > 0) {
_tOwned[account] = tokenFromReflection(_rOwned[account]);
}
_isExcludedFromDividends[account] = excluded;
_excludedFromDividends.push(account);
} else {
for (uint256 i = 0; i < _excludedFromDividends.length; i++) {
if (_excludedFromDividends[i] == account) {
_excludedFromDividends[i] = _excludedFromDividends[_excludedFromDividends.length - 1];
_tOwned[account] = 0;
_isExcludedFromDividends[account] = false;
_excludedFromDividends.pop();
break;
}
}
}
emit ExcludeFromDividendsChange(account, excluded);
}
function setMinimumTokensBeforeSwap(uint256 newValue) external onlyOwner {
require(newValue != minimumTokensBeforeSwap, "Shaman: Cannot update minimumTokensBeforeSwap to same value");
emit MinTokenAmountBeforeSwapChange(newValue, minimumTokensBeforeSwap);
minimumTokensBeforeSwap = newValue;
}
function claimETHOverflow() external onlyOwner {
require(address(this).balance > 0, "Shaman: Cannot send more than contract balance");
uint256 amount = address(this).balance;
(bool success,) = address(owner()).call{value : amount}("");
if (success){
emit ClaimETHOverflow(amount);
}
}
// Getters
function name() external view returns (string memory) {
return _name;
}
function symbol() external view returns (string memory) {
return _symbol;
}
function decimals() external view virtual returns (uint8) {
return _decimals;
}
function totalSupply() external view override returns (uint256) {
return _tTotal;
}
function balanceOf(address account) public view override returns (uint256) {
if (_isExcludedFromDividends[account]) return _tOwned[account];
return tokenFromReflection(_rOwned[account]);
}
function totalFees() external view returns (uint256) {
return _tFeeTotal;
}
function allowance(address owner, address spender) external view override returns (uint256) {
return _allowances[owner][spender];
}
function getBaseBuyFees() external view returns (uint8, uint8, uint8, uint8, uint8){
return (_base.liquidityFeeOnBuy, _base.marketingFeeOnBuy, _base.devFeeOnBuy, _base.buyBackFeeOnBuy, _base.holdersFeeOnBuy);
}
function getBaseSellFees() external view returns (uint8, uint8, uint8, uint8, uint8){
return (_base.liquidityFeeOnSell, _base.marketingFeeOnSell, _base.devFeeOnSell, _base.buyBackFeeOnSell, _base.holdersFeeOnSell);
}
function tokenFromReflection(uint256 rAmount) public view returns(uint256) {
require(rAmount <= _rTotal, "Shaman: Amount must be less than total reflections");
uint256 currentRate = _getRate();
return rAmount / currentRate;
}
function reflectionFromToken(uint256 tAmount, bool deductTransferFee) external view returns (uint256) {
require(tAmount <= _tTotal, "Shaman: Amount must be less than supply");
uint256 currentRate = _getRate();
uint256 rAmount = tAmount * currentRate;
if (!deductTransferFee) {
return rAmount;
}
else {
uint256 rTotalFee = tAmount * _totalFee / 100 * currentRate;
uint256 rTransferAmount = rAmount - rTotalFee;
return rTransferAmount;
}
}
// Main
function _transfer(
address from,
address to,
uint256 amount
) internal {
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");
require(amount <= balanceOf(from), "Shaman: Cannot transfer more than balance");
bool isBuyFromLp = automatedMarketMakerPairs[from];
bool isSelltoLp = automatedMarketMakerPairs[to];
if(!_isAllowedToTradeWhenDisabled[from] && !_isAllowedToTradeWhenDisabled[to]) {
require(isTradingEnabled, "Shaman: Trading is currently disabled.");
if (!_isExcludedFromMaxTransactionLimit[to] && !_isExcludedFromMaxTransactionLimit[from]) {
require(amount <= maxTxAmount, "Shaman: Transfer amount exceeds the maxTxAmount.");
}
if (!_isExcludedFromMaxWalletLimit[to]) {
require((balanceOf(to) + amount) <= maxWalletAmount, "Shaman: Expected wallet amount exceeds the maxWalletAmount.");
}
}
_adjustTaxes(isBuyFromLp, isSelltoLp);
bool canSwap = balanceOf(address(this)) >= minimumTokensBeforeSwap;
if (
isTradingEnabled &&
canSwap &&
!_swapping &&
_totalFee > 0 &&
automatedMarketMakerPairs[to]
) {
_swapping = true;
_swapAndLiquify();
_swapping = false;
}
bool takeFee = !_swapping && isTradingEnabled;
if(_isExcludedFromFee[from] || _isExcludedFromFee[to]){
takeFee = false;
}
_tokenTransfer(from, to, amount, takeFee);
}
function _tokenTransfer(address sender,address recipient, uint256 tAmount, bool takeFee) private {
(uint256 tTransferAmount,uint256 tFee, uint256 tOther) = _getTValues(tAmount, takeFee);
(uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 rOther) = _getRValues(tAmount, tFee, tOther, _getRate());
if (_isExcludedFromDividends[sender]) {
_tOwned[sender] = _tOwned[sender] - tAmount;
}
if (_isExcludedFromDividends[recipient]) {
_tOwned[recipient] = _tOwned[recipient] + tTransferAmount;
}
_rOwned[sender] = _rOwned[sender] - rAmount;
_rOwned[recipient] = _rOwned[recipient] + rTransferAmount;
_takeContractFees(rOther, tOther);
_reflectFee(rFee, tFee);
emit Transfer(sender, recipient, tTransferAmount);
}
function _reflectFee(uint256 rFee, uint256 tFee) private {
_rTotal -= rFee;
_tFeeTotal += tFee;
}
function _getTValues(uint256 tAmount, bool takeFee) private view returns (uint256,uint256,uint256){
if (!takeFee) {
return (tAmount, 0, 0);
}
else {
uint256 tFee = tAmount * _holdersFee / 100;
uint256 tOther = tAmount * (_liquidityFee + _devFee + _marketingFee + _buyBackFee) / 100;
uint256 tTransferAmount = tAmount - (tFee + tOther);
return (tTransferAmount, tFee, tOther);
}
}
function _getRValues(
uint256 tAmount,
uint256 tFee,
uint256 tOther,
uint256 currentRate
) private pure returns ( uint256, uint256, uint256, uint256) {
uint256 rAmount = tAmount * currentRate;
uint256 rFee = tFee * currentRate;
uint256 rOther = tOther * currentRate;
uint256 rTransferAmount = rAmount - (rFee + rOther);
return (rAmount, rTransferAmount, rFee, rOther);
}
function _getRate() private view returns (uint256) {
(uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
return rSupply.div(tSupply);
}
function _getCurrentSupply() private view returns (uint256, uint256) {
uint256 rSupply = _rTotal;
uint256 tSupply = _tTotal;
for (uint256 i = 0; i < _excludedFromDividends.length; i++) {
if (
_rOwned[_excludedFromDividends[i]] > rSupply ||
_tOwned[_excludedFromDividends[i]] > tSupply
) return (_rTotal, _tTotal);
rSupply = rSupply - _rOwned[_excludedFromDividends[i]];
tSupply = tSupply - _tOwned[_excludedFromDividends[i]];
}
if (rSupply < _rTotal / _tTotal) return (_rTotal, _tTotal);
return (rSupply, tSupply);
}
function _takeContractFees(uint256 rOther, uint256 tOther) private {
if (_isExcludedFromDividends[address(this)]) {
_tOwned[address(this)] += tOther;
}
_rOwned[address(this)] += rOther;
}
function _adjustTaxes(bool isBuyFromLp, bool isSelltoLp) private {
_liquidityFee = 0;
_devFee = 0;
_marketingFee = 0;
_buyBackFee = 0;
_holdersFee = 0;
if (isBuyFromLp) {
_liquidityFee = _base.liquidityFeeOnBuy;
_devFee = _base.devFeeOnBuy;
_marketingFee = _base.marketingFeeOnBuy;
_buyBackFee = _base.buyBackFeeOnBuy;
_holdersFee = _base.holdersFeeOnBuy;
}
if (isSelltoLp) {
_liquidityFee = _base.liquidityFeeOnSell;
_devFee = _base.devFeeOnSell;
_marketingFee = _base.marketingFeeOnSell;
_buyBackFee = _base.buyBackFeeOnSell;
_holdersFee = _base.holdersFeeOnSell;
}
_totalFee = _liquidityFee + _marketingFee + _devFee + _buyBackFee + _holdersFee;
emit FeesApplied(_liquidityFee, _marketingFee, _devFee, _buyBackFee, _holdersFee, _totalFee);
}
function _setCustomSellTaxPeriod(CustomTaxPeriod storage map,
uint8 _liquidityFeeOnSell,
uint8 _marketingFeeOnSell,
uint8 _devFeeOnSell,
uint8 _buyBackFeeOnSell,
uint8 _holdersFeeOnSell
) private {
if (map.liquidityFeeOnSell != _liquidityFeeOnSell) {
emit CustomTaxPeriodChange(_liquidityFeeOnSell, map.liquidityFeeOnSell, 'liquidityFeeOnSell', map.periodName);
map.liquidityFeeOnSell = _liquidityFeeOnSell;
}
if (map.marketingFeeOnSell != _marketingFeeOnSell) {
emit CustomTaxPeriodChange(_marketingFeeOnSell, map.marketingFeeOnSell, 'marketingFeeOnSell', map.periodName);
map.marketingFeeOnSell = _marketingFeeOnSell;
}
if (map.devFeeOnSell != _devFeeOnSell) {
emit CustomTaxPeriodChange(_devFeeOnSell, map.devFeeOnSell, 'devFeeOnSell', map.periodName);
map.devFeeOnSell = _devFeeOnSell;
}
if (map.buyBackFeeOnSell != _buyBackFeeOnSell) {
emit CustomTaxPeriodChange(_buyBackFeeOnSell, map.buyBackFeeOnSell, 'buyBackFeeOnSell', map.periodName);
map.buyBackFeeOnSell = _buyBackFeeOnSell;
}
if (map.holdersFeeOnSell != _holdersFeeOnSell) {
emit CustomTaxPeriodChange(_holdersFeeOnSell, map.holdersFeeOnSell, 'holdersFeeOnSell', map.periodName);
map.holdersFeeOnSell = _holdersFeeOnSell;
}
}
function _setCustomBuyTaxPeriod(CustomTaxPeriod storage map,
uint8 _liquidityFeeOnBuy,
uint8 _marketingFeeOnBuy,
uint8 _devFeeOnBuy,
uint8 _buyBackFeeOnBuy,
uint8 _holdersFeeOnBuy
) private {
if (map.liquidityFeeOnBuy != _liquidityFeeOnBuy) {
emit CustomTaxPeriodChange(_liquidityFeeOnBuy, map.liquidityFeeOnBuy, 'liquidityFeeOnBuy', map.periodName);
map.liquidityFeeOnBuy = _liquidityFeeOnBuy;
}
if (map.marketingFeeOnBuy != _marketingFeeOnBuy) {
emit CustomTaxPeriodChange(_marketingFeeOnBuy, map.marketingFeeOnBuy, 'marketingFeeOnBuy', map.periodName);
map.marketingFeeOnBuy = _marketingFeeOnBuy;
}
if (map.devFeeOnBuy != _devFeeOnBuy) {
emit CustomTaxPeriodChange(_devFeeOnBuy, map.devFeeOnBuy, 'devFeeOnBuy', map.periodName);
map.devFeeOnBuy = _devFeeOnBuy;
}
if (map.buyBackFeeOnBuy != _buyBackFeeOnBuy) {
emit CustomTaxPeriodChange(_buyBackFeeOnBuy, map.buyBackFeeOnBuy, 'buyBackFeeOnBuy', map.periodName);
map.buyBackFeeOnBuy = _buyBackFeeOnBuy;
}
if (map.holdersFeeOnBuy != _holdersFeeOnBuy) {
emit CustomTaxPeriodChange(_holdersFeeOnBuy, map.holdersFeeOnBuy, 'holdersFeeOnBuy', map.periodName);
map.holdersFeeOnBuy = _holdersFeeOnBuy;
}
}
function _swapAndLiquify() private {
uint256 contractBalance = balanceOf(address(this));
uint256 initialETHBalance = address(this).balance;
uint8 totalFeePrior = _totalFee;
uint8 liquidityFeePrior = _liquidityFee;
uint8 marketingFeePrior = _marketingFee;
uint8 devFeePrior = _devFee;
uint8 buyBackFeePrior = _buyBackFee;
uint8 holdersFeePrior = _holdersFee;
uint256 amountToLiquify = contractBalance * _liquidityFee / _totalFee / 2;
uint256 amountToSwapForETH = contractBalance - amountToLiquify;
_swapTokensForETH(amountToSwapForETH);
uint256 ETHBalanceAfterSwap = address(this).balance - initialETHBalance;
uint256 totalETHFee = totalFeePrior - (liquidityFeePrior / 2) - (holdersFeePrior);
uint256 amountETHLiquidity = ETHBalanceAfterSwap * liquidityFeePrior / totalETHFee / 2;
uint256 amountETHDev = ETHBalanceAfterSwap * devFeePrior / totalETHFee;
uint256 amountETHBuyBack = ETHBalanceAfterSwap * buyBackFeePrior / totalETHFee;
uint256 amountETHMarketing = ETHBalanceAfterSwap - (amountETHLiquidity + amountETHDev + amountETHBuyBack);
payable(marketingWallet).transfer(amountETHMarketing);
payable(devWallet).transfer(amountETHDev);
payable(buyBackWallet).transfer(amountETHBuyBack);
if (amountToLiquify > 0) {
_addLiquidity(amountToLiquify, amountETHLiquidity);
emit SwapAndLiquify(amountToSwapForETH, amountETHLiquidity, amountToLiquify);
}
_totalFee = totalFeePrior;
_liquidityFee = liquidityFeePrior;
_marketingFee = marketingFeePrior;
_devFee = devFeePrior;
_buyBackFee = buyBackFeePrior;
_holdersFee = holdersFeePrior;
}
function _swapTokensForETH(uint256 tokenAmount) private {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0, // accept any amount of ETH
path,
address(this),
block.timestamp
);
}
function _addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
_approve(address(this), address(uniswapV2Router), tokenAmount);
uniswapV2Router.addLiquidityETH{value: ethAmount}(
address(this),
tokenAmount,
0, // slippage is unavoidable
0, // slippage is unavoidable
liquidityWallet,
block.timestamp
);
}
}
Read Contract
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
buyBackWallet 0x1cd348c0 → address
decimals 0x313ce567 → uint8
devWallet 0x8ea5220f → address
getBaseBuyFees 0xcd43e228 → uint8, uint8, uint8, uint8, uint8
getBaseSellFees 0xfe017535 → uint8, uint8, uint8, uint8, uint8
isTradingEnabled 0x064a59d0 → bool
liquidityWallet 0xd4698016 → address
marketingWallet 0x75f0a874 → address
maxTxAmount 0x8c0b5e22 → uint256
maxWalletAmount 0xaa4bde28 → uint256
minimumTokensBeforeSwap 0xd2d7ad83 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
reflectionFromToken 0x4549b039 → uint256
symbol 0x95d89b41 → string
tokenFromReflection 0x2d838119 → uint256
totalFees 0x13114a9d → uint256
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address
Write Contract 21 functions
These functions modify contract state and require a wallet transaction to execute.
activateTrading 0x0bd05b69
No parameters
allowTradingWhenDisabled 0xd3221576
address account
bool allowed
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
claimETHOverflow 0x66164f6f
No parameters
deactivateTrading 0x34cf1fea
No parameters
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
excludeFromDividends 0x0483f7a0
address account
bool excluded
excludeFromFees 0xc0246668
address account
bool excluded
excludeFromMaxTransactionLimit 0x880bcbc1
address account
bool excluded
excludeFromMaxWalletLimit 0x781edb3c
address account
bool excluded
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
renounceOwnership 0x715018a6
No parameters
setBaseFeesOnBuy 0x9fad9683
uint8 _liquidityFeeOnBuy
uint8 _marketingFeeOnBuy
uint8 _devFeeOnBuy
uint8 _buyBackFeeOnBuy
uint8 _holdersFeeOnBuy
setBaseFeesOnSell 0xb1ba39ea
uint8 _liquidityFeeOnSell
uint8 _marketingFeeOnSell
uint8 _devFeeOnSell
uint8 _buyBackFeeOnSell
uint8 _holdersFeeOnSell
setMaxTransactionAmount 0x1e293c10
uint256 newValue
setMaxWalletAmount 0x27a14fc2
uint256 newValue
setMinimumTokensBeforeSwap 0xaee50b1e
uint256 newValue
setWallets 0x83672f3e
address newLiquidityWallet
address newMarketingWallet
address newDevWallet
address newBuyBackWallet
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
Token Balances (1)
View Transfers →Recent Transactions
No transactions found for this address