aboutsummaryrefslogtreecommitdiffstats
path: root/utils/keys.go
blob: 2f39c10b2c92d32edc2e4be304c26d859045f2a7 (plain) (blame)
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
package utils

import (
    "fmt"
    "github.com/ethereum/eth-go/ethutil"
    "github.com/obscuren/secp256k1-go"
)

func CreateKeyPair(force bool) {
    data, _ := ethutil.Config.Db.Get([]byte("KeyRing"))
    if len(data) == 0 || force {
        pub, prv := secp256k1.GenerateKeyPair()
        pair := &ethutil.Key{PrivateKey: prv, PublicKey: pub}
        ethutil.Config.Db.Put([]byte("KeyRing"), pair.RlpEncode())
        mne := ethutil.MnemonicEncode(ethutil.Hex(prv))

        fmt.Printf(`
Generating new address and keypair.
Please keep your keys somewhere save.

++++++++++++++++ KeyRing +++++++++++++++++++
addr: %x
prvk: %x
pubk: %x
++++++++++++++++++++++++++++++++++++++++++++
save these words so you can restore your account later: %s
`, pair.Address(), prv, pub, mne)

    }
}

func ImportPrivateKey(prvKey string) {
    key := ethutil.FromHex(prvKey)
    msg := []byte("tmp")
    // Couldn't think of a better way to get the pub key
    sig, _ := secp256k1.Sign(msg, key)
    pub, _ := secp256k1.RecoverPubkey(msg, sig)
    pair := &ethutil.Key{PrivateKey: key, PublicKey: pub}
    ethutil.Config.Db.Put([]byte("KeyRing"), pair.RlpEncode())

    fmt.Printf(`
Importing private key

++++++++++++++++ KeyRing +++++++++++++++++++
addr: %x
prvk: %x
pubk: %x
++++++++++++++++++++++++++++++++++++++++++++

`, pair.Address(), key, pub)
}