-
Notifications
You must be signed in to change notification settings - Fork 970
JSON output
David Pokora edited this page May 8, 2019
·
59 revisions
At the top level, the JSON output provided by slither will appear in the following format:
{
"success": true,
"error": null,
"results": []
}
-
success
(boolean):true
ifresults
were output successfully,false
if anerror
occurred. -
error
(string | null): Ifsuccess
isfalse
, this will be a string with relevant error information. Otherwise, it will benull
. -
results
(result array, see below): Ifsuccess
istrue
, this will be an array populated with relevant slither findings.
A vulnerability/result found in the results
array above will be of the following format:
{
"check": "...",
"impact": "...",
"confidence": "...",
"description": "...",
"elements": [
{
"type": "item0",
"item0_additional_info": "...",
"source_mapping" : "..."
},
{
"type": "item1",
"item1_additional_info": "...",
"source_mapping" : "..."
}]
}
-
check
(string): The detector identifier (see the list of detectors) -
impact
(string): representation of the impact (High
/Medium
/Low
/Informational
) -
confidence
(string): representation of the confidence (High
/Medium
/Low
) -
description
(string): output of the slither -
elements
: (element array, see below): an array of relevant items for this finding which map to some source code.- NOTE: When writing a detector, the first element should be carefully chosen to represent the most significant portion of mapped code for the finding (the area of source on which external tooling should primarily focus for the issue).
-
additional_info
: (OPTIONAL, any): Offers additional detector-specific information, does not always exist.
Each element found in elements
above is of the form:
{
"type": "...",
"name": "...",
"source_mapping": { ... }
}
-
type
(string): Refers to the type of element, this can be either: (contract
,function
,variable
,node
,pragma
,enum
,struct
,event
). -
name
(string): Refers to the name of the element.- For
contract
/function
/variable
/enum
/struct
/event
types, this refers to the definition name. - For
node
types, this refers to a string representation of any underlying expression. A blank string is used if there is no underlying expression. - For
pragma
types, this refers to a string representation of theversion
portion of the pragma (ie:^0.5.0
).
- For
-
source_mapping
(source mapping, see below): Refers to a source mapping object which defines the source range which represents this element. -
additional_info
: (OPTIONAL, any): Offers additional detector-specific element information, does not always exist.
Additionally, there are element type-specific fields included:
- For
function
/enum
/struct
/event
type elements:-
contract
(contract element): The parent contract of the function.
-
- For
variable
type elements:-
contract
(OPTIONAL, contract element): The parent contract of the variable. Included if the variable is a state variable. -
function
(OPTIONAL, function element): The parent function of the variable. Included if the variable is a local variable.
-
- For
node
type elements:-
function
(function element): The parent function of the node.
-
- For
pragma
type elements:-
directive
(string array): Fully serialized pragma directive (ie:["solidity", "^", "0.4", ".9"]
)
-
Each source_mapping
object is used to map an element to some portion of source. It should be of the form:
"source_mapping": {
"start": 45
"length": 58,
"filename_relative": "contracts/tests/constant.sol",
"filename_absolute": "/tmp/contracts/tests/constant.sol",
"filename_short": "tests/constant.sol",
"filename_used": "contracts/tests/constant.sol",
"lines": [
5,
6,
7
],
"starting_column": 1,
"ending_column": 24,
}
-
start
(integer): Refers to the starting byte position of the mapped source. -
length
(integer): Refers to the byte-length of the mapped source. -
filename_relative
(string): A relative file path from the analysis directory. -
filename_absolute
(string): An absolute file path to the file. -
filename_short
(string): A short version of the filename used for display purposes. Hides platform-specific directories (ex:node_modules
). -
filename_used
(string): The path used by the platform for analysis (non-standard). -
lines
(integer array): An array of line numbers which the mapped source spans. Line numbers begin from 1. -
starting_column
(integer): The starting column/character position for the first mapped source line. Begins from 1. -
ending_column
(integer): The ending column/character position for the last mapped source line. Begins from 1.
Some detectors have non standard elements
-
constant-function
:contain_assembly
: bool -
naming-convention
: "convention": "CapWords", "name": "contract_name", "target": "target_name"-
convention
can be:CapWords
mixedCase
l_O_I_should_not_be_used
UPPER_CASE_WITH_UNDERSCORES
-
target
can be:contract
structure
event
function
variable
variable_constant
parameter
enum
modifier
-
-
reentrancy
(all variants):- list of "external_calls":
expression
/source_mapping
- list of "external_calls_sending_eth":
expression
/source_mapping
- list of "variables_written":
expression
/source_mapping
/name
- list of "external_calls":