Address Contract Verified
Address
0x0000BdAA645097eF80F9d475f341d0d107A45B3A
Balance
0 ETH
Nonce
1
Code Size
7395 bytes
Creator
0x64A4551B...Af35 at tx 0xbdb200cb...26edd7
Indexed Transactions
0
Contract Bytecode
7395 bytes
0x60806040526004361061014a575f3560e01c8063715018a6116100b357806398a5c3151161006d57806398a5c315146103a4578063a9059cbb146103c3578063c9567bf9146103e2578063dd62ed3e146103f6578063e7d656bd1461043a578063f2fde38b1461044e575f80fd5b8063715018a614610306578063751039fc1461031a5780637d1db4a51461032e5780638da5cb5b146103435780638f9a55c01461035f57806395d89b4114610374575f80fd5b8063313ce56711610104578063313ce5671461025957806349bd5a5e1461027457806351bc3c851461029357806352f7c988146102a95780635431c94e146102c857806370a08231146102e7575f80fd5b806306fdde0314610155578063095ea7b3146101975780631694505e146101c657806318160ddd146101fd57806323b872dd146102255780632fd689e314610244575f80fd5b3661015157005b5f80fd5b348015610160575f80fd5b50604080518082019091526008815267109c985a5b9b195d60c21b60208201525b60405161018e91906119b8565b60405180910390f35b3480156101a2575f80fd5b506101b66101b13660046119fe565b61046d565b604051901515815260200161018e565b3480156101d1575f80fd5b506012546101e5906001600160a01b031681565b6040516001600160a01b03909116815260200161018e565b348015610208575f80fd5b506b015b6a759f4835dc240000005b60405190815260200161018e565b348015610230575f80fd5b506101b661023f366004611a28565b610483565b34801561024f575f80fd5b5061021760165481565b348015610264575f80fd5b506040516012815260200161018e565b34801561027f575f80fd5b506013546101e5906001600160a01b031681565b34801561029e575f80fd5b506102a76104ea565b005b3480156102b4575f80fd5b506102a76102c3366004611a66565b61053f565b3480156102d3575f80fd5b506102a76102e2366004611a86565b610635565b3480156102f2575f80fd5b50610217610301366004611abd565b610742565b348015610311575f80fd5b506102a7610763565b348015610325575f80fd5b506102a76107d4565b348015610339575f80fd5b5061021760145481565b34801561034e575f80fd5b505f546001600160a01b03166101e5565b34801561036a575f80fd5b5061021760155481565b34801561037f575f80fd5b50604080518082019091526008815267109490525393115560c21b6020820152610181565b3480156103af575f80fd5b506102a76103be366004611ad8565b610828565b3480156103ce575f80fd5b506101b66103dd3660046119fe565b610856565b3480156103ed575f80fd5b506102a7610862565b348015610401575f80fd5b50610217610410366004611a86565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b348015610445575f80fd5b506102a76108fa565b348015610459575f80fd5b506102a7610468366004611abd565b610941565b5f610479338484610a28565b5060015b92915050565b5f61048f848484610b4b565b6104e084336104db85604051806060016040528060288152602001611c86602891396001600160a01b038a165f9081526004602090815260408083203384529091529020549190610fe9565b610a28565b5060019392505050565b6010546001600160a01b0316336001600160a01b0316148061051f57506011546001600160a01b0316336001600160a01b0316145b610527575f80fd5b5f61053130610742565b905061053c81611021565b50565b5f546001600160a01b031633146105715760405162461bcd60e51b815260040161056890611aef565b60405180910390fd5b601e8211156105cd5760405162461bcd60e51b815260206004820152602260248201527f42757920746178206d757374206265206265747765656e20302520616e642033604482015261302560f01b6064820152608401610568565b601e81111561062a5760405162461bcd60e51b815260206004820152602360248201527f53656c6c20746178206d757374206265206265747765656e20302520616e642060448201526233302560e81b6064820152608401610568565b600991909155600b55565b6010546001600160a01b0316336001600160a01b0316148061066a57506011546001600160a01b0316336001600160a01b0316145b610672575f80fd5b6001600160a01b0382166106c85760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f7420626520300000000000006044820152606401610568565b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa15801561070c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107309190611b24565b905061073d838383611191565b505050565b6001600160a01b0381165f9081526002602052604081205461047d906111e3565b5f546001600160a01b0316331461078c5760405162461bcd60e51b815260040161056890611aef565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b6010546001600160a01b0316336001600160a01b0316148061080957506011546001600160a01b0316336001600160a01b0316145b610811575f80fd5b6b015b6a759f4835dc240000006014819055601555565b5f546001600160a01b031633146108515760405162461bcd60e51b815260040161056890611aef565b601655565b5f610479338484610b4b565b5f546001600160a01b0316331461088b5760405162461bcd60e51b815260040161056890611aef565b601354600160a01b900460ff16156108e55760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207265656e61626c652074726164696e670000000000000000006044820152606401610568565b6013805460ff60a01b1916600160a01b179055565b6010546001600160a01b0316336001600160a01b0316148061092f57506011546001600160a01b0316336001600160a01b0316145b610937575f80fd5b4761053c81611265565b5f546001600160a01b0316331461096a5760405162461bcd60e51b815260040161056890611aef565b6001600160a01b0381166109cf5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610568565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610a8a5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610568565b6001600160a01b038216610aeb5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610568565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610baf5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610568565b6001600160a01b038216610c115760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610568565b5f8111610c725760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610568565b5f546001600160a01b03848116911614801590610c9c57505f546001600160a01b03838116911614155b15610edf57601354600160a01b900460ff16610d34575f546001600160a01b03848116911614610d345760405162461bcd60e51b815260206004820152603f60248201527f544f4b454e3a2054686973206163636f756e742063616e6e6f742073656e642060448201527f746f6b656e7320756e74696c2074726164696e6720697320656e61626c6564006064820152608401610568565b601454811115610d865760405162461bcd60e51b815260206004820152601c60248201527f544f4b454e3a204d6178205472616e73616374696f6e204c696d6974000000006044820152606401610568565b6013546001600160a01b03838116911614610e0b5760155481610da884610742565b610db29190611b4f565b10610e0b5760405162461bcd60e51b815260206004820152602360248201527f544f4b454e3a2042616c616e636520657863656564732077616c6c65742073696044820152627a652160e81b6064820152608401610568565b5f610e1530610742565b601654601454919250821015908210610e2e5760145491505b808015610e455750601354600160a81b900460ff16155b8015610e5f57506013546001600160a01b03868116911614155b8015610e745750601354600160b01b900460ff165b8015610e9857506001600160a01b0385165f9081526005602052604090205460ff16155b8015610ebc57506001600160a01b0384165f9081526005602052604090205460ff16155b15610edc57610eca82611021565b478015610eda57610eda47611265565b505b50505b6001600160a01b0383165f9081526005602052604090205460019060ff1680610f1f57506001600160a01b0383165f9081526005602052604090205460ff165b80610f5157506013546001600160a01b03858116911614801590610f5157506013546001600160a01b03848116911614155b15610f5d57505f610fd7565b6013546001600160a01b038581169116148015610f8857506012546001600160a01b03848116911614155b15610f9a57600854600c55600954600d555b6013546001600160a01b038481169116148015610fc557506012546001600160a01b03858116911614155b15610fd757600a54600c55600b54600d555b610fe3848484846112a0565b50505050565b5f818484111561100c5760405162461bcd60e51b815260040161056891906119b8565b505f6110188486611b62565b95945050505050565b6013805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f8151811061106757611067611b75565b6001600160a01b03928316602091820292909201810191909152601254604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156110be573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906110e29190611b89565b816001815181106110f5576110f5611b75565b6001600160a01b03928316602091820292909201015260125461111b9130911684610a28565b60125460405163791ac94760e01b81526001600160a01b039091169063791ac947906111539085905f90869030904290600401611ba4565b5f604051808303815f87803b15801561116a575f80fd5b505af115801561117c573d5f803e3d5ffd5b50506013805460ff60a81b1916905550505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261073d9084906112ce565b5f6006548211156112495760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b6064820152608401610568565b5f61125261139f565b905061125e83826113c0565b9392505050565b6011546040516001600160a01b039091169082156108fc029083905f818181858888f1935050505015801561129c573d5f803e3d5ffd5b5050565b806112ad576112ad611401565b6112b884848461142e565b80610fe357610fe3600e54600c55600f54600d55565b5f611322826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661151f9092919063ffffffff16565b80519091501561073d57808060200190518101906113409190611c15565b61073d5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610568565b5f805f6113aa611535565b90925090506113b982826113c0565b9250505090565b5f61125e83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061157c565b600c541580156114115750600d54155b1561141857565b600c8054600e55600d8054600f555f9182905555565b5f805f805f8061143d876115a8565b6001600160a01b038f165f90815260026020526040902054959b5093995091975095509350915061146e90876115fd565b6001600160a01b03808b165f9081526002602052604080822093909355908a168152205461149c908661163e565b6001600160a01b0389165f908152600260205260409020556114bd8161169c565b6114c784836116e2565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161150c91815260200190565b60405180910390a3505050505050505050565b606061152d84845f85611706565b949350505050565b6006545f9081906b015b6a759f4835dc2400000061155382826113c0565b821015611573575050600654926b015b6a759f4835dc2400000092509050565b90939092509050565b5f818361159c5760405162461bcd60e51b815260040161056891906119b8565b505f6110188486611c34565b5f805f805f805f805f6115c08a600c54600d546117dd565b9250925092505f6115cf61139f565b90505f805f6115e08e87878761182f565b919e509c509a509598509396509194505050505091939550919395565b5f61125e83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610fe9565b5f8061164a8385611b4f565b90508381101561125e5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610568565b5f6116a561139f565b90505f6116b2838361187b565b305f908152600260205260409020549091506116ce908261163e565b305f90815260026020526040902055505050565b6006546116ef90836115fd565b6006556007546116ff908261163e565b6007555050565b6060824710156117675760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610568565b5f80866001600160a01b031685876040516117829190611c53565b5f6040518083038185875af1925050503d805f81146117bc576040519150601f19603f3d011682016040523d82523d5f602084013e6117c1565b606091505b50915091506117d2878383876118f9565b979650505050505050565b5f8080806117f660646117f0898961187b565b906113c0565b90505f61180860646117f08a8961187b565b90505f61181f826118198b866115fd565b906115fd565b9992985090965090945050505050565b5f80808061183d888661187b565b90505f61184a888761187b565b90505f611857888861187b565b90505f6118688261181986866115fd565b939b939a50919850919650505050505050565b5f825f0361188a57505f61047d565b5f6118958385611c6e565b9050826118a28583611c34565b1461125e5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610568565b606083156119675782515f03611960576001600160a01b0385163b6119605760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610568565b508161152d565b61152d838381511561197c5781518083602001fd5b8060405162461bcd60e51b815260040161056891906119b8565b5f5b838110156119b0578181015183820152602001611998565b50505f910152565b602081525f82518060208401526119d6816040850160208701611996565b601f01601f19169190910160400192915050565b6001600160a01b038116811461053c575f80fd5b5f8060408385031215611a0f575f80fd5b8235611a1a816119ea565b946020939093013593505050565b5f805f60608486031215611a3a575f80fd5b8335611a45816119ea565b92506020840135611a55816119ea565b929592945050506040919091013590565b5f8060408385031215611a77575f80fd5b50508035926020909101359150565b5f8060408385031215611a97575f80fd5b8235611aa2816119ea565b91506020830135611ab2816119ea565b809150509250929050565b5f60208284031215611acd575f80fd5b813561125e816119ea565b5f60208284031215611ae8575f80fd5b5035919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611b34575f80fd5b5051919050565b634e487b7160e01b5f52601160045260245ffd5b8082018082111561047d5761047d611b3b565b8181038181111561047d5761047d611b3b565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215611b99575f80fd5b815161125e816119ea565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611bf45784516001600160a01b031683529383019391830191600101611bcf565b50506001600160a01b03969096166060850152505050608001529392505050565b5f60208284031215611c25575f80fd5b8151801515811461125e575f80fd5b5f82611c4e57634e487b7160e01b5f52601260045260245ffd5b500490565b5f8251611c64818460208701611996565b9190910192915050565b808202811582820484141761047d5761047d611b3b56fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220d4b66a5e9ad69869c6bb9aa922e9b461d700b468f3efbf825fc2762f05a3aec364736f6c63430008170033
Verified Source Code Full Match
Compiler: v0.8.23+commit.f704f362
EVM: shanghai
Optimization: Yes (200 runs)
BRAINLET.sol 904 lines
// SPDX-License-Identifier: MIT
/**
Brainlet $BRAINLET is just no-brainer!
███████
██░░░░░░██
██▒ ███░░░░░░░░▒█
██░░▓███ ██░░░░░░░░░░░░█
█░█░░░░░░░██ ██░░░▓▓██████░░▒█
█░░█░░░░░░░░░██ ██░░░█░░░█████▓░░██
█░░░█░░░░░░░░░░░█ ██░░░░░██▒▒▓████░░░██
█░░░░░█░░░░░░░░░░░██ ████░░░░░░░░░░░░███░░▒█
█░░░░░░█░░░░░░░░░░░░████ ███▓░░░░░░██░▓█░░░░░░░░░░░█
█░░░░░░█░░░░░░░████████░░░▓████████░░░░███░░░░░░█▒░░░░░░░░░░░░█
▓░░░░░░██░░░░░░█░░░████████░░░░░░░░░░░░██░░░░░░▓▓░░░░██▒░░░░░█
▒▓░░░░░░░░█░░░░░██░░███████░██░░░░░█░░░░░░░░░░███████████░░░░█
█░░░░░░░▓░░█░░░░░░███████████░░░░░█░░█████████████████░░░░░░█
█░░░░░░░░█░░░█░░░░░░░░░░░░░░░░░░░░░░░░░░██████████▒░░░░░░░░█
█░░░░░░░░░█░░░▓░█░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░█
█▓░░░░░░░░░█░░░░░░██░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░█
█▒░░░░░░░░░░█░░░░░░░░███░█░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░██
█░░░░░░░░░░░█░░░░░░░░░░░░████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░██
█░░░░░░░░░░░░░░░░░░░░░░░░░░██░██░░░░░░░░░░░░░░░░░░░░░░░░░░▓█
█░░░░░░░░░░░░░░░░░░░░░░░░░░░░██░░███░░░░░░░░░░░░░░░░░░░░░█
██░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░██░░░░███▒▒░░░░░░░░░░░░░▒█
█░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░██▓░░░░░░░░░░░░░░░██
█░░░░░░░░░░░███░░░░░░░░░░░░░░░░░░░░░░░░░░▒████████████
██░░░░░░░░░░░█░░░░░░░░░░░░░░░░░░░░░░░░░░░█░░░░░░░░░█
██░░░░░░░░░░░░█░░░░░░░░░░░░░░░░░░░░░░░░░░░░░▒░░░░░░░░██
███░░░░░░░░░░██░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░██░░░░░░░░██████████████
████▓░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░█████
██░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░▒███░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░█░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
██████ ██████ █████ ██ ███ ██ ██ ███████ ████████
██ ██ ██ ██ ██ ██ ██ ████ ██ ██ ██ ██
██████ ██████ ███████ ██ ██ ██ ██ ██ █████ ██
██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██
██████ ██ ██ ██ ██ ██ ██ ████ ███████ ███████ ██
Brainlet is an internet slang term primarily used as a pejorative on 4chan when referring
to those with limited intelligence, implying they have no brain. Brainlet starting
with contract 0x0000B.. which means that ZERO brain is in the contract.
WEB: https://brainlet.meme
X: https://x.com/brainlet_eth
TG: https://t.me/brainlet_eth
*/
pragma solidity ^0.8.23;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
}
library Address {
function isContract(address account) internal view returns (bool) {
return account.code.length > 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
functionCallWithValue(
target,
data,
0,
"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);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but also transferring `value` wei to `target`.
*
* Requirements:
*
* - the calling contract must have an ETH balance of at least `value`.
* - the called Solidity function must be `payable`.
*
* _Available since v3.1._
*/
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"
);
}
/**
* @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
* with `errorMessage` as a fallback revert reason when `target` reverts.
*
* _Available since v3.1._
*/
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"
);
(bool success, bytes memory returndata) = target.call{value: value}(
data
);
return
verifyCallResultFromTarget(
target,
success,
returndata,
errorMessage
);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but performing a static call.
*
* _Available since v3.3._
*/
function functionStaticCall(
address target,
bytes memory data
) internal view returns (bytes memory) {
return
functionStaticCall(
target,
data,
"Address: low-level static call failed"
);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
* but performing a static call.
*
* _Available since v3.3._
*/
function functionStaticCall(
address target,
bytes memory data,
string memory errorMessage
) internal view returns (bytes memory) {
(bool success, bytes memory returndata) = target.staticcall(data);
return
verifyCallResultFromTarget(
target,
success,
returndata,
errorMessage
);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
* but performing a delegate call.
*
* _Available since v3.4._
*/
function functionDelegateCall(
address target,
bytes memory data
) internal returns (bytes memory) {
return
functionDelegateCall(
target,
data,
"Address: low-level delegate call failed"
);
}
/**
* @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
* but performing a delegate call.
*
* _Available since v3.4._
*/
function functionDelegateCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
(bool success, bytes memory returndata) = target.delegatecall(data);
return
verifyCallResultFromTarget(
target,
success,
returndata,
errorMessage
);
}
/**
* @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
* the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
*
* _Available since v4.8._
*/
function verifyCallResultFromTarget(
address target,
bool success,
bytes memory returndata,
string memory errorMessage
) internal view returns (bytes memory) {
if (success) {
if (returndata.length == 0) {
// only check isContract if the call was successful and the return data is empty
// otherwise we already know that it was a contract
require(isContract(target), "Address: call to non-contract");
}
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
/**
* @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
* revert reason or using the provided one.
*
* _Available since v4.3._
*/
function verifyCallResult(
bool success,
bytes memory returndata,
string memory errorMessage
) internal pure returns (bytes memory) {
if (success) {
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
function _revert(
bytes memory returndata,
string memory errorMessage
) private pure {
// Look for revert reason and bubble it up if present
if (returndata.length > 0) {
// The easiest way to bubble the revert reason is using memory via assembly
/// @solidity memory-safe-assembly
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
library SafeERC20 {
using Address for address;
function safeTransfer(IERC20 token, address to, uint256 value) internal {
_callOptionalReturn(
token,
abi.encodeWithSelector(token.transfer.selector, to, value)
);
}
function safeTransferFrom(
IERC20 token,
address from,
address to,
uint256 value
) internal {
_callOptionalReturn(
token,
abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
);
}
function _callOptionalReturn(IERC20 token, bytes memory data) private {
bytes memory returndata = address(token).functionCall(
data,
"SafeERC20: low-level call failed"
);
if (returndata.length > 0) {
require(
abi.decode(returndata, (bool)),
"SafeERC20: ERC20 operation did not succeed"
);
}
}
function safeApprove(
IERC20 token,
address spender,
uint256 value
) internal {
// safeApprove should only be called when setting an initial allowance,
// or when resetting it to zero. To increase and decrease it, use
// 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
require(
(value == 0) || (token.allowance(address(this), spender) == 0),
"SafeERC20: approve from non-zero to non-zero allowance"
);
_callOptionalReturn(
token,
abi.encodeWithSelector(token.approve.selector, spender, value)
);
}
}
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
);
}
contract Ownable is Context {
address private _owner;
address private _previousOwner;
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;
}
}
library SafeMath {
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
return sub(a, b, "SafeMath: subtraction overflow");
}
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b <= a, errorMessage);
uint256 c = a - b;
return c;
}
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b, "SafeMath: multiplication overflow");
return c;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
return div(a, b, "SafeMath: division by zero");
}
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
uint256 c = a / b;
return c;
}
}
interface IUniswapV2Factory {
function createPair(
address tokenA,
address tokenB
) external returns (address pair);
}
interface IUniswapV2Router02 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidityETH(
address token,
uint256 amountTokenDesired,
uint256 amountTokenMin,
uint256 amountETHMin,
address to,
uint256 deadline
)
external
payable
returns (uint256 amountToken, uint256 amountETH, uint256 liquidity);
}
contract BRAINLET is Context, IERC20, Ownable {
using SafeMath for uint256;
string private constant _name = "Brainlet";
string private constant _symbol = "BRAINLET";
uint8 private constant _decimals = 18;
mapping(address => uint256) private _rOwned;
mapping(address => uint256) private _tOwned;
mapping(address => mapping(address => uint256)) private _allowances;
mapping(address => bool) private _removeFee;
uint256 private constant MAX = ~uint256(0);
uint256 private constant _tTotal = 420_000_000 * 10 ** 18;
uint256 private _rTotal = (MAX - (MAX % _tTotal));
uint256 private _tFeeTotal;
uint256 private _redisFeeOnBuy = 0;
uint256 private _taxFeeOnBuy = 13;
uint256 private _redisFeeOnSell = 0;
uint256 private _taxFeeOnSell = 20;
//Original Fee
uint256 private _redisFee = _redisFeeOnSell;
uint256 private _taxFee = _taxFeeOnSell;
uint256 private _previousredisFee = _redisFee;
uint256 private _previoustaxFee = _taxFee;
address payable private _developmentAddress =
payable(0xaa2Ba6Da5aC75F07236Eff15Dee83FCB61d11894);
address payable private _marketingAddress =
payable(0xaa2Ba6Da5aC75F07236Eff15Dee83FCB61d11894);
IUniswapV2Router02 public uniswapV2Router;
address public uniswapV2Pair;
bool private tradingOpen;
bool private inSwap = false;
bool private swapEnabled = true;
uint256 public _maxTxAmount = 5_880_000 * 10 ** 18;
uint256 public _maxWalletSize = 5_880_000 * 10 ** 18;
uint256 public _swapTokensAtAmount = 1_260_000 * 10 ** 18;
event MaxTxAmountUpdated(uint256 _maxTxAmount);
modifier lockTheSwap() {
inSwap = true;
_;
inSwap = false;
}
constructor() {
_rOwned[_msgSender()] = _rTotal;
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(
0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
);
uniswapV2Router = _uniswapV2Router;
uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
.createPair(address(this), _uniswapV2Router.WETH());
_removeFee[owner()] = true;
_removeFee[address(this)] = true;
_removeFee[_developmentAddress] = true;
_removeFee[_marketingAddress] = true;
emit Transfer(address(0), _msgSender(), _tTotal);
}
function name() public pure returns (string memory) {
return _name;
}
function symbol() public pure returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public pure override returns (uint256) {
return _tTotal;
}
function balanceOf(address account) public view override returns (uint256) {
return tokenFromReflection(_rOwned[account]);
}
function transfer(
address recipient,
uint256 amount
) public override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(
address owner,
address spender
) public view override returns (uint256) {
return _allowances[owner][spender];
}
function approve(
address spender,
uint256 amount
) public override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public override returns (bool) {
_transfer(sender, recipient, amount);
_approve(
sender,
_msgSender(),
_allowances[sender][_msgSender()].sub(
amount,
"ERC20: transfer amount exceeds allowance"
)
);
return true;
}
function tokenFromReflection(
uint256 rAmount
) private view returns (uint256) {
require(
rAmount <= _rTotal,
"Amount must be less than total reflections"
);
uint256 currentRate = _getRate();
return rAmount.div(currentRate);
}
function destroyFee() private {
if (_redisFee == 0 && _taxFee == 0) return;
_previousredisFee = _redisFee;
_previoustaxFee = _taxFee;
_redisFee = 0;
_taxFee = 0;
}
function revertFee() private {
_redisFee = _previousredisFee;
_taxFee = _previoustaxFee;
}
function _approve(address owner, address spender, uint256 amount) private {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _transfer(address from, address to, uint256 amount) private {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
require(amount > 0, "Transfer amount must be greater than zero");
if (from != owner() && to != owner()) {
//Trade start check
if (!tradingOpen) {
require(
from == owner(),
"TOKEN: This account cannot send tokens until trading is enabled"
);
}
require(amount <= _maxTxAmount, "TOKEN: Max Transaction Limit");
if (to != uniswapV2Pair) {
require(
balanceOf(to) + amount < _maxWalletSize,
"TOKEN: Balance exceeds wallet size!"
);
}
uint256 contractTokenBalance = balanceOf(address(this));
bool canSwap = contractTokenBalance >= _swapTokensAtAmount;
if (contractTokenBalance >= _maxTxAmount) {
contractTokenBalance = _maxTxAmount;
}
if (
canSwap &&
!inSwap &&
from != uniswapV2Pair &&
swapEnabled &&
!_removeFee[from] &&
!_removeFee[to]
) {
swapTokensForEth(contractTokenBalance);
uint256 contractETHBalance = address(this).balance;
if (contractETHBalance > 0) {
sendETHToFee(address(this).balance);
}
}
}
bool takeFee = true;
//Transfer Tokens
if (
(_removeFee[from] || _removeFee[to]) ||
(from != uniswapV2Pair && to != uniswapV2Pair)
) {
takeFee = false;
} else {
//Set Fee for Buys
if (from == uniswapV2Pair && to != address(uniswapV2Router)) {
_redisFee = _redisFeeOnBuy;
_taxFee = _taxFeeOnBuy;
}
//Set Fee for Sells
if (to == uniswapV2Pair && from != address(uniswapV2Router)) {
_redisFee = _redisFeeOnSell;
_taxFee = _taxFeeOnSell;
}
}
_tokenTransfer(from, to, amount, takeFee);
}
function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
}
function sendETHToFee(uint256 amount) private {
_marketingAddress.transfer(amount);
}
function openTrading() public onlyOwner {
require(!tradingOpen, "Cannot reenable trading");
tradingOpen = true;
}
function manualSwap() external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
uint256 contractBalance = balanceOf(address(this));
swapTokensForEth(contractBalance);
}
function manualSendFee() external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
uint256 contractETHBalance = address(this).balance;
sendETHToFee(contractETHBalance);
}
function _tokenTransfer(
address sender,
address recipient,
uint256 amount,
bool takeFee
) private {
if (!takeFee) destroyFee();
_transferStandard(sender, recipient, amount);
if (!takeFee) revertFee();
}
function _transferStandard(
address sender,
address recipient,
uint256 tAmount
) private {
(
uint256 rAmount,
uint256 rTransferAmount,
uint256 rFee,
uint256 tTransferAmount,
uint256 tFee,
uint256 tTeam
) = _getValues(tAmount);
_rOwned[sender] = _rOwned[sender].sub(rAmount);
_rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);
_takeTeam(tTeam);
_reflectFee(rFee, tFee);
emit Transfer(sender, recipient, tTransferAmount);
}
function _takeTeam(uint256 tTeam) private {
uint256 currentRate = _getRate();
uint256 rTeam = tTeam.mul(currentRate);
_rOwned[address(this)] = _rOwned[address(this)].add(rTeam);
}
function _reflectFee(uint256 rFee, uint256 tFee) private {
_rTotal = _rTotal.sub(rFee);
_tFeeTotal = _tFeeTotal.add(tFee);
}
receive() external payable {}
function _getValues(
uint256 tAmount
)
private
view
returns (uint256, uint256, uint256, uint256, uint256, uint256)
{
(uint256 tTransferAmount, uint256 tFee, uint256 tTeam) = _getTValues(
tAmount,
_redisFee,
_taxFee
);
uint256 currentRate = _getRate();
(uint256 rAmount, uint256 rTransferAmount, uint256 rFee) = _getRValues(
tAmount,
tFee,
tTeam,
currentRate
);
return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tTeam);
}
function _getTValues(
uint256 tAmount,
uint256 redisFee,
uint256 taxFee
) private pure returns (uint256, uint256, uint256) {
uint256 tFee = tAmount.mul(redisFee).div(100);
uint256 tTeam = tAmount.mul(taxFee).div(100);
uint256 tTransferAmount = tAmount.sub(tFee).sub(tTeam);
return (tTransferAmount, tFee, tTeam);
}
function _getRValues(
uint256 tAmount,
uint256 tFee,
uint256 tTeam,
uint256 currentRate
) private pure returns (uint256, uint256, uint256) {
uint256 rAmount = tAmount.mul(currentRate);
uint256 rFee = tFee.mul(currentRate);
uint256 rTeam = tTeam.mul(currentRate);
uint256 rTransferAmount = rAmount.sub(rFee).sub(rTeam);
return (rAmount, rTransferAmount, rFee);
}
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;
if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal);
return (rSupply, tSupply);
}
function setFee(
uint256 taxFeeOnBuy,
uint256 taxFeeOnSell
) public onlyOwner {
require(
taxFeeOnBuy >= 0 && taxFeeOnBuy <= 30,
"Buy tax must be between 0% and 30%"
);
require(
taxFeeOnSell >= 0 && taxFeeOnSell <= 30,
"Sell tax must be between 0% and 30%"
);
_taxFeeOnBuy = taxFeeOnBuy;
_taxFeeOnSell = taxFeeOnSell;
}
//Set minimum tokens required to swap.
function setMinSwapTokensThreshold(
uint256 swapTokensAtAmount
) public onlyOwner {
_swapTokensAtAmount = swapTokensAtAmount;
}
function removeLimits() external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
_maxTxAmount = _tTotal;
_maxWalletSize = _tTotal;
}
function rescueTokens(address _token, address _to) external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
require(_token != address(0), "_token address cannot be 0");
uint256 _contractBalance = IERC20(_token).balanceOf(address(this));
SafeERC20.safeTransfer(IERC20(_token), _to, _contractBalance);
}
}
Read Contract
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_swapTokensAtAmount 0x2fd689e3 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSendFee 0xe7d656bd
No parameters
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
rescueTokens 0x5431c94e
address _token
address _to
setFee 0x52f7c988
uint256 taxFeeOnBuy
uint256 taxFeeOnSell
setMinSwapTokensThreshold 0x98a5c315
uint256 swapTokensAtAmount
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