forked from ScrypHQ/scryp-dapp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathScrypTestFlight.sol
193 lines (158 loc) · 5.73 KB
/
ScrypTestFlight.sol
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
pragma solidity ^0.4.24;
/* Make sure other contracts all in same directory */
import "./Owned.sol";
import "./TokenRecipient.sol";
contract ScrypTestflight is Owned {
/* Public variables of the token */
string public standard = "Test Scryp 0.1";
string public name;
string public symbol;
uint8 public decimals;
uint256 public totalSupply;
/* This creates an array with all balances */
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
/* These arrays are for saving the total USD saved and the total Scryp
earned per each user */
mapping (address => uint256) public usdSaved;
mapping (address => uint256) public scrypEarned;
/* This generates a public event on the blockchain
that will notify clients */
event Transfer(address indexed from, address indexed to, uint256 value);
/* This notifies clients about the amount burnt */
event Burn(address indexed from, uint256 value);
/* Initializes contract with initial supply tokens
to the creator of the contract */
constructor(
uint256 initialSupply,
string tokenName,
uint8 decimalUnits,
string tokenSymbol,
address centralMinter
)
public
{
if (centralMinter != 0 ) {
owner = centralMinter;
}
/* Give the creator all initial tokens */
balanceOf[msg.sender] = initialSupply;
/* Count the initial supply as Scryp earned by the creator */
scrypEarned[msg.sender] = initialSupply;
/* Update total supply */
totalSupply = initialSupply;
/* Set the name for display purposes */
name = tokenName;
/* Set the symbol for display purposes */
symbol = tokenSymbol;
/* Amount of decimals for display purposes */
decimals = decimalUnits;
}
/* This is a function allowing the owner to mint new tokens after
contract deployment */
function mintToken(address target, uint256 mintedAmount) onlyOwner public {
balanceOf[target] += mintedAmount;
scrypEarned[target] += mintedAmount;
totalSupply += mintedAmount;
emit Transfer(0, owner, mintedAmount);
emit Transfer(owner, target, mintedAmount);
}
/* Send coins */
function transfer(address _to, uint256 _value) public {
/* Prevent transfer to 0x0 address. Use burn() instead */
require(_to != 0x0);
/* Check if the sender has enough */
require(balanceOf[msg.sender] >= _value);
/* Check for overflows */
require((balanceOf[_to] + _value) >= balanceOf[_to]);
/* Subtract from the sender */
balanceOf[msg.sender] -= _value;
/* Add the same to the recipient */
balanceOf[_to] += _value;
scrypEarned[_to] += _value;
/* Notify anyone listening that this transfer took place */
emit Transfer(msg.sender, _to, _value);
}
/* Allow another contract to spend some tokens in your behalf */
function approve(
address _spender,
uint256 _value
)
public
returns (bool success)
{
allowance[msg.sender][_spender] = _value;
return true;
}
/* Approve and then communicate the approved contract in a single tx */
function approveAndCall(
address _spender,
uint256 _value,
bytes _extraData
)
public
returns (bool success)
{
TokenRecipient spender = TokenRecipient(_spender);
if (approve(_spender, _value)) {
spender.receiveApproval(msg.sender, _value, this, _extraData);
return true;
}
}
/* A contract attempts to get the coins */
function transferFrom(
address _from,
address _to,
uint256 _value
)
public
returns (bool success)
{
/* Prevent transfer to 0x0 address. Use burn() instead */
require(_to != 0x0);
/* Check if the sender has enough */
require(balanceOf[_from] >= _value);
/* Check for overflows */
require((balanceOf[_to] + _value) >= balanceOf[_to]);
/* Check allowance */
require(_value <= allowance[_from][msg.sender]);
/* Subtract from the sender */
balanceOf[_from] -= _value;
/* Add the same to the recipient */
balanceOf[_to] += _value;
scrypEarned[_to] += _value;
allowance[_from][msg.sender] -= _value;
emit Transfer(_from, _to, _value);
return true;
}
function burn(uint256 _value) public returns (bool success) {
/* Check if the sender has enough */
require(balanceOf[msg.sender] >= _value);
/* Subtract from the sender */
balanceOf[msg.sender] -= _value;
usdSaved[msg.sender] += _value;
/* Updates totalSupply */
totalSupply -= _value;
emit Burn(msg.sender, _value);
return true;
}
function burnFrom(
address _from,
uint256 _value
)
public
returns (bool success)
{
/* Check if the sender has enough */
require(balanceOf[_from] >= _value);
/* Check allowance */
require(_value <= allowance[_from][msg.sender]);
/* Subtract from the sender */
balanceOf[_from] -= _value;
usdSaved[_from] += _value;
/* Updates totalSupply */
totalSupply -= _value;
emit Burn(_from, _value);
return true;
}
}