Provides implementations with full tests coverage for various Ethereum smart contracts:
An ERC20 implementation which includes many defense mechanisms and best practices from https://github.com/guylando/KnowledgeLists/blob/master/EthereumSmartContracts.md , for example:
- Protects from double spend exploit of approve mechanism.
- Protects from ether getting locked.
- Protects from tokens getting locked.
- Protects from contracts getting trapped as being owned by the token contract.
- Provides a protection mechanism against a future discovered bug by first allowing to pause the token (which is important as described in: OpenZeppelin/openzeppelin-contracts#795 (comment)) and then to migrate the token to a new address safely and without trust issues.
- Protects from decreaseAllowance failing when it is used to quickly remove allowance from an attacker.
- Supports unbounded allowance to allow better gas usage for the users of this token.
- Provides easy transperency into information saved in the contract so any non-technical user can verify that the deployed contract is not malicious.
- Protects from undetected unexpected behavior when calling the contract by performing a wide range of input validations everywhere.
- Uses latest solidity compiler version to get the benefits of all the improvements of latest compiler version.
- Locks into specific compiler version to prevent the contract being compiled by a compiler version which will introduce bugs into the contract.
- Well documented and tested. Has unit tests coverage of all the functions in over 200 automatic tests. Includes a plugin which estimates all the used functions gas usage (https://github.com/cgewecke/eth-gas-reporter). Includes code coverage report on how much code and cases the tests cover (https://github.com/sc-forks/solidity-coverage). You can find the tests summary and execution information here: https://github.com/guylando/EthereumSmartContracts/blob/master/SafeUpgradeableTokenERC20/Token_Automatic_Tests_Summary.txt and the tests code coverage report here: https://github.com/guylando/EthereumSmartContracts/blob/master/SafeUpgradeableTokenERC20/tests-code-coverage-report/index.html (download the repository and then open this html file to see the report).
- Successfully approved after being scanned for security vulnerabilities by the Mithril smart contracts security analysis tool https://github.com/ConsenSys/mythril
- Successfully verified that no serious bugs and vulnerabilities exist by using the Slither static solidity security analyzer https://github.com/crytic/slither
- Surya analysis tool (https://github.com/ConsenSys/surya) contract structure report is provided at https://github.com/guylando/EthereumSmartContracts/blob/master/SafeUpgradeableTokenERC20/SafeUpgradeableTokenERC20_surya_report.md
- Verified the code is free of serious bugs and vulnerabilities using the top solidity linters: https://github.com/protofire/solhint and https://github.com/duaraghav8/Ethlint
- Verified the code that no serious bugs and vulnerabilities exist by using the smartdec static security analysis tool: https://tool.smartdec.net
- Verified the code that no serious bugs and vulnerabilities exist by using mythos client of the mythx api: https://mythx.io/
To easily deploy the contract you can just copy https://github.com/guylando/EthereumSmartContracts/blob/master/SafeUpgradeableTokenERC20/contracts/SafeUpgradeableTokenERC20.sol to remix and choose 0.5.8 compiler version and then it should be compiled successfully and be ready for deployment with your desired token parameters.
The contract was audited by the Callisto network (here EthereumCommonwealth/Auditing#265) which found no serious security vulnerabilities in the contract and concluded that the contract is safe for deployment and will not endanger the investors.