// 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; mapping(bytes32 => bool) private contractFinished; constructor( IERC20 token, uint256 _proofPeriod, uint256 _proofTimeout, uint8 _proofDowntime, uint256 _collateralAmount, uint256 _slashMisses, uint256 _slashPercentage ) Marketplace( token, _collateralAmount, _proofPeriod, _proofTimeout, _proofDowntime ) { collateralAmount = _collateralAmount; slashMisses = _slashMisses; slashPercentage = _slashPercentage; } function getRequest(bytes32 id) public view returns (Request memory) { return _request(id); } function finishContract(bytes32 id) public { require(_host(id) != address(0), "Contract not started"); require(!contractFinished[id], "Contract already finished"); require(block.timestamp > proofEnd(id), "Contract has not ended yet"); contractFinished[id] = true; require( token.transfer(_host(id), _request(id).ask.reward), "Payment failed" ); } function missingProofs(bytes32 contractId) public view returns (uint256) { return _missed(contractId); } function isProofRequired(bytes32 contractId) public view returns (bool) { return _isProofRequired(contractId); } function willProofBeRequired(bytes32 contractId) public view returns (bool) { return _willProofBeRequired(contractId); } 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, bytes calldata proof) public { _submitProof(contractId, proof); } function markProofAsMissing(bytes32 contractId, uint256 period) public { _markProofAsMissing(contractId, period); if (_missed(contractId) % slashMisses == 0) { _slash(_host(contractId), slashPercentage); } } }