* rename ERC20 to IERC20 * move ERC20.sol to IERC20.sol * rename StandardToken to ERC20 * rename StandardTokenMock to ERC20Mock * move StandardToken.sol to ERC20.sol, likewise test and mock files * rename MintableToken to ERC20Mintable * move MintableToken.sol to ERC20Mintable.sol, likewise test and mock files * rename BurnableToken to ERC20Burnable * move BurnableToken.sol to ERC20Burnable.sol, likewise for related files * rename CappedToken to ERC20Capped * move CappedToken.sol to ERC20Capped.sol, likewise for related files * rename PausableToken to ERC20Pausable * move PausableToken.sol to ERC20Pausable.sol, likewise for related files * rename DetailedERC20 to ERC20Detailed * move DetailedERC20.sol to ERC20Detailed.sol, likewise for related files * rename ERC721 to IERC721, and likewise for other related interfaces * move ERC721.sol to IERC721.sol, likewise for other 721 interfaces * rename ERC721Token to ERC721 * move ERC721Token.sol to ERC721.sol, likewise for related files * rename ERC721BasicToken to ERC721Basic * move ERC721BasicToken.sol to ERC721Basic.sol, likewise for related files * rename ERC721PausableToken to ERC721Pausable * move ERC721PausableToken.sol to ERC721Pausable.sol * rename ERC165 to IERC165 * move ERC165.sol to IERC165.sol * amend comment that ERC20 is based on FirstBlood * fix comments mentioning IERC721Receiver
61 lines
1.8 KiB
Solidity
61 lines
1.8 KiB
Solidity
pragma solidity ^0.4.24;
|
|
|
|
import "../crowdsale/validation/CappedCrowdsale.sol";
|
|
import "../crowdsale/distribution/RefundableCrowdsale.sol";
|
|
import "../crowdsale/emission/MintedCrowdsale.sol";
|
|
import "../token/ERC20/ERC20Mintable.sol";
|
|
|
|
|
|
/**
|
|
* @title SampleCrowdsaleToken
|
|
* @dev Very simple ERC20 Token that can be minted.
|
|
* It is meant to be used in a crowdsale contract.
|
|
*/
|
|
contract SampleCrowdsaleToken is ERC20Mintable {
|
|
|
|
string public constant name = "Sample Crowdsale Token";
|
|
string public constant symbol = "SCT";
|
|
uint8 public constant decimals = 18;
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* @title SampleCrowdsale
|
|
* @dev This is an example of a fully fledged crowdsale.
|
|
* The way to add new features to a base crowdsale is by multiple inheritance.
|
|
* In this example we are providing following extensions:
|
|
* CappedCrowdsale - sets a max boundary for raised funds
|
|
* RefundableCrowdsale - set a min goal to be reached and returns funds if it's not met
|
|
*
|
|
* After adding multiple features it's good practice to run integration tests
|
|
* to ensure that subcontracts works together as intended.
|
|
*/
|
|
// XXX There doesn't seem to be a way to split this line that keeps solium
|
|
// happy. See:
|
|
// https://github.com/duaraghav8/Solium/issues/205
|
|
// --elopio - 2018-05-10
|
|
// solium-disable-next-line max-len
|
|
contract SampleCrowdsale is CappedCrowdsale, RefundableCrowdsale, MintedCrowdsale {
|
|
|
|
constructor(
|
|
uint256 _openingTime,
|
|
uint256 _closingTime,
|
|
uint256 _rate,
|
|
address _wallet,
|
|
uint256 _cap,
|
|
ERC20Mintable _token,
|
|
uint256 _goal
|
|
)
|
|
public
|
|
Crowdsale(_rate, _wallet, _token)
|
|
CappedCrowdsale(_cap)
|
|
TimedCrowdsale(_openingTime, _closingTime)
|
|
RefundableCrowdsale(_goal)
|
|
{
|
|
//As goal needs to be met for a successful crowdsale
|
|
//the value needs to less or equal than a cap which is limit for accepted funds
|
|
require(_goal <= _cap);
|
|
}
|
|
}
|