2022-12-01 21:42:27 +11:00

110 lines
3.1 KiB
Solidity

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "./Marketplace.sol";
import "./Proofs.sol";
import "./Collateral.sol";
contract Storage is Collateral, Marketplace {
uint256 public collateralAmount;
uint256 public slashMisses;
uint256 public slashPercentage;
uint256 public minCollateralThreshold;
constructor(
IERC20 token,
uint256 _proofPeriod,
uint256 _proofTimeout,
uint8 _proofDowntime,
uint256 _collateralAmount,
uint256 _slashMisses,
uint256 _slashPercentage,
uint256 _minCollateralThreshold
)
Marketplace(
token,
_collateralAmount,
_proofPeriod,
_proofTimeout,
_proofDowntime
)
{
collateralAmount = _collateralAmount;
slashMisses = _slashMisses;
slashPercentage = _slashPercentage;
minCollateralThreshold = _minCollateralThreshold;
}
function getRequest(DAL.RequestId requestId) public view returns (Marketplace.Request memory) {
DAL.Request storage request = _request(requestId);
return Request(DAL.ClientId.unwrap(request.client),
request.ask,
request.content,
request.expiry,
request.nonce);
// return _request(requestId);
}
function getSlot(DAL.SlotId slotId) public view returns (DAL.Slot memory) {
return _slot(slotId);
// return _slot(slotId);
}
function getHost(DAL.SlotId slotId) public view returns (DAL.HostId) {
return _host(slotId);
// return _host(slotId);
}
function missingProofs(DAL.SlotId slotId) public view returns (uint256) {
return _missed(_toProofId(slotId));
}
function isProofRequired(DAL.SlotId slotId) public view returns (bool) {
if(!_slotAcceptsProofs(slotId)) {
return false;
}
return _isProofRequired(_toProofId(slotId));
}
function willProofBeRequired(DAL.SlotId slotId) public view returns (bool) {
if(!_slotAcceptsProofs(slotId)) {
return false;
}
return _willProofBeRequired(_toProofId(slotId));
}
function getChallenge(DAL.SlotId slotId) public view returns (bytes32) {
if(!_slotAcceptsProofs(slotId)) {
return bytes32(0);
}
return _getChallenge(_toProofId(slotId));
}
function getPointer(DAL.SlotId slotId) public view returns (uint8) {
return _getPointer(_toProofId(slotId));
}
function submitProof(DAL.SlotId slotId, bytes calldata proof) public {
_submitProof(_toProofId(slotId), proof);
}
function markProofAsMissing(DAL.SlotId slotId, uint256 period)
public
slotMustAcceptProofs(slotId)
{
ProofId proofId = _toProofId(slotId);
_markProofAsMissing(proofId, period);
address host = DAL.HostId.unwrap(_host(slotId));
if (_missed(_toProofId(slotId)) % slashMisses == 0) {
_slash(host, slashPercentage);
if (balanceOf(host) < minCollateralThreshold) {
// When the collateral drops below the minimum threshold, the slot
// needs to be freed so that there is enough remaining collateral to be
// distributed for repairs and rewards (with any leftover to be burnt).
_freeSlot(slotId);
}
}
}
}