diff options
author | Fabio Berger <me@fabioberger.com> | 2017-11-10 06:18:03 +0800 |
---|---|---|
committer | Fabio Berger <me@fabioberger.com> | 2017-11-10 06:18:03 +0800 |
commit | 62861d1e1315a14e955b30a45db05e7907b0d22d (patch) | |
tree | 86077be09b3a9ce41923c44fd57ecede1a94cc1d /src/utils | |
parent | 0c8886ad0c0e1cffa7da0495a648028d1fe54476 (diff) | |
download | dexon-0x-contracts-62861d1e1315a14e955b30a45db05e7907b0d22d.tar.gz dexon-0x-contracts-62861d1e1315a14e955b30a45db05e7907b0d22d.tar.zst dexon-0x-contracts-62861d1e1315a14e955b30a45db05e7907b0d22d.zip |
Move isValidSignature implementation into signatureUtils
Diffstat (limited to 'src/utils')
-rw-r--r-- | src/utils/signature_utils.ts | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/utils/signature_utils.ts b/src/utils/signature_utils.ts index b312b5554..d066f8bf0 100644 --- a/src/utils/signature_utils.ts +++ b/src/utils/signature_utils.ts @@ -2,6 +2,21 @@ import * as ethUtil from 'ethereumjs-util'; import {ECSignature} from '../types'; export const signatureUtils = { + isValidSignature(data: string, signature: ECSignature, signerAddress: string): boolean { + const dataBuff = ethUtil.toBuffer(data); + const msgHashBuff = ethUtil.hashPersonalMessage(dataBuff); + try { + const pubKey = ethUtil.ecrecover( + msgHashBuff, + signature.v, + ethUtil.toBuffer(signature.r), + ethUtil.toBuffer(signature.s)); + const retrievedAddress = ethUtil.bufferToHex(ethUtil.pubToAddress(pubKey)); + return retrievedAddress === signerAddress; + } catch (err) { + return false; + } + }, parseSignatureHexAsVRS(signatureHex: string): ECSignature { const signatureBuffer = ethUtil.toBuffer(signatureHex); let v = signatureBuffer[0]; |