2020-10-15 22:31:52 +00:00
|
|
|
package accounts
|
2020-07-20 21:12:46 +00:00
|
|
|
|
|
|
|
import (
|
2022-02-08 19:13:36 +00:00
|
|
|
"context"
|
2023-06-14 20:48:30 +00:00
|
|
|
"encoding/json"
|
2020-07-22 04:49:04 +00:00
|
|
|
"fmt"
|
2020-07-20 21:12:46 +00:00
|
|
|
"os"
|
|
|
|
"path/filepath"
|
2020-08-06 23:40:49 +00:00
|
|
|
"sort"
|
2020-07-20 21:12:46 +00:00
|
|
|
"testing"
|
|
|
|
|
2023-03-17 18:52:56 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v4/config/params"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/crypto/bls"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/encoding/bytesutil"
|
|
|
|
ethpbservice "github.com/prysmaticlabs/prysm/v4/proto/eth/service"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/testing/assert"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/testing/require"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/validator/accounts/iface"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/validator/keymanager"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/validator/keymanager/local"
|
2020-07-20 21:12:46 +00:00
|
|
|
)
|
|
|
|
|
2022-02-08 19:13:36 +00:00
|
|
|
func TestImportAccounts_NoPassword(t *testing.T) {
|
|
|
|
local.ResetCaches()
|
|
|
|
walletDir, passwordsDir, passwordFilePath := setupWalletAndPasswordsDir(t)
|
|
|
|
keysDir := filepath.Join(t.TempDir(), "keysDir")
|
|
|
|
require.NoError(t, os.MkdirAll(keysDir, os.ModePerm))
|
|
|
|
|
|
|
|
cliCtx := setupWalletCtx(t, &testWalletConfig{
|
|
|
|
walletDir: walletDir,
|
|
|
|
passwordsDir: passwordsDir,
|
|
|
|
keysDir: keysDir,
|
|
|
|
keymanagerKind: keymanager.Local,
|
|
|
|
walletPasswordFile: passwordFilePath,
|
|
|
|
accountPasswordFile: passwordFilePath,
|
|
|
|
})
|
2022-09-02 14:56:47 +00:00
|
|
|
opts := []Option{
|
|
|
|
WithWalletDir(walletDir),
|
|
|
|
WithKeymanagerType(keymanager.Local),
|
|
|
|
WithWalletPassword(password),
|
|
|
|
}
|
|
|
|
acc, err := NewCLIManager(opts...)
|
|
|
|
require.NoError(t, err)
|
|
|
|
w, err := acc.WalletCreate(cliCtx.Context)
|
2022-02-08 19:13:36 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
km, err := w.InitializeKeymanager(cliCtx.Context, iface.InitKeymanagerConfig{ListenForChanges: false})
|
|
|
|
require.NoError(t, err)
|
|
|
|
importer, ok := km.(keymanager.Importer)
|
|
|
|
require.Equal(t, true, ok)
|
|
|
|
resp, err := ImportAccounts(context.Background(), &ImportAccountsConfig{
|
2022-06-21 15:26:56 +00:00
|
|
|
Keystores: []*keymanager.Keystore{{}},
|
2022-02-08 19:13:36 +00:00
|
|
|
Importer: importer,
|
|
|
|
AccountPassword: "",
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(resp))
|
|
|
|
require.Equal(t, resp[0].Status, ethpbservice.ImportedKeystoreStatus_ERROR)
|
2020-07-31 20:17:39 +00:00
|
|
|
}
|
|
|
|
|
2020-08-06 23:40:49 +00:00
|
|
|
func TestImport_SortByDerivationPath(t *testing.T) {
|
2022-02-01 19:54:19 +00:00
|
|
|
local.ResetCaches()
|
2020-08-06 23:40:49 +00:00
|
|
|
type test struct {
|
|
|
|
name string
|
|
|
|
input []string
|
|
|
|
want []string
|
|
|
|
}
|
|
|
|
tests := []test{
|
|
|
|
{
|
|
|
|
name: "Basic sort",
|
|
|
|
input: []string{
|
|
|
|
"keystore_m_12381_3600_2_0_0.json",
|
|
|
|
"keystore_m_12381_3600_1_0_0.json",
|
|
|
|
"keystore_m_12381_3600_0_0_0.json",
|
|
|
|
},
|
|
|
|
want: []string{
|
|
|
|
"keystore_m_12381_3600_0_0_0.json",
|
|
|
|
"keystore_m_12381_3600_1_0_0.json",
|
|
|
|
"keystore_m_12381_3600_2_0_0.json",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Large digit accounts",
|
|
|
|
input: []string{
|
|
|
|
"keystore_m_12381_3600_30020330_0_0.json",
|
|
|
|
"keystore_m_12381_3600_430490934_0_0.json",
|
|
|
|
"keystore_m_12381_3600_0_0_0.json",
|
|
|
|
"keystore_m_12381_3600_333_0_0.json",
|
|
|
|
},
|
|
|
|
want: []string{
|
|
|
|
"keystore_m_12381_3600_0_0_0.json",
|
|
|
|
"keystore_m_12381_3600_333_0_0.json",
|
|
|
|
"keystore_m_12381_3600_30020330_0_0.json",
|
|
|
|
"keystore_m_12381_3600_430490934_0_0.json",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Some filenames with derivation path, others without",
|
|
|
|
input: []string{
|
|
|
|
"keystore_m_12381_3600_4_0_0.json",
|
|
|
|
"keystore.json",
|
|
|
|
"keystore-2309023.json",
|
|
|
|
"keystore_m_12381_3600_1_0_0.json",
|
|
|
|
"keystore_m_12381_3600_3_0_0.json",
|
|
|
|
},
|
|
|
|
want: []string{
|
|
|
|
"keystore_m_12381_3600_1_0_0.json",
|
|
|
|
"keystore_m_12381_3600_3_0_0.json",
|
|
|
|
"keystore_m_12381_3600_4_0_0.json",
|
|
|
|
"keystore.json",
|
|
|
|
"keystore-2309023.json",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
sort.Sort(byDerivationPath(tt.input))
|
|
|
|
assert.DeepEqual(t, tt.want, tt.input)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-11 16:32:05 +00:00
|
|
|
func Test_importPrivateKeyAsAccount(t *testing.T) {
|
|
|
|
walletDir, _, passwordFilePath := setupWalletAndPasswordsDir(t)
|
2020-11-10 22:45:17 +00:00
|
|
|
privKeyDir := filepath.Join(t.TempDir(), "privKeys")
|
2020-08-11 16:32:05 +00:00
|
|
|
require.NoError(t, os.MkdirAll(privKeyDir, os.ModePerm))
|
|
|
|
privKeyFileName := filepath.Join(privKeyDir, "privatekey.txt")
|
|
|
|
|
|
|
|
// We create a new private key and save it to a file on disk.
|
2020-10-30 19:06:33 +00:00
|
|
|
privKey, err := bls.RandKey()
|
|
|
|
require.NoError(t, err)
|
2020-08-11 16:32:05 +00:00
|
|
|
privKeyHex := fmt.Sprintf("%x", privKey.Marshal())
|
|
|
|
require.NoError(
|
|
|
|
t,
|
2022-04-18 20:42:07 +00:00
|
|
|
os.WriteFile(privKeyFileName, []byte(privKeyHex), params.BeaconIoConfig().ReadWritePermissions),
|
2020-08-11 16:32:05 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// We instantiate a new wallet from a cli context.
|
|
|
|
cliCtx := setupWalletCtx(t, &testWalletConfig{
|
|
|
|
walletDir: walletDir,
|
2022-02-01 19:54:19 +00:00
|
|
|
keymanagerKind: keymanager.Local,
|
2020-08-11 16:32:05 +00:00
|
|
|
walletPasswordFile: passwordFilePath,
|
|
|
|
privateKeyFile: privKeyFileName,
|
|
|
|
})
|
2020-08-31 19:46:45 +00:00
|
|
|
walletPass := "Passwordz0320$"
|
2022-09-02 14:56:47 +00:00
|
|
|
opts := []Option{
|
|
|
|
WithWalletDir(walletDir),
|
|
|
|
WithKeymanagerType(keymanager.Local),
|
|
|
|
WithWalletPassword(walletPass),
|
|
|
|
}
|
|
|
|
acc, err := NewCLIManager(opts...)
|
|
|
|
require.NoError(t, err)
|
|
|
|
w, err := acc.WalletCreate(cliCtx.Context)
|
2020-08-11 16:32:05 +00:00
|
|
|
require.NoError(t, err)
|
2022-06-27 13:34:38 +00:00
|
|
|
km, err := local.NewKeymanager(
|
2020-08-31 19:46:45 +00:00
|
|
|
cliCtx.Context,
|
2022-02-01 19:54:19 +00:00
|
|
|
&local.SetupConfig{
|
2022-06-27 13:34:38 +00:00
|
|
|
Wallet: w,
|
2021-02-24 18:05:46 +00:00
|
|
|
ListenForChanges: false,
|
2020-08-31 19:46:45 +00:00
|
|
|
},
|
2020-08-11 16:32:05 +00:00
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-27 13:34:38 +00:00
|
|
|
assert.NoError(t, importPrivateKeyAsAccount(cliCtx.Context, w, km, privKeyFileName))
|
2020-08-11 16:32:05 +00:00
|
|
|
|
|
|
|
// We re-instantiate the keymanager and check we now have 1 public key.
|
2022-06-27 13:34:38 +00:00
|
|
|
km, err = local.NewKeymanager(
|
2020-08-31 19:46:45 +00:00
|
|
|
cliCtx.Context,
|
2022-02-01 19:54:19 +00:00
|
|
|
&local.SetupConfig{
|
2022-06-27 13:34:38 +00:00
|
|
|
Wallet: w,
|
2021-02-24 18:05:46 +00:00
|
|
|
ListenForChanges: false,
|
2020-08-31 19:46:45 +00:00
|
|
|
},
|
2020-08-11 16:32:05 +00:00
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
2022-06-27 13:34:38 +00:00
|
|
|
pubKeys, err := km.FetchValidatingPublicKeys(cliCtx.Context)
|
2020-08-11 16:32:05 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 1, len(pubKeys))
|
|
|
|
assert.DeepEqual(t, pubKeys[0], bytesutil.ToBytes48(privKey.PublicKey().Marshal()))
|
|
|
|
}
|
2023-06-14 20:48:30 +00:00
|
|
|
|
|
|
|
func Test_NameToDescriptionChangeIsOK(t *testing.T) {
|
|
|
|
jsonString := `{"version":1, "name":"hmmm"}`
|
|
|
|
type Obj struct {
|
|
|
|
Version uint `json:"version"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
}
|
|
|
|
a := &Obj{}
|
|
|
|
require.NoError(t, json.Unmarshal([]byte(jsonString), a))
|
|
|
|
require.Equal(t, a.Description, "")
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_MarshalOmitsName(t *testing.T) {
|
|
|
|
type Obj struct {
|
|
|
|
Version uint `json:"version"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
}
|
|
|
|
a := &Obj{
|
|
|
|
Version: 1,
|
|
|
|
Description: "hmm",
|
|
|
|
}
|
|
|
|
|
|
|
|
bytes, err := json.Marshal(a)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, string(bytes), `{"version":1,"description":"hmm"}`)
|
|
|
|
}
|