99 lines
2.8 KiB
Solidity
Raw Normal View History

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "./Marketplace.sol";
import "./Proofs.sol";
import "./Collateral.sol";
contract Storage is Collateral, Marketplace, Proofs {
uint256 public collateralAmount;
2022-02-09 14:17:23 +01:00
uint256 public slashMisses;
uint256 public slashPercentage;
mapping(bytes32 => ContractState) private contractState;
constructor(
IERC20 token,
uint256 _proofPeriod,
uint256 _proofTimeout,
2022-03-10 10:19:21 +01:00
uint8 _proofDowntime,
uint256 _collateralAmount,
2022-02-09 14:17:23 +01:00
uint256 _slashMisses,
uint256 _slashPercentage
2022-03-10 10:19:21 +01:00
)
Marketplace(token, _collateralAmount)
Proofs(_proofPeriod, _proofTimeout, _proofDowntime)
{
collateralAmount = _collateralAmount;
slashMisses = _slashMisses;
slashPercentage = _slashPercentage;
2021-11-02 12:45:09 +01:00
}
function startContract(bytes32 id) public {
Offer storage offer = _offer(id);
require(msg.sender == offer.host, "Only host can call this function");
require(_selectedOffer(offer.requestId) == id, "Offer was not selected");
contractState[id] = ContractState.started;
Request storage request = _request(offer.requestId);
_expectProofs(id, request.proofProbability, request.duration);
}
2021-11-04 10:19:23 +01:00
function finishContract(bytes32 id) public {
require(contractState[id] == ContractState.started, "Contract not started");
require(block.timestamp > proofEnd(id), "Contract has not ended yet");
contractState[id] = ContractState.finished;
Offer storage offer = _offer(id);
require(token.transfer(offer.host, offer.price), "Payment failed");
}
function proofPeriod() public view returns (uint256) {
return _period();
}
function proofTimeout() public view returns (uint256) {
return _timeout();
}
2022-02-09 14:17:23 +01:00
function proofEnd(bytes32 contractId) public view returns (uint256) {
return _end(contractId);
}
2022-02-09 14:17:23 +01:00
function missingProofs(bytes32 contractId) public view returns (uint256) {
return _missed(contractId);
}
function isProofRequired(bytes32 contractId) public view returns (bool) {
return _isProofRequired(contractId);
}
2021-10-18 14:55:59 +02:00
function willProofBeRequired(bytes32 contractId) public view returns (bool) {
return _willProofBeRequired(contractId);
}
2022-03-10 13:04:46 +01:00
function getChallenge(bytes32 contractId) public view returns (bytes32) {
return _getChallenge(contractId);
}
function getPointer(bytes32 id) public view returns (uint8) {
return _getPointer(id);
}
function submitProof(bytes32 contractId, bool proof) public {
_submitProof(contractId, proof);
2021-10-19 09:37:03 +02:00
}
function markProofAsMissing(bytes32 contractId, uint256 period) public {
_markProofAsMissing(contractId, period);
if (_missed(contractId) % slashMisses == 0) {
Offer storage offer = _offer(contractId);
_slash(offer.host, slashPercentage);
}
2021-10-19 09:37:03 +02:00
}
enum ContractState {
none,
started,
finished
}
}