-
Notifications
You must be signed in to change notification settings - Fork 98
/
Copy path0x17fd666fa0784885fa1afec8ac624d9b7e72b752-FLIK-FLiK.sol
173 lines (133 loc) · 5.92 KB
/
0x17fd666fa0784885fa1afec8ac624d9b7e72b752-FLIK-FLiK.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
pragma solidity ^0.4.13;
contract owned {
address public owner;
function owned() {
owner = msg.sender;
}
modifier onlyOwner {
require(msg.sender == owner);
_;
}
function transferOwnership(address newOwner) onlyOwner {
owner = newOwner;
}
}
contract tokenRecipient { function receiveApproval(address _from, uint256 _value, address _token, bytes _extraData); }
contract FLiK is owned {
/* Public variables of the token */
string public standard = 'FLiK 0.1';
string public name;
string public symbol;
uint8 public decimals = 14;
uint256 public totalSupply;
bool public locked;
uint256 public icoSince;
uint256 public icoTill;
/* This creates an array with all balances */
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
/* This generates a public event on the blockchain that will notify clients */
event Transfer(address indexed from, address indexed to, uint256 value);
event IcoFinished();
uint256 public buyPrice = 1;
/* Initializes contract with initial supply tokens to the creator of the contract */
function FLiK(
uint256 initialSupply,
string tokenName,
string tokenSymbol,
uint256 _icoSince,
uint256 _icoTill
) {
totalSupply = initialSupply;
balanceOf[this] = totalSupply / 100 * 90; // Give the smart contract 90% of initial tokens
name = tokenName; // Set the name for display purposes
symbol = tokenSymbol; // Set the symbol for display purposes
balanceOf[msg.sender] = totalSupply / 100 * 10; // Give 10% of total supply to contract owner
Transfer(this, msg.sender, balanceOf[msg.sender]);
if(_icoSince == 0 && _icoTill == 0) {
icoSince = 1503187200;
icoTill = 1505865600;
}
else {
icoSince = _icoSince;
icoTill = _icoTill;
}
}
/* Send coins */
function transfer(address _to, uint256 _value) {
require(locked == false); // Check if smart contract is locked
require(balanceOf[msg.sender] >= _value); // Check if the sender has enough
require(balanceOf[_to] + _value > balanceOf[_to]); // Check for overflows
balanceOf[msg.sender] -= _value; // Subtract from the sender
balanceOf[_to] += _value; // Add the same to the recipient
Transfer(msg.sender, _to, _value); // Notify anyone listening that this transfer took place
}
/* Allow another contract to spend some tokens in your behalf */
function approve(address _spender, uint256 _value) 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) 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) returns (bool success) {
require(locked == false); // Check if smart contract is locked
require(_value > 0);
require(balanceOf[_from] >= _value); // Check if the sender has enough
require(balanceOf[_to] + _value > balanceOf[_to]); // Check for overflows
require(_value <= allowance[_from][msg.sender]); // Check allowance
balanceOf[_from] -= _value; // Subtract from the sender
balanceOf[_to] += _value; // Add the same to the recipient
allowance[_from][msg.sender] -= _value;
Transfer(_from, _to, _value);
return true;
}
function buy(uint256 ethers, uint256 time) internal {
require(locked == false); // Check if smart contract is locked
require(time >= icoSince && time <= icoTill); // check for ico dates
require(ethers > 0); // check if ethers is greater than zero
uint amount = ethers / buyPrice;
require(balanceOf[this] >= amount); // check if smart contract has sufficient number of tokens
balanceOf[msg.sender] += amount;
balanceOf[this] -= amount;
Transfer(this, msg.sender, amount);
}
function () payable {
buy(msg.value, now);
}
function internalIcoFinished(uint256 time) internal returns (bool) {
if(time > icoTill) {
uint256 unsoldTokens = balanceOf[this];
balanceOf[owner] += unsoldTokens;
balanceOf[this] = 0;
Transfer(this, owner, unsoldTokens);
IcoFinished();
return true;
}
return false;
}
/* 0x356e2927 */
function icoFinished() onlyOwner {
internalIcoFinished(now);
}
/* 0xd271011d */
function transferEthers() onlyOwner {
owner.transfer(this.balance);
}
function setBuyPrice(uint256 _buyPrice) onlyOwner {
buyPrice = _buyPrice;
}
/*
locking: 0x211e28b60000000000000000000000000000000000000000000000000000000000000001
unlocking: 0x211e28b60000000000000000000000000000000000000000000000000000000000000000
*/
function setLocked(bool _locked) onlyOwner {
locked = _locked;
}
}