* Change import path from zos-lib to upgrades in all contracts * Update readme with new naming * Update package and deps names * Change path to initializable in AST of networks.jsons * Migrate manifest version * Use new oz file locations * Rename in ERC20Migrator comments * Update SDK install instructions in README * Update gitignore to use new session file name * trigger CI * Fixes to readme and package version * Use 2.5.0 release of OpenZeppelin SDK
63 lines
2.1 KiB
Solidity
63 lines
2.1 KiB
Solidity
pragma solidity ^0.5.2;
|
|
|
|
import "@openzeppelin/upgrades/contracts/Initializable.sol";
|
|
import "../crowdsale/validation/CappedCrowdsale.sol";
|
|
import "../crowdsale/distribution/RefundableCrowdsale.sol";
|
|
import "../crowdsale/emission/MintedCrowdsale.sol";
|
|
import "../token/ERC20/ERC20Mintable.sol";
|
|
import "../token/ERC20/ERC20Detailed.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 Initializable, ERC20Mintable, ERC20Detailed {
|
|
function initialize(address sender) public initializer {
|
|
ERC20Mintable.initialize(sender);
|
|
ERC20Detailed.initialize("Sample Crowdsale Token", "SCT", 18);
|
|
}
|
|
|
|
uint256[50] private ______gap;
|
|
}
|
|
|
|
/**
|
|
* @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
|
|
* MintedCrowdsale - assumes the token can be minted by the crowdsale, which does so
|
|
* when receiving purchases.
|
|
*
|
|
* After adding multiple features it's good practice to run integration tests
|
|
* to ensure that subcontracts works together as intended.
|
|
*/
|
|
contract SampleCrowdsale is Initializable, Crowdsale, CappedCrowdsale, RefundableCrowdsale, MintedCrowdsale {
|
|
|
|
function initialize(
|
|
uint256 openingTime,
|
|
uint256 closingTime,
|
|
uint256 rate,
|
|
address payable wallet,
|
|
uint256 cap,
|
|
ERC20Mintable token,
|
|
uint256 goal
|
|
)
|
|
public
|
|
initializer
|
|
{
|
|
Crowdsale.initialize(rate, wallet, token);
|
|
CappedCrowdsale.initialize(cap);
|
|
TimedCrowdsale.initialize(openingTime, closingTime);
|
|
RefundableCrowdsale.initialize(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);
|
|
}
|
|
|
|
uint256[50] private ______gap;
|
|
}
|