mirror of
https://github.com/status-im/status-go.git
synced 2025-01-09 14:16:21 +00:00
be9c55bc16
* WIP accounts implementation * Accounts datasore and changes to status mobile API * Add library changes and method to update config * Handle error after account selection * Add two methods to start account to backend * Use encrypted database for settings and add a service for them * Resolve linter warning * Bring back StartNode StopNode for tests * Add sub accounts and get/save api * Changes to accounts structure * Login use root address and fetch necessary info from database * Cover accounts store with tests * Refactor in progress * Initialize status keystore instance before starting ethereum node * Rework library tests * Resolve failures in private api test and send transaction test * Pass pointer to initialized config to unmarshal * Use multiaccounts/accounts naming consistently Multiaccount is used as a login identifier Account references an address and a key, if account is not watch-only. * Add login timestamp stored in the database to accounts.Account object * Add photo-path field for multiaccount struct * Add multiaccoutns rpc with updateAccount method Update to any other account that wasn't used for login will return an error * Fix linter in services/accounts * Select account before starting a node * Save list of accounts on first login * Pass account manager to accounts service to avoid selecting account before starting a node * Add logs to login with save and regualr login
58 lines
1.2 KiB
Go
58 lines
1.2 KiB
Go
package accounts
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/p2p"
|
|
"github.com/ethereum/go-ethereum/rpc"
|
|
"github.com/status-im/status-go/account"
|
|
"github.com/status-im/status-go/multiaccounts"
|
|
"github.com/status-im/status-go/multiaccounts/accounts"
|
|
)
|
|
|
|
// NewService initializes service instance.
|
|
func NewService(db *accounts.Database, mdb *multiaccounts.Database, manager *account.Manager) *Service {
|
|
return &Service{db, mdb, manager}
|
|
}
|
|
|
|
// Service is a browsers service.
|
|
type Service struct {
|
|
db *accounts.Database
|
|
mdb *multiaccounts.Database
|
|
manager *account.Manager
|
|
}
|
|
|
|
// Start a service.
|
|
func (s *Service) Start(*p2p.Server) error {
|
|
return nil
|
|
}
|
|
|
|
// Stop a service.
|
|
func (s *Service) Stop() error {
|
|
return nil
|
|
}
|
|
|
|
// APIs returns list of available RPC APIs.
|
|
func (s *Service) APIs() []rpc.API {
|
|
return []rpc.API{
|
|
{
|
|
Namespace: "settings",
|
|
Version: "0.1.0",
|
|
Service: NewSettingsAPI(s.db),
|
|
},
|
|
{
|
|
Namespace: "accounts",
|
|
Version: "0.1.0",
|
|
Service: NewAccountsAPI(s.db),
|
|
},
|
|
{
|
|
Namespace: "multiaccounts",
|
|
Version: "0.1.0",
|
|
Service: NewMultiAccountsAPI(s.mdb, s.manager),
|
|
},
|
|
}
|
|
}
|
|
|
|
// Protocols returns list of p2p protocols.
|
|
func (s *Service) Protocols() []p2p.Protocol {
|
|
return nil
|
|
}
|