Improve ECDSA tests and docs (#2619)
This commit is contained in:
@ -4,23 +4,6 @@ function toEthSignedMessageHash (messageHex) {
|
||||
return web3.utils.sha3(Buffer.concat([prefix, messageBuffer]));
|
||||
}
|
||||
|
||||
function fixSignature (signature) {
|
||||
// in geth its always 27/28, in ganache its 0/1. Change to 27/28 to prevent
|
||||
// signature malleability if version is 0/1
|
||||
// see https://github.com/ethereum/go-ethereum/blob/v1.8.23/internal/ethapi/api.go#L465
|
||||
let v = parseInt(signature.slice(130, 132), 16);
|
||||
if (v < 27) {
|
||||
v += 27;
|
||||
}
|
||||
const vHex = v.toString(16);
|
||||
return signature.slice(0, 130) + vHex;
|
||||
}
|
||||
|
||||
// signs message in node (ganache auto-applies "Ethereum Signed Message" prefix)
|
||||
async function signMessage (signer, messageHex = '0x') {
|
||||
return fixSignature(await web3.eth.sign(messageHex, signer));
|
||||
};
|
||||
|
||||
/**
|
||||
* Create a signer between a contract and a signer for a voucher of method, args, and redeemer
|
||||
* Note that `method` is the web3 method, not the truffle-contract method
|
||||
@ -55,12 +38,10 @@ const getSignFor = (contract, signer) => (redeemer, methodName, methodArgs = [])
|
||||
|
||||
// return the signature of the "Ethereum Signed Message" hash of the hash of `parts`
|
||||
const messageHex = web3.utils.soliditySha3(...parts);
|
||||
return signMessage(signer, messageHex);
|
||||
return web3.eth.sign(messageHex, signer);
|
||||
};
|
||||
|
||||
module.exports = {
|
||||
signMessage,
|
||||
toEthSignedMessageHash,
|
||||
fixSignature,
|
||||
getSignFor,
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user