2018-05-03 07:35:58 +00:00
|
|
|
package signal
|
|
|
|
|
2023-07-05 15:56:34 +00:00
|
|
|
import (
|
2023-09-16 01:20:23 +00:00
|
|
|
"encoding/json"
|
|
|
|
|
2023-07-05 15:56:34 +00:00
|
|
|
"github.com/status-im/status-go/multiaccounts"
|
|
|
|
"github.com/status-im/status-go/multiaccounts/settings"
|
|
|
|
)
|
|
|
|
|
2018-05-03 07:35:58 +00:00
|
|
|
const (
|
|
|
|
// EventNodeStarted is triggered when underlying node is started
|
|
|
|
EventNodeStarted = "node.started"
|
|
|
|
|
|
|
|
// EventNodeReady is triggered when underlying node is fully ready
|
|
|
|
// (consider backend to be fully registered)
|
|
|
|
EventNodeReady = "node.ready"
|
|
|
|
|
|
|
|
// EventNodeStopped is triggered when underlying node is fully stopped
|
|
|
|
EventNodeStopped = "node.stopped"
|
|
|
|
|
|
|
|
// EventNodeCrashed is triggered when node crashes
|
|
|
|
EventNodeCrashed = "node.crashed"
|
|
|
|
|
|
|
|
// EventChainDataRemoved is triggered when node's chain data is removed
|
|
|
|
EventChainDataRemoved = "chaindata.removed"
|
2019-08-20 15:38:40 +00:00
|
|
|
|
|
|
|
// EventLoggedIn is once node was injected with user account and ready to be used.
|
|
|
|
EventLoggedIn = "node.login"
|
2018-05-03 07:35:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// NodeCrashEvent is special kind of error, used to report node crashes
|
|
|
|
type NodeCrashEvent struct {
|
|
|
|
Error string `json:"error"`
|
|
|
|
}
|
|
|
|
|
2019-09-03 13:00:14 +00:00
|
|
|
// NodeLoginEvent returns the result of the login event
|
|
|
|
type NodeLoginEvent struct {
|
2023-09-16 01:20:23 +00:00
|
|
|
Error string `json:"error,omitempty"`
|
|
|
|
Settings *settings.Settings `json:"settings,omitempty"`
|
|
|
|
Account *multiaccounts.Account `json:"account,omitempty"`
|
|
|
|
EnsUsernames json.RawMessage `json:"ensUsernames,omitempty"`
|
2019-09-03 13:00:14 +00:00
|
|
|
}
|
|
|
|
|
2018-05-03 07:35:58 +00:00
|
|
|
// SendNodeCrashed emits a signal when status node has crashed, and
|
|
|
|
// provides error description.
|
|
|
|
func SendNodeCrashed(err error) {
|
|
|
|
send(EventNodeCrashed,
|
|
|
|
NodeCrashEvent{
|
|
|
|
Error: err.Error(),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// SendNodeStarted emits a signal when status node has just started (but not
|
|
|
|
// finished startup yet).
|
|
|
|
func SendNodeStarted() {
|
|
|
|
send(EventNodeStarted, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SendNodeReady emits a signal when status node has started and successfully
|
|
|
|
// completed startup.
|
|
|
|
func SendNodeReady() {
|
|
|
|
send(EventNodeReady, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SendNodeStopped emits a signal when underlying node has stopped.
|
|
|
|
func SendNodeStopped() {
|
|
|
|
send(EventNodeStopped, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SendChainDataRemoved emits a signal when node's chain data has been removed.
|
|
|
|
func SendChainDataRemoved() {
|
|
|
|
send(EventChainDataRemoved, nil)
|
|
|
|
}
|
2019-08-20 15:38:40 +00:00
|
|
|
|
2023-09-16 01:20:23 +00:00
|
|
|
func SendLoggedIn(account *multiaccounts.Account, settings *settings.Settings, ensUsernames json.RawMessage, err error) {
|
|
|
|
event := NodeLoginEvent{Settings: settings, Account: account, EnsUsernames: ensUsernames}
|
2019-09-03 13:00:14 +00:00
|
|
|
if err != nil {
|
|
|
|
event.Error = err.Error()
|
|
|
|
}
|
|
|
|
send(EventLoggedIn, event)
|
2019-08-20 15:38:40 +00:00
|
|
|
}
|