2021-11-02 09:04:51 +01:00
|
|
|
const { ethers } = require("hardhat")
|
2022-09-22 12:21:49 +10:00
|
|
|
const { hours } = require("./time")
|
|
|
|
const { currentTime } = require("./evm")
|
2023-01-17 11:07:12 +01:00
|
|
|
const { hexlify, randomBytes } = ethers.utils
|
2021-11-02 09:04:51 +01:00
|
|
|
|
2023-01-17 13:55:58 +01:00
|
|
|
const exampleConfiguration = () => ({
|
|
|
|
collateral: {
|
2023-03-30 11:11:21 +02:00
|
|
|
repairRewardPercentage: 10,
|
|
|
|
maxNumberOfSlashes: 5,
|
2023-01-17 13:55:58 +01:00
|
|
|
slashCriterion: 3,
|
|
|
|
slashPercentage: 10,
|
|
|
|
},
|
|
|
|
proofs: {
|
|
|
|
period: 10,
|
|
|
|
timeout: 5,
|
|
|
|
downtime: 64,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2022-09-22 12:21:49 +10:00
|
|
|
const exampleRequest = async () => {
|
|
|
|
const now = await currentTime()
|
|
|
|
return {
|
|
|
|
client: hexlify(randomBytes(20)),
|
|
|
|
ask: {
|
|
|
|
slots: 4,
|
|
|
|
slotSize: 1 * 1024 * 1024 * 1024, // 1 Gigabyte
|
|
|
|
duration: hours(10),
|
|
|
|
proofProbability: 4, // require a proof roughly once every 4 periods
|
|
|
|
reward: 84,
|
|
|
|
maxSlotLoss: 2,
|
2023-03-08 12:02:34 +01:00
|
|
|
collateral: 200,
|
2022-04-06 14:26:56 +02:00
|
|
|
},
|
2022-09-22 12:21:49 +10:00
|
|
|
content: {
|
|
|
|
cid: "zb2rhheVmk3bLks5MgzTqyznLu1zqGH5jrfTA1eAZXrjx7Vob",
|
2024-01-10 15:12:18 +01:00
|
|
|
merkleRoot: Array.from(randomBytes(32)),
|
2022-04-06 14:26:56 +02:00
|
|
|
},
|
2022-09-22 12:21:49 +10:00
|
|
|
expiry: now + hours(1),
|
|
|
|
nonce: hexlify(randomBytes(32)),
|
|
|
|
}
|
|
|
|
}
|
2022-02-15 17:01:54 +01:00
|
|
|
|
2023-01-17 13:55:58 +01:00
|
|
|
module.exports = { exampleConfiguration, exampleRequest }
|