diff options
author | Maran <maran.hidskes@gmail.com> | 2014-05-14 20:04:43 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-05-14 20:04:43 +0800 |
commit | c9db87277be495b3567b2831f2f88b8192edb20f (patch) | |
tree | 3cd3abb22e998fe4ffaf3d3dd3e5571c422d5d69 /utils | |
parent | 2c7b625daaf062192db2fa604344f79c1bdbb232 (diff) | |
parent | f18ec51cb3959cc662bfc7b84314cd1d3b1541b5 (diff) | |
download | dexon-c9db87277be495b3567b2831f2f88b8192edb20f.tar.gz dexon-c9db87277be495b3567b2831f2f88b8192edb20f.tar.zst dexon-c9db87277be495b3567b2831f2f88b8192edb20f.zip |
Fix merge conflicts
Diffstat (limited to 'utils')
-rw-r--r-- | utils/cmd.go | 13 | ||||
-rw-r--r-- | utils/keys.go | 57 |
2 files changed, 61 insertions, 9 deletions
diff --git a/utils/cmd.go b/utils/cmd.go index 66cfbeff9..8395ac8fc 100644 --- a/utils/cmd.go +++ b/utils/cmd.go @@ -1,9 +1,7 @@ package utils import ( - "encoding/hex" "github.com/ethereum/eth-go" - "github.com/ethereum/eth-go/ethchain" "github.com/ethereum/eth-go/ethminer" "github.com/ethereum/eth-go/ethpub" "github.com/ethereum/eth-go/ethrpc" @@ -26,15 +24,12 @@ func DoMining(ethereum *eth.Ethereum) { // Set Mining status ethereum.Mining = true - data, _ := ethutil.Config.Db.Get([]byte("KeyRing")) - if len(data) == 0 { + if ethutil.GetKeyRing().Len() == 0 { log.Println("No address found, can't start mining") return } - - keyRing := ethutil.NewValueFromBytes(data) - addr := keyRing.Get(0).Bytes() - pair, _ := ethchain.NewKeyPairFromSec(ethutil.FromHex(hex.EncodeToString(addr))) + keyPair := ethutil.GetKeyRing().Get(0) + addr := keyPair.Address() go func() { // Give it some time to connect with peers @@ -45,7 +40,7 @@ func DoMining(ethereum *eth.Ethereum) { } log.Println("Miner started") - miner := ethminer.NewDefaultMiner(pair.Address(), ethereum) + miner := ethminer.NewDefaultMiner(addr, ethereum) miner.Start() }() } diff --git a/utils/keys.go b/utils/keys.go index 2f39c10b2..1c0f6a9d6 100644 --- a/utils/keys.go +++ b/utils/keys.go @@ -7,6 +7,60 @@ import ( ) func CreateKeyPair(force bool) { + if force { + ethutil.GetKeyRing().Reset() + fmt.Println("resetting") + } + + if ethutil.GetKeyRing().Get(0) == nil { + _, prv := secp256k1.GenerateKeyPair() + + keyPair, err := ethutil.GetKeyRing().NewKeyPair(prv) + if err != nil { + panic(err) + } + + mne := ethutil.MnemonicEncode(ethutil.Hex(keyPair.PrivateKey)) + + 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 +`, keyPair.Address(), keyPair.PrivateKey, keyPair.PublicKey, mne) + } +} + +func ImportPrivateKey(sec string) { + ethutil.GetKeyRing().Reset() + + keyPair, err := ethutil.GetKeyRing().NewKeyPair(ethutil.FromHex(sec)) + if err != nil { + panic(err) + } + + mne := ethutil.MnemonicEncode(ethutil.Hex(keyPair.PrivateKey)) + + 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 +`, keyPair.Address(), keyPair.PrivateKey, keyPair.PublicKey, mne) +} + +/* +func CreateKeyPair(force bool) { data, _ := ethutil.Config.Db.Get([]byte("KeyRing")) if len(data) == 0 || force { pub, prv := secp256k1.GenerateKeyPair() @@ -28,7 +82,9 @@ save these words so you can restore your account later: %s } } +*/ +/* func ImportPrivateKey(prvKey string) { key := ethutil.FromHex(prvKey) msg := []byte("tmp") @@ -49,3 +105,4 @@ pubk: %x `, pair.Address(), key, pub) } +*/ |