2019-12-19 19:27:27 +01:00
|
|
|
// TODO: Make independent version for Nimbus
|
|
|
|
|
|
|
|
package account
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/accounts"
|
|
|
|
"github.com/ethereum/go-ethereum/accounts/keystore"
|
2020-01-02 10:10:19 +01:00
|
|
|
|
2019-12-30 11:28:44 +01:00
|
|
|
gethbridge "github.com/status-im/status-go/eth-node/bridge/geth"
|
2019-12-19 19:27:27 +01:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
// makeAccountManager creates ethereum accounts.Manager with single disk backend and lightweight kdf.
|
|
|
|
// If keydir is empty new temporary directory with go-ethereum-keystore will be intialized.
|
|
|
|
func makeAccountManager(keydir string) (manager *accounts.Manager, err error) {
|
|
|
|
if keydir == "" {
|
|
|
|
// There is no datadir.
|
|
|
|
keydir, err = ioutil.TempDir("", "go-ethereum-keystore")
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if err := os.MkdirAll(keydir, 0700); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
config := accounts.Config{InsecureUnlockAllowed: false}
|
|
|
|
return accounts.NewManager(&config, keystore.NewKeyStore(keydir, keystore.LightScryptN, keystore.LightScryptP)), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func makeKeyStore(manager *accounts.Manager) (types.KeyStore, error) {
|
|
|
|
backends := manager.Backends(keystore.KeyStoreType)
|
|
|
|
if len(backends) == 0 {
|
|
|
|
return nil, ErrAccountKeyStoreMissing
|
|
|
|
}
|
|
|
|
keyStore, ok := backends[0].(*keystore.KeyStore)
|
|
|
|
if !ok {
|
|
|
|
return nil, ErrAccountKeyStoreMissing
|
|
|
|
}
|
|
|
|
|
2019-12-30 11:28:44 +01:00
|
|
|
return gethbridge.WrapKeyStore(keyStore), nil
|
2019-12-19 19:27:27 +01:00
|
|
|
}
|