2020-11-17 06:00:20 +00:00
|
|
|
package imported
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
|
|
)
|
|
|
|
|
|
|
|
// DisableAccounts disables public keys from the user's wallet.
|
2021-01-20 14:39:07 +00:00
|
|
|
func (km *Keymanager) DisableAccounts(ctx context.Context, pubKeys [][]byte) error {
|
2020-11-17 06:00:20 +00:00
|
|
|
if pubKeys == nil || len(pubKeys) < 1 {
|
|
|
|
return errors.New("no public keys specified to disable")
|
|
|
|
}
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
for _, pk := range pubKeys {
|
2021-01-20 14:39:07 +00:00
|
|
|
if _, ok := km.disabledPublicKeys[bytesutil.ToBytes48(pk)]; !ok {
|
|
|
|
km.disabledPublicKeys[bytesutil.ToBytes48(pk)] = true
|
2020-11-17 06:00:20 +00:00
|
|
|
}
|
|
|
|
}
|
2021-01-20 14:39:07 +00:00
|
|
|
return km.rewriteDisabledKeysToDisk(ctx)
|
2020-11-17 06:00:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// EnableAccounts enables public keys from a user's wallet if they are disabled.
|
2021-01-20 14:39:07 +00:00
|
|
|
func (km *Keymanager) EnableAccounts(ctx context.Context, pubKeys [][]byte) error {
|
2020-11-17 06:00:20 +00:00
|
|
|
if pubKeys == nil || len(pubKeys) < 1 {
|
|
|
|
return errors.New("no public keys specified to enable")
|
|
|
|
}
|
|
|
|
lock.Lock()
|
|
|
|
defer lock.Unlock()
|
|
|
|
for _, pk := range pubKeys {
|
2021-01-20 14:39:07 +00:00
|
|
|
delete(km.disabledPublicKeys, bytesutil.ToBytes48(pk))
|
2020-11-17 06:00:20 +00:00
|
|
|
}
|
2021-01-20 14:39:07 +00:00
|
|
|
return km.rewriteDisabledKeysToDisk(ctx)
|
2020-11-17 06:00:20 +00:00
|
|
|
}
|
|
|
|
|
2021-01-20 14:39:07 +00:00
|
|
|
func (km *Keymanager) rewriteDisabledKeysToDisk(ctx context.Context) error {
|
|
|
|
encoded, err := km.wallet.ReadFileAtPath(ctx, AccountsPath, AccountsKeystoreFileName)
|
2020-11-17 06:00:20 +00:00
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "could not read keystore file for accounts")
|
|
|
|
}
|
2021-01-12 16:52:01 +00:00
|
|
|
keystore := &AccountsKeystoreRepresentation{}
|
2020-11-17 06:00:20 +00:00
|
|
|
if err := json.Unmarshal(encoded, keystore); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
disabledKeysStrings := make([]string, 0)
|
2021-01-20 14:39:07 +00:00
|
|
|
for pk := range km.disabledPublicKeys {
|
2020-11-17 06:00:20 +00:00
|
|
|
disabledKeysStrings = append(disabledKeysStrings, fmt.Sprintf("%x", pk))
|
|
|
|
}
|
|
|
|
keystore.DisabledPublicKeys = disabledKeysStrings
|
|
|
|
encoded, err = json.MarshalIndent(keystore, "", "\t")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-01-20 14:39:07 +00:00
|
|
|
if err := km.wallet.WriteFileAtPath(ctx, AccountsPath, AccountsKeystoreFileName, encoded); err != nil {
|
2020-11-17 06:00:20 +00:00
|
|
|
return errors.Wrap(err, "could not write keystore file for accounts")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|