Unable to find manual contract audit (e.g. Certik, PeckShield, Solidity...)
Reentrancy in GreenBioX._transfer(address,address,uint256) (#1026-1054):
External calls:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
State variables written after the call(s):
- _tokenTransfer(from,to,amount) (#1053)
- _rOwned[address(this)] = _rOwned[address(this)].add(rLiquidity) (#926)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1168)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1177)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1188)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1169)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#867)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1179)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1189)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#869)
- _tokenTransfer(from,to,amount) (#1053)
- _rTotal = _rTotal.sub(rFee) (#881)
- _tokenTransfer(from,to,amount) (#1053)
- _tOwned[address(this)] = _tOwned[address(this)].add(tLiquidity) (#928)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#866)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#1187)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#1178)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#868)
Apply the check-effects-interactions pattern.
Additional information: link
Reentrancy in GreenBioX.constructor() (#733-754):
External calls:
- uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#739-740)
State variables written after the call(s):
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _rTotal = _rTotal.sub(rFee) (#881)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _rTotal = _rTotal.sub(rFee) (#881)
Apply the check-effects-interactions pattern.
Additional information: link
GreenBioX.addLiquidity(uint256,uint256) (#1097-1110) ignores return value by uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
Ensure that all the return values of the function calls are used.
Additional information: link
GreenBioX.allowance(address,address).owner (#782) shadows:
- Ownable.owner() (#422-424) (function)
GreenBioX._approve(address,address,uint256).owner (#1018) shadows:
- Ownable.owner() (#422-424) (function)
Rename the local variables that shadow another component.
Additional information: link
GreenBioX.setTaxFeePercentage(uint256) (#964-967) should emit an event for:
- _taxFee = taxFee (#965)
- _previousTaxFee = _taxFee (#966)
GreenBioX.setMarketingFeePercentage(uint256) (#969-972) should emit an event for:
- _MarketingFee = MarketingFee (#970)
- _previousMarketingFee = _MarketingFee (#971)
GreenBioX.setNatureFeePercentage(uint256) (#973-976) should emit an event for:
- _NatureFee = NatureFee (#974)
- _previousNatureFee = _NatureFee (#975)
GreenBioX.setLiquidityFeePercentage(uint256) (#977-980) should emit an event for:
- _liquidityFee = liquidityFee (#978)
- _previousLiquidityFee = _liquidityFee (#979)
GreenBioX.setBurningPercentage(uint256) (#981-983) should emit an event for:
- BurningPercentage = _burnPercentage (#982)
GreenBioX.setMaxTxPercentage(uint256) (#1001-1005) should emit an event for:
- _maxTxAmount = _tTotal.mul(maxTxPercentage).div(10 ** 2) (#1002-1004)
GreenBioX.setMaxTxAmount(uint256) (#1006-1008) should emit an event for:
- _maxTxAmount = maxTxAmount (#1007)
Emit an event for critical parameter changes.
Additional information: link
GreenBioX.setMarketingWallet(address).newWallet (#992) lacks a zero-check on :
- MarketingWallet = newWallet (#993)
GreenBioX.setNatureWallet(address).newWallet (#996) lacks a zero-check on :
- NatureAddress = newWallet (#997)
Check that the address is not zero.
Additional information: link
Reentrancy in GreenBioX._transfer(address,address,uint256) (#1026-1054):
External calls:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
State variables written after the call(s):
- _tokenTransfer(from,to,amount) (#1053)
- _MarketingFee = _previousMarketingFee (#960)
- _MarketingFee = 0 (#953)
- _tokenTransfer(from,to,amount) (#1053)
- _NatureFee = _previousNatureFee (#962)
- _NatureFee = 0 (#955)
- _tokenTransfer(from,to,amount) (#1053)
- _liquidityFee = _previousLiquidityFee (#961)
- _liquidityFee = 0 (#954)
- _liquidityFee = 0 (#1147)
- _liquidityFee = _previousLiquidityFee (#1159)
- _tokenTransfer(from,to,amount) (#1053)
- _previousLiquidityFee = _liquidityFee (#948)
- _tokenTransfer(from,to,amount) (#1053)
- _previousMarketingFee = _MarketingFee (#947)
- _tokenTransfer(from,to,amount) (#1053)
- _previousNatureFee = _NatureFee (#949)
- _tokenTransfer(from,to,amount) (#1053)
- _previousTaxFee = _taxFee (#946)
- _tokenTransfer(from,to,amount) (#1053)
- _tFeeTotal = _tFeeTotal.add(tFee) (#882)
- _tokenTransfer(from,to,amount) (#1053)
- _taxFee = _previousTaxFee (#959)
- _taxFee = 0 (#952)
- _taxFee = 0 (#1146)
- _taxFee = _previousTaxFee (#1158)
Reentrancy in GreenBioX.constructor() (#733-754):
External calls:
- uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#739-740)
State variables written after the call(s):
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _MarketingFee = _previousMarketingFee (#960)
- _MarketingFee = 0 (#953)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _MarketingFee = _previousMarketingFee (#960)
- _MarketingFee = 0 (#953)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _NatureFee = _previousNatureFee (#962)
- _NatureFee = 0 (#955)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _NatureFee = _previousNatureFee (#962)
- _NatureFee = 0 (#955)
- _isExcludedFromFee[owner()] = true (#746)
- _isExcludedFromFee[address(this)] = true (#747)
- _isExcludedFromFee[NatureAddress] = true (#748)
- _isExcludedFromFee[MarketingWallet] = true (#749)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _liquidityFee = _previousLiquidityFee (#961)
- _liquidityFee = 0 (#954)
- _liquidityFee = 0 (#1147)
- _liquidityFee = _previousLiquidityFee (#1159)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _liquidityFee = _previousLiquidityFee (#961)
- _liquidityFee = 0 (#954)
- _liquidityFee = 0 (#1147)
- _liquidityFee = _previousLiquidityFee (#1159)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _previousLiquidityFee = _liquidityFee (#948)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _previousLiquidityFee = _liquidityFee (#948)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _previousMarketingFee = _MarketingFee (#947)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _previousMarketingFee = _MarketingFee (#947)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _previousNatureFee = _NatureFee (#949)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _previousNatureFee = _NatureFee (#949)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _previousTaxFee = _taxFee (#946)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _previousTaxFee = _taxFee (#946)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _rOwned[address(this)] = _rOwned[address(this)].add(rLiquidity) (#926)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1168)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1177)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1188)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1169)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#867)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1179)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1189)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#869)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _rOwned[address(this)] = _rOwned[address(this)].add(rLiquidity) (#926)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1168)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1177)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#1188)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1169)
- _rOwned[sender] = _rOwned[sender].sub(rAmount) (#867)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1179)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#1189)
- _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount) (#869)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _tFeeTotal = _tFeeTotal.add(tFee) (#882)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _tFeeTotal = _tFeeTotal.add(tFee) (#882)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _tOwned[address(this)] = _tOwned[address(this)].add(tLiquidity) (#928)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#866)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#1187)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#1178)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#868)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _tOwned[address(this)] = _tOwned[address(this)].add(tLiquidity) (#928)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#866)
- _tOwned[sender] = _tOwned[sender].sub(tAmount) (#1187)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#1178)
- _tOwned[recipient] = _tOwned[recipient].add(tTransferAmount) (#868)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- _taxFee = _previousTaxFee (#959)
- _taxFee = 0 (#952)
- _taxFee = 0 (#1146)
- _taxFee = _previousTaxFee (#1158)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- _taxFee = _previousTaxFee (#959)
- _taxFee = 0 (#952)
- _taxFee = 0 (#1146)
- _taxFee = _previousTaxFee (#1158)
- uniswapV2Router = _uniswapV2Router (#743)
Reentrancy in GreenBioX.swapAndLiquify(uint256) (#1056-1077):
External calls:
- swapTokensForEth(half) (#1068)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
- addLiquidity(otherHalf,newBalance) (#1074)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
External calls sending eth:
- addLiquidity(otherHalf,newBalance) (#1074)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
State variables written after the call(s):
- addLiquidity(otherHalf,newBalance) (#1074)
- _allowances[owner][spender] = amount (#1022)
Reentrancy in GreenBioX.transferFrom(address,address,uint256) (#791-795):
External calls:
- _transfer(sender,recipient,amount) (#792)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
External calls sending eth:
- _transfer(sender,recipient,amount) (#792)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
State variables written after the call(s):
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,BEP20: transfer amount exceeds allowance)) (#793)
- _allowances[owner][spender] = amount (#1022)
Apply the check-effects-interactions pattern.
Additional information: link
Reentrancy in GreenBioX._transfer(address,address,uint256) (#1026-1054):
External calls:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
External calls sending eth:
- swapAndLiquify(contractTokenBalance) (#1049)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
Event emitted after the call(s):
- Transfer(sender,recipient,tTransferAmount) (#1172)
- _tokenTransfer(from,to,amount) (#1053)
- Transfer(sender,recipient,tTransferAmount) (#1182)
- _tokenTransfer(from,to,amount) (#1053)
- Transfer(sender,recipient,tTransferAmount) (#1192)
- _tokenTransfer(from,to,amount) (#1053)
- Transfer(sender,recipient,tTransferAmount) (#872)
- _tokenTransfer(from,to,amount) (#1053)
Reentrancy in GreenBioX.constructor() (#733-754):
External calls:
- uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#739-740)
Event emitted after the call(s):
- Transfer(address(0),_msgSender(),_tTotal) (#751)
- Transfer(sender,recipient,tTransferAmount) (#1172)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- Transfer(sender,recipient,tTransferAmount) (#1172)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- Transfer(sender,recipient,tTransferAmount) (#1182)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- Transfer(sender,recipient,tTransferAmount) (#1192)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
- Transfer(sender,recipient,tTransferAmount) (#1192)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- Transfer(sender,recipient,tTransferAmount) (#1182)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- Transfer(sender,recipient,tTransferAmount) (#872)
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
- Transfer(sender,recipient,tTransferAmount) (#872)
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
Reentrancy in GreenBioX.swapAndLiquify(uint256) (#1056-1077):
External calls:
- swapTokensForEth(half) (#1068)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
- addLiquidity(otherHalf,newBalance) (#1074)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
External calls sending eth:
- addLiquidity(otherHalf,newBalance) (#1074)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
Event emitted after the call(s):
- Approval(owner,spender,amount) (#1023)
- addLiquidity(otherHalf,newBalance) (#1074)
- SwapAndLiquify(half,newBalance,otherHalf) (#1076)
Reentrancy in GreenBioX.transferFrom(address,address,uint256) (#791-795):
External calls:
- _transfer(sender,recipient,amount) (#792)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
- uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(tokenAmount,0,path,address(this),block.timestamp) (#1088-1094)
External calls sending eth:
- _transfer(sender,recipient,amount) (#792)
- uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this),tokenAmount,0,0,owner(),block.timestamp) (#1102-1109)
Event emitted after the call(s):
- Approval(owner,spender,amount) (#1023)
- _approve(sender,_msgSender(),_allowances[sender][_msgSender()].sub(amount,BEP20: transfer amount exceeds allowance)) (#793)
Apply the check-effects-interactions pattern.
Additional information: link
Address.isContract(address) (#274-283) uses assembly
- INLINE ASM (#281)
Address._functionCallWithValue(address,bytes,uint256,string) (#367-388) uses assembly
- INLINE ASM (#380-383)
Do not use evm assembly.
Additional information: link
GreenBioX.includeInReward(address) (#851-862) has costly operations inside a loop:
- _excluded.pop() (#858)
Use a local variable to hold the loop computation result.
Additional information: link
Address._functionCallWithValue(address,bytes,uint256,string) (#367-388) is never used and should be removed
Address.functionCall(address,bytes) (#327-329) is never used and should be removed
Address.functionCall(address,bytes,string) (#337-339) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256) (#352-354) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256,string) (#362-365) is never used and should be removed
Address.isContract(address) (#274-283) is never used and should be removed
Address.sendValue(address,uint256) (#301-307) is never used and should be removed
Context._msgData() (#247-250) is never used and should be removed
SafeMath.mod(uint256,uint256) (#220-222) is never used and should be removed
SafeMath.mod(uint256,uint256,string) (#236-239) is never used and should be removed
Remove unused functions.
Additional information: link
GreenBioX._rTotal (#685) is set pre-construction with a non-constant function or state variable:
- (MAX - (MAX % _tTotal))
GreenBioX._previousTaxFee (#696) is set pre-construction with a non-constant function or state variable:
- _taxFee
GreenBioX._previousLiquidityFee (#699) is set pre-construction with a non-constant function or state variable:
- _liquidityFee
GreenBioX._previousMarketingFee (#702) is set pre-construction with a non-constant function or state variable:
- _MarketingFee
GreenBioX._previousNatureFee (#705) is set pre-construction with a non-constant function or state variable:
- _NatureFee
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 version^0.8.0 (#12) allows old versions
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) (#301-307):
- (success) = recipient.call{value: amount}() (#305)
Low level call in Address._functionCallWithValue(address,bytes,uint256,string) (#367-388):
- (success,returndata) = target.call{value: weiValue}(data) (#371)
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() (#494) is not in mixedCase
Function IUniswapV2Pair.PERMIT_TYPEHASH() (#495) is not in mixedCase
Function IUniswapV2Pair.MINIMUM_LIQUIDITY() (#512) is not in mixedCase
Function IUniswapV2Router01.WETH() (#534) is not in mixedCase
Parameter GreenBioX.calculateTaxFee(uint256)._amount (#931) is not in mixedCase
Parameter GreenBioX.calculateLiquidityFee(uint256)._amount (#937) is not in mixedCase
Parameter GreenBioX.setMarketingFeePercentage(uint256).MarketingFee (#969) is not in mixedCase
Parameter GreenBioX.setNatureFeePercentage(uint256).NatureFee (#973) is not in mixedCase
Parameter GreenBioX.setBurningPercentage(uint256)._burnPercentage (#981) is not in mixedCase
Parameter GreenBioX.setSwapAndLiquifyEnabled(bool)._enabled (#1009) is not in mixedCase
Variable GreenBioX.MarketingWallet (#687) is not in mixedCase
Variable GreenBioX.NatureAddress (#688) is not in mixedCase
Variable GreenBioX.DeadAddress (#689) is not in mixedCase
Variable GreenBioX._taxFee (#695) is not in mixedCase
Variable GreenBioX._liquidityFee (#698) is not in mixedCase
Variable GreenBioX._MarketingFee (#701) is not in mixedCase
Variable GreenBioX._NatureFee (#704) is not in mixedCase
Variable GreenBioX.BurningPercentage (#707) is not in mixedCase
Variable GreenBioX._maxTxAmount (#716) is not in mixedCase
Follow the Solidity naming convention.
Additional information: link
Redundant expression "this (#248)" inContext (#242-251)
Remove redundant statements if they congest code but offer no value.
Additional information: link
Variable IUniswapV2Router01.addLiquidity(address,address,uint256,uint256,uint256,uint256,address,uint256).amountADesired (#539) is too similar to IUniswapV2Router01.addLiquidity(address,address,uint256,uint256,uint256,uint256,address,uint256).amountBDesired (#540)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX.reflectionFromToken(uint256,bool).rTransferAmount (#830) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._transferFromExcluded(address,address,uint256).tTransferAmount (#1186)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._transferStandard(address,address,uint256).rTransferAmount (#1167) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._transferBothExcluded(address,address,uint256).rTransferAmount (#865) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX._getValues(uint256).rTransferAmount (#887) is too similar to GreenBioX._transferStandard(address,address,uint256).tTransferAmount (#1167)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._transferFromExcluded(address,address,uint256).rTransferAmount (#1186) is too similar to GreenBioX._getTValues(uint256).tTransferAmount (#894)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._transferToExcluded(address,address,uint256).tTransferAmount (#1176)
Variable GreenBioX._getRValues(uint256,uint256,uint256,uint256).rTransferAmount (#902) is too similar to GreenBioX._transferBothExcluded(address,address,uint256).tTransferAmount (#865)
Variable GreenBioX._transferToExcluded(address,address,uint256).rTransferAmount (#1176) is too similar to GreenBioX._getValues(uint256).tTransferAmount (#886)
Prevent variables from having similar names.
Additional information: link
GreenBioX.constructor() (#733-754) uses literals with too many digits:
- _tokenTransfer(owner(),address(0x0d01dd873666cCb071a3C483DCD24FAB6e548834),5000000000000 * 10 ** 18) (#752)
GreenBioX.constructor() (#733-754) uses literals with too many digits:
- _tokenTransfer(owner(),address(0x5D29d8F33d56917949eC831d631934CF9197b265),3000000000000 * 10 ** 18) (#753)
GreenBioX.slitherConstructorVariables() (#670-1196) uses literals with too many digits:
- DeadAddress = 0x000000000000000000000000000000000000dEaD (#689)
Use: Ether suffix, Time suffix, or The scientific notation
Additional information: link
Ownable._previousOwner (#405) is never used in GreenBioX (#670-1196)
Ownable._lockTime (#406) is never used in GreenBioX (#670-1196)
Remove unused state variables.
Additional information: link
GreenBioX.DeadAddress (#689) should be constant
GreenBioX._decimals (#693) should be constant
GreenBioX._name (#691) should be constant
GreenBioX._symbol (#692) should be constant
GreenBioX._tTotal (#684) should be constant
GreenBioX.numTokensSellToAddToLiquidity (#717) should be constant
Ownable._lockTime (#406) should be constant
Ownable._previousOwner (#405) should be constant
Add the constant attributes to state variables that never change.
Additional information: link
renounceOwnership() should be declared external:
- Ownable.renounceOwnership() (#441-444)
transferOwnership(address) should be declared external:
- Ownable.transferOwnership(address) (#450-454)
name() should be declared external:
- GreenBioX.name() (#756-758)
symbol() should be declared external:
- GreenBioX.symbol() (#760-762)
decimals() should be declared external:
- GreenBioX.decimals() (#764-766)
totalSupply() should be declared external:
- GreenBioX.totalSupply() (#768-770)
transfer(address,uint256) should be declared external:
- GreenBioX.transfer(address,uint256) (#777-780)
allowance(address,address) should be declared external:
- GreenBioX.allowance(address,address) (#782-784)
approve(address,uint256) should be declared external:
- GreenBioX.approve(address,uint256) (#786-789)
transferFrom(address,address,uint256) should be declared external:
- GreenBioX.transferFrom(address,address,uint256) (#791-795)
increaseAllowance(address,uint256) should be declared external:
- GreenBioX.increaseAllowance(address,uint256) (#797-800)
decreaseAllowance(address,uint256) should be declared external:
- GreenBioX.decreaseAllowance(address,uint256) (#802-805)
isExcludedFromReward(address) should be declared external:
- GreenBioX.isExcludedFromReward(address) (#807-809)
totalFees() should be declared external:
- GreenBioX.totalFees() (#811-813)
deliver(uint256) should be declared external:
- GreenBioX.deliver(uint256) (#815-822)
reflectionFromToken(uint256,bool) should be declared external:
- GreenBioX.reflectionFromToken(uint256,bool) (#824-833)
excludeFromReward(address) should be declared external:
- GreenBioX.excludeFromReward(address) (#841-849)
excludeFromFee(address) should be declared external:
- GreenBioX.excludeFromFee(address) (#984-986)
includeInFee(address) should be declared external:
- GreenBioX.includeInFee(address) (#988-990)
setSwapAndLiquifyEnabled(bool) should be declared external:
- GreenBioX.setSwapAndLiquifyEnabled(bool) (#1009-1012)
isExcludedFromFee(address) should be declared external:
- GreenBioX.isExcludedFromFee(address) (#1014-1016)
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 price dump / death
Token has no active CoinGecko listing / rank
Token has no active CoinMarketCap listing / rank
Unable to find Telegram and Twitter accounts