2023-02-21 13:35:26 +01:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2023-05-16 12:48:00 +02:00
|
|
|
"github.com/status-im/status-go/multiaccounts/accounts"
|
2023-02-21 13:35:26 +01:00
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
|
|
|
)
|
|
|
|
|
2023-05-16 12:48:00 +02:00
|
|
|
func (m *Messenger) prepareSyncKeycardsMessage(keyUID string) (message []*protobuf.SyncKeycard, err error) {
|
2023-07-05 14:41:58 +02:00
|
|
|
keycards, err := m.settings.GetKeycardsWithSameKeyUID(keyUID)
|
2023-02-21 13:35:26 +01:00
|
|
|
if err != nil {
|
2023-07-05 14:41:58 +02:00
|
|
|
return
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
for _, kc := range keycards {
|
2023-05-16 12:48:00 +02:00
|
|
|
syncKeycard := kc.ToSyncKeycard()
|
|
|
|
message = append(message, syncKeycard)
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-02-27 11:19:18 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) dispatchKeycardActivity(keyUID string, keycardUID string, newKeycardUID string, accountAddresses []types.Address,
|
|
|
|
callback func(uint64) error) error {
|
|
|
|
clock, _ := m.getLastClockWithRelatedChat()
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
finalKeyUID := keyUID
|
|
|
|
if finalKeyUID == "" {
|
|
|
|
dbKeycard, err := m.settings.GetKeycardByKeycardUID(keycardUID)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
finalKeyUID = dbKeycard.KeyUID
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
if err := callback(clock); err != nil {
|
2023-02-21 13:35:26 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
return m.resolveAndSyncKeypairOrJustWalletAccount(finalKeyUID, types.Address{}, clock, m.dispatchMessage)
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
// This function stores keycard to db and notifies paired devices about that if keycard with `KeycardUID` is not already stored.
|
|
|
|
// Keycard position is fully maintained by the backend.
|
|
|
|
// If keycard is already stored, this function updates `KeycardName` and adds accounts which are not already added, in this case
|
|
|
|
// `KeycardLocked` and `Position` remains as they were, they won't be changed.
|
|
|
|
func (m *Messenger) SaveOrUpdateKeycard(ctx context.Context, keycard *accounts.Keycard) (err error) {
|
|
|
|
dbKeycard, err := m.settings.GetKeycardByKeycardUID(keycard.KeycardUID)
|
|
|
|
if err != nil && err != accounts.ErrNoKeycardForPassedKeycardUID {
|
2023-02-21 13:35:26 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
if dbKeycard == nil {
|
|
|
|
position, err := m.settings.GetPositionForNextNewKeycard()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
keycard.Position = position
|
|
|
|
keycard.KeycardLocked = false
|
|
|
|
} else {
|
|
|
|
keycard.Position = dbKeycard.Position
|
|
|
|
keycard.KeycardLocked = dbKeycard.KeycardLocked
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
return m.dispatchKeycardActivity(keycard.KeyUID, "", "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.SaveOrUpdateKeycard(*keycard, clock, true)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) SetKeycardName(ctx context.Context, keycardUID string, kpName string) error {
|
|
|
|
return m.dispatchKeycardActivity("", keycardUID, "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.SetKeycardName(keycardUID, kpName, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) KeycardLocked(ctx context.Context, keycardUID string) error {
|
|
|
|
return m.dispatchKeycardActivity("", keycardUID, "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.KeycardLocked(keycardUID, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) KeycardUnlocked(ctx context.Context, keycardUID string) error {
|
|
|
|
return m.dispatchKeycardActivity("", keycardUID, "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.KeycardUnlocked(keycardUID, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) DeleteKeycardAccounts(ctx context.Context, keycardUID string, accountAddresses []types.Address) error {
|
|
|
|
return m.dispatchKeycardActivity("", keycardUID, "", accountAddresses, func(clock uint64) error {
|
|
|
|
return m.settings.DeleteKeycardAccounts(keycardUID, accountAddresses, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) DeleteKeycard(ctx context.Context, keycardUID string) error {
|
|
|
|
return m.dispatchKeycardActivity("", keycardUID, "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.DeleteKeycard(keycardUID, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) DeleteAllKeycardsWithKeyUID(ctx context.Context, keyUID string) error {
|
|
|
|
return m.dispatchKeycardActivity(keyUID, "", "", []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.DeleteAllKeycardsWithKeyUID(keyUID, clock)
|
|
|
|
})
|
|
|
|
}
|
2023-02-21 13:35:26 +01:00
|
|
|
|
2023-07-05 14:41:58 +02:00
|
|
|
func (m *Messenger) UpdateKeycardUID(ctx context.Context, oldKeycardUID string, newKeycardUID string) error {
|
|
|
|
return m.dispatchKeycardActivity("", oldKeycardUID, newKeycardUID, []types.Address{}, func(clock uint64) error {
|
|
|
|
return m.settings.UpdateKeycardUID(oldKeycardUID, newKeycardUID, clock)
|
|
|
|
})
|
2023-02-21 13:35:26 +01:00
|
|
|
}
|