add new features on cp
This commit is contained in:
@@ -29,7 +29,7 @@ contract CP is CPVesting {
|
||||
address[] calldata addressList,
|
||||
uint256[] calldata timeLine,
|
||||
uint256[] calldata valueList,
|
||||
bool isOpenTWAP
|
||||
bool[] calldata switches //0 isOverCapStop 1 isOpenTWAP
|
||||
) external {
|
||||
/*
|
||||
Address List
|
||||
@@ -59,9 +59,10 @@ contract CP is CPVesting {
|
||||
2. phase calm duration
|
||||
3. freeze duration
|
||||
4. vesting duration
|
||||
5. claim lock duration
|
||||
*/
|
||||
|
||||
require(timeLine.length == 5, "LIST_LENGTH_WRONG");
|
||||
require(timeLine.length == 6, "LIST_LENGTH_WRONG");
|
||||
|
||||
_PHASE_BID_STARTTIME_ = timeLine[0];
|
||||
_PHASE_BID_ENDTIME_ = _PHASE_BID_STARTTIME_.add(timeLine[1]);
|
||||
@@ -69,7 +70,7 @@ contract CP is CPVesting {
|
||||
|
||||
_FREEZE_DURATION_ = timeLine[3];
|
||||
_VESTING_DURATION_ = timeLine[4];
|
||||
|
||||
_CLAIM_LOCK_DURATION_ = timeLine[5];
|
||||
require(block.timestamp <= _PHASE_BID_STARTTIME_, "TIMELINE_WRONG");
|
||||
|
||||
/*
|
||||
@@ -93,7 +94,8 @@ contract CP is CPVesting {
|
||||
|
||||
_TOTAL_BASE_ = _BASE_TOKEN_.balanceOf(address(this));
|
||||
|
||||
_IS_OPEN_TWAP_ = isOpenTWAP;
|
||||
_IS_OVERCAP_STOP = switches[0];
|
||||
_IS_OPEN_TWAP_ = switches[1];
|
||||
|
||||
require(address(this).balance == _SETTEL_FUND_, "SETTLE_FUND_NOT_MATCH");
|
||||
}
|
||||
@@ -101,6 +103,6 @@ contract CP is CPVesting {
|
||||
// ============ Version Control ============
|
||||
|
||||
function version() virtual external pure returns (string memory) {
|
||||
return "CP 1.0.0";
|
||||
return "CP 1.0.1";
|
||||
}
|
||||
}
|
||||
|
||||
@@ -31,6 +31,9 @@ contract CPFunding is CPStorage {
|
||||
|
||||
modifier isBidderAllow(address bidder) {
|
||||
require(_BIDDER_PERMISSION_.isAllowed(bidder), "BIDDER_NOT_ALLOWED");
|
||||
if(_IS_OVERCAP_STOP) {
|
||||
require(_QUOTE_TOKEN_.balanceOf(address(this)) < _POOL_QUOTE_CAP_, "ALREADY_OVER_CAP");
|
||||
}
|
||||
_;
|
||||
}
|
||||
|
||||
|
||||
@@ -23,6 +23,7 @@ contract CPStorage is InitializableOwnable, ReentrancyGuard {
|
||||
uint256 internal constant _SETTLEMENT_EXPIRE_ = 86400 * 7;
|
||||
uint256 internal constant _SETTEL_FUND_ = 200 finney;
|
||||
bool public _IS_OPEN_TWAP_ = false;
|
||||
bool public _IS_OVERCAP_STOP = false;
|
||||
|
||||
// ============ Timeline ============
|
||||
|
||||
@@ -68,12 +69,13 @@ contract CPStorage is InitializableOwnable, ReentrancyGuard {
|
||||
uint256 public _K_;
|
||||
uint256 public _I_;
|
||||
|
||||
// ============ LP Token Vesting ============
|
||||
// ============ LP Token Vesting && Claim Params ============
|
||||
|
||||
uint256 public _TOTAL_LP_AMOUNT_;
|
||||
uint256 public _FREEZE_DURATION_;
|
||||
uint256 public _VESTING_DURATION_;
|
||||
uint256 public _CLIFF_RATE_;
|
||||
uint256 public _CLAIM_LOCK_DURATION_;
|
||||
|
||||
// ============ Modifiers ============
|
||||
|
||||
|
||||
@@ -40,6 +40,11 @@ contract CPVesting is CPFunding {
|
||||
_;
|
||||
}
|
||||
|
||||
modifier afterClaimLockDuration() {
|
||||
require(_SETTLED_ && block.timestamp >= _SETTLED_TIME_.add(_CLAIM_LOCK_DURATION_), "CLAIM_LOCKED");
|
||||
_;
|
||||
}
|
||||
|
||||
modifier afterFreeze() {
|
||||
require(_SETTLED_ && block.timestamp >= _SETTLED_TIME_.add(_FREEZE_DURATION_), "FREEZED");
|
||||
_;
|
||||
@@ -47,7 +52,7 @@ contract CPVesting is CPFunding {
|
||||
|
||||
// ============ Bidder Functions ============
|
||||
|
||||
function bidderClaim(address to,bytes calldata data) external afterSettlement {
|
||||
function bidderClaim(address to,bytes calldata data) external afterClaimLockDuration {
|
||||
require(!_CLAIMED_[msg.sender], "ALREADY_CLAIMED");
|
||||
_CLAIMED_[msg.sender] = true;
|
||||
|
||||
|
||||
@@ -13,7 +13,7 @@ interface ICP {
|
||||
address[] calldata addressList,
|
||||
uint256[] calldata timeLine,
|
||||
uint256[] calldata valueList,
|
||||
bool isOpenTWAP
|
||||
bool[] calldata switches
|
||||
) external;
|
||||
|
||||
function bid(address to) external;
|
||||
|
||||
@@ -41,6 +41,7 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
uint256 public _K_ = 0;
|
||||
uint256 public _CLIFF_RATE_ = 10**18;
|
||||
|
||||
mapping(address => address) liquidityProtectWhitelist;
|
||||
|
||||
// ============ Registry ============
|
||||
|
||||
@@ -52,6 +53,7 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
// ============ modifiers ===========
|
||||
|
||||
modifier valueCheck(
|
||||
address creator,
|
||||
address cpAddress,
|
||||
address baseToken,
|
||||
uint256[] memory timeLine,
|
||||
@@ -64,7 +66,9 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
|
||||
uint256 baseTokenBalance = IERC20(baseToken).balanceOf(cpAddress);
|
||||
require(valueList[0].mul(100) <= baseTokenBalance.mul(valueList[2]).div(10**18).mul(_CAP_RATIO_),"CP_FACTORY : QUOTE_CAP_INVALID");
|
||||
require(timeLine[3]>= _FREEZE_DURATION_, "CP_FACTORY : FREEZE_DURATION_INVALID");
|
||||
if(liquidityProtectWhitelist[creator] != baseToken) {
|
||||
require(timeLine[3]>= _FREEZE_DURATION_, "CP_FACTORY : FREEZE_DURATION_INVALID");
|
||||
}
|
||||
_;
|
||||
}
|
||||
|
||||
@@ -102,18 +106,17 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
function initCrowdPooling(
|
||||
address cpAddress,
|
||||
address creator,
|
||||
address baseToken,
|
||||
address quoteToken,
|
||||
address[] memory tokens,//0 baseToken 1 quoteToken
|
||||
uint256[] memory timeLine,
|
||||
uint256[] memory valueList,
|
||||
bool isOpenTWAP
|
||||
) external valueCheck(cpAddress,baseToken,timeLine,valueList) {
|
||||
bool[] memory switches
|
||||
) external valueCheck(creator,cpAddress,tokens[0],timeLine,valueList) {
|
||||
{
|
||||
address[] memory addressList = new address[](7);
|
||||
addressList[0] = creator;
|
||||
addressList[1] = _DEFAULT_MAINTAINER_;
|
||||
addressList[2] = baseToken;
|
||||
addressList[3] = quoteToken;
|
||||
addressList[2] = tokens[0];
|
||||
addressList[3] = tokens[1];
|
||||
addressList[4] = _DEFAULT_PERMISSION_MANAGER_;
|
||||
addressList[5] = _DEFAULT_MT_FEE_RATE_MODEL_;
|
||||
addressList[6] = _DVM_FACTORY_;
|
||||
@@ -122,14 +125,14 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
addressList,
|
||||
timeLine,
|
||||
valueList,
|
||||
isOpenTWAP
|
||||
switches
|
||||
);
|
||||
}
|
||||
|
||||
_REGISTRY_[baseToken][quoteToken].push(cpAddress);
|
||||
_REGISTRY_[tokens[0]][tokens[1]].push(cpAddress);
|
||||
_USER_REGISTRY_[creator].push(cpAddress);
|
||||
|
||||
emit NewCP(baseToken, quoteToken, creator, cpAddress);
|
||||
emit NewCP(tokens[0], tokens[1], creator, cpAddress);
|
||||
}
|
||||
|
||||
// ============ View Functions ============
|
||||
@@ -159,6 +162,10 @@ contract CrowdPoolingFactory is InitializableOwnable {
|
||||
}
|
||||
|
||||
// ============ Owner Functions ============
|
||||
|
||||
function setLiquidityProtectWhitelist(address creator, address baseToken) external onlyOwner {
|
||||
liquidityProtectWhitelist[creator] = baseToken;
|
||||
}
|
||||
|
||||
function updateCPTemplate(address _newCPTemplate) external onlyOwner {
|
||||
_CP_TEMPLATE_ = _newCPTemplate;
|
||||
|
||||
@@ -38,6 +38,7 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
uint256 public _VEST_DURATION_ = 0;
|
||||
uint256 public _CLIFF_RATE_ = 10**18;
|
||||
|
||||
mapping(address => address) liquidityProtectWhitelist;
|
||||
|
||||
// ============ Registry ============
|
||||
|
||||
@@ -49,6 +50,7 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
// ============ modifiers ===========
|
||||
|
||||
modifier valueCheck(
|
||||
address creator,
|
||||
address cpAddress,
|
||||
address baseToken,
|
||||
uint256[] memory timeLine,
|
||||
@@ -57,7 +59,10 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
require(timeLine[2] <= _CALM_DURATION_, "CP_FACTORY : PHASE_CALM_DURATION_INVALID");
|
||||
require(timeLine[4] == _VEST_DURATION_, "CP_FACTORY : VEST_DURATION_INVALID");
|
||||
require(valueList[3] == _CLIFF_RATE_, "CP_FACTORY : CLIFF_RATE_INVALID");
|
||||
require(timeLine[3] >= _FREEZE_DURATION_, "CP_FACTORY : FREEZE_DURATION_INVALID");
|
||||
|
||||
if(liquidityProtectWhitelist[creator] != baseToken) {
|
||||
require(timeLine[3]>= _FREEZE_DURATION_, "CP_FACTORY : FREEZE_DURATION_INVALID");
|
||||
}
|
||||
_;
|
||||
}
|
||||
|
||||
@@ -95,18 +100,17 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
function initCrowdPooling(
|
||||
address cpAddress,
|
||||
address creator,
|
||||
address baseToken,
|
||||
address quoteToken,
|
||||
address[] memory tokens,//0 baseToken 1 quoteToken
|
||||
uint256[] memory timeLine,
|
||||
uint256[] memory valueList,
|
||||
bool isOpenTWAP
|
||||
) external valueCheck(cpAddress,baseToken,timeLine,valueList) {
|
||||
bool[] memory switches
|
||||
) external valueCheck(creator,cpAddress,tokens[0],timeLine,valueList) {
|
||||
{
|
||||
address[] memory addressList = new address[](7);
|
||||
addressList[0] = creator;
|
||||
addressList[1] = _DEFAULT_MAINTAINER_;
|
||||
addressList[2] = baseToken;
|
||||
addressList[3] = quoteToken;
|
||||
addressList[2] = tokens[0];
|
||||
addressList[3] = tokens[1];
|
||||
addressList[4] = _DEFAULT_PERMISSION_MANAGER_;
|
||||
addressList[5] = _DEFAULT_MT_FEE_RATE_MODEL_;
|
||||
addressList[6] = _DVM_FACTORY_;
|
||||
@@ -117,14 +121,14 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
addressList,
|
||||
timeLine,
|
||||
valueList,
|
||||
isOpenTWAP
|
||||
switches
|
||||
);
|
||||
}
|
||||
|
||||
_REGISTRY_[baseToken][quoteToken].push(cpAddress);
|
||||
_REGISTRY_[tokens[0]][tokens[1]].push(cpAddress);
|
||||
_USER_REGISTRY_[creator].push(cpAddress);
|
||||
|
||||
emit NewCP(baseToken, quoteToken, creator, cpAddress);
|
||||
emit NewCP(tokens[0], tokens[1], creator, cpAddress);
|
||||
}
|
||||
|
||||
// ============ View Functions ============
|
||||
@@ -154,6 +158,10 @@ contract UpCrowdPoolingFactory is InitializableOwnable {
|
||||
}
|
||||
|
||||
// ============ Owner Functions ============
|
||||
|
||||
function setLiquidityProtectWhitelist(address creator, address baseToken) external onlyOwner {
|
||||
liquidityProtectWhitelist[creator] = baseToken;
|
||||
}
|
||||
|
||||
function updateCPTemplate(address _newCPTemplate) external onlyOwner {
|
||||
_CP_TEMPLATE_ = _newCPTemplate;
|
||||
|
||||
@@ -87,11 +87,10 @@ interface IDODOV2 {
|
||||
function initCrowdPooling(
|
||||
address cpAddress,
|
||||
address creator,
|
||||
address baseToken,
|
||||
address quoteToken,
|
||||
address[] memory tokens,
|
||||
uint256[] memory timeLine,
|
||||
uint256[] memory valueList,
|
||||
bool isOpenTWAP
|
||||
bool[] memory switches
|
||||
) external;
|
||||
|
||||
function bid(address to) external;
|
||||
|
||||
@@ -63,7 +63,7 @@ contract DODOCpProxy is ReentrancyGuard {
|
||||
uint256 baseInAmount,
|
||||
uint256[] memory timeLine,
|
||||
uint256[] memory valueList,
|
||||
bool isOpenTWAP,
|
||||
bool[] memory switches,
|
||||
uint256 deadLine
|
||||
) external payable preventReentrant judgeExpired(deadLine) returns (address payable newUpCrowdPooling) {
|
||||
address _baseToken = baseToken;
|
||||
@@ -82,14 +82,17 @@ contract DODOCpProxy is ReentrancyGuard {
|
||||
(bool success, ) = newUpCrowdPooling.call{value: msg.value}("");
|
||||
require(success, "DODOCpProxy: Transfer failed");
|
||||
|
||||
address[] memory tokens = new address[](2);
|
||||
tokens[0] = _baseToken;
|
||||
tokens[1] = _quoteToken;
|
||||
|
||||
IDODOV2(_UPCP_FACTORY_).initCrowdPooling(
|
||||
newUpCrowdPooling,
|
||||
msg.sender,
|
||||
_baseToken,
|
||||
_quoteToken,
|
||||
tokens,
|
||||
timeLine,
|
||||
valueList,
|
||||
isOpenTWAP
|
||||
switches
|
||||
);
|
||||
}
|
||||
|
||||
@@ -101,7 +104,7 @@ contract DODOCpProxy is ReentrancyGuard {
|
||||
uint256 baseInAmount,
|
||||
uint256[] memory timeLine,
|
||||
uint256[] memory valueList,
|
||||
bool isOpenTWAP,
|
||||
bool[] memory switches,
|
||||
uint256 deadLine
|
||||
) external payable preventReentrant judgeExpired(deadLine) returns (address payable newCrowdPooling) {
|
||||
address _baseToken = baseToken;
|
||||
@@ -120,14 +123,17 @@ contract DODOCpProxy is ReentrancyGuard {
|
||||
(bool success, ) = newCrowdPooling.call{value: msg.value}("");
|
||||
require(success, "DODOCpProxy: Transfer failed");
|
||||
|
||||
address[] memory tokens = new address[](2);
|
||||
tokens[0] = _baseToken;
|
||||
tokens[1] = _quoteToken;
|
||||
|
||||
IDODOV2(_CP_FACTORY_).initCrowdPooling(
|
||||
newCrowdPooling,
|
||||
msg.sender,
|
||||
_baseToken,
|
||||
_quoteToken,
|
||||
tokens,
|
||||
timeLine,
|
||||
valueList,
|
||||
isOpenTWAP
|
||||
switches
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user