-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathecrecover3.js
82 lines (69 loc) · 2.19 KB
/
ecrecover3.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// not working now
const contract = require('truffle-contract')
const Web3 = require('web3')
const provider = new Web3.providers.HttpProvider('http://127.0.0.1:9545')
const web3 = new Web3(provider)
const SignArtifact = require('./build/contracts/Sign')
const Sign = contract(SignArtifact)
Sign.setProvider(provider)
function splitSign(sign) {
sign = sign.startsWith('0x')? sign.substr(2): sign;
const r = '0x' + sign.slice(0, 64)
const s = '0x' + sign.slice(64, 128)
const v = '0x' + sign.slice(128, 130)
var v_decimal = web3.toDecimal(v)
if(v_decimal != 27 && v_decimal != 28) {
v_decimal += 27
}
return {r, s, v, v_decimal}
}
const addr = web3.eth.accounts[0]
const msg = '123'
var msg_hash = web3.sha3(msg)
var signature = web3.eth.sign(addr, msg_hash)
console.log(`address -----> ${addr}`)
console.log(`msg ---------> ${msg_hash}`)
console.log(`hex(msg) ----> ${msg_hash}`)
console.log(`sig ---------> ${signature}`)
var {r, s, v, v_decimal} = splitSign(signature)
console.log(`r -----------> ${r}`)
console.log(`s -----------> ${s}`)
console.log(`v -----------> ${v}`)
console.log(`vd ----------> ${v_decimal}`)
Sign.deployed().then(instance => {
return instance.getPrefix.call(
msg_hash
)
}).then(data => {
console.log(`-> getPreifx output: ${data}`)
})
var signMsg = "\x19Ethereum Signed Message:\n32" + msg_hash
console.log("<- signMsg: " + signMsg)
console.log("<- signMsgHex: " + web3.fromAscii(signMsg))
console.log("<- signMagHash: " + web3.sha3(web3.fromAscii(signMsg)))
var signMsgHash = web3.sha3(signMsg)
Sign.deployed().then(instance => {
return instance.recoverAddrFromHash.call(
signMsgHash,
v_decimal,
r,
s
)
}).then(data => {
console.log('-----data from hash------')
console.log('input hash ==> ' + signMsgHash)
console.log(`input addr ==> ${addr}`)
console.log(`output addr => ${data}`)
}).catch(e => {
console.log('i got an error')
console.log(e)
})
Sign.deployed().then(instance => {
return instance.hashBytes.call(
web3.fromAscii(signMsg)
)
}).then(data => {
console.log(`signMsg Hash output ${data}`)
})
// signature = msg + addr
// addr = msg + signature