2023-01-06 20:21:14 +08:00
|
|
|
package pairing
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-06-26 13:14:27 +02:00
|
|
|
"crypto/ecdsa"
|
2023-01-06 20:21:14 +08:00
|
|
|
"fmt"
|
|
|
|
"path/filepath"
|
2024-06-26 13:14:27 +02:00
|
|
|
"strings"
|
|
|
|
|
|
|
|
ethcrypto "github.com/ethereum/go-ethereum/crypto"
|
2023-01-06 20:21:14 +08:00
|
|
|
|
|
|
|
"github.com/status-im/status-go/api"
|
|
|
|
"github.com/status-im/status-go/multiaccounts/accounts"
|
2023-02-17 21:02:42 +08:00
|
|
|
"github.com/status-im/status-go/multiaccounts/settings"
|
2023-01-06 20:21:14 +08:00
|
|
|
"github.com/status-im/status-go/params"
|
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
2023-04-26 14:48:49 +03:00
|
|
|
|
|
|
|
"github.com/status-im/status-go/signal"
|
2023-01-06 20:21:14 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type SyncRawMessageHandler struct {
|
|
|
|
backend *api.GethStatusBackend
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewSyncRawMessageHandler(backend *api.GethStatusBackend) *SyncRawMessageHandler {
|
|
|
|
return &SyncRawMessageHandler{backend: backend}
|
|
|
|
}
|
|
|
|
|
2023-02-28 20:32:45 +08:00
|
|
|
func (s *SyncRawMessageHandler) CollectInstallationData(rawMessageCollector *RawMessageCollector, deviceType string) error {
|
2023-03-23 11:44:15 +00:00
|
|
|
// TODO Could this function be part of the installation data exchange flow?
|
|
|
|
// https://github.com/status-im/status-go/issues/3304
|
2023-02-28 20:32:45 +08:00
|
|
|
messenger := s.backend.Messenger()
|
|
|
|
if messenger == nil {
|
|
|
|
return fmt.Errorf("messenger is nil when CollectInstallationData")
|
|
|
|
}
|
|
|
|
err := messenger.SetInstallationDeviceType(deviceType)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
_, err = messenger.SendPairInstallation(context.TODO(), rawMessageCollector.dispatchMessage)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2023-05-16 12:48:00 +02:00
|
|
|
func (s *SyncRawMessageHandler) PrepareRawMessage(keyUID, deviceType string) (rm []*protobuf.RawMessage, kp *accounts.Keypair, syncSettings *settings.Settings, err error) {
|
2023-04-03 00:08:29 +01:00
|
|
|
syncSettings = new(settings.Settings)
|
2023-01-06 20:21:14 +08:00
|
|
|
messenger := s.backend.Messenger()
|
|
|
|
if messenger == nil {
|
2023-04-03 00:08:29 +01:00
|
|
|
return nil, nil, nil, fmt.Errorf("messenger is nil when PrepareRawMessage")
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
currentAccount, err := s.backend.GetActiveAccount()
|
|
|
|
if err != nil {
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
if keyUID != currentAccount.KeyUID {
|
2023-04-03 00:08:29 +01:00
|
|
|
return nil, nil, nil, fmt.Errorf("keyUID not equal")
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
messenger.SetLocalPairing(true)
|
|
|
|
defer func() {
|
|
|
|
messenger.SetLocalPairing(false)
|
|
|
|
}()
|
|
|
|
rawMessageCollector := new(RawMessageCollector)
|
|
|
|
err = messenger.SyncDevices(context.TODO(), currentAccount.Name, currentAccount.Identicon, rawMessageCollector.dispatchMessage)
|
|
|
|
if err != nil {
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
2023-02-28 20:32:45 +08:00
|
|
|
|
|
|
|
err = s.CollectInstallationData(rawMessageCollector, deviceType)
|
|
|
|
if err != nil {
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
|
2023-04-03 00:08:29 +01:00
|
|
|
rsm := rawMessageCollector.convertToSyncRawMessage()
|
|
|
|
rm = rsm.RawMessages
|
2023-02-28 20:32:45 +08:00
|
|
|
|
2023-01-06 20:21:14 +08:00
|
|
|
accountService := s.backend.StatusNode().AccountService()
|
2023-04-03 00:08:29 +01:00
|
|
|
|
2023-05-16 12:48:00 +02:00
|
|
|
kp, err = accountService.GetKeypairByKeyUID(keyUID)
|
2023-01-06 20:21:14 +08:00
|
|
|
if err != nil {
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
2023-04-03 00:08:29 +01:00
|
|
|
*syncSettings, err = accountService.GetSettings()
|
2023-01-06 20:21:14 +08:00
|
|
|
if err != nil {
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
2023-02-06 17:55:41 +08:00
|
|
|
|
2023-03-29 18:12:27 +01:00
|
|
|
return
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
|
2023-06-27 09:54:49 +02:00
|
|
|
func (s *SyncRawMessageHandler) HandleRawMessage(accountPayload *AccountPayload, nodeConfig *params.NodeConfig, settingCurrentNetwork, deviceType string, deviceName string, rmp *RawMessagesPayload) (err error) {
|
2023-02-28 20:32:45 +08:00
|
|
|
account := accountPayload.multiaccount
|
2023-01-06 20:21:14 +08:00
|
|
|
|
2023-02-28 20:32:45 +08:00
|
|
|
activeAccount, _ := s.backend.GetActiveAccount()
|
|
|
|
if activeAccount == nil { // not login yet
|
|
|
|
s.backend.UpdateRootDataDir(nodeConfig.RootDataDir)
|
|
|
|
// because client don't know keyUID before received data, we need help client to update keystore dir
|
|
|
|
keystoreDir := filepath.Join(nodeConfig.KeyStoreDir, account.KeyUID)
|
|
|
|
nodeConfig.KeyStoreDir = keystoreDir
|
2024-06-26 13:14:27 +02:00
|
|
|
|
|
|
|
var chatKey *ecdsa.PrivateKey
|
|
|
|
if accountPayload.chatKey != "" {
|
|
|
|
chatKeyHex := strings.Trim(accountPayload.chatKey, "0x")
|
|
|
|
chatKey, err = ethcrypto.HexToECDSA(chatKeyHex)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2023-06-09 08:43:51 +02:00
|
|
|
}
|
2024-06-26 13:14:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if accountPayload.exist {
|
|
|
|
err = s.backend.StartNodeWithAccount(*account, accountPayload.password, nodeConfig, chatKey)
|
2023-02-28 20:32:45 +08:00
|
|
|
} else {
|
|
|
|
accountManager := s.backend.AccountManager()
|
|
|
|
err = accountManager.InitKeystore(filepath.Join(nodeConfig.RootDataDir, keystoreDir))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-06-27 09:54:49 +02:00
|
|
|
rmp.setting.DeviceName = deviceName
|
2023-04-03 00:08:29 +01:00
|
|
|
rmp.setting.InstallationID = nodeConfig.ShhextConfig.InstallationID
|
|
|
|
rmp.setting.CurrentNetwork = settingCurrentNetwork
|
2023-02-06 17:55:41 +08:00
|
|
|
|
2024-06-26 13:14:27 +02:00
|
|
|
err = s.backend.StartNodeWithAccountAndInitialConfig(*account, accountPayload.password, *rmp.setting, nodeConfig, rmp.profileKeypair.Accounts, chatKey)
|
2023-02-28 20:32:45 +08:00
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
messenger := s.backend.Messenger()
|
2023-01-11 19:30:54 +08:00
|
|
|
if messenger == nil {
|
|
|
|
return fmt.Errorf("messenger is nil when HandleRawMessage")
|
|
|
|
}
|
2023-02-28 20:32:45 +08:00
|
|
|
err = messenger.SetInstallationDeviceType(deviceType)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-04-26 14:48:49 +03:00
|
|
|
|
|
|
|
installations := GetMessengerInstallationsMap(messenger)
|
|
|
|
|
|
|
|
err = messenger.HandleSyncRawMessages(rmp.rawMessages)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if newInstallation := FindNewInstallations(messenger, installations); newInstallation != nil {
|
|
|
|
signal.SendLocalPairingEvent(Event{
|
|
|
|
Type: EventReceivedInstallation,
|
|
|
|
Action: ActionPairingInstallation,
|
|
|
|
Data: newInstallation})
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2023-01-06 20:21:14 +08:00
|
|
|
}
|