P2E business management game MetaStock is a P2E business management game with a powerful artificial intelligence engine developed using Chainlink services. Earn crazy APR with your BNB, AVAX, FTM, MATIC, HECO, ONE, VLX with Metastock decentralized node protocol. Mint a Company, Hire employees to earn more money, Create more FREE businesses with your earnings, Compound your returns and earn a passive income. All this with a 0 tax token.
HasForeignAsset.getAsset(IBEP20) (#467-469) ignores return value by asset.transfer(owner(),this.assetBalance(asset)) (#468)
Use SafeERC20, or ensure that the transfer/transferFrom return value is checked.
Additional information: link
Unable to verify that contract auditor is trusted: Certik, Quantstamp, Hacken, Solidity, Paladinsec, Openzeppelin, Verichains
Contract ownership is not renounced (belongs to a wallet)
Contract locking ether found:
Contract MetaStocks (#496-774) has payable functions:
- MetaStocks.receive() (#522-524)
But does not have a function to withdraw the ether
Remove the payable attribute or add a withdraw function.
Additional information: link
MetaStocks.allowance(address,address).owner (#588) shadows:
- Ownable.owner() (#438-440) (function)
MetaStocks._approve(address,address,uint256).owner (#739) shadows:
- Ownable.owner() (#438-440) (function)
Rename the local variables that shadow another component.
Additional information: link
Address._functionCallWithValue(address,bytes,uint256,string) (#290-311) is never used and should be removed
Address.functionCall(address,bytes) (#250-252) is never used and should be removed
Address.functionCall(address,bytes,string) (#260-262) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256) (#275-277) is never used and should be removed
Address.functionCallWithValue(address,bytes,uint256,string) (#285-288) is never used and should be removed
Address.isContract(address) (#197-206) is never used and should be removed
Address.sendValue(address,uint256) (#224-230) is never used and should be removed
Context._msgData() (#404-407) is never used and should be removed
MetaStocks._setupDecimals(uint8) (#754-756) is never used and should be removed
SafeMath.div(uint256,uint256) (#117-119) is never used and should be removed
SafeMath.div(uint256,uint256,string) (#133-139) is never used and should be removed
SafeMath.mod(uint256,uint256) (#153-155) is never used and should be removed
SafeMath.mod(uint256,uint256,string) (#169-172) is never used and should be removed
Remove unused functions.
Additional information: link
Pragma version^0.8.2 (#17) allows old versions
solc-0.8.2 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) (#224-230):
- (success) = recipient.call{value: amount}() (#228)
Low level call in Address._functionCallWithValue(address,bytes,uint256,string) (#290-311):
- (success,returndata) = target.call{value: weiValue}(data) (#294)
Avoid low-level calls. Check the call success. If the call is meant for a contract, check for code existence
Additional information: link
Redundant expression "this (#405)" inContext (#399-408)
Remove redundant statements if they congest code but offer no value.
Additional information: link
MetaStocks.constructor() (#514-520) uses literals with too many digits:
- _maxSupply = 4300000 (#518)
Use: Ether suffix, Time suffix, or The scientific notation
Additional information: link
Address.isContract(address) (#197-206) uses assembly
- INLINE ASM (#204)
Address._functionCallWithValue(address,bytes,uint256,string) (#290-311) uses assembly
- INLINE ASM (#303-306)
Do not use evm assembly.
Additional information: link
transferOwnership(address) should be declared external:
- Ownable.transferOwnership(address) (#454-458)
name() should be declared external:
- MetaStocks.name() (#529-531)
symbol() should be declared external:
- MetaStocks.symbol() (#537-539)
decimals() should be declared external:
- MetaStocks.decimals() (#554-556)
totalSupply() should be declared external:
- MetaStocks.totalSupply() (#561-563)
balanceOf(address) should be declared external:
- MetaStocks.balanceOf(address) (#568-570)
transfer(address,uint256) should be declared external:
- MetaStocks.transfer(address,uint256) (#580-583)
allowance(address,address) should be declared external:
- MetaStocks.allowance(address,address) (#588-590)
approve(address,uint256) should be declared external:
- MetaStocks.approve(address,uint256) (#599-602)
transferFrom(address,address,uint256) should be declared external:
- MetaStocks.transferFrom(address,address,uint256) (#616-620)
increaseAllowance(address,uint256) should be declared external:
- MetaStocks.increaseAllowance(address,uint256) (#634-637)
decreaseAllowance(address,uint256) should be declared external:
- MetaStocks.decreaseAllowance(address,uint256) (#653-656)
burn(uint256) should be declared external:
- MetaStocks.burn(uint256) (#723-725)
Use the external attribute for functions never called from the contract.
Additional information: link
BscScan page for the token does not contain additional info: website, socials, description, etc.
Additional information: link
Unable to find audit link on the website
Unable to find Twitter link on the website
Token is not listed at Mobula.Finance
Additional information: link
Unable to find token on CoinHunt
Additional information: link
Young tokens have high risks of scam / price dump / death
Young tokens have high risks of scam / price dump / death
Young tokens have high risks of scam / price dump / death
Young tokens have high risks of scam / price dump / death
Young tokens have high risks of scam / price dump / death
Token has no active CoinGecko listing / rank
Unable to find Blog account (Reddit or Medium)