blog: Update the embark-mythx article to reflect lib changes
The `embark-mythx` plugin was recently taken over by embarklabs and completely re-written. These changes serve to update the article to reflect the updates to the library.
This commit is contained in:
parent
2714c81bd7
commit
3eea461d27
@ -1,8 +1,8 @@
|
|||||||
title: Smart Contract security analysis with MythX
|
title: Smart Contract security analysis with MythX
|
||||||
summary: "Analyse Smart Contract security throughout the development lifecycle using the Embark MythX plugin."
|
summary: "Analyse Smart Contract security throughout the development lifecycle using the Embark MythX plugin."
|
||||||
author: graham_mcbain
|
author: eric_mastro
|
||||||
categories:
|
categories:
|
||||||
- smart contracts
|
- smart-contracts
|
||||||
- security
|
- security
|
||||||
- mythx
|
- mythx
|
||||||
- tutorial
|
- tutorial
|
||||||
@ -47,7 +47,10 @@ npm i -g embark
|
|||||||
The rest of this article will assume you have Embark installed globally, and therefore available from the CLI.
|
The rest of this article will assume you have Embark installed globally, and therefore available from the CLI.
|
||||||
|
|
||||||
### Create a MythX account
|
### Create a MythX account
|
||||||
You'll need to [create a MythX account](https://docs.mythx.io/en/latest/getting-started/index.html) before any contracts can be submitted. The dashboard of this account will list all completed analyses. Signing up for a free plan is easy. The free plan is a great way to test out MythX's features without forking over any dollary-doos. You may skip the step of connecting your Ethereum address with MetaMask if you'd like, as a username and password are sufficient to proceed with this tutorial.
|
You'll need to [create a MythX account](https://docs.mythx.io/en/latest/getting-started/index.html) before any contracts can be submitted. The dashboard of this account will list all completed analyses. Signing up for a free plan is easy. The free plan is a great way to test out MythX's features without forking over any dollary-doos. You may skip the step of connecting your Ethereum address with MetaMask if you'd like, as a username, password, and API key are sufficient to proceed with this tutorial.
|
||||||
|
|
||||||
|
### Obtain a MythX API key
|
||||||
|
Once you've created a MythX account, we need to obtain an API key. This can be done on the [Tools page](https://dashboard.mythx.io/#/console/tools). Simply enter your MythX password and click the "Generate API Key" button. We will use the API key in Step 4.
|
||||||
|
|
||||||
## Step 2. Create a ÐApp
|
## Step 2. Create a ÐApp
|
||||||
For this article, we will be creating a demo ÐApp to use as a base for submitting our first contract for analysis. However, if you already have a ÐApp with contracdts that you'd like to use instead, simply skip this step.
|
For this article, we will be creating a demo ÐApp to use as a base for submitting our first contract for analysis. However, if you already have a ÐApp with contracdts that you'd like to use instead, simply skip this step.
|
||||||
@ -85,8 +88,9 @@ npm i embark-mythx --save
|
|||||||
```
|
```
|
||||||
|
|
||||||
## Step 4. Create a `.env` file with MythX credentials
|
## Step 4. Create a `.env` file with MythX credentials
|
||||||
Create a `.env` file in the root of your ÐApp. Add your MythX username and password like so:
|
Create a `.env` file in the root of your ÐApp. Add your MythX API key, username, and password like so:
|
||||||
```
|
```
|
||||||
|
MYTHX_API_KEY="1234...7890"
|
||||||
MYTHX_USERNAME="satoshi.nakamoto@gmail.com"
|
MYTHX_USERNAME="satoshi.nakamoto@gmail.com"
|
||||||
MYTHX_PASSWORD="abc123"
|
MYTHX_PASSWORD="abc123"
|
||||||
```
|
```
|
||||||
@ -110,25 +114,32 @@ Embark (development) > verify help
|
|||||||
```
|
```
|
||||||
We can see there are a few options for us to use and we can also see how they can be used:
|
We can see there are a few options for us to use and we can also see how they can be used:
|
||||||
```
|
```
|
||||||
Usage:
|
Available Commands
|
||||||
verify [--full] [--debug] [--limit] [--initial-delay] [<contracts>]
|
|
||||||
verify status <uuid>
|
|
||||||
verify help
|
|
||||||
|
|
||||||
Options:
|
verify <options> [contracts] Runs MythX verification. If array of contracts are specified, only those contracts will be analysed.
|
||||||
--full, -f Perform full rather than quick analysis.
|
verify report [--format] uuid Get the report of a completed analysis.
|
||||||
--debug, -d Additional debug output.
|
verify status uuid Get the status of an already submitted analysis.
|
||||||
--limit, -l Maximum number of concurrent analyses.
|
verify list Displays a list of the last 20 submitted analyses in a table.
|
||||||
--initial-delay, -i Time in seconds before first analysis status check.
|
verify help Display this usage guide.
|
||||||
|
|
||||||
[<contracts>] List of contracts to submit for analysis (default: all).
|
Examples
|
||||||
status <uuid> Retrieve analysis status for given MythX UUID.
|
|
||||||
help This help.
|
verify --mode full SimpleStorage ERC20 Runs a full MythX verification for the SimpleStorage and ERC20 contracts only.
|
||||||
|
verify status 0d60d6b3-e226-4192-b9c6-66b45eca3746 Gets the status of the MythX analysis with the specified uuid.
|
||||||
|
verify report --format stylish 0d60d6b3-e226-4192-b9c6-66b45eca3746 Gets the status of the MythX analysis with the specified uuid.
|
||||||
|
|
||||||
|
Verify options
|
||||||
|
|
||||||
|
-m, --mode string Analysis mode. Options: quick, standard, deep (default: quick).
|
||||||
|
-o, --format string Output format. Options: text, stylish, compact, table, html, json (default: stylish).
|
||||||
|
-c, --no-cache-lookup Deactivate MythX cache lookups (default: false).
|
||||||
|
-d, --debug Print MythX API request and response.
|
||||||
|
-l, --limit number Maximum number of concurrent analyses (default: 10).
|
||||||
|
-t, --timeout number Timeout in secs to wait for analysis to finish (default: smart default based on mode).
|
||||||
```
|
```
|
||||||
|
|
||||||
### Verify the SimpleStorage contract
|
### Verify the SimpleStorage contract
|
||||||
Let's take a peek to see how easy it is to analyse our SimpleStorage contract.
|
Let's take a peek to see how easy it is to analyse our SimpleStorage contract.
|
||||||
|
|
||||||
In the Embark console, execute the following command to submit our SimpleStorage contract for MythX security analysis:
|
In the Embark console, execute the following command to submit our SimpleStorage contract for MythX security analysis:
|
||||||
```
|
```
|
||||||
verify
|
verify
|
||||||
@ -136,7 +147,9 @@ verify
|
|||||||
The results should look the following:
|
The results should look the following:
|
||||||
data:image/s3,"s3://crabby-images/df7be/df7be8613f996d8634a9596b2b3ebb7fe63afb57" alt="SimpleStorage security analysis"
|
data:image/s3,"s3://crabby-images/df7be/df7be8613f996d8634a9596b2b3ebb7fe63afb57" alt="SimpleStorage security analysis"
|
||||||
|
|
||||||
We can see from the security analysis output in the console that there is an error marked "SWC-103". Looking at the [SWC Registry for SWC-103](https://swcregistry.io/docs/SWC-103) help, we can remedy this by changing line 1 of our `contracts/simple_storage.sol` to:
|
First, we can see that a MythX job was submitted, with a URL that takes us to the analysis job in the MythX dashboard.
|
||||||
|
|
||||||
|
Second, we can see from the security analysis output in the console that there is a warning marked "SWC-103". Looking at the [SWC Registry for SWC-103](https://swcregistry.io/docs/SWC-103) help, we can remedy this by changing line 1 of our `contracts/simple_storage.sol` to:
|
||||||
```
|
```
|
||||||
pragma solidity 0.6.1;
|
pragma solidity 0.6.1;
|
||||||
```
|
```
|
||||||
@ -145,12 +158,8 @@ Embark will detect the change in the contract and automatically recompile and re
|
|||||||
verify
|
verify
|
||||||
```
|
```
|
||||||
And voila!
|
And voila!
|
||||||
```
|
data:image/s3,"s3://crabby-images/0b36b/0b36b1d4314cfd632ef7865b1b92f303eb95435d" alt="SimpleStorage security analysis success"
|
||||||
Running MythX analysis in background.
|
|
||||||
Submitting 'SimpleStorage' for quick analysis...
|
|
||||||
|
|
||||||
MythX analysis found no vulnerabilities.
|
|
||||||
```
|
|
||||||
MythX has confirmed that we no longer have any security issues!
|
MythX has confirmed that we no longer have any security issues!
|
||||||
|
|
||||||
### Viewing the submissions in the MythX dashboard
|
### Viewing the submissions in the MythX dashboard
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 95 KiB After Width: | Height: | Size: 107 KiB |
BIN
source/assets/images/mythx_simplestorage-analysis-success.png
Normal file
BIN
source/assets/images/mythx_simplestorage-analysis-success.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 68 KiB |
Binary file not shown.
Before Width: | Height: | Size: 47 KiB After Width: | Height: | Size: 56 KiB |
Loading…
x
Reference in New Issue
Block a user