2021-10-12 16:59:34 +02:00
|
|
|
const { ethers } = require("hardhat")
|
|
|
|
|
2021-11-02 09:45:49 +01:00
|
|
|
function hashRequest({
|
|
|
|
duration, size, contentHash, proofPeriod, proofTimeout, nonce
|
|
|
|
}) {
|
2021-10-20 14:28:05 +02:00
|
|
|
const type = "[dagger.request.v1]"
|
2021-10-12 16:59:34 +02:00
|
|
|
return ethers.utils.solidityKeccak256(
|
2021-10-20 14:28:05 +02:00
|
|
|
["string", "uint", "uint", "bytes32", "uint", "uint", "bytes32"],
|
2021-11-02 09:45:49 +01:00
|
|
|
[type, duration, size, contentHash, proofPeriod, proofTimeout, nonce]
|
2021-10-12 16:59:34 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-11-02 09:45:49 +01:00
|
|
|
function hashBid({requestHash, bidExpiry, price}) {
|
2021-10-20 14:28:05 +02:00
|
|
|
const type = "[dagger.bid.v1]"
|
2021-10-12 16:59:34 +02:00
|
|
|
return ethers.utils.solidityKeccak256(
|
2021-10-18 15:29:58 +02:00
|
|
|
["string", "bytes32", "uint", "uint"],
|
2021-11-02 09:45:49 +01:00
|
|
|
[type, requestHash, bidExpiry, 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 }
|