mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-15 00:04:17 +00:00
73 lines
2.1 KiB
Solidity
73 lines
2.1 KiB
Solidity
/* solium-disable no-empty-blocks */
|
|
/* solium-disable security/no-inline-assembly */
|
|
|
|
pragma solidity >=0.5.0 <0.6.0;
|
|
|
|
|
|
/**
|
|
* @dev Uses ethereum signed messages
|
|
*/
|
|
contract MessageSigned {
|
|
|
|
constructor() internal {}
|
|
|
|
/**
|
|
* @dev recovers address who signed the message
|
|
* @param _signHash operation ethereum signed message hash
|
|
* @param _messageSignature message `_signHash` signature
|
|
*/
|
|
function _recoverAddress(bytes32 _signHash, bytes memory _messageSignature)
|
|
internal
|
|
pure
|
|
returns(address)
|
|
{
|
|
uint8 v;
|
|
bytes32 r;
|
|
bytes32 s;
|
|
(v,r,s) = signatureSplit(_messageSignature);
|
|
return ecrecover(
|
|
_signHash,
|
|
v,
|
|
r,
|
|
s
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dev Hash a hash with `"\x19Ethereum Signed Message:\n32"`
|
|
* @param _hash Sign to hash.
|
|
* @return Hash to be signed.
|
|
*/
|
|
function _getSignHash(bytes32 _hash) internal pure returns (bytes32 signHash) {
|
|
signHash = keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", _hash));
|
|
}
|
|
|
|
/**
|
|
* @dev divides bytes signature into `uint8 v, bytes32 r, bytes32 s`
|
|
* @param _signature Signature string
|
|
*/
|
|
function signatureSplit(bytes memory _signature)
|
|
internal
|
|
pure
|
|
returns (uint8 v, bytes32 r, bytes32 s)
|
|
{
|
|
require(_signature.length == 65, "Bad signature length");
|
|
// The signature format is a compact form of:
|
|
// {bytes32 r}{bytes32 s}{uint8 v}
|
|
// Compact means, uint8 is not padded to 32 bytes.
|
|
assembly {
|
|
r := mload(add(_signature, 32))
|
|
s := mload(add(_signature, 64))
|
|
// Here we are loading the last 32 bytes, including 31 bytes
|
|
// of 's'. There is no 'mload8' to do this.
|
|
//
|
|
// 'byte' is not working due to the Solidity parser, so lets
|
|
// use the second best option, 'and'
|
|
v := and(mload(add(_signature, 65)), 0xff)
|
|
}
|
|
if (v < 27) {
|
|
v += 27;
|
|
}
|
|
require(v == 27 || v == 28, "Bad signature version");
|
|
}
|
|
} |