Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0xBC1ba885e143c7E7372c510EaD49Bda9A2db6d1A
Balance 0 ETH
Nonce 2
Code Size 9672 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

9672 bytes
0x6080604052600436106103905760003560e01c806377359aa7116101dc578063bf56b37111610102578063e2573bde116100a0578063f887ea401161006f578063f887ea4014610a80578063f8b45b0514610aa0578063fabe628314610ab6578063ffb54a9914610ad657600080fd5b8063e2573bde14610a15578063eb0751d914610a2a578063f2fde38b14610a40578063f708a64f14610a6057600080fd5b8063c9567bf9116100dc578063c9567bf914610984578063caa5581b14610999578063d920334e146109af578063dd62ed3e146109cf57600080fd5b8063bf56b37114610938578063c45a01551461094e578063c8d1293d1461096e57600080fd5b80638da5cb5b1161017a578063a8aa1b3111610149578063a8aa1b31146108b8578063a9059cbb146108d8578063b515566a146108f8578063bb542ef01461091857600080fd5b80638da5cb5b146107fc5780638ea5220f1461084a57806395d89b411461086a578063a3a2e89e1461089857600080fd5b806381934031116101b657806381934031146107c757806389291a8f146107e7578063893d20e8146107fc5780638b42507f1461081a57600080fd5b806377359aa7146107665780637db1342c146107865780637dfcbe34146107a657600080fd5b8063313ce567116102c15780634a74bb021161025f57806370a082311161022e57806370a08231146106ef578063715018a6146107255780637437681e1461073a57806375df13051461075057600080fd5b80634a74bb0214610679578063571ac8b01461069a5780636303516c146106ba57806366eb3785146106da57600080fd5b80633f4218e01161029b5780633f4218e0146105ed5780634355855a1461061d578063454343771461064d578063470624021461066357600080fd5b8063313ce567146105915780633330f55f146105ad5780633dab5269146105cd57600080fd5b806323b872dd1161032e5780632b14ca56116103085780632b14ca561461051b5780632d48e896146105315780632dbea2e11461055157806330ca34ee1461057157600080fd5b806323b872dd146104c6578063273123b7146104e65780632b112e491461050657600080fd5b80630b027d111161036a5780630b027d111461043757806312fb41871461045957806318160ddd146104915780631f53ac02146104a657600080fd5b80630445b6671461039c57806306fdde03146103c5578063095ea7b31461040757600080fd5b3661039757005b600080fd5b3480156103a857600080fd5b506103b2601e5481565b6040519081526020015b60405180910390f35b3480156103d157600080fd5b5060408051808201909152601081526f53686961205265666c656374696f6e7360801b60208201525b6040516103bc91906120f3565b34801561041357600080fd5b5061042761042236600461216d565b610af7565b60405190151581526020016103bc565b34801561044357600080fd5b50610457610452366004612199565b610b64565b005b34801561046557600080fd5b50600154610479906001600160a01b031681565b6040516001600160a01b0390911681526020016103bc565b34801561049d57600080fd5b506002546103b2565b3480156104b257600080fd5b506104576104c13660046121b2565b610b9c565b3480156104d257600080fd5b506104276104e13660046121cf565b610be8565b3480156104f257600080fd5b506104576105013660046121b2565b610caa565b34801561051257600080fd5b506103b2610cf5565b34801561052757600080fd5b506103b260105481565b34801561053d57600080fd5b5061045761054c366004612210565b610d47565b34801561055d57600080fd5b5061045761056c366004612232565b610ddb565b34801561057d57600080fd5b5061045761058c366004612210565b610e13565b34801561059d57600080fd5b50604051601281526020016103bc565b3480156105b957600080fd5b50601a54610479906001600160a01b031681565b3480156105d957600080fd5b506104576105e836600461226e565b610e48565b3480156105f957600080fd5b506104276106083660046121b2565b600a6020526000908152604090205460ff1681565b34801561062957600080fd5b506104276106383660046121b2565b600c6020526000908152604090205460ff1681565b34801561065957600080fd5b506103b260145481565b34801561066f57600080fd5b506103b2600f5481565b34801561068557600080fd5b5060195461042790600160a81b900460ff1681565b3480156106a657600080fd5b506104276106b53660046121b2565b610e94565b3480156106c657600080fd5b50600e54610479906001600160a01b031681565b3480156106e657600080fd5b50610457610ea2565b3480156106fb57600080fd5b506103b261070a3660046121b2565b6001600160a01b031660009081526003602052604090205490565b34801561073157600080fd5b50610457610ed6565b34801561074657600080fd5b506103b2601c5481565b34801561075c57600080fd5b506103b260135481565b34801561077257600080fd5b506103b26107813660046121b2565b610f4a565b34801561079257600080fd5b506104576107a1366004612199565b610fb9565b3480156107b257600080fd5b5060085461042790600160a01b900460ff1681565b3480156107d357600080fd5b506104576107e2366004612199565b610fe8565b3480156107f357600080fd5b50610457611076565b34801561080857600080fd5b506000546001600160a01b0316610479565b34801561082657600080fd5b506104276108353660046121b2565b600b6020526000908152604090205460ff1681565b34801561085657600080fd5b50601954610479906001600160a01b031681565b34801561087657600080fd5b5060408051808201909152600581526429a424a0a960d91b60208201526103fa565b3480156108a457600080fd5b506104576108b336600461228a565b6110e6565b3480156108c457600080fd5b50601654610479906001600160a01b031681565b3480156108e457600080fd5b506104276108f336600461216d565b61113b565b34801561090457600080fd5b506104576109133660046122d5565b611148565b34801561092457600080fd5b506104576109333660046121b2565b6111da565b34801561094457600080fd5b506103b2600d5481565b34801561095a57600080fd5b50601754610479906001600160a01b031681565b34801561097a57600080fd5b506103b260125481565b34801561099057600080fd5b50610457611226565b3480156109a557600080fd5b506103b260115481565b3480156109bb57600080fd5b506104576109ca366004612199565b611269565b3480156109db57600080fd5b506103b26109ea36600461239a565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b348015610a2157600080fd5b50610457611298565b348015610a3657600080fd5b506103b2601b5481565b348015610a4c57600080fd5b50610457610a5b3660046121b2565b6112f7565b348015610a6c57600080fd5b50610457610a7b36600461228a565b6113e1565b348015610a8c57600080fd5b50601554610479906001600160a01b031681565b348015610aac57600080fd5b506103b2601d5481565b348015610ac257600080fd5b50610457610ad136600461228a565b611415565b348015610ae257600080fd5b5060195461042790600160b01b900460ff1681565b3360008181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92590610b529086815260200190565b60405180910390a35060015b92915050565b6000546001600160a01b03163314610b975760405162461bcd60e51b8152600401610b8e906123d3565b60405180910390fd5b601b55565b6000546001600160a01b03163314610bc65760405162461bcd60e51b8152600401610b8e906123d3565b601980546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316600090815260046020908152604080832033845290915281205460001914610c95576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387166000908152600482528381203382529091529190912054610c709184906114ac565b6001600160a01b03851660009081526004602090815260408083203384529091529020555b610ca08484846114e6565b90505b9392505050565b6000546001600160a01b03163314610cd45760405162461bcd60e51b8152600401610b8e906123d3565b6001600160a01b03166000908152600960205260409020805460ff19169055565b6008546001600160a01b0316600090815260036020526040812054610d42906007546001600160a01b0316600090815260036020526040902054610d3c906002549061199c565b9061199c565b905090565b6000546001600160a01b03163314610d715760405162461bcd60e51b8152600401610b8e906123d3565b601a546040516316a4744b60e11b815260048101849052602481018390526001600160a01b0390911690632d48e896906044015b600060405180830381600087803b158015610dbf57600080fd5b505af1158015610dd3573d6000803e3d6000fd5b505050505050565b6000546001600160a01b03163314610e055760405162461bcd60e51b8152600401610b8e906123d3565b601192909255601255601355565b6000546001600160a01b03163314610e3d5760405162461bcd60e51b8152600401610b8e906123d3565b600f91909155601055565b6000546001600160a01b03163314610e725760405162461bcd60e51b8152600401610b8e906123d3565b60198054921515600160a81b0260ff60a81b1990931692909217909155601e55565b6000610b5e82600019610af7565b6000546001600160a01b03163314610ecc5760405162461bcd60e51b8152600401610b8e906123d3565b610ed46119de565b565b6000546001600160a01b03163314610f005760405162461bcd60e51b8152600401610b8e906123d3565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b601a5460405163051fa63360e31b81526001600160a01b03838116600483015260009216906328fd319890602401602060405180830381865afa158015610f95573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b5e9190612408565b6000546001600160a01b03163314610fe35760405162461bcd60e51b8152600401610b8e906123d3565b601d55565b6000546001600160a01b031633146110125760405162461bcd60e51b8152600401610b8e906123d3565b601a546040516001624d3b8760e01b03198152600481018390526001600160a01b039091169063ffb2c47990602401600060405180830381600087803b15801561105b57600080fd5b505af115801561106f573d6000803e3d6000fd5b5050505050565b6000546001600160a01b031633146110a05760405162461bcd60e51b8152600401610b8e906123d3565b4780156110e3576019546040516001600160a01b039091169082156108fc029083906000818181858888f193505050501580156110e1573d6000803e3d6000fd5b505b50565b6000546001600160a01b031633146111105760405162461bcd60e51b8152600401610b8e906123d3565b6001600160a01b03919091166000908152600a60205260409020805460ff1916911515919091179055565b6000610ca33384846114e6565b6000546001600160a01b031633146111725760405162461bcd60e51b8152600401610b8e906123d3565b60005b81518110156110e15760016009600084848151811061119657611196612421565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff1916911515919091179055806111d28161244d565b915050611175565b6000546001600160a01b031633146112045760405162461bcd60e51b8152600401610b8e906123d3565b601880546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b031633146112505760405162461bcd60e51b8152600401610b8e906123d3565b43600d556019805460ff60b01b1916600160b01b179055565b6000546001600160a01b031633146112935760405162461bcd60e51b8152600401610b8e906123d3565b601c55565b601a5460405163bd14ae2760e01b81523360048201526001600160a01b039091169063bd14ae2790602401600060405180830381600087803b1580156112dd57600080fd5b505af11580156112f1573d6000803e3d6000fd5b50505050565b6000546001600160a01b031633146113215760405162461bcd60e51b8152600401610b8e906123d3565b6001600160a01b0381166113865760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610b8e565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b0316331461140b5760405162461bcd60e51b8152600401610b8e906123d3565b6110e18282611b6c565b6000546001600160a01b0316331461143f5760405162461bcd60e51b8152600401610b8e906123d3565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6000610ca383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611c7d565b600081848411156114d05760405162461bcd60e51b8152600401610b8e91906120f3565b5060006114dd8486612466565b95945050505050565b600080546001600160a01b0385811691161480159061151357506000546001600160a01b03848116911614155b1561157157601954600160b01b900460ff166115715760405162461bcd60e51b815260206004820152601760248201527f686f6c6420757220686f7273657320626967206775792e0000000000000000006044820152606401610b8e565b6001600160a01b03841660009081526009602052604090205460ff161580156115b357506001600160a01b03831660009081526009602052604090205460ff16155b6115bc57600080fd5b601954600160a01b900460ff16156115e0576115d9848484611cab565b9050610ca3565b601c548211158061160957506001600160a01b0384166000908152600b602052604090205460ff165b61163a5760405162461bcd60e51b81526020600482015260026024820152610e8f60f31b6044820152606401610b8e565b6001600160a01b0383166000908152600b602052604090205460ff1615801561166c5750600854600160a01b900460ff165b156116ce57601d546001600160a01b0384166000908152600360205260409020546116979084611d91565b11156116ce5760405162461bcd60e51b81526020600482015260066024820152651dd85b1b195d60d21b6044820152606401610b8e565b6016546001600160a01b031633148015906116f35750601954600160a01b900460ff16155b80156117085750601954600160a81b900460ff165b80156117255750601e543060009081526003602052604090205410155b15611732576117326119de565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0387166000908152600390915291909120546117849184906114ac565b6001600160a01b038516600090815260036020908152604080832093909355600a90529081205460ff161580156117d457506001600160a01b0384166000908152600a602052604090205460ff16155b6117de57826117e9565b6117e9858585611df0565b6001600160a01b03851660009081526003602052604090205490915061180f9082611d91565b6001600160a01b038086166000908152600360209081526040808320949094559188168152600c909152205460ff166118b357601a546001600160a01b0386811660008181526003602052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401600060405180830381600087803b1580156118a057600080fd5b505af19250505080156118b1575060015b505b6001600160a01b0384166000908152600c602052604090205460ff1661194457601a546001600160a01b0385811660008181526003602052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401600060405180830381600087803b15801561193157600080fd5b505af1925050508015611942575060015b505b836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161198991815260200190565b60405180910390a3506001949350505050565b6000610ca383836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506114ac565b6019805460ff60a01b1916600160a01b17905530600090815260036020526040812054601254909190611a2490600290611a1e9060649082908790611eb3565b9061146a565b90506000611a32838361199c565b9050611a3d81611f35565b60004790506000611a5e6064611a1e60115485611eb390919063ffffffff16565b90506000611a7c6064611a1e60135486611eb390919063ffffffff16565b90506000611a9f6002611a1e6064611a1e60125489611eb390919063ffffffff16565b90508315611ae3576019546040516001600160a01b039091169083156108fc029084906000818181858888f19350505050158015611ae1573d6000803e3d6000fd5b505b601a60009054906101000a90046001600160a01b03166001600160a01b031663d0e30db0846040518263ffffffff1660e01b81526004016000604051808303818588803b158015611b3357600080fd5b505af193505050508015611b45575060015b508515611b5657611b56868261205e565b50506019805460ff60a01b191690555050505050565b6001600160a01b0382163014801590611b9357506016546001600160a01b03838116911614155b611b9c57600080fd5b6001600160a01b0382166000908152600c60205260409020805460ff19168215801591909117909155611c3457601a54604051630a5b654b60e11b81526001600160a01b03848116600483015260006024830152909116906314b6ca9690604401600060405180830381600087803b158015611c1757600080fd5b505af1158015611c2b573d6000803e3d6000fd5b505050506110e1565b601a546001600160a01b0383811660008181526003602052604090819020549051630a5b654b60e11b8152600481019290925260248201529116906314b6ca9690604401610da5565b60008183611c9e5760405162461bcd60e51b8152600401610b8e91906120f3565b5060006114dd848661247d565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386166000908152600390915291822054611cfc9184906114ac565b6001600160a01b038086166000908152600360205260408082209390935590851681522054611d2b9083611d91565b6001600160a01b0380851660008181526003602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611d7f9086815260200190565b60405180910390a35060019392505050565b600080611d9e838561249f565b905083811015610ca35760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610b8e565b60165460009081906001600160a01b03858116911614611e1257600f54611e16565b6010545b90506000611e296064611a1e8685611eb3565b30600090815260036020526040902054909150611e469082611d91565b30600081815260036020526040908190209290925590516001600160a01b038816907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90611e979085815260200190565b60405180910390a3611ea9848261199c565b9695505050505050565b600082600003611ec557506000610b5e565b6000611ed183856124b7565b905082611ede858361247d565b14610ca35760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610b8e565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611f6a57611f6a612421565b6001600160a01b03928316602091820292909201810191909152601554604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611fc3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611fe791906124d6565b81600181518110611ffa57611ffa612421565b60200260200101906001600160a01b031690816001600160a01b0316815250506120243083610af7565b5060155460405163791ac94760e01b81526001600160a01b039091169063791ac94790610da59085906000908690309042906004016124f3565b601554600e5460405163f305d71960e01b81523060048201526024810185905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af11580156120ce573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061106f9190612564565b600060208083528351808285015260005b8181101561212057858101830151858201604001528201612104565b81811115612132576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146110e357600080fd5b803561216881612148565b919050565b6000806040838503121561218057600080fd5b823561218b81612148565b946020939093013593505050565b6000602082840312156121ab57600080fd5b5035919050565b6000602082840312156121c457600080fd5b8135610ca381612148565b6000806000606084860312156121e457600080fd5b83356121ef81612148565b925060208401356121ff81612148565b929592945050506040919091013590565b6000806040838503121561222357600080fd5b50508035926020909101359150565b60008060006060848603121561224757600080fd5b505081359360208301359350604090920135919050565b8035801515811461216857600080fd5b6000806040838503121561228157600080fd5b61218b8361225e565b6000806040838503121561229d57600080fd5b82356122a881612148565b91506122b66020840161225e565b90509250929050565b634e487b7160e01b600052604160045260246000fd5b600060208083850312156122e857600080fd5b823567ffffffffffffffff8082111561230057600080fd5b818501915085601f83011261231457600080fd5b813581811115612326576123266122bf565b8060051b604051601f19603f8301168101818110858211171561234b5761234b6122bf565b60405291825284820192508381018501918883111561236957600080fd5b938501935b8285101561238e5761237f8561215d565b8452938501939285019261236e565b98975050505050505050565b600080604083850312156123ad57600080fd5b82356123b881612148565b915060208301356123c881612148565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561241a57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006001820161245f5761245f612437565b5060010190565b60008282101561247857612478612437565b500390565b60008261249a57634e487b7160e01b600052601260045260246000fd5b500490565b600082198211156124b2576124b2612437565b500190565b60008160001904831182151516156124d1576124d1612437565b500290565b6000602082840312156124e857600080fd5b8151610ca381612148565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156125435784516001600160a01b03168352938301939183019160010161251e565b50506001600160a01b03969096166060850152505050608001529392505050565b60008060006060848603121561257957600080fd5b835192506020840151915060408401519050925092509256fea264697066735822122043b25b4e0d84aea469bfe109dd4fb47bdb9289bb45a8b6c1f508f5d2012d131c64736f6c634300080d0033

Verified Source Code Full Match

Compiler: v0.8.13+commit.abaa5c0e EVM: london Optimization: Yes (200 runs)
shiar.sol 679 lines
/*

$SHIAR - SHIA Reflections
Reflecting on the epic success of Shiba Saga, SHIAR is the mirrored version of SHIA, rewarding holders with juicy reflections. 

4% TAX, 3% automatic $SHIA reflections to all $SHIAR holders, 1% marketing.

https://t.me/shiareflections

*/

// SPDX-License-Identifier: Unlicensed

pragma solidity 0.8.13;

/**
 * Standard SafeMath, stripped down to just add/sub/mul/div
 */
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) {
        // Solidity only automatically asserts when dividing by 0
        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;
    }
}

/**
 * ERC20 standard interface.
 */
interface IERC20 {
    function totalSupply() external view returns (uint256);
    function decimals() external view returns (uint8);
    function symbol() external view returns (string memory);
    function name() external view returns (string memory);
    function getOwner() external view returns (address);
    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);
}

 
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
 
    function _msgData() internal view virtual returns (bytes calldata) {
        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;
    }
}


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

interface IDEXRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);

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

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

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;

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

interface IShiaReflections {
    function setDistributionCriteria(uint256 _minPeriod, uint256 _minDistribution) external;
    function setShare(address shareholder, uint256 amount) external;
    function deposit() external payable;
    function process(uint256 gas) external;
    function gibTokens(address shareholder) external;
}


contract ShiaReflections is IShiaReflections {

    using SafeMath for uint256;
    address _token;

    address public SHIA;

    IDEXRouter router;

    struct Share {
        uint256 amount;
        uint256 totalExcluded;
        uint256 totalRealised;
    }

    address[] shareholders;
    mapping (address => uint256) shareholderIndexes;
    mapping (address => uint256) shareholderClaims;
    mapping (address => Share) public shares;

    uint256 public totalShares;
    uint256 public totalDividends;
    uint256 public totalDistributed;
    uint256 public dividendsPerShare;
    uint256 public dividendsPerShareAccuracyFactor = 10 ** 36;

    uint256 public minPeriod = 30 minutes;
    uint256 public minDistribution = 0 * (10 ** 9);

    uint256 public currentIndex;
    bool initialized;

    modifier initialization() {
        require(!initialized);
        _;
        initialized = true;
    }

    modifier onlyToken() {
        require(msg.sender == _token); _;
    }

    constructor () {
        _token = msg.sender;
        router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        SHIA = 0x43D7E65B8fF49698D9550a7F315c87E67344FB59;
    }
    
    receive() external payable {
        deposit();
    }

    function setDistributionCriteria(uint256 newMinPeriod, uint256 newMinDistribution) external override onlyToken {
        minPeriod = newMinPeriod;
        minDistribution = newMinDistribution;
    }

    function setShare(address shareholder, uint256 amount) external override onlyToken {

        if(shares[shareholder].amount > 0){
            distributeDividend(shareholder);
        }

        if(amount > 0 && shares[shareholder].amount == 0){
            addShareholder(shareholder);
        }else if(amount == 0 && shares[shareholder].amount > 0){
            removeShareholder(shareholder);
        }

        totalShares = totalShares.sub(shares[shareholder].amount).add(amount);
        shares[shareholder].amount = amount;
        shares[shareholder].totalExcluded = getCumulativeDividends(shares[shareholder].amount);
    }

    function deposit() public payable override {

        uint256 balanceBefore = IERC20(SHIA).balanceOf(address(this));

        address[] memory path = new address[](2);
        path[0] = router.WETH();
        path[1] = address(SHIA);

        router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: msg.value}(
            0,
            path,
            address(this),
            block.timestamp
        );

        uint256 amount = IERC20(SHIA).balanceOf(address(this)).sub(balanceBefore);
        totalDividends = totalDividends.add(amount);
        dividendsPerShare = dividendsPerShare.add(dividendsPerShareAccuracyFactor.mul(amount).div(totalShares));
    }
    
    function process(uint256 gas) external override {
        uint256 shareholderCount = shareholders.length;

        if(shareholderCount == 0) { return; }

        uint256 iterations = 0;
        uint256 gasUsed = 0;
        uint256 gasLeft = gasleft();

        while(gasUsed < gas && iterations < shareholderCount) {

            if(currentIndex >= shareholderCount){ currentIndex = 0; }

            if(shouldDistribute(shareholders[currentIndex])){
                distributeDividend(shareholders[currentIndex]);
            }

            gasUsed = gasUsed.add(gasLeft.sub(gasleft()));
            gasLeft = gasleft();
            currentIndex++;
            iterations++;
        }
    }
    
    function shouldDistribute(address shareholder) public view returns (bool) {
        return shareholderClaims[shareholder] + minPeriod < block.timestamp
                && getUnpaidEarnings(shareholder) > minDistribution;
    }

    function distributeDividend(address shareholder) internal {
        if(shares[shareholder].amount == 0){ return; }

        uint256 amount = getUnpaidEarnings(shareholder);
        if(amount > 0){
            totalDistributed = totalDistributed.add(amount);
            IERC20(SHIA).transfer(shareholder, amount);
            shareholderClaims[shareholder] = block.timestamp;
            shares[shareholder].totalRealised = shares[shareholder].totalRealised.add(amount);
            shares[shareholder].totalExcluded = getCumulativeDividends(shares[shareholder].amount);
        }
    }
    
    function gibTokens(address shareholder) external override onlyToken {
        distributeDividend(shareholder);
    }

    function getUnpaidEarnings(address shareholder) public view returns (uint256) {
        if(shares[shareholder].amount == 0){ return 0; }

        uint256 shareholderTotalDividends = getCumulativeDividends(shares[shareholder].amount);
        uint256 shareholderTotalExcluded = shares[shareholder].totalExcluded;

        if(shareholderTotalDividends <= shareholderTotalExcluded){ return 0; }

        return shareholderTotalDividends.sub(shareholderTotalExcluded);
    }

    function getCumulativeDividends(uint256 share) internal view returns (uint256) {
        return share.mul(dividendsPerShare).div(dividendsPerShareAccuracyFactor);
    }

    function addShareholder(address shareholder) internal {
        shareholderIndexes[shareholder] = shareholders.length;
        shareholders.push(shareholder);
    }

    function removeShareholder(address shareholder) internal {
        shareholders[shareholderIndexes[shareholder]] = shareholders[shareholders.length-1];
        shareholderIndexes[shareholders[shareholders.length-1]] = shareholderIndexes[shareholder];
        shareholders.pop();
    }
}

contract shiar is Context, IERC20, Ownable {
    using SafeMath for uint256;

    address public SHIA = 0x43D7E65B8fF49698D9550a7F315c87E67344FB59; //SHIA CA

    string private constant _name = "Shia Reflections";
    string private constant _symbol = "SHIAR";
    uint8 private constant _decimals = 18;
    
    uint256 private _totalSupply = 1000000000 * (10 ** _decimals);

    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping (address => uint256) private cooldown;

    address private WETH;
    address DEAD = 0x000000000000000000000000000000000000dEaD;
    address ZERO = 0x0000000000000000000000000000000000000000;

    bool public antiBot = true;

    mapping (address => bool) private bots; 
    mapping (address => bool) public isFeeExempt;
    mapping (address => bool) public isTxLimitExempt;
    mapping (address => bool) public isDividendExempt;

    uint256 public launchedAt;
    address public lpWallet = DEAD;

    uint256 public buyFee = 90;
    uint256 public sellFee = 90;

    uint256 public toReflections = 50;
    uint256 public toLiquidity = 0;
    uint256 public toMarketing = 50;

    uint256 public allocationSum = 100;

    IDEXRouter public router;
    address public pair;
    address public factory;
    address private tokenOwner;
    address public devWallet = payable(0xa5d4d9A5b4b3de255aDAb44D88C2D9139cAd2794);

    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = true;
    bool public tradingOpen = false;
    
    ShiaReflections public shiaReflections;
    uint256 public shiaReflectionsGas = 0;

    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }

    uint256 public maxTx = _totalSupply.div(100);
    uint256 public maxWallet = _totalSupply.div(50);
    uint256 public swapThreshold = _totalSupply.div(400);

    constructor () {
        router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
            
        WETH = router.WETH();
        
        pair = IDEXFactory(router.factory()).createPair(WETH, address(this));
        
        _allowances[address(this)][address(router)] = type(uint256).max;

        shiaReflections = new ShiaReflections();
        
        isFeeExempt[owner()] = true;
        isFeeExempt[devWallet] = true;            

        isDividendExempt[pair] = true;
        isDividendExempt[address(this)] = true;
        isDividendExempt[DEAD] = true;    

        isTxLimitExempt[owner()] = true;
        isTxLimitExempt[pair] = true;
        isTxLimitExempt[DEAD] = true;
        isTxLimitExempt[devWallet] = true;  


        _balances[owner()] = _totalSupply;
    
        emit Transfer(address(0), owner(), _totalSupply);
    }

    receive() external payable { }


    function setBots(address[] memory bots_) external onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }
    
    //once enabled, cannot be reversed
    function openTrading() external onlyOwner {
        launchedAt = block.number;
        tradingOpen = true;
    }      

    function changeTotalFees(uint256 newBuyFee, uint256 newSellFee) external onlyOwner {

        buyFee = newBuyFee;
        sellFee = newSellFee;
    } 
    
    function changeFeeAllocation(uint256 newRewardFee, uint256 newLpFee, uint256 newMarketingFee) external onlyOwner {
        toReflections = newRewardFee;
        toLiquidity = newLpFee;
        toMarketing = newMarketingFee;
    }

    function changeTxLimit(uint256 newLimit) external onlyOwner {
        maxTx = newLimit;
    }

    function changeWalletLimit(uint256 newLimit) external onlyOwner {
        maxWallet  = newLimit;
    }
    
    function changeIsFeeExempt(address holder, bool exempt) external onlyOwner {
        isFeeExempt[holder] = exempt;
    }

    function changeIsTxLimitExempt(address holder, bool exempt) external onlyOwner {      
        isTxLimitExempt[holder] = exempt;
    }

    function setDevWallet(address payable newDevWallet) external onlyOwner {
        devWallet = payable(newDevWallet);
    }

    function setOwnerWallet(address payable newOwnerWallet) external onlyOwner {
        tokenOwner = newOwnerWallet;
    }     

    function changeSwapBackSettings(bool enableSwapBack, uint256 newSwapBackLimit) external onlyOwner {
        swapAndLiquifyEnabled  = enableSwapBack;
        swapThreshold = newSwapBackLimit;
    }

    function setDistributionCriteria(uint256 newMinPeriod, uint256 newMinDistribution) external onlyOwner {
        shiaReflections.setDistributionCriteria(newMinPeriod, newMinDistribution);        
    }

    function delBot(address notbot) external onlyOwner {
        bots[notbot] = false;
    }

    function _setIsDividendExempt(address holder, bool exempt) internal {
        require(holder != address(this) && holder != pair);
        isDividendExempt[holder] = exempt;
        if(exempt){
            shiaReflections.setShare(holder, 0);
        }else{
            shiaReflections.setShare(holder, _balances[holder]);
        }
    }

    function setIsDividendExempt(address holder, bool exempt) external onlyOwner {
        _setIsDividendExempt(holder, exempt);
    }

    function changeShiaReflectionsGas(uint256 newGas) external onlyOwner {
        shiaReflectionsGas = newGas;
    }           

    function getCirculatingSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(ZERO));
    }

    function totalSupply() external view override returns (uint256) { return _totalSupply; }
    function decimals() external pure override returns (uint8) { return _decimals; }
    function symbol() external pure override returns (string memory) { return _symbol; }
    function name() external pure override returns (string memory) { return _name; }
    function getOwner() external view override returns (address) { return owner(); }
    function balanceOf(address account) public view override returns (uint256) { return _balances[account]; }
    function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; }
    
    function approve(address spender, uint256 amount) public override returns (bool) {
        _allowances[msg.sender][spender] = amount;
        emit Approval(msg.sender, spender, amount);
        return true;
    }

    function approveMax(address spender) external returns (bool) {
        return approve(spender, type(uint256).max);
    }

    function transfer(address recipient, uint256 amount) external override returns (bool) {
        return _transfer(msg.sender, recipient, amount);
    }

    function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) {
        if(_allowances[sender][msg.sender] != type(uint256).max){
            _allowances[sender][msg.sender] = _allowances[sender][msg.sender].sub(amount, "Insufficient Allowance");
        }

        return _transfer(sender, recipient, amount);
    }

    function _transfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        if (sender!= owner() && recipient!= owner()) require(tradingOpen, "hold ur horses big guy."); //transfers disabled before tradingActive
        require(!bots[sender] && !bots[recipient]);

        if(inSwapAndLiquify){ return _basicTransfer(sender, recipient, amount); }

        require(amount <= maxTx || isTxLimitExempt[sender], "tx");

        if(!isTxLimitExempt[recipient] && antiBot)
        {
            require(_balances[recipient].add(amount) <= maxWallet, "wallet");
        }

        if(msg.sender != pair && !inSwapAndLiquify && swapAndLiquifyEnabled && _balances[address(this)] >= swapThreshold){ swapBack(); }

        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        
        uint256 finalAmount = !isFeeExempt[sender] && !isFeeExempt[recipient] ? takeFee(sender, recipient, amount) : amount;
        _balances[recipient] = _balances[recipient].add(finalAmount);

        // Dividend tracker
        if(!isDividendExempt[sender]) {
            try shiaReflections.setShare(sender, _balances[sender]) {} catch {}
        }

        if(!isDividendExempt[recipient]) {
            try shiaReflections.setShare(recipient, _balances[recipient]) {} catch {} 
        }

        emit Transfer(sender, recipient, finalAmount);
        return true;
    }    

    function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }  
    
    function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) {
        
        uint256 feeApplicable = pair == recipient ? sellFee : buyFee;
        uint256 feeAmount = amount.mul(feeApplicable).div(100);

        _balances[address(this)] = _balances[address(this)].add(feeAmount);
        emit Transfer(sender, address(this), feeAmount);

        return amount.sub(feeAmount);
    }
    
    function swapTokensForEth(uint256 tokenAmount) private {

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.WETH();

        approve(address(this), tokenAmount);

        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0,
            0,
            lpWallet,
            block.timestamp
        );
    }

    function swapBack() internal lockTheSwap {
    
        uint256 tokenBalance = _balances[address(this)]; 
        uint256 tokensForLiquidity = tokenBalance.mul(toLiquidity).div(100).div(2);     
        uint256 amountToSwap = tokenBalance.sub(tokensForLiquidity);

        swapTokensForEth(amountToSwap);

        uint256 totalEthBalance = address(this).balance;
        uint256 ethForSHIA = totalEthBalance.mul(toReflections).div(100);
        uint256 ethForDev = totalEthBalance.mul(toMarketing).div(100);
        uint256 ethForLiquidity = totalEthBalance.mul(toLiquidity).div(100).div(2);
      
        if (totalEthBalance > 0){
            payable(devWallet).transfer(ethForDev);
        }
        
        try shiaReflections.deposit{value: ethForSHIA}() {} catch {}
        
        if (tokensForLiquidity > 0){
            addLiquidity(tokensForLiquidity, ethForLiquidity);
        }
    }

    function manualSwapBack() external onlyOwner {
        swapBack();
    }

    function clearStuckEth() external onlyOwner {
        uint256 contractETHBalance = address(this).balance;
        if(contractETHBalance > 0){          
            payable(devWallet).transfer(contractETHBalance);
        }
    }

    function manualProcessGas(uint256 manualGas) external onlyOwner {
        shiaReflections.process(manualGas);
    }

    function checkPendingReflections(address shareholder) external view returns (uint256) {
        return shiaReflections.getUnpaidEarnings(shareholder);
    }

    function getSHIA() external {
        shiaReflections.gibTokens(msg.sender);
    }
}

Read Contract

SHIA 0x12fb4187 → address
allocationSum 0x45434377 → uint256
allowance 0xdd62ed3e → uint256
antiBot 0x7dfcbe34 → bool
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256
checkPendingReflections 0x77359aa7 → uint256
decimals 0x313ce567 → uint8
devWallet 0x8ea5220f → address
factory 0xc45a0155 → address
getCirculatingSupply 0x2b112e49 → uint256
getOwner 0x893d20e8 → address
isDividendExempt 0x4355855a → bool
isFeeExempt 0x3f4218e0 → bool
isTxLimitExempt 0x8b42507f → bool
launchedAt 0xbf56b371 → uint256
lpWallet 0x6303516c → address
maxTx 0x7437681e → uint256
maxWallet 0xf8b45b05 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
sellFee 0x2b14ca56 → uint256
shiaReflections 0x3330f55f → address
shiaReflectionsGas 0xeb0751d9 → uint256
swapAndLiquifyEnabled 0x4a74bb02 → bool
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
toLiquidity 0xc8d1293d → uint256
toMarketing 0x75df1305 → uint256
toReflections 0xcaa5581b → uint256
totalSupply 0x18160ddd → uint256
tradingOpen 0xffb54a99 → bool

Write Contract 25 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approveMax 0x571ac8b0
address spender
returns: bool
changeFeeAllocation 0x2dbea2e1
uint256 newRewardFee
uint256 newLpFee
uint256 newMarketingFee
changeIsFeeExempt 0xa3a2e89e
address holder
bool exempt
changeIsTxLimitExempt 0xfabe6283
address holder
bool exempt
changeShiaReflectionsGas 0x0b027d11
uint256 newGas
changeSwapBackSettings 0x3dab5269
bool enableSwapBack
uint256 newSwapBackLimit
changeTotalFees 0x30ca34ee
uint256 newBuyFee
uint256 newSellFee
changeTxLimit 0xd920334e
uint256 newLimit
changeWalletLimit 0x7db1342c
uint256 newLimit
clearStuckEth 0x89291a8f
No parameters
delBot 0x273123b7
address notbot
getSHIA 0xe2573bde
No parameters
manualProcessGas 0x81934031
uint256 manualGas
manualSwapBack 0x66eb3785
No parameters
openTrading 0xc9567bf9
No parameters
renounceOwnership 0x715018a6
No parameters
setBots 0xb515566a
address[] bots_
setDevWallet 0x1f53ac02
address newDevWallet
setDistributionCriteria 0x2d48e896
uint256 newMinPeriod
uint256 newMinDistribution
setIsDividendExempt 0xf708a64f
address holder
bool exempt
setOwnerWallet 0xbb542ef0
address newOwnerWallet
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address