-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathresult.txt
96 lines (68 loc) · 3.54 KB
/
result.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
13 warnings found!
================================ warning ================================
address(dao).call.value(amount)(bytes4(sha3("donate(uint256)")),amount);
^-- Use keccak256() instead of sha3()
https://github.com/ethereum/EIPs/issues/59
================================ warning ================================
msg.sender.send(amount);
^-- Use transfer() instead of send()
http://solidity.readthedocs.io/en/develop/types.html#members-of-addresses
================================ warning ================================
suicide(msg.sender);
^-- Use selfdestruct() instead of suicide()
https://github.com/ethereum/EIPs/blob/master/EIPS/eip-6.md
================================ warning ================================
throw;
^-- Use revert() instead of throw
https://solidity.readthedocs.io/en/develop/control-structures.html#error-handling-assert-require-revert-and-exceptions
================================ warning ================================
address(dao).call.value(amount)(bytes4(sha3("donate(uint256)")),amount);
^-- Low-level call() result unchecked
https://github.com/ConsenSys/smart-contract-best-practices#external-calls
================================ warning ================================
if (credit[msg.sender]>= amount) {
if (!msg.sender.call.value(amount)()) {
suicide(msg.sender);
throw;
}
credit[msg.sender]-=amount;
--> Could potentially lead to re-entrancy vulnerability
http://solidity.readthedocs.io/en/develop/security-considerations.html#re-entrancy
================================ warning ================================
if (yourGuess == now % 2 > 0) {
^-- Do not use now for randomness
https://github.com/ethereum/wiki/wiki/Safety#timestamp-dependence
================================ warning ================================
function queryCredit(address to) public returns (uint) {
// return credit[to];
}
--> No Return Statement
https://tool.smartdec.net/knowledge/SOLIDITY_FUNCTIONS_RETURNS_TYPE_AND_NO_RETURN
================================ warning ================================
function oddOrEven(bool yourGuess) external payable returns (bool) {
// uint now = 1;
if (yourGuess == now % 2 > 0) {
uint fee = msg.value / 10;
msg.sender.transfer(msg.value * 2 - fee);
}
}
--> No Return Statement
https://tool.smartdec.net/knowledge/SOLIDITY_FUNCTIONS_RETURNS_TYPE_AND_NO_RETURN
================================ warning ================================
function () {
// dont receive ether via fallback
}
--> Fallback function should have "payable" modifier.
http://solidity.readthedocs.io/en/develop/contracts.html#fallback-function
================================ warning ================================
uint d = b - a;
^-- The subtraction operation might overflow
https://ethereumdev.io/safemath-protect-overflows/
================================ warning ================================
uint c = a + b;
^-- The addition operation might overflow
https://ethereumdev.io/safemath-protect-overflows/
================================ warning ================================
uint e = a * b;
^-- The multiplication operation might overflow
https://ethereumdev.io/safemath-protect-overflows/