Introduction
We express our gratitude to the WhiteBIT team for the collaborative engagement that enabled the execution of this Smart Contract Security Assessment.
WhiteBIT is Europe’s largest international centralized crypto-to-fiat exchange with over 2 million registered users and a team of 350+ members that meet all KYC and AML requirements.
title | content |
---|---|
Platform | EVM |
Language | Solidity |
Timeline | 18/04/2022 - 19/08/2022 |
Methodology | https://hackenio.cc/sc_methodology→ |
Review Scope | |
---|---|
Repository | https://github.com/whitebit-exchange/wbt-token→ |
Commit | 2ab92561d118bcf0801adeab5cddea86d813b61b |
Review Scope
- Commit
- 2ab92561d118bcf0801adeab5cddea86d813b61b
Audit Summary
10/10
10/10
7/10
10/10
The system users should acknowledge all the risks summed up in the risks section of the report
Document Information
This report may contain confidential information about IT systems and the intellectual property of the Customer, as well as information about potential vulnerabilities and methods of their exploitation.
The report can be disclosed publicly after prior consent by another Party. Any subsequent publication of this report shall be without mandatory consent.
Document | |
---|---|
Name | Smart Contract Code Review and Security Analysis Report for WhiteBIT |
Audited By | Hacken |
Website | https://whitebit.com→ |
Changelog | 22/04/2022 - Preliminary Report |
03/05/2022 - Second Review | |
06/05/2022 - Third Review | |
19/08/2022 - Fourth Review |
Document
- Name
- Smart Contract Code Review and Security Analysis Report for WhiteBIT
- Audited By
- Hacken
- Website
- https://whitebit.com→
- Changelog
- 22/04/2022 - Preliminary Report
- 03/05/2022 - Second Review
- 06/05/2022 - Third Review
- 19/08/2022 - Fourth Review
System Overview
WhiteBIT is Europe’s largest international centralized crypto-to-fiat exchange with over 2 million registered users and a team of 350+ members that meet all KYC and AML requirements.
Token — simple TRC-20 token that mints nothing after the deployment. Additional minting is allowed. The token has the ability to add addresses to the black list, which will stop all operations with the address. For blacklisted addresses, it has the ability to destroy funds.
It has the following attributes:
Name: WhiteBIT WBT
Symbol: WBT
Decimals: 8
Total supply: 400m (100m for TRC network)
Privileged roles
The owner of the WBT contract can add or remove addresses from the blacklist to lock funds.
The owner of the WBT contract can destroy funds for any blacklisted address.
The owner of the WBT contract has the ability to burn tokens.
The owner of the WBT contract can pause the contract, so all transfers would be stopped.
The owner of the WBT contract can mint tokens without any limits.
Executive Summary
Documentation quality
The total Documentation Quality score is 10 out of 10.
The Customer provided superficial functional requirements.
Technical description is not provided.
Code quality
The total Code Quality score is 7 out of 10.
Limited number of unit tests provided.
Architecture quality
The architecture quality score is 10 out of 10.
Code is well-structured and easy-readable.
Security score
Upon auditing, the code was found to contain 2 critical, 0 high, 0 medium, and 5 low severity issues, leading to a security score of 10 out of 10.
All identified issues are detailed in the “Findings” section of this report.
Summary
The comprehensive audit of the customer's smart contract yields an overall score of 10. This score reflects the combined evaluation of documentation, code quality, test coverage, and security aspects of the project.
Findings
Code ― | Title | Status | Severity | |
---|---|---|---|---|
F-2022-1527 | Incorrect TRC20 interface | fixed | Critical | |
F-2022-1526 | Mint is not limited | fixed | Critical | |
F-2022-1532 | DestroyBlackFunds event has an incorrect burned amount value | fixed | Low | |
F-2022-1531 | Zero address is allowed | fixed | Low | |
F-2024-1530 | The public function could be declared external | fixed | Low | |
F-2022-1529 | Boolean equality | fixed | Low | |
F-2022-1528 | Variable Shadowing | fixed | Low |
Identify vulnerabilities in your smart contracts.
Appendix 1. Severity Definitions
When auditing smart contracts, Hacken is using a risk-based approach that considers Likelihood, Impact, Exploitability and Complexity metrics to evaluate findings and score severities.
Reference on how risk scoring is done is available through the repository in our Github organization:
Severity | Description |
---|---|
Critical | Critical vulnerabilities are usually straightforward to exploit and can lead to the loss of user funds or contract state manipulation. |
High | High vulnerabilities are usually harder to exploit, requiring specific conditions, or have a more limited scope, but can still lead to the loss of user funds or contract state manipulation. |
Medium | Medium vulnerabilities are usually limited to state manipulations and, in most cases, cannot lead to asset loss. Contradictions and requirements violations. Major deviations from best practices are also in this category. |
Low | Major deviations from best practices or major Gas inefficiency. These issues will not have a significant impact on code execution, do not affect security score but can affect code quality score. |
Severity
- Critical
Description
- Critical vulnerabilities are usually straightforward to exploit and can lead to the loss of user funds or contract state manipulation.
Severity
- High
Description
- High vulnerabilities are usually harder to exploit, requiring specific conditions, or have a more limited scope, but can still lead to the loss of user funds or contract state manipulation.
Severity
- Medium
Description
- Medium vulnerabilities are usually limited to state manipulations and, in most cases, cannot lead to asset loss. Contradictions and requirements violations. Major deviations from best practices are also in this category.
Severity
- Low
Description
- Major deviations from best practices or major Gas inefficiency. These issues will not have a significant impact on code execution, do not affect security score but can affect code quality score.
Appendix 2. Scope
The scope of the project includes the following smart contracts from the provided repository:
Scope Details | |
---|---|
Repository | https://github.com/whitebit-exchange/wbt-token→ |
Commit | 2ab92561d118bcf0801adeab5cddea86d813b61b |
Requirements | Provided |
Technical Requirements | Not Provided |
Scope Details
- Commit
- 2ab92561d118bcf0801adeab5cddea86d813b61b
- Requirements
- Provided
- Technical Requirements
- Not Provided
Contracts in Scope
BlackList.sol
TRC20Detailed.sol
TRC20.sol
ITRC20.sol
Ownable.sol
Pausable.sol
SafeMath.sol
WbtToken.sol