0%
    Verified
  • Verified, Token, Router
  • DAO
  • Fungible Token
  • Router
  • ERC-20

The following smart contract is a token contract called AIGoneWild. It implements the ERC20 interface and includes features such as a maximum transaction limit, maximum wallet limit, and fees for liquidity, marketing, development, and burning. The contract also includes a swap and liquify function, as well as a swap back function to prevent price impact. The contract also has the ability to set parameters and structure for the token.

0x21c4118c57f142d9de711396b2d329fa0f57a033
Copied
Copied
AIGoneWild Source Code
/** https://twitter.com/aigonewildeth https://t.me/aigonewild http://aigonewild.org/ */ // SPDX-License-Identifier: MIT pragma solidity 0.8.16; library SafeMath { function add(uint256 a, uint256 b) internal pure returns (uint256) {return a + b;} function sub(uint256 a, uint256 b) internal pure returns (uint256) {return a - b;} function mul(uint256 a, uint256 b) internal pure returns (uint256) {return a * b;} function div(uint256 a, uint256 b) internal pure returns (uint256) {return a / b;} function mod(uint256 a, uint256 b) internal pure returns (uint256) {return a % b;} function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked {uint256 c = a + b; if(c < a) return(false, 0); return(true, c);}} function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked {if(b > a) return(false, 0); return(true, a - b);}} function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked {if (a == 0) return(true, 0); uint256 c = a * b; if(c / a != b) return(false, 0); return(true, c);}} function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked {if(b == 0) return(false, 0); return(true, a / b);}} function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked {if(b == 0) return(false, 0); return(true, a % b);}} function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { unchecked{require(b <= a, errorMessage); return a - b;}} function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { unchecked{require(b > 0, errorMessage); return a / b;}} function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { unchecked{require(b > 0, errorMessage); return a % b;}}} 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 Ownable { address internal owner; constructor(address _owner) {owner = _owner;} modifier onlyOwner() {require(isOwner(msg.sender), "!OWNER"); _;} function isOwner(address account) public view returns (bool) {return account == owner;} function transferOwnership(address payable adr) public onlyOwner {owner = adr; emit OwnershipTransferred(adr);} event OwnershipTransferred(address owner); } interface IFactory{ function createPair(address tokenA, address tokenB) external returns (address pair); function getPair(address tokenA, address tokenB) external view returns (address pair); } interface IRouter { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function removeLiquidityWithPermit( address tokenA, address tokenB, uint liquidity, uint amountAMin, uint amountBMin, address to, uint deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint amountA, uint amountB); 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; } contract AIGoneWild is IERC20, Ownable { using SafeMath for uint256; string private constant _name = 'AIGoneWild'; string private constant _symbol = 'AIGW'; uint8 private constant _decimals = 9; uint256 private _totalSupply = 69000000 * (10 ** _decimals); uint256 private _maxTxAmountPercent = 100; // 10000; uint256 private _maxTransferPercent = 100; uint256 private _maxWalletPercent = 100; mapping (address => uint256) _balances; mapping (address => mapping (address => uint256)) private _allowances; mapping (address => bool) public isFeeExempt; mapping (address => bool) private isBot; IRouter router; address public pair; bool private tradingAllowed = false; uint256 private liquidityFee = 0; uint256 private marketingFee = 300; uint256 private developmentFee = 100; uint256 private burnFee = 0; uint256 private totalFee = 1000; uint256 private sellFee = 4000; uint256 private transferFee = 4000; uint256 private denominator = 10000; bool private swapEnabled = true; uint256 private swapTimes; bool private swapping; uint256 private swapThreshold = ( _totalSupply * 200 ) / 100000; uint256 private _minTokenAmount = ( _totalSupply * 10 ) / 100000; modifier lockTheSwap {swapping = true; _; swapping = false;} address internal constant DEAD = 0x000000000000000000000000000000000000dEaD; address internal constant development_receiver = 0xE2cb3EBC27d5d148dE29Fc1E9d02dE57C401F6AF; address internal constant marketing_receiver = 0xB4424bc71f5dE6e5746b64C86FD2Ff804612fE21; address internal constant liquidity_receiver = 0xE2cb3EBC27d5d148dE29Fc1E9d02dE57C401F6AF; constructor() Ownable(msg.sender) { IRouter _router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); address _pair = IFactory(_router.factory()).createPair(address(this), _router.WETH()); router = _router; pair = _pair; isFeeExempt[address(this)] = true; isFeeExempt[liquidity_receiver] = true; isFeeExempt[marketing_receiver] = true; isFeeExempt[msg.sender] = true; _balances[msg.sender] = _totalSupply; emit Transfer(address(0), msg.sender, _totalSupply); } receive() external payable {} function name() public pure returns (string memory) {return _name;} function symbol() public pure returns (string memory) {return _symbol;} function decimals() public pure returns (uint8) {return _decimals;} function startTrading() external onlyOwner {tradingAllowed = true;} function getOwner() external view override returns (address) { return owner; } function balanceOf(address account) public view override returns (uint256) {return _balances[account];} function transfer(address recipient, uint256 amount) public override returns (bool) {_transfer(msg.sender, recipient, amount);return true;} function allowance(address owner, address spender) public view override returns (uint256) {return _allowances[owner][spender];} function isCont(address addr) internal view returns (bool) {uint size; assembly { size := extcodesize(addr) } return size > 0; } function setisBot(address _address, bool _enabled) external onlyOwner {isBot[_address] = _enabled;} function setisExempt(address _address, bool _enabled) external onlyOwner {isFeeExempt[_address] = _enabled;} function approve(address spender, uint256 amount) public override returns (bool) {_approve(msg.sender, spender, amount);return true;} function totalSupply() public view override returns (uint256) {return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(address(0)));} function _maxWalletToken() public view returns (uint256) {return totalSupply() * _maxWalletPercent / denominator;} function _maxTxAmount() public view returns (uint256) {return totalSupply() * _maxTxAmountPercent / denominator;} function _maxTransferAmount() public view returns (uint256) {return totalSupply() * _maxTransferPercent / denominator;} function preTxCheck(address sender, address recipient, uint256 amount) internal view { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); require(amount > uint256(0), "Transfer amount must be greater than zero"); require(amount <= balanceOf(sender),"You are trying to transfer more than your balance"); } function _transfer(address sender, address recipient, uint256 amount) private { preTxCheck(sender, recipient, amount); checkTradingAllowed(sender, recipient); checkMaxWallet(sender, recipient, amount); swapbackCounters(sender, recipient); checkTxLimit(sender, recipient, amount); swapBack(sender, recipient, amount); _balances[sender] = _balances[sender].sub(amount); uint256 amountReceived = shouldTakeFee(sender, recipient) ? takeFee(sender, recipient, amount) : amount; _balances[recipient] = _balances[recipient].add(amountReceived); emit Transfer(sender, recipient, amountReceived); } function setStructure(uint256 _liquidity, uint256 _marketing, uint256 _burn, uint256 _development, uint256 _total, uint256 _sell, uint256 _trans) external onlyOwner { liquidityFee = _liquidity; marketingFee = _marketing; burnFee = _burn; developmentFee = _development; totalFee = _total; sellFee = _sell; transferFee = _trans; require(totalFee <= denominator.div(5) &amp;&amp; sellFee <= denominator.div(5), "totalFee and sellFee cannot be more than 20%"); } function setParameters(uint256 _buy, uint256 _trans, uint256 _wallet) external onlyOwner { uint256 newTx = (totalSupply() * _buy) / 10000; uint256 newTransfer = (totalSupply() * _trans) / 10000; uint256 newWallet = (totalSupply() * _wallet) / 10000; _maxTxAmountPercent = _buy; _maxTransferPercent = _trans; _maxWalletPercent = _wallet; uint256 limit = totalSupply().mul(5).div(1000); require(newTx >= limit &amp;&amp; newTransfer >= limit &amp;&amp; newWallet >= limit, "Max TXs and Max Wallet cannot be less than .5%"); } function checkTradingAllowed(address sender, address recipient) internal view { if(!isFeeExempt[sender] &amp;&amp; !isFeeExempt[recipient]){require(tradingAllowed, "tradingAllowed");} } function checkMaxWallet(address sender, address recipient, uint256 amount) internal view { if(!isFeeExempt[sender] &amp;&amp; !isFeeExempt[recipient] &amp;&amp; recipient != address(pair) &amp;&amp; recipient != address(DEAD)){ require((_balances[recipient].add(amount)) <= _maxWalletToken(), "Exceeds maximum wallet amount.");} } function swapbackCounters(address sender, address recipient) internal { if(recipient == pair &amp;&amp; !isFeeExempt[sender]){swapTimes += uint256(1);} } function checkTxLimit(address sender, address recipient, uint256 amount) internal view { if(sender != pair){require(amount <= _maxTransferAmount() || isFeeExempt[sender] || isFeeExempt[recipient], "TX Limit Exceeded");} require(amount <= _maxTxAmount() || isFeeExempt[sender] || isFeeExempt[recipient], "TX Limit Exceeded"); } function swapAndLiquify(uint256 tokens) private lockTheSwap { uint256 _denominator = (liquidityFee.add(1).add(marketingFee).add(developmentFee)).mul(2); uint256 tokensToAddLiquidityWith = tokens.mul(liquidityFee).div(_denominator); uint256 toSwap = tokens.sub(tokensToAddLiquidityWith); uint256 initialBalance = address(this).balance; swapTokensForETH(toSwap); uint256 deltaBalance = address(this).balance.sub(initialBalance); uint256 unitBalance= deltaBalance.div(_denominator.sub(liquidityFee)); uint256 ETHToAddLiquidityWith = unitBalance.mul(liquidityFee); if(ETHToAddLiquidityWith > uint256(0)){addLiquidity(tokensToAddLiquidityWith, ETHToAddLiquidityWith); } uint256 marketingAmt = unitBalance.mul(2).mul(marketingFee); if(marketingAmt > 0){payable(marketing_receiver).transfer(marketingAmt);} uint256 remainingBalance = address(this).balance; if(remainingBalance > uint256(0)){payable(development_receiver).transfer(remainingBalance);} } function addLiquidity(uint256 tokenAmount, uint256 ETHAmount) private { _approve(address(this), address(router), tokenAmount); router.addLiquidityETH{value: ETHAmount}( address(this), tokenAmount, 0, 0, liquidity_receiver, block.timestamp); } function swapTokensForETH(uint256 tokenAmount) private { address[] memory path = new address[](2); path[0] = address(this); path[1] = router.WETH(); _approve(address(this), address(router), tokenAmount); router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, path, address(this), block.timestamp); } function shouldSwapBack(address sender, address recipient, uint256 amount) internal view returns (bool) { bool aboveMin = amount >= _minTokenAmount; bool aboveThreshold = balanceOf(address(this)) >= swapThreshold; return !swapping &amp;&amp; swapEnabled &amp;&amp; tradingAllowed &amp;&amp; aboveMin &amp;&amp; !isFeeExempt[sender] &amp;&amp; recipient == pair &amp;&amp; swapTimes >= uint256(2) &amp;&amp; aboveThreshold; } function swapBack(address sender, address recipient, uint256 amount) internal { if(shouldSwapBack(sender, recipient, amount)){swapAndLiquify(swapThreshold); swapTimes = uint256(0);} } function shouldTakeFee(address sender, address recipient) internal view returns (bool) { return !isFeeExempt[sender] &amp;&amp; !isFeeExempt[recipient]; } function getTotalFee(address sender, address recipient) internal view returns (uint256) { if(isBot[sender] || isBot[recipient]){return denominator.sub(uint256(100));} if(recipient == pair){return sellFee;} if(sender == pair){return totalFee;} return transferFee; } function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) { if(getTotalFee(sender, recipient) > 0){ uint256 feeAmount = amount.div(denominator).mul(getTotalFee(sender, recipient)); _balances[address(this)] = _balances[address(this)].add(feeAmount); emit Transfer(sender, address(this), feeAmount); if(burnFee > uint256(0)){_transfer(address(this), address(DEAD), amount.div(denominator).mul(burnFee));} return amount.sub(feeAmount);} return amount; } function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) { _transfer(sender, recipient, amount); _approve(sender, msg.sender, _allowances[sender][msg.sender].sub(amount, "ERC20: transfer amount exceeds allowance")); return true; } function _approve(address owner, address spender, uint256 amount) private { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } }
AIGoneWild ABI
Copied
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_maxTransferAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxWalletToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"getOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isFeeExempt","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_buy","type":"uint256"},{"internalType":"uint256","name":"_trans","type":"uint256"},{"internalType":"uint256","name":"_wallet","type":"uint256"}],"name":"setParameters","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_liquidity","type":"uint256"},{"internalType":"uint256","name":"_marketing","type":"uint256"},{"internalType":"uint256","name":"_burn","type":"uint256"},{"internalType":"uint256","name":"_development","type":"uint256"},{"internalType":"uint256","name":"_total","type":"uint256"},{"internalType":"uint256","name":"_sell","type":"uint256"},{"internalType":"uint256","name":"_trans","type":"uint256"}],"name":"setStructure","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setisBot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"setisExempt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"adr","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]
AIGoneWild Bytecode
Copied
6080604052620000126009600a62000458565b620000229063041cdb4062000470565b60018181556064600281905560038190556004819055600a805460ff60a01b191690556000600b81905561012c600c55600d91909155600e556103e8600f55610fa060108190556011556127106012556013805460ff19169091179055620186a090620000919060c862000470565b6200009d919062000492565b601655620186a0600154600a620000b5919062000470565b620000c1919062000492565b601755348015620000d157600080fd5b50600080546001600160a01b031916331781556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d9291839163c45a0155916004808201926020929091908290030181865afa15801562000139573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200015f9190620004b5565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001ad573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001d39190620004b5565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af115801562000221573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002479190620004b5565b600980546001600160a01b038581166001600160a01b031992831617909255600a805492841692909116919091179055306000908152600760209081526040808320805460ff1990811660019081179092557fbf37ef89ecf475c1c8c2269b65a2dfb25afb9f07727ecff5f8b37efcac90ddc180548216831790557f13b424a9f01212c32cf9d25280b0e25d062bd6536bb34d026fac0e3aa696bdb68054821683179055338086528386208054909216831790915590546005845282852081905591519182529394507fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050620004e0565b634e487b7160e01b600052601160045260246000fd5b600181815b808511156200039a5781600019048211156200037e576200037e62000343565b808516156200038c57918102915b93841c93908002906200035e565b509250929050565b600082620003b35750600162000452565b81620003c25750600062000452565b8160018114620003db5760028114620003e65762000406565b600191505062000452565b60ff841115620003fa57620003fa62000343565b50506001821b62000452565b5060208310610133831016604e8410600b84101617156200042b575081810a62000452565b62000437838362000359565b80600019048211156200044e576200044e62000343565b0290505b92915050565b60006200046960ff841683620003a2565b9392505050565b60008160001904831182151516156200048d576200048d62000343565b500290565b600082620004b057634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215620004c857600080fd5b81516001600160a01b03811681146200046957600080fd5b611ac780620004f06000396000f3fe6080604052600436106101395760003560e01c806348ff2b8b116100ab5780638c41180e1161006f5780638c41180e1461039657806395d89b41146103b6578063a8aa1b31146103e3578063a9059cbb14610403578063dd62ed3e14610423578063f2fde38b1461046957600080fd5b806348ff2b8b146102e457806370a082311461030457806378109e541461033a5780637d1db4a51461034f578063893d20e81461036457600080fd5b806323b872dd116100fd57806323b872dd14610214578063293230b8146102345780632f54bf6e14610249578063313ce5671461027857806334c5d2ce146102945780633f4218e0146102b457600080fd5b8063044019301461014557806306fdde0314610167578063095ea7b3146101ac57806318160ddd146101dc5780631f976b7e146101ff57600080fd5b3661014057005b600080fd5b34801561015157600080fd5b50610165610160366004611726565b610489565b005b34801561017357600080fd5b5060408051808201909152600a815269105251dbdb9955da5b1960b21b60208201525b6040516101a39190611772565b60405180910390f35b3480156101b857600080fd5b506101cc6101c73660046117d8565b610577565b60405190151581526020016101a3565b3480156101e857600080fd5b506101f161058e565b6040519081526020016101a3565b34801561020b57600080fd5b506101f16105ff565b34801561022057600080fd5b506101cc61022f366004611804565b610623565b34801561024057600080fd5b5061016561068d565b34801561025557600080fd5b506101cc610264366004611845565b6000546001600160a01b0391821691161490565b34801561028457600080fd5b50604051600981526020016101a3565b3480156102a057600080fd5b506101656102af366004611862565b6106cc565b3480156102c057600080fd5b506101cc6102cf366004611845565b60076020526000908152604090205460ff1681565b3480156102f057600080fd5b506101656102ff36600461188e565b610813565b34801561031057600080fd5b506101f161031f366004611845565b6001600160a01b031660009081526005602052604090205490565b34801561034657600080fd5b506101f1610868565b34801561035b57600080fd5b506101f1610878565b34801561037057600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101a3565b3480156103a257600080fd5b506101656103b136600461188e565b610888565b3480156103c257600080fd5b506040805180820190915260048152634149475760e01b6020820152610196565b3480156103ef57600080fd5b50600a5461037e906001600160a01b031681565b34801561040f57600080fd5b506101cc61041e3660046117d8565b6108dd565b34801561042f57600080fd5b506101f161043e3660046118cc565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b34801561047557600080fd5b50610165610484366004611845565b6108ea565b6000546001600160a01b031633146104bc5760405162461bcd60e51b81526004016104b3906118fa565b60405180910390fd5b600b879055600c869055600e859055600d849055600f839055601082905560118190556012546104ed906005610968565b600f541115801561050d5750601254610507906005610968565b60105411155b61056e5760405162461bcd60e51b815260206004820152602c60248201527f746f74616c46656520616e642073656c6c4665652063616e6e6f74206265206d60448201526b6f7265207468616e2032302560a01b60648201526084016104b3565b50505050505050565b6000610584338484610974565b5060015b92915050565b60056020527f05b8ccbb9d4d8fb16ea74ce3c29a41f1b461fbdaff4714a0d9a8eb05499746bc5461dead60009081527f7d509c07f0d4edcc2dd1b53aae68677132eb562dcba78e36381b63ccaf66e6ba5460015491926105fa9290916105f49190610a98565b90610a98565b905090565b600060125460035461060f61058e565b6106199190611930565b6105fa919061194f565b6000610630848484610aa4565b610682843361067d85604051806060016040528060288152602001611a6a602891396001600160a01b038a1660009081526006602090815260408083203384529091529020549190610bca565b610974565b5060015b9392505050565b6000546001600160a01b031633146106b75760405162461bcd60e51b81526004016104b3906118fa565b600a805460ff60a01b1916600160a01b179055565b6000546001600160a01b031633146106f65760405162461bcd60e51b81526004016104b3906118fa565b60006127108461070461058e565b61070e9190611930565b610718919061194f565b905060006127108461072861058e565b6107329190611930565b61073c919061194f565b905060006127108461074c61058e565b6107569190611930565b610760919061194f565b600287905560038690556004859055905060006107926103e861078c600561078661058e565b90610bf6565b90610968565b90508084101580156107a45750808310155b80156107b05750808210155b61056e5760405162461bcd60e51b815260206004820152602e60248201527f4d61782054587320616e64204d61782057616c6c65742063616e6e6f7420626560448201526d206c657373207468616e202e352560901b60648201526084016104b3565b6000546001600160a01b0316331461083d5760405162461bcd60e51b81526004016104b3906118fa565b6001600160a01b03919091166000908152600760205260409020805460ff1916911515919091179055565b600060125460045461060f61058e565b600060125460025461060f61058e565b6000546001600160a01b031633146108b25760405162461bcd60e51b81526004016104b3906118fa565b6001600160a01b03919091166000908152600860205260409020805460ff1916911515919091179055565b6000610584338484610aa4565b6000546001600160a01b031633146109145760405162461bcd60e51b81526004016104b3906118fa565b600080546001600160a01b0319166001600160a01b0383169081179091556040519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861639060200160405180910390a150565b6000610686828461194f565b6001600160a01b0383166109d65760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104b3565b6001600160a01b038216610a375760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104b3565b6001600160a01b0383811660008181526006602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006106868284611971565b610aaf838383610c02565b610ab98383610db1565b610ac4838383610e46565b610ace8383610f37565b610ad9838383610f8e565b610ae48383836110c5565b6001600160a01b038316600090815260056020526040902054610b079082610a98565b6001600160a01b038416600090815260056020526040812091909155610b2d84846110ea565b610b375781610b42565b610b42848484611130565b6001600160a01b038416600090815260056020526040902054909150610b68908261121e565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610bbc9085815260200190565b60405180910390a350505050565b60008184841115610bee5760405162461bcd60e51b81526004016104b39190611772565b505050900390565b60006106868284611930565b6001600160a01b038316610c665760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104b3565b6001600160a01b038216610cc85760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104b3565b60008111610d2a5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104b3565b6001600160a01b038316600090815260056020526040902054811115610dac5760405162461bcd60e51b815260206004820152603160248201527f596f752061726520747279696e6720746f207472616e73666572206d6f7265206044820152707468616e20796f75722062616c616e636560781b60648201526084016104b3565b505050565b6001600160a01b03821660009081526007602052604090205460ff16158015610df357506001600160a01b03811660009081526007602052604090205460ff16155b15610e4257600a54600160a01b900460ff16610e425760405162461bcd60e51b815260206004820152600e60248201526d1d1c98591a5b99d05b1b1bddd95960921b60448201526064016104b3565b5050565b6001600160a01b03831660009081526007602052604090205460ff16158015610e8857506001600160a01b03821660009081526007602052604090205460ff16155b8015610ea25750600a546001600160a01b03838116911614155b8015610eb957506001600160a01b03821661dead14155b15610dac57610ec6610868565b6001600160a01b038316600090815260056020526040902054610ee9908361121e565b1115610dac5760405162461bcd60e51b815260206004820152601e60248201527f45786365656473206d6178696d756d2077616c6c657420616d6f756e742e000060448201526064016104b3565b600a546001600160a01b038281169116148015610f6d57506001600160a01b03821660009081526007602052604090205460ff16155b15610e4257600160146000828254610f859190611984565b90915550505050565b600a546001600160a01b0384811691161461103457610fab6105ff565b81111580610fd157506001600160a01b03831660009081526007602052604090205460ff165b80610ff457506001600160a01b03821660009081526007602052604090205460ff165b6110345760405162461bcd60e51b8152602060048201526011602482015270151608131a5b5a5d08115e18d959591959607a1b60448201526064016104b3565b61103c610878565b8111158061106257506001600160a01b03831660009081526007602052604090205460ff165b8061108557506001600160a01b03821660009081526007602052604090205460ff165b610dac5760405162461bcd60e51b8152602060048201526011602482015270151608131a5b5a5d08115e18d959591959607a1b60448201526064016104b3565b6110d083838361122a565b15610dac576110e06016546112dc565b6000601455505050565b6001600160a01b03821660009081526007602052604081205460ff161580156106865750506001600160a01b031660009081526007602052604090205460ff1615919050565b60008061113d8585611467565b11156112175760006111606111528686611467565b601254610786908690610968565b3060009081526005602052604090205490915061117d908261121e565b30600081815260056020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111ce9085815260200190565b60405180910390a3600e5415611205576112053061dead611200600e546107866012548961096890919063ffffffff16565b610aa4565b61120f8382610a98565b915050610686565b5092915050565b60006106868284611984565b6017546016543060009081526005602052604081205460155491938510159211159060ff1615801561125e575060135460ff165b80156112735750600a54600160a01b900460ff165b801561127c5750815b80156112a157506001600160a01b03861660009081526007602052604090205460ff16155b80156112ba5750600a546001600160a01b038681169116145b80156112c95750600260145410155b80156112d25750805b9695505050505050565b6015805460ff19166001908117909155600d54600c54600b546000936113169360029361078693919261131092839161121e565b9061121e565b905060006113338261078c600b5486610bf690919063ffffffff16565b905060006113418483610a98565b90504761134d82611508565b60006113594783610a98565b9050600061137c611375600b5488610a9890919063ffffffff16565b8390610968565b90506000611395600b5483610bf690919063ffffffff16565b905080156113a7576113a78682611662565b600c546000906113bc90610786856002610bf6565b905080156114075760405173b4424bc71f5de6e5746b64c86fd2ff804612fe219082156108fc029083906000818181858888f19350505050158015611405573d6000803e3d6000fd5b505b4780156114515760405173e2cb3ebc27d5d148de29fc1e9d02de57c401f6af9082156108fc029083906000818181858888f1935050505015801561144f573d6000803e3d6000fd5b505b50506015805460ff191690555050505050505050565b6001600160a01b03821660009081526008602052604081205460ff16806114a657506001600160a01b03821660009081526008602052604090205460ff165b156114c0576012546114b9906064610a98565b9050610588565b600a546001600160a01b03908116908316036114df5750601054610588565b600a546001600160a01b03908116908416036114fe5750600f54610588565b5060115492915050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061153d5761153d611997565b6001600160a01b03928316602091820292909201810191909152600954604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611596573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115ba91906119ad565b816001815181106115cd576115cd611997565b6001600160a01b0392831660209182029290920101526009546115f39130911684610974565b60095460405163791ac94760e01b81526001600160a01b039091169063791ac9479061162c9085906000908690309042906004016119ca565b600060405180830381600087803b15801561164657600080fd5b505af115801561165a573d6000803e3d6000fd5b505050505050565b60095461167a9030906001600160a01b031684610974565b60095460405163f305d71960e01b815230600482015260248101849052600060448201819052606482015273e2cb3ebc27d5d148de29fc1e9d02de57c401f6af60848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af11580156116fa573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061171f9190611a3b565b5050505050565b600080600080600080600060e0888a03121561174157600080fd5b505085359760208701359750604087013596606081013596506080810135955060a0810135945060c0013592509050565b600060208083528351808285015260005b8181101561179f57858101830151858201604001528201611783565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146117d557600080fd5b50565b600080604083850312156117eb57600080fd5b82356117f6816117c0565b946020939093013593505050565b60008060006060848603121561181957600080fd5b8335611824816117c0565b92506020840135611834816117c0565b929592945050506040919091013590565b60006020828403121561185757600080fd5b8135610686816117c0565b60008060006060848603121561187757600080fd5b505081359360208301359350604090920135919050565b600080604083850312156118a157600080fd5b82356118ac816117c0565b9150602083013580151581146118c157600080fd5b809150509250929050565b600080604083850312156118df57600080fd5b82356118ea816117c0565b915060208301356118c1816117c0565b60208082526006908201526510a7aba722a960d11b604082015260600190565b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561194a5761194a61191a565b500290565b60008261196c57634e487b7160e01b600052601260045260246000fd5b500490565b818103818111156105885761058861191a565b808201808211156105885761058861191a565b634e487b7160e01b600052603260045260246000fd5b6000602082840312156119bf57600080fd5b8151610686816117c0565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611a1a5784516001600160a01b0316835293830193918301916001016119f5565b50506001600160a01b03969096166060850152505050608001529392505050565b600080600060608486031215611a5057600080fd5b835192506020840151915060408401519050925092509256fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212202ee8731f34e4bc64bc4beb6bb49a7d5911af71ae6515aa336ead4d4e9168599e64736f6c63430008100033
Smart Contracts contract page background

Checkout more smart contracts

    Ethereum  logo

    LidoExecutionLayerRewardsVault

    Verified

    The following smart contract is called LidoExecutionLayerRewardsVault. It is used to manage rewards for the Lido protocol. The contract allows Lido to withdraw rewards, recover ERC20 and ERC721 tokens, and receive ETH. The contract uses the SafeERC20 library to ensure safe transfers of ERC20 tokens. The purpose of this contract is to provide a secure and efficient way to manage rewards for the Lido protocol.

    0x388c818ca8b9251b393131c08a736a67ccb19297
    Copied
    • Lido
    • Proposer Fee Recipient
    • Router
    Ethereum  logo

    SHILAINU

    Verified

    The following smart contract is the SHILAINU token contract, which is an ERC20 token with a total supply of 1 trillion. It includes features such as transaction limits, fees, and automatic liquidity provision. The contract also has a blacklist mode and the ability to set fee and transaction exemptions for specific addresses. The purpose of the contract is to provide a decentralized currency for the Shiba Inu community.

    0x20c3fa331a385b63ee39137e99d0cf2db142fce1
    Copied
    • Verified
    • Fungible Token
    • ERC20
    Ethereum  logo

    LooksRareAirdrop

    Verified

    The following smart contract is a LooksRareAirdrop contract that allows users to claim airdrop rewards in the form of ERC20 tokens. Users must provide a valid merkle proof and meet certain requirements, including having a signed maker order and approval for the collection. The contract is pausable and has a maximum amount that can be claimed. The owner can set the merkle root, update the end timestamp, and withdraw token rewards.

    0xa35dce3e0e6ceb67a30b8d7f4aee721c949b5970
    Copied
    • Verified, Token
    • LooksRare
    • Fungible Token
    • ERC-20
Section background image

Build blockchain magic

Alchemy combines the most powerful web3 developer products and tools with resources, community and legendary support.

Get your API key