mirror of https://github.com/crytic/slither
Merge pull request #377 from crytic/dev-fix-reentrancy-events
Remove FPs in reentrancy-eventspull/386/head
commit
de0f437f0f
@ -0,0 +1,151 @@ |
||||
{ |
||||
"success": true, |
||||
"error": null, |
||||
"results": { |
||||
"detectors": [ |
||||
{ |
||||
"elements": [ |
||||
{ |
||||
"type": "function", |
||||
"name": "bug", |
||||
"source_mapping": { |
||||
"start": 86, |
||||
"length": 68, |
||||
"filename_used": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_relative": "tests/reentrancy-0.5.1-events.sol", |
||||
"filename_absolute": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_short": "tests/reentrancy-0.5.1-events.sol", |
||||
"is_dependency": false, |
||||
"lines": [ |
||||
14, |
||||
15, |
||||
16, |
||||
17 |
||||
], |
||||
"starting_column": 5, |
||||
"ending_column": 6 |
||||
}, |
||||
"type_specific_fields": { |
||||
"parent": { |
||||
"type": "contract", |
||||
"name": "Test", |
||||
"source_mapping": { |
||||
"start": 51, |
||||
"length": 193, |
||||
"filename_used": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_relative": "tests/reentrancy-0.5.1-events.sol", |
||||
"filename_absolute": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_short": "tests/reentrancy-0.5.1-events.sol", |
||||
"is_dependency": false, |
||||
"lines": [ |
||||
11, |
||||
12, |
||||
13, |
||||
14, |
||||
15, |
||||
16, |
||||
17, |
||||
18, |
||||
19, |
||||
20, |
||||
21, |
||||
22, |
||||
23, |
||||
24 |
||||
], |
||||
"starting_column": 1, |
||||
"ending_column": 2 |
||||
} |
||||
}, |
||||
"signature": "bug(C)" |
||||
} |
||||
}, |
||||
{ |
||||
"type": "node", |
||||
"name": "c.f()", |
||||
"source_mapping": { |
||||
"start": 120, |
||||
"length": 5, |
||||
"filename_used": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_relative": "tests/reentrancy-0.5.1-events.sol", |
||||
"filename_absolute": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_short": "tests/reentrancy-0.5.1-events.sol", |
||||
"is_dependency": false, |
||||
"lines": [ |
||||
15 |
||||
], |
||||
"starting_column": 9, |
||||
"ending_column": 14 |
||||
}, |
||||
"type_specific_fields": { |
||||
"parent": { |
||||
"type": "function", |
||||
"name": "bug", |
||||
"source_mapping": { |
||||
"start": 86, |
||||
"length": 68, |
||||
"filename_used": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_relative": "tests/reentrancy-0.5.1-events.sol", |
||||
"filename_absolute": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_short": "tests/reentrancy-0.5.1-events.sol", |
||||
"is_dependency": false, |
||||
"lines": [ |
||||
14, |
||||
15, |
||||
16, |
||||
17 |
||||
], |
||||
"starting_column": 5, |
||||
"ending_column": 6 |
||||
}, |
||||
"type_specific_fields": { |
||||
"parent": { |
||||
"type": "contract", |
||||
"name": "Test", |
||||
"source_mapping": { |
||||
"start": 51, |
||||
"length": 193, |
||||
"filename_used": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_relative": "tests/reentrancy-0.5.1-events.sol", |
||||
"filename_absolute": "/home/travis/build/crytic/slither/tests/reentrancy-0.5.1-events.sol", |
||||
"filename_short": "tests/reentrancy-0.5.1-events.sol", |
||||
"is_dependency": false, |
||||
"lines": [ |
||||
11, |
||||
12, |
||||
13, |
||||
14, |
||||
15, |
||||
16, |
||||
17, |
||||
18, |
||||
19, |
||||
20, |
||||
21, |
||||
22, |
||||
23, |
||||
24 |
||||
], |
||||
"starting_column": 1, |
||||
"ending_column": 2 |
||||
} |
||||
}, |
||||
"signature": "bug(C)" |
||||
} |
||||
} |
||||
}, |
||||
"additional_fields": { |
||||
"underlying_type": "external_calls" |
||||
} |
||||
} |
||||
], |
||||
"description": "Reentrancy in Test.bug(C) (tests/reentrancy-0.5.1-events.sol#14-17):\n\tExternal calls:\n\t- c.f() (tests/reentrancy-0.5.1-events.sol#15)\n\tEvent emitted after the call(s):\n\t- E() (tests/reentrancy-0.5.1-events.sol#16)\n", |
||||
"markdown": "Reentrancy in [Test.bug(C)](tests/reentrancy-0.5.1-events.sol#L14-L17):\n\tExternal calls:\n\t- [c.f()](tests/reentrancy-0.5.1-events.sol#L15)\n\tEvent emitted after the call(s):\n\t- [E()](tests/reentrancy-0.5.1-events.sol#L16)\n", |
||||
"id": "9654da7d8b8d85c90bc2ee1ddaea365f98f14d9981149b354f8a3d84f98ea576", |
||||
"check": "reentrancy-events", |
||||
"impact": "Low", |
||||
"confidence": "Medium" |
||||
} |
||||
] |
||||
} |
||||
} |
@ -0,0 +1,24 @@ |
||||
contract C{ |
||||
|
||||
|
||||
function f() public{ |
||||
|
||||
} |
||||
|
||||
} |
||||
|
||||
|
||||
contract Test{ |
||||
event E(); |
||||
|
||||
function bug(C c) public{ |
||||
c.f(); |
||||
emit E(); |
||||
} |
||||
|
||||
function ok(C c) public{ |
||||
emit E(); |
||||
c.f(); |
||||
c.f(); |
||||
} |
||||
} |
Loading…
Reference in new issue