2020-03-10 12:20:34 -07:00
|
|
|
// (c) 2019-2020, Ava Labs, Inc. All rights reserved.
|
|
|
|
// See the file LICENSE for licensing terms.
|
|
|
|
|
|
|
|
package avm
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ava-labs/gecko/database"
|
|
|
|
"github.com/ava-labs/gecko/ids"
|
|
|
|
"github.com/ava-labs/gecko/utils/crypto"
|
|
|
|
)
|
|
|
|
|
|
|
|
var addresses = ids.Empty
|
|
|
|
|
|
|
|
type userState struct{ vm *VM }
|
|
|
|
|
2020-05-10 16:26:39 -07:00
|
|
|
func (s *userState) SetAddresses(db database.Database, addrs []ids.ShortID) error {
|
2020-03-10 12:20:34 -07:00
|
|
|
bytes, err := s.vm.codec.Marshal(addrs)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return db.Put(addresses.Bytes(), bytes)
|
|
|
|
}
|
|
|
|
|
2020-05-10 16:26:39 -07:00
|
|
|
func (s *userState) Addresses(db database.Database) ([]ids.ShortID, error) {
|
2020-03-10 12:20:34 -07:00
|
|
|
bytes, err := db.Get(addresses.Bytes())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2020-05-10 16:26:39 -07:00
|
|
|
addresses := []ids.ShortID{}
|
2020-03-10 12:20:34 -07:00
|
|
|
if err := s.vm.codec.Unmarshal(bytes, &addresses); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return addresses, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *userState) SetKey(db database.Database, sk *crypto.PrivateKeySECP256K1R) error {
|
2020-05-10 16:26:39 -07:00
|
|
|
return db.Put(sk.PublicKey().Address().Bytes(), sk.Bytes())
|
2020-03-10 12:20:34 -07:00
|
|
|
}
|
|
|
|
|
2020-05-10 16:26:39 -07:00
|
|
|
func (s *userState) Key(db database.Database, address ids.ShortID) (*crypto.PrivateKeySECP256K1R, error) {
|
2020-03-10 12:20:34 -07:00
|
|
|
factory := crypto.FactorySECP256K1R{}
|
|
|
|
|
|
|
|
bytes, err := db.Get(address.Bytes())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
sk, err := factory.ToPrivateKey(bytes)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return sk.(*crypto.PrivateKeySECP256K1R), nil
|
|
|
|
}
|