2021-10-12 16:59:34 +02:00
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
pragma solidity ^0.8.0;
|
|
|
|
|
2022-02-22 09:25:42 +01:00
|
|
|
import "./Marketplace.sol";
|
2021-11-01 12:30:35 +01:00
|
|
|
import "./Proofs.sol";
|
2022-02-15 17:54:19 +01:00
|
|
|
import "./Collateral.sol";
|
2021-10-12 16:59:34 +02:00
|
|
|
|
2022-06-13 10:40:18 +02:00
|
|
|
contract Storage is Collateral, Marketplace {
|
2022-02-15 17:54:19 +01:00
|
|
|
uint256 public collateralAmount;
|
2022-02-09 14:17:23 +01:00
|
|
|
uint256 public slashMisses;
|
|
|
|
uint256 public slashPercentage;
|
2022-09-13 17:18:55 +10:00
|
|
|
uint256 public minCollateralThreshold;
|
2021-11-02 11:19:52 +01:00
|
|
|
|
2021-11-04 14:19:58 +01:00
|
|
|
constructor(
|
|
|
|
IERC20 token,
|
2022-03-02 15:44:58 +01:00
|
|
|
uint256 _proofPeriod,
|
|
|
|
uint256 _proofTimeout,
|
2022-03-10 10:19:21 +01:00
|
|
|
uint8 _proofDowntime,
|
2022-02-15 17:54:19 +01:00
|
|
|
uint256 _collateralAmount,
|
2022-02-09 14:17:23 +01:00
|
|
|
uint256 _slashMisses,
|
2022-09-13 17:14:57 +10:00
|
|
|
uint256 _slashPercentage,
|
2022-09-13 17:18:55 +10:00
|
|
|
uint256 _minCollateralThreshold
|
2022-03-10 10:19:21 +01:00
|
|
|
)
|
2022-06-13 10:40:18 +02:00
|
|
|
Marketplace(
|
|
|
|
token,
|
|
|
|
_collateralAmount,
|
|
|
|
_proofPeriod,
|
|
|
|
_proofTimeout,
|
|
|
|
_proofDowntime
|
|
|
|
)
|
2022-03-10 10:19:21 +01:00
|
|
|
{
|
2022-02-15 17:54:19 +01:00
|
|
|
collateralAmount = _collateralAmount;
|
2021-11-04 14:19:58 +01:00
|
|
|
slashMisses = _slashMisses;
|
|
|
|
slashPercentage = _slashPercentage;
|
2022-09-13 17:18:55 +10:00
|
|
|
minCollateralThreshold = _minCollateralThreshold;
|
2021-11-02 12:45:09 +01:00
|
|
|
}
|
2021-10-20 12:07:35 +02:00
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function getRequest(bytes32 requestId) public view returns (Request memory) {
|
|
|
|
return _request(requestId);
|
2022-04-06 14:52:02 +02:00
|
|
|
}
|
|
|
|
|
2022-08-22 16:16:45 +10:00
|
|
|
function getSlot(bytes32 slotId) public view returns (Slot memory) {
|
|
|
|
return _slot(slotId);
|
|
|
|
}
|
|
|
|
|
2022-09-13 17:18:55 +10:00
|
|
|
function getHost(bytes32 slotId) public view returns (address) {
|
|
|
|
return _host(slotId);
|
2022-07-04 11:16:55 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function missingProofs(bytes32 slotId) public view returns (uint256) {
|
|
|
|
return _missed(slotId);
|
2021-10-20 12:07:35 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function isProofRequired(bytes32 slotId) public view returns (bool) {
|
2022-09-08 17:56:01 +10:00
|
|
|
if(!_slotAcceptsProofs(slotId)) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-08-17 15:24:19 +10:00
|
|
|
return _isProofRequired(slotId);
|
2021-10-14 12:37:14 +02:00
|
|
|
}
|
2021-10-18 14:55:59 +02:00
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function willProofBeRequired(bytes32 slotId) public view returns (bool) {
|
2022-09-08 17:56:01 +10:00
|
|
|
if(!_slotAcceptsProofs(slotId)) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-08-17 15:24:19 +10:00
|
|
|
return _willProofBeRequired(slotId);
|
2022-04-05 11:27:02 +02:00
|
|
|
}
|
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function getChallenge(bytes32 slotId) public view returns (bytes32) {
|
2022-09-08 17:56:01 +10:00
|
|
|
if(!_slotAcceptsProofs(slotId)) {
|
|
|
|
return bytes32(0);
|
|
|
|
}
|
2022-08-17 15:24:19 +10:00
|
|
|
return _getChallenge(slotId);
|
2022-03-10 13:04:46 +01:00
|
|
|
}
|
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function getPointer(bytes32 slotId) public view returns (uint8) {
|
|
|
|
return _getPointer(slotId);
|
2022-03-10 13:35:41 +01:00
|
|
|
}
|
|
|
|
|
2022-08-17 15:24:19 +10:00
|
|
|
function submitProof(bytes32 slotId, bytes calldata proof) public {
|
|
|
|
_submitProof(slotId, proof);
|
2021-10-19 09:37:03 +02:00
|
|
|
}
|
|
|
|
|
2022-09-08 17:56:01 +10:00
|
|
|
function markProofAsMissing(bytes32 slotId, uint256 period)
|
|
|
|
public
|
|
|
|
slotMustAcceptProofs(slotId)
|
|
|
|
{
|
2022-08-17 15:24:19 +10:00
|
|
|
_markProofAsMissing(slotId, period);
|
2022-09-13 17:18:55 +10:00
|
|
|
address host = _host(slotId);
|
|
|
|
if (_missed(slotId) % slashMisses == 0) {
|
|
|
|
|
|
|
|
uint256 slashAmount = _slashAmount(host, slashPercentage);
|
|
|
|
if (balanceOf(host) - slashAmount < minCollateralThreshold) {
|
|
|
|
// If host has been slashed enough such that the next slashing would
|
|
|
|
// cause the collateral to drop below the minimum threshold, the slot
|
|
|
|
// needs to be freed as the remaining collateral must be used for
|
|
|
|
// repairs and rewards (with any leftover to be burnt).
|
|
|
|
_freeSlot(slotId);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
_slash(host, slashPercentage);
|
|
|
|
}
|
2022-09-13 17:14:57 +10:00
|
|
|
}
|
2021-10-19 09:37:03 +02:00
|
|
|
}
|
2021-10-12 16:59:34 +02:00
|
|
|
}
|