Reentrancy in CESAPROTOCOL._transfer(address,address,uint256) (#500-551):
External calls:
- swapAndLiquify(contractTokenBalance) (#532)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#532)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
State variables written after the call(s):
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- _tOwned[sender] = _tOwned[sender] - tAmount (#634)
- _tOwned[recipient] = _tOwned[recipient] + tAmount (#635)
- _tOwned[sender] = _tOwned[sender] - tAmount (#646)
- _tOwned[recipient] = _tOwned[recipient] + tTransferAmount (#647)
- _tOwned[address(this)] = _tOwned[address(this)] + buyFEE (#648)
- _tOwned[sender] = _tOwned[sender] - tAmount (#659)
- _tOwned[recipient] = _tOwned[recipient] + tTransferAmount_scope_0 (#660)
- _tOwned[address(this)] = _tOwned[address(this)] + sellFEE (#661)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- _tTotal = _tTotal - tAmount (#639)
- _tTotal = _tTotal - tTransferAmount (#652)
- _tTotal = _tTotal - tTransferAmount_scope_0 (#665)
- txCount ++ (#545)
Apply the check-effects-interactions pattern.
Additional information: link
Unable to find manual contract audit (e.g. Certik, PeckShield, Solidity...)
Contract ownership is not renounced (belongs to a wallet)
CESAPROTOCOL.swapAndLiquify(uint256) (#559-589) performs a multiplication on the result of a division:
-split_M = Percent_Marketing * 100 / (Percent_AutoLP + Percent_Marketing + Percent_Dev) (#574)
-BNB_M = BNB_Total * split_M / 100 (#575)
CESAPROTOCOL.swapAndLiquify(uint256) (#559-589) performs a multiplication on the result of a division:
-split_D = Percent_Dev * 100 / (Percent_AutoLP + Percent_Marketing + Percent_Dev) (#577)
-BNB_D = BNB_Total * split_D / 100 (#578)
Consider ordering multiplication before division.
Additional information: link
CESAPROTOCOL._transfer(address,address,uint256).isBuy (#536) is a local variable never initialized
Initialize all the variables. If a variable is meant to be initialized to zero, explicitly set it to zero to improve code readability.
Additional information: link
CESAPROTOCOL.addLiquidity(uint256,uint256) (#607-618) ignores return value by uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
Ensure that all the return values of the function calls are used.
Additional information: link
Reentrancy in CESAPROTOCOL.constructor() (#411-432):
External calls:
- uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#421-422)
State variables written after the call(s):
- _isExcludedFromFee[owner()] = true (#425)
- _isExcludedFromFee[address(this)] = true (#426)
- _isExcludedFromFee[Wallet_Marketing] = true (#427)
- _isExcludedFromFee[Wallet_Burn] = true (#428)
- uniswapV2Router = _uniswapV2Router (#423)
Reentrancy in CESAPROTOCOL.swapAndLiquify(uint256) (#559-589):
External calls:
- swapTokensForBNB(tokens_to_LP_Half + tokens_to_M + tokens_to_D) (#571)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
External calls sending eth:
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
State variables written after the call(s):
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- _allowances[theOwner][theSpender] = amount (#495)
Reentrancy in CESAPROTOCOL.transferFrom(address,address,uint256) (#468-472):
External calls:
- _transfer(sender,recipient,amount) (#469)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
External calls sending eth:
- _transfer(sender,recipient,amount) (#469)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
State variables written after the call(s):
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,ERC20: transfer amount exceeds allowance)) (#470)
- _allowances[theOwner][theSpender] = amount (#495)
Apply the check-effects-interactions pattern.
Additional information: link
Reentrancy in CESAPROTOCOL._transfer(address,address,uint256) (#500-551):
External calls:
- swapAndLiquify(contractTokenBalance) (#532)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#532)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
Event emitted after the call(s):
- Transfer(sender,recipient,tAmount) (#636)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- Transfer(sender,recipient,tTransferAmount) (#649)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- Transfer(sender,recipient,tTransferAmount_scope_0) (#662)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
Reentrancy in CESAPROTOCOL.constructor() (#411-432):
External calls:
- uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#421-422)
Event emitted after the call(s):
- Transfer(address(0),owner(),_tTotal) (#430)
Reentrancy in CESAPROTOCOL.swapAndLiquify(uint256) (#559-589):
External calls:
- swapTokensForBNB(tokens_to_LP_Half + tokens_to_M + tokens_to_D) (#571)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
External calls sending eth:
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
Event emitted after the call(s):
- Approval(theOwner,theSpender,amount) (#496)
- addLiquidity(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D)) (#581)
- SwapAndLiquify(tokens_to_LP_Half,(BNB_Total - BNB_M - BNB_D),tokens_to_LP_Half) (#582)
Reentrancy in CESAPROTOCOL.transferFrom(address,address,uint256) (#468-472):
External calls:
- _transfer(sender,recipient,amount) (#469)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#597-603)
External calls sending eth:
- _transfer(sender,recipient,amount) (#469)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
Event emitted after the call(s):
- Approval(theOwner,theSpender,amount) (#496)
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,ERC20: transfer amount exceeds allowance)) (#470)
Apply the check-effects-interactions pattern.
Additional information: link
Address.isContract(address) (#78-82) uses assembly
- INLINE ASM (#80)
Address._verifyCallResult(bool,bytes,string) (#130-143) uses assembly
- INLINE ASM (#135-138)
Do not use evm assembly.
Additional information: link
Address._verifyCallResult(bool,bytes,string) (#130-143) is never used and should be removed
Address.functionCall(address,bytes) (#90-92) is never used and should be removed
Address.functionCall(address,bytes,string) (#94-96) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256) (#98-100) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256,string) (#102-107) is never used and should be removed
Address.functionDelegateCall(address,bytes) (#120-122) is never used and should be removed
Address.functionDelegateCall(address,bytes,string) (#124-128) is never used and should be removed
Address.functionStaticCall(address,bytes) (#109-111) is never used and should be removed
Address.functionStaticCall(address,bytes,string) (#113-117) is never used and should be removed
Address.isContract(address) (#78-82) is never used and should be removed
Address.sendValue(address,uint256) (#84-88) is never used and should be removed
CESAPROTOCOL._getCurrentSupply() (#486-488) is never used and should be removed
Context._msgData() (#69-72) is never used and should be removed
SafeMath.div(uint256,uint256) (#43-45) is never used and should be removed
SafeMath.div(uint256,uint256,string) (#54-59) is never used and should be removed
SafeMath.mul(uint256,uint256) (#39-41) is never used and should be removed
SafeMath.sub(uint256,uint256) (#35-37) is never used and should be removed
Remove unused functions.
Additional information: link
CESAPROTOCOL._maxWalletToken (#385) is set pre-construction with a non-constant function or state variable:
- _tTotal * 100 / 100
CESAPROTOCOL._previousMaxWalletToken (#386) is set pre-construction with a non-constant function or state variable:
- _maxWalletToken
CESAPROTOCOL._maxTxAmount (#388) is set pre-construction with a non-constant function or state variable:
- _tTotal * 100 / 100
CESAPROTOCOL._previousMaxTxAmount (#389) is set pre-construction with a non-constant function or state variable:
- _maxTxAmount
Remove any initialization of state variables via non-constant state variables or function calls. If variables must be set upon contract deployment, locate initialization in the constructor instead.
Additional information: link
Pragma version0.8.10 (#14) necessitates a version too recent to be trusted. Consider deploying with 0.6.12/0.7.6/0.8.7
solc-0.8.10 is not recommended for deployment
Deploy with any of the following Solidity versions: 0.5.16 - 0.5.17, 0.6.11 - 0.6.12, 0.7.5 - 0.7.6 Use a simple pragma version that allows any of these versions. Consider using the latest version of Solidity for testing.
Additional information: link
Low level call in Address.sendValue(address,uint256) (#84-88):
- (success) = recipient.call{value: amount}() (#86)
Low level call in Address.functionCallWithValue(address,bytes,uint256,string) (#102-107):
- (success,returndata) = target.call{value: value}(data) (#105)
Low level call in Address.functionStaticCall(address,bytes,string) (#113-117):
- (success,returndata) = target.staticcall(data) (#115)
Low level call in Address.functionDelegateCall(address,bytes,string) (#124-128):
- (success,returndata) = target.delegatecall(data) (#126)
Avoid low-level calls. Check the call success. If the call is meant for a contract, check for code existence
Additional information: link
Function IUniswapV2Pair.DOMAIN_SEPARATOR() (#172) is not in mixedCase
Function IUniswapV2Pair.PERMIT_TYPEHASH() (#173) is not in mixedCase
Function IUniswapV2Pair.MINIMUM_LIQUIDITY() (#186) is not in mixedCase
Function IUniswapV2Router01.WETH() (#203) is not in mixedCase
Parameter CESAPROTOCOL.addLiquidity(uint256,uint256).BNBAmount (#607) is not in mixedCase
Function CESAPROTOCOL.remove_Random_Tokens(address,uint256) (#620-626) is not in mixedCase
Parameter CESAPROTOCOL.remove_Random_Tokens(address,uint256).random_Token_Address (#620) is not in mixedCase
Parameter CESAPROTOCOL.remove_Random_Tokens(address,uint256).percent_of_Tokens (#620) is not in mixedCase
Variable CESAPROTOCOL._isExcludedFromFee (#361) is not in mixedCase
Variable CESAPROTOCOL.Wallet_Marketing (#363) is not in mixedCase
Variable CESAPROTOCOL.Wallet_Dev (#364) is not in mixedCase
Constant CESAPROTOCOL.Wallet_Burn (#365) is not in UPPER_CASE_WITH_UNDERSCORES
Constant CESAPROTOCOL._decimals (#369) is not in UPPER_CASE_WITH_UNDERSCORES
Constant CESAPROTOCOL._name (#371) is not in UPPER_CASE_WITH_UNDERSCORES
Constant CESAPROTOCOL._symbol (#372) is not in UPPER_CASE_WITH_UNDERSCORES
Variable CESAPROTOCOL._Tax_On_Buy (#377) is not in mixedCase
Variable CESAPROTOCOL._Tax_On_Sell (#378) is not in mixedCase
Variable CESAPROTOCOL.Percent_Marketing (#380) is not in mixedCase
Variable CESAPROTOCOL.Percent_Dev (#381) is not in mixedCase
Variable CESAPROTOCOL.Percent_Burn (#382) is not in mixedCase
Variable CESAPROTOCOL.Percent_AutoLP (#383) is not in mixedCase
Variable CESAPROTOCOL._maxWalletToken (#385) is not in mixedCase
Variable CESAPROTOCOL._maxTxAmount (#388) is not in mixedCase
Follow the Solidity naming convention.
Additional information: link
Redundant expression "this (#70)" inContext (#64-73)
Remove redundant statements if they congest code but offer no value.
Additional information: link
Reentrancy in CESAPROTOCOL._transfer(address,address,uint256) (#500-551):
External calls:
- swapAndLiquify(contractTokenBalance) (#532)
- wallet.transfer(amount) (#554)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#532)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
State variables written after the call(s):
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- _tOwned[sender] = _tOwned[sender] - tAmount (#634)
- _tOwned[recipient] = _tOwned[recipient] + tAmount (#635)
- _tOwned[sender] = _tOwned[sender] - tAmount (#646)
- _tOwned[recipient] = _tOwned[recipient] + tTransferAmount (#647)
- _tOwned[address(this)] = _tOwned[address(this)] + buyFEE (#648)
- _tOwned[sender] = _tOwned[sender] - tAmount (#659)
- _tOwned[recipient] = _tOwned[recipient] + tTransferAmount_scope_0 (#660)
- _tOwned[address(this)] = _tOwned[address(this)] + sellFEE (#661)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- _tTotal = _tTotal - tAmount (#639)
- _tTotal = _tTotal - tTransferAmount (#652)
- _tTotal = _tTotal - tTransferAmount_scope_0 (#665)
- txCount ++ (#545)
Event emitted after the call(s):
- Transfer(sender,recipient,tAmount) (#636)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- Transfer(sender,recipient,tTransferAmount) (#649)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
- Transfer(sender,recipient,tTransferAmount_scope_0) (#662)
- _tokenTransfer(from,to,amount,takeFee,isBuy) (#549)
Reentrancy in CESAPROTOCOL.transferFrom(address,address,uint256) (#468-472):
External calls:
- _transfer(sender,recipient,amount) (#469)
- wallet.transfer(amount) (#554)
External calls sending eth:
- _transfer(sender,recipient,amount) (#469)
- wallet.transfer(amount) (#554)
- uniswapV2Router.addLiquidityETH{value: BNBAmount}(address(this),tokenAmount,0,0,Wallet_Burn,block.timestamp) (#610-617)
State variables written after the call(s):
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,ERC20: transfer amount exceeds allowance)) (#470)
- _allowances[theOwner][theSpender] = amount (#495)
Event emitted after the call(s):
- Approval(theOwner,theSpender,amount) (#496)
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,ERC20: transfer amount exceeds allowance)) (#470)
Apply the check-effects-interactions pattern.
Additional information: link
Variable IUniswapV2Router01.addLiquidity(address,address,uint256,uint256,uint256,uint256,address,uint256).amountADesired (#207) is too similar to IUniswapV2Router01.addLiquidity(address,address,uint256,uint256,uint256,uint256,address,uint256).amountBDesired (#208)
Variable CESAPROTOCOL.swapAndLiquify(uint256).tokens_to_D (#567) is too similar to CESAPROTOCOL.swapAndLiquify(uint256).tokens_to_M (#566)
Prevent variables from having similar names.
Additional information: link
CESAPROTOCOL.slitherConstructorConstantVariables() (#337-674) uses literals with too many digits:
- Wallet_Burn = address(0x000000000000000000000000000000000000dEaD) (#365)
Use: Ether suffix, Time suffix, or The scientific notation
Additional information: link
CESAPROTOCOL.MAX (#368) is never used in CESAPROTOCOL (#337-674)
CESAPROTOCOL._previousMaxWalletToken (#386) is never used in CESAPROTOCOL (#337-674)
CESAPROTOCOL._previousMaxTxAmount (#389) is never used in CESAPROTOCOL (#337-674)
Remove unused state variables.
Additional information: link
CESAPROTOCOL.Percent_AutoLP (#383) should be constant
CESAPROTOCOL.Percent_Burn (#382) should be constant
CESAPROTOCOL.Percent_Dev (#381) should be constant
CESAPROTOCOL.Percent_Marketing (#380) should be constant
CESAPROTOCOL.Wallet_Dev (#364) should be constant
CESAPROTOCOL.Wallet_Marketing (#363) should be constant
CESAPROTOCOL._Tax_On_Buy (#377) should be constant
CESAPROTOCOL._Tax_On_Sell (#378) should be constant
CESAPROTOCOL.swapAndLiquifyEnabled (#395) should be constant
CESAPROTOCOL.swapTrigger (#375) should be constant
Add the constant attributes to state variables that never change.
Additional information: link
renounceOwnership() should be declared external:
- CESAPROTOCOL.renounceOwnership() (#354-357)
name() should be declared external:
- CESAPROTOCOL.name() (#434-436)
symbol() should be declared external:
- CESAPROTOCOL.symbol() (#438-440)
decimals() should be declared external:
- CESAPROTOCOL.decimals() (#442-444)
totalSupply() should be declared external:
- CESAPROTOCOL.totalSupply() (#446-448)
transfer(address,uint256) should be declared external:
- CESAPROTOCOL.transfer(address,uint256) (#454-457)
allowance(address,address) should be declared external:
- CESAPROTOCOL.allowance(address,address) (#459-461)
approve(address,uint256) should be declared external:
- CESAPROTOCOL.approve(address,uint256) (#463-466)
transferFrom(address,address,uint256) should be declared external:
- CESAPROTOCOL.transferFrom(address,address,uint256) (#468-472)
increaseAllowance(address,uint256) should be declared external:
- CESAPROTOCOL.increaseAllowance(address,uint256) (#474-477)
decreaseAllowance(address,uint256) should be declared external:
- CESAPROTOCOL.decreaseAllowance(address,uint256) (#479-482)
remove_Random_Tokens(address,uint256) should be declared external:
- CESAPROTOCOL.remove_Random_Tokens(address,uint256) (#620-626)
Use the external attribute for functions never called from the contract.
Additional information: link
Unable to find website, listings and other project-related information
Young tokens have high risks of scam / price dump / death
Token has no active CoinGecko listing / rank
Token has no active CoinMarketCap listing / rank
Unable to find Telegram and Twitter accounts