文件 1 的 1:Crowdsale.sol
pragma solidity 0.4.18;
contract IOwned {
function owner() public view returns (address) { owner; }
function transferOwnership(address _newOwner) public;
}
contract Owned is IOwned {
address public owner;
function Owned() public {
owner = msg.sender;
}
modifier validAddress(address _address) {
require(_address != 0x0);
_;
}
modifier onlyOwner {
assert(msg.sender == owner);
_;
}
function transferOwnership(address _newOwner) public validAddress(_newOwner) onlyOwner {
require(_newOwner != owner);
owner = _newOwner;
}
}
library SafeMath {
function mul(uint256 a, uint256 b) internal view returns (uint256) {
uint256 c = a * b;
assert(a == 0 || c / a == b);
return c;
}
function div(uint256 a, uint256 b) internal view returns (uint256) {
uint256 c = a / b;
return c;
}
function sub(uint256 a, uint256 b) internal view returns (uint256) {
assert(b <= a);
return a - b;
}
function add(uint256 a, uint256 b) internal view returns (uint256) {
uint256 c = a + b;
assert(c >= a);
return c;
}
}
contract IERC20Token {
function name() public view returns (string) { name; }
function symbol() public view returns (string) { symbol; }
function decimals() public view returns (uint8) { decimals; }
function totalSupply() public view returns (uint256) { totalSupply; }
function balanceOf(address _owner) public view returns (uint256 balance) { _owner; balance; }
function allowance(address _owner, address _spender) public view returns (uint256 remaining) { _owner; _spender; remaining; }
function transfer(address _to, uint256 _value) public returns (bool);
function transferFrom(address _from, address _to, uint256 _value) public returns (bool);
function approve(address _spender, uint256 _value) public returns (bool);
}
contract ERC20Token is IERC20Token {
using SafeMath for uint256;
string public standard = 'Token 0.1';
string public name = '';
string public symbol = '';
uint8 public decimals = 0;
uint256 public totalSupply = 0;
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
function ERC20Token(string _name, string _symbol, uint8 _decimals) public {
require(bytes(_name).length > 0 && bytes(_symbol).length > 0);
name = _name;
symbol = _symbol;
decimals = _decimals;
}
modifier validAddress(address _address) {
require(_address != 0x0);
_;
}
function transfer(address _to, uint256 _value) public validAddress(_to) returns (bool) {
require(_value <= balanceOf[msg.sender]);
balanceOf[msg.sender] = balanceOf[msg.sender].sub(_value);
balanceOf[_to] = balanceOf[_to].add(_value);
Transfer(msg.sender, _to, _value);
return true;
}
function transferFrom(address _from, address _to, uint256 _value) public validAddress(_to) returns (bool) {
require(_value <= allowance[_from][msg.sender]);
require(_value <= balanceOf[_from]);
allowance[_from][msg.sender] = allowance[_from][msg.sender].sub(_value);
balanceOf[_from] = balanceOf[_from].sub(_value);
balanceOf[_to] = balanceOf[_to].add(_value);
Transfer(_from, _to, _value);
return true;
}
function approve(address _spender, uint256 _value) public validAddress(_spender) returns (bool) {
require(_value == 0 || allowance[msg.sender][_spender] == 0);
allowance[msg.sender][_spender] = _value;
Approval(msg.sender, _spender, _value);
return true;
}
}
contract ISerenityToken {
function initialSupply () public view returns (uint256) { initialSupply; }
function totalSoldTokens () public view returns (uint256) { totalSoldTokens; }
function totalProjectToken() public view returns (uint256) { totalProjectToken; }
function fundingEnabled() public view returns (bool) { fundingEnabled; }
function transfersEnabled() public view returns (bool) { transfersEnabled; }
}
contract SerenityToken is ISerenityToken, ERC20Token, Owned {
using SafeMath for uint256;
address public fundingWallet;
bool public fundingEnabled = true;
uint256 public maxSaleToken = 400000000 ether;
uint256 public initialSupply = 400000000 ether;
uint256 public totalSoldTokens = 0;
uint256 public totalProjectToken;
bool public transfersEnabled = false;
mapping (address => bool) internal fundingWallets;
event Finalize(address indexed _from, uint256 _value);
event DisableTransfers(address indexed _from);
function SerenityToken() ERC20Token("Serenity", "SRNT", 18) public {
fundingWallet = msg.sender;
balanceOf[fundingWallet] = maxSaleToken;
balanceOf[0x47c8F28e6056374aBA3DF0854306c2556B104601] = maxSaleToken;
balanceOf[0xCAD0AfB8Ec657D0DB9518B930855534f6433360f] = maxSaleToken;
balanceOf[0x041375343c3Bd1Bb28b40b5Ce7b4665A9a6e21D0] = maxSaleToken;
fundingWallets[fundingWallet] = true;
fundingWallets[0x47c8F28e6056374aBA3DF0854306c2556B104601] = true;
fundingWallets[0xCAD0AfB8Ec657D0DB9518B930855534f6433360f] = true;
fundingWallets[0x041375343c3Bd1Bb28b40b5Ce7b4665A9a6e21D0] = true;
}
modifier validAddress(address _address) {
require(_address != 0x0);
_;
}
modifier transfersAllowed(address _address) {
if (fundingEnabled) {
require(fundingWallets[_address]);
}
else {
require(transfersEnabled);
}
_;
}
function transfer(address _to, uint256 _value) public validAddress(_to) transfersAllowed(msg.sender) returns (bool) {
return super.transfer(_to, _value);
}
function autoTransfer(address _to, uint256 _value) public validAddress(_to) onlyOwner returns (bool) {
return super.transfer(_to, _value);
}
function transferFrom(address _from, address _to, uint256 _value) public validAddress(_to) transfersAllowed(_from) returns (bool) {
return super.transferFrom(_from, _to, _value);
}
function getTotalSoldTokens() public view returns (uint256) {
uint256 result = 0;
result = result.add(maxSaleToken.sub(balanceOf[fundingWallet]));
result = result.add(maxSaleToken.sub(balanceOf[0x47c8F28e6056374aBA3DF0854306c2556B104601]));
result = result.add(maxSaleToken.sub(balanceOf[0xCAD0AfB8Ec657D0DB9518B930855534f6433360f]));
result = result.add(maxSaleToken.sub(balanceOf[0x041375343c3Bd1Bb28b40b5Ce7b4665A9a6e21D0]));
return result;
}
function finalize() external onlyOwner {
require(fundingEnabled);
totalSoldTokens = getTotalSoldTokens();
totalProjectToken = totalSoldTokens.mul(15).div(100);
balanceOf[fundingWallet] = 0;
balanceOf[0xCAD0AfB8Ec657D0DB9518B930855534f6433360f] = 0;
balanceOf[0x041375343c3Bd1Bb28b40b5Ce7b4665A9a6e21D0] = 0;
balanceOf[0x47c8F28e6056374aBA3DF0854306c2556B104601] = totalProjectToken;
fundingEnabled = false;
transfersEnabled = true;
Transfer(this, fundingWallet, 0);
Finalize(msg.sender, totalSupply);
}
function disableTransfers() external onlyOwner {
require(transfersEnabled);
transfersEnabled = false;
DisableTransfers(msg.sender);
}
function disableFundingWallets(address _address) external onlyOwner {
require(fundingEnabled);
require(fundingWallet != _address);
require(fundingWallets[_address]);
fundingWallets[_address] = false;
}
function enableFundingWallets(address _address) external onlyOwner {
require(fundingEnabled);
require(fundingWallet != _address);
fundingWallets[_address] = true;
}
}
contract Crowdsale {
using SafeMath for uint256;
SerenityToken public token;
mapping(uint256 => uint8) internal icoWeeksDiscounts;
bool public isICOStarted = false;
uint256 public icoStartTime;
uint256 public icoEndTime;
address public wallet = 0x47c8F28e6056374aBA3DF0854306c2556B104601;
event TokenPurchase(address indexed purchaser, address indexed beneficiary, uint256 value, uint256 amount);
modifier validAddress(address _address) {
require(_address != 0x0);
_;
}
function Crowdsale() public {
token = createTokenContract();
initDiscounts();
}
function initDiscounts() internal {
icoWeeksDiscounts[0] = 40;
icoWeeksDiscounts[1] = 35;
icoWeeksDiscounts[2] = 30;
icoWeeksDiscounts[3] = 25;
icoWeeksDiscounts[4] = 20;
icoWeeksDiscounts[5] = 10;
}
function createTokenContract() internal returns (SerenityToken) {
return new SerenityToken();
}
function () public payable {
buyTokens(msg.sender);
}
function getDiscount() internal view returns (uint8) {
require(isICOStarted == true);
require(icoStartTime < now);
require(icoEndTime > now);
uint256 weeksPassed = now.sub(icoStartTime).div(7 days);
return icoWeeksDiscounts[weeksPassed];
}
function buyTokens(address beneficiary) public validAddress(beneficiary) payable {
require(isICOStarted);
require(validPurchase());
uint8 discountPercents = getDiscount();
uint256 tokens = msg.value.mul(100).div(100 - discountPercents).mul(10000);
require(tokens >= 100 ether);
token.autoTransfer(beneficiary, tokens);
TokenPurchase(msg.sender, beneficiary, msg.value, tokens);
forwardFunds();
}
function activateICO(uint256 _icoEndTime) public {
require(msg.sender == wallet);
require(_icoEndTime >= now);
require(isICOStarted == false);
isICOStarted = true;
icoEndTime = _icoEndTime;
icoStartTime = now;
}
function forwardFunds() internal {
wallet.transfer(msg.value);
}
function finalize() public {
require(msg.sender == wallet);
token.finalize();
}
function validPurchase() internal view returns (bool) {
bool withinICOPeriod = isICOStarted && now >= icoStartTime && now <= icoEndTime;
bool nonZeroPurchase = msg.value != 0;
return withinICOPeriod && nonZeroPurchase;
}
}
{
"compilationTarget": {
"Crowdsale.sol": "Crowdsale"
},
"libraries": {},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}