Skip to content

Commit

Permalink
Merge pull request #13 from CoinFabrik/develop
Browse files Browse the repository at this point in the history
Make M1 release
  • Loading branch information
aurecoinfabrik authored Nov 5, 2024
2 parents 5f20f4c + 46a6d28 commit f0fca43
Show file tree
Hide file tree
Showing 32 changed files with 5,312 additions and 1 deletion.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
/env
/env
/venv
21 changes: 21 additions & 0 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
MIT License

Copyright (c) 2024 CoinFabrik

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
92 changes: 92 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
# Scout Substrate Dataset: Audited Substrate Projects

![https://img.shields.io/badge/license-MIT-green](https://img.shields.io/badge/license-MIT-green)

<p align="center">
<img src="./assets/scout-in-the-dark-cave-0.png" alt="Scout Entering the Cave of Audits" width="300" center />
</p>

Welcome to the **Scout Substrate Dataset**, a collection of thoroughly analyzed audited Substrate pallets, runtime, and node code. This repository serves as a knowledge base for Substrate developers, auditors, and security researchers aiming to identify common Substrate vulnerabilities and improve the security of their projects.

Our goal is to provide a reference point for the community, compiling key security issues found in Substrate projects, facilitating better security practices, and serving as a resource for improving vulnerability detection tools like [Scout](https://www.coinfabrik.com/products/scout/)

### Dataset Breakdown

We have structured the `Scout Substrate Dataset` into the following folders:

- **`/dataset/`**:
- **`findings.json`**: A comprehensive list of all findings across the audited projects.
- **`findings-linear.json`**: The `findings.json` file further processed to be imported in hugging face.
- **`/audited-projects/`**:
- Contains directories for each audited project, labeled by `[audited-project-id]-[project-name]`.
- Each directory contains:
- **`[project-audit].pdf`**: The original audit report in PDF format.
- **`findings-[audited-project-id]-[project-name].json`**: JSON file containing the project-specific findings.

For information on accessing the full codebase, including audited and remediated code for each project, refer to the [Accessing Audited Project Code](#accessing-audited-project-code) section below.

## Audited Projects

This dataset currently contains the following audited Substrate projects:

| Audited Project ID | Project Name | Auditor |
| ------------------ | ------------- | ---------------------- |
| 1 | Parallel | Trail of Bits |
| 2 | Parallel | SlowMist |
| 3 | Ava Protocol | Slow Mist |
| 5 | Nodle | Halborn |
| 6 | Reef Chain | Halborn |
| 7 | Manta Network | Veridise |
| 8 | Manta Network | Halborn |
| 9 | Manta Network | Veridise |
| 10 | Astar | Security Research Labs |
| 11 | Astar | Zellic |

More projects will be added as new audits are analyzed.

## Accessing Audited Project Code

For access to the complete codebase associated with this dataset, including tagged archives for each audit finding and remediation, visit the [Scout Substrate Dataset Code](https://github.com/CoinFabrik/scout-substrate-dataset-code) repository. Download bundles by tag or commit hash, enabling a full historical view of each project version.

## Substrate Issue Classes

As we analyzed various audit reports and their respective findings, we observed a range of issue classes applied by auditing companies, each recorded under the field `vulnerability_class_audit` in the dataset. Despite some variation in classification, certain categories tend to recur.

To provide a common classification across the reviewed audits, we provide a `vulnerability_class_scout` field for each finding. Below, we list several issue classes that we find applicable to **Substrate pallets**, **runtime**, and **node code**, and that we applied for this field.

- **Dependency**: Issues related to using vulnerable or outdated dependencies in the project. These vulnerabilities could introduce potential risks due to unmaintained or insecure libraries.
_Example Projects with Findings in this Class: [1-Parallel], [2-Parallel], [5-Nodle]_

- **Arithmetic**: Arithmetic-related vulnerabilities, such as unchecked arithmetic operations, saturating calculations, and overflows. These issues can result in unexpected behaviors or crashes due to incorrect handling of mathematical operations.
_Example Projects with Findings in this Class: [3-AvaProtocol], [6-ReefChain], [7-MantaNetwork]_

- **Weight Management**: Incorrect or missing weight calculations, including static versus dynamic weight handling, or failure to account for changes in workload. This can lead to DoS vulnerabilities as resource costs are underestimated.
_Example Projects with Findings in this Class: [7-MantaNetwork], [10-Astar], [4-Pendulum]_

- **Error Handling and Validation**: Inadequate error handling and validation, such as improper use of `DispatchError`, missing error checks, and insufficient input validation. These issues can cause unexpected program flows and unauthorized access.
_Example Projects with Findings in this Class: [5-Nodle], [4-Pendulum], [1-Parallel]_

- **Denial of Service (DoS) and Spamming**: Vulnerabilities that could lead to potential denial of service or spamming, often tied to extrinsic calls or weights.
_Example Projects with Findings in this Class: [4-Pendulum], [10-Astar]_

- **Business Logic**: Issues in project-specific rules or logic, leading to exploitable or unintended behaviors.
_Example Projects with Findings in this Class: [7-MantaNetwork], [5-Nodle]_

- **Code Quality**: Issues impacting readability, maintainability, or structure, increasing risk of errors.
_Example Projects with Findings in this Class: [7-MantaNetwork], [5-Nodle]_

- **TBD**: Findings or issues with pending classification.

We understand that this classification depends largely on expert criteria and that a finding could potentially be assigned to multiple classes simultaneously. We plan to further refine this classification as we add more audited projects to the dataset.

## About CoinFabrik

We - [CoinFabrik](https://www.coinfabrik.com/) - are a research and development company specialized in Web3, with a strong background in cybersecurity. Founded in 2014, we have worked on over 500 blockchain-related projects, EVM-based and also for Solana, Algorand, and Polkadot. Beyond development, we offer security audits through a dedicated in-house team of senior cybersecurity professionals, currently working on code in Substrate, Solidity, Clarity, Rust, and TEAL.

Our team has an academic background in computer science and mathematics, with work experience focused on cybersecurity and software development, including academic publications, patents turned into products, and conference presentations. Furthermore, we have an ongoing collaboration on knowledge transfer and open-source projects with the University of Buenos Aires.

As proud members, and with the support of the [Polkadot Assurance Legion (PAL)](https://github.com/polkadot-assurance-legion/pal-docs), we are pleased to contribute this audited code dataset to the Substrate community, aiming to enhance vulnerability detection and promote security best practices within the Polkadot ecosystem.

## License

Scout is licensed and distributed under a MIT license. [Contact us](https://www.coinfabrik.com/) if you're looking for an exception to the terms.
Binary file added assets/scout-in-the-dark-cave-0.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Loading

0 comments on commit f0fca43

Please sign in to comment.