Unable to find manual contract audit (e.g. Certik, PeckShield, Solidity...)
Reentrancy in DOGETREASURE._transfer(address,address,uint256) (#158-192):
External calls:
- swapAddLiquidity() (#185)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
External calls sending eth:
- swapAddLiquidity() (#185)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
State variables written after the call(s):
- _balances[recipient] += amount (#189)
Reentrancy in DOGETREASURE.swapAddLiquidity() (#207-225):
External calls:
- swapTokensForEth(devAmount,devWallet) (#213)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- swapTokensForEth(sellHalf,address(this)) (#218)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
External calls sending eth:
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
State variables written after the call(s):
- _inSwap = false (#223)
Reentrancy in DOGETREASURE.transferFrom(address,address,uint256) (#239-248):
External calls:
- _transfer(sender,recipient,amount) (#243)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
External calls sending eth:
- _transfer(sender,recipient,amount) (#243)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
State variables written after the call(s):
- _approve(sender,msg.sender,currentAllowance - amount) (#245)
- _allowances[owner][spender] = amount (#230)
Apply the check-effects-interactions pattern.
Additional information: link
DOGETREASURE.withdrawToken(address,uint256) (#288-292) ignores return value by _tokenContract.transfer(msg.sender,amount) (#291)
Use SafeERC20, or ensure that the transfer/transferFrom return value is checked.
Additional information: link
Combination 3: Reentrancy vulnerabilities + Unchecked transfer vulnerability. Usual for scams. May be justified by some complex mechanics (e.g. rebase, reflections). DYOR & manual audit are advised.
DOGETREASURE._transfer(address,address,uint256) (#158-192) performs a multiplication on the result of a division:
-devAmount = amount / 100 * devFee (#175)
DOGETREASURE._transfer(address,address,uint256) (#158-192) performs a multiplication on the result of a division:
-liquidityAmount = amount / 100 * liquidityFee (#176)
DOGETREASURE.swapAddLiquidity() (#207-225) performs a multiplication on the result of a division:
-devAmount = tokenBalance / (devFee + liquidityFee) * devFee (#212)
Consider ordering multiplication before division.
Additional information: link
DOGETREASURE.addLiquidity(uint256,uint256) (#194-197) ignores return value by _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
Ensure that all the return values of the function calls are used.
Additional information: link
DOGETREASURE.setLimits(uint256,uint256,uint256) (#107-111) should emit an event for:
- maxWalletLimit = _maxWalletLimit * 10 ** _decimals (#108)
- _maxTxAmount = _maxTxLimit * 10 ** _decimals (#109)
- addLiquidityAmount = _addLiquidityAmount * 10 ** _decimals (#110)
DOGETREASURE.setFees(uint8,uint8) (#113-116) should emit an event for:
- devFee = _devFee (#114)
- liquidityFee = _liquidityFee (#115)
Emit an event for critical parameter changes.
Additional information: link
DOGETREASURE.setAddresses(address)._devWallet (#103) lacks a zero-check on :
- devWallet = _devWallet (#104)
Check that the address is not zero.
Additional information: link
Reentrancy in DOGETREASURE.constructor() (#73-91):
External calls:
- uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this),_uniswapV2Router.WETH()) (#80)
State variables written after the call(s):
- setExcludedAll(address(this)) (#82)
- _excludedFees[user] = status (#127)
- setExcludedAll(_owner) (#83)
- _excludedFees[user] = status (#127)
- setExcludedAll(uniswapPair) (#84)
- _excludedFees[user] = status (#127)
- setExcludedAll(_uniswapRouter) (#85)
- _excludedFees[user] = status (#127)
- setExcludedAll(_pinksaleContract) (#86)
- _excludedFees[user] = status (#127)
- setExcludedAll(address(this)) (#82)
- _excludedMaxTransaction[user] = status (#119)
- setExcludedAll(_owner) (#83)
- _excludedMaxTransaction[user] = status (#119)
- setExcludedAll(uniswapPair) (#84)
- _excludedMaxTransaction[user] = status (#119)
- setExcludedAll(_uniswapRouter) (#85)
- _excludedMaxTransaction[user] = status (#119)
- setExcludedAll(_pinksaleContract) (#86)
- _excludedMaxTransaction[user] = status (#119)
- setExcludedAll(address(this)) (#82)
- _excludedMaxWallet[user] = status (#123)
- setExcludedAll(_owner) (#83)
- _excludedMaxWallet[user] = status (#123)
- setExcludedAll(uniswapPair) (#84)
- _excludedMaxWallet[user] = status (#123)
- setExcludedAll(_uniswapRouter) (#85)
- _excludedMaxWallet[user] = status (#123)
- setExcludedAll(_pinksaleContract) (#86)
- _excludedMaxWallet[user] = status (#123)
- setLimits(100000000,100000000,1000000) (#89)
- _maxTxAmount = _maxTxLimit * 10 ** _decimals (#109)
- setLimits(100000000,100000000,1000000) (#89)
- addLiquidityAmount = _addLiquidityAmount * 10 ** _decimals (#110)
- setFees(5,4) (#90)
- devFee = _devFee (#114)
- setAddresses(msg.sender) (#87)
- devWallet = _devWallet (#104)
- setFees(5,4) (#90)
- liquidityFee = _liquidityFee (#115)
- setLimits(100000000,100000000,1000000) (#89)
- maxWalletLimit = _maxWalletLimit * 10 ** _decimals (#108)
Reentrancy in DOGETREASURE.swapAddLiquidity() (#207-225):
External calls:
- swapTokensForEth(devAmount,devWallet) (#213)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- swapTokensForEth(sellHalf,address(this)) (#218)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
State variables written after the call(s):
- swapTokensForEth(sellHalf,address(this)) (#218)
- _allowances[owner][spender] = amount (#230)
Reentrancy in DOGETREASURE.swapAddLiquidity() (#207-225):
External calls:
- swapTokensForEth(devAmount,devWallet) (#213)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- swapTokensForEth(sellHalf,address(this)) (#218)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
External calls sending eth:
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
State variables written after the call(s):
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _allowances[owner][spender] = amount (#230)
Apply the check-effects-interactions pattern.
Additional information: link
Reentrancy in DOGETREASURE._transfer(address,address,uint256) (#158-192):
External calls:
- swapAddLiquidity() (#185)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
External calls sending eth:
- swapAddLiquidity() (#185)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
Event emitted after the call(s):
- Transfer(sender,recipient,amount) (#191)
Reentrancy in DOGETREASURE.swapAddLiquidity() (#207-225):
External calls:
- swapTokensForEth(devAmount,devWallet) (#213)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- swapTokensForEth(sellHalf,address(this)) (#218)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
Event emitted after the call(s):
- Approval(owner,spender,amount) (#231)
- swapTokensForEth(sellHalf,address(this)) (#218)
Reentrancy in DOGETREASURE.swapAddLiquidity() (#207-225):
External calls:
- swapTokensForEth(devAmount,devWallet) (#213)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- swapTokensForEth(sellHalf,address(this)) (#218)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
External calls sending eth:
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
Event emitted after the call(s):
- Approval(owner,spender,amount) (#231)
- addLiquidity(sellAmount - sellHalf,receivedEth) (#221)
Reentrancy in DOGETREASURE.transferFrom(address,address,uint256) (#239-248):
External calls:
- _transfer(sender,recipient,amount) (#243)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
- _uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(amount,0,path,receiver,block.timestamp + 1200) (#204)
External calls sending eth:
- _transfer(sender,recipient,amount) (#243)
- _uniswapV2Router.addLiquidityETH{value: amount}(address(this),tokenAmount,0,0,address(this),block.timestamp + 1200) (#196)
Event emitted after the call(s):
- Approval(owner,spender,amount) (#231)
- _approve(sender,msg.sender,currentAllowance - amount) (#245)
Apply the check-effects-interactions pattern.
Additional information: link
DOGETREASURE (#34-294) should inherit from IERC20 (#15-17)
Inherit from the missing interface or contract.
Additional information: link
Function IUniswapV2Router01.WETH() (#21) is not in mixedCase
Parameter DOGETREASURE.setAddresses(address)._devWallet (#103) is not in mixedCase
Parameter DOGETREASURE.setLimits(uint256,uint256,uint256)._maxWalletLimit (#107) is not in mixedCase
Parameter DOGETREASURE.setLimits(uint256,uint256,uint256)._maxTxLimit (#107) is not in mixedCase
Parameter DOGETREASURE.setLimits(uint256,uint256,uint256)._addLiquidityAmount (#107) is not in mixedCase
Parameter DOGETREASURE.setFees(uint8,uint8)._devFee (#113) is not in mixedCase
Parameter DOGETREASURE.setFees(uint8,uint8)._liquidityFee (#113) is not in mixedCase
Variable DOGETREASURE._maxTxAmount (#45) is not in mixedCase
Variable DOGETREASURE.HEX_MAX_NUM (#49) is not in mixedCase
Follow the Solidity naming convention.
Additional information: link
DOGETREASURE.constructor() (#73-91) uses literals with too many digits:
- setLimits(100000000,100000000,1000000) (#89)
DOGETREASURE.slitherConstructorVariables() (#34-294) uses literals with too many digits:
- _totalSupply = 100000000 (#37)
Use: Ether suffix, Time suffix, or The scientific notation
Additional information: link
DOGETREASURE.HEX_MAX_NUM (#49) should be constant
DOGETREASURE._decimals (#38) should be constant
DOGETREASURE._name (#35) should be constant
DOGETREASURE._pinksaleContract (#40) should be constant
DOGETREASURE._symbol (#36) should be constant
DOGETREASURE._uniswapRouter (#39) should be constant
Add the constant attributes to state variables that never change.
Additional information: link
setInSwap(bool) should be declared external:
- DOGETREASURE.setInSwap(bool) (#99-101)
setBlacklistWallet(address,bool) should be declared external:
- DOGETREASURE.setBlacklistWallet(address,bool) (#130-132)
name() should be declared external:
- DOGETREASURE.name() (#134-136)
symbol() should be declared external:
- DOGETREASURE.symbol() (#138-140)
decimals() should be declared external:
- DOGETREASURE.decimals() (#142-144)
totalSupply() should be declared external:
- DOGETREASURE.totalSupply() (#146-148)
getOwner() should be declared external:
- DOGETREASURE.getOwner() (#150-152)
transfer(address,uint256) should be declared external:
- DOGETREASURE.transfer(address,uint256) (#234-237)
transferFrom(address,address,uint256) should be declared external:
- DOGETREASURE.transferFrom(address,address,uint256) (#239-248)
approve(address,uint256) should be declared external:
- DOGETREASURE.approve(address,uint256) (#250-253)
allowance(address,address) should be declared external:
- DOGETREASURE.allowance(address,address) (#255-257)
increaseAllowance(address,uint256) should be declared external:
- DOGETREASURE.increaseAllowance(address,uint256) (#259-262)
decreaseAllowance(address,uint256) should be declared external:
- DOGETREASURE.decreaseAllowance(address,uint256) (#264-269)
transferOwnership(address) should be declared external:
- DOGETREASURE.transferOwnership(address) (#271-275)
renounceOwnership() should be declared external:
- DOGETREASURE.renounceOwnership() (#277-280)
withdraw(uint256) should be declared external:
- DOGETREASURE.withdraw(uint256) (#282-286)
withdrawToken(address,uint256) should be declared external:
- DOGETREASURE.withdrawToken(address,uint256) (#288-292)
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