2021-10-12 16:59:34 +02:00
|
|
|
const { ethers } = require("hardhat")
|
|
|
|
|
2021-10-14 14:49:29 +02:00
|
|
|
function hashRequest(duration, size, hash, proofPeriod, proofTimeout) {
|
2021-10-12 16:59:34 +02:00
|
|
|
return ethers.utils.solidityKeccak256(
|
2021-10-14 14:49:29 +02:00
|
|
|
["string", "uint", "uint", "bytes32", "uint", "uint"],
|
|
|
|
["[dagger.request.v1]", duration, size, hash, proofPeriod, proofTimeout]
|
2021-10-12 16:59:34 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:29:58 +02:00
|
|
|
function hashBid(requestHash, expiry, price) {
|
2021-10-12 16:59:34 +02:00
|
|
|
return ethers.utils.solidityKeccak256(
|
2021-10-18 15:29:58 +02:00
|
|
|
["string", "bytes32", "uint", "uint"],
|
|
|
|
["[dagger.bid.v1]", requestHash, expiry, price]
|
2021-10-12 16:59:34 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
async function sign(signer, hash) {
|
|
|
|
return await signer.signMessage(ethers.utils.arrayify(hash))
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = { hashRequest, hashBid, sign }
|