mirror of
https://github.com/status-im/status-go.git
synced 2025-01-09 06:12:55 +00:00
cb5ccb52c4
* Add DeliveryService to Whisper to track incoming and outgoing messages. * Have log tagged log lines for incoming and outgoing messages.
79 lines
2.0 KiB
Go
79 lines
2.0 KiB
Go
package node
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"encoding/json"
|
|
|
|
gethcommon "github.com/ethereum/go-ethereum/common"
|
|
gethmessage "github.com/ethereum/go-ethereum/common/message"
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
whisper "github.com/ethereum/go-ethereum/whisper/whisperv5"
|
|
"github.com/status-im/status-go/geth/common"
|
|
"github.com/status-im/status-go/geth/log"
|
|
)
|
|
|
|
// LogDeliveryService implements the whisper.DeliveryServer which logs out
|
|
// stats of whisper.MessageState to the log.
|
|
type LogDeliveryService struct{}
|
|
|
|
// SendState logs incoming whisper.MesssageState into the log.
|
|
func (ld LogDeliveryService) SendState(state whisper.MessageState) {
|
|
var stat common.MessageState
|
|
var protocol string
|
|
var payload []byte
|
|
var from, to string
|
|
|
|
if state.IsP2P {
|
|
protocol = "P2P"
|
|
} else {
|
|
protocol = "RPC"
|
|
}
|
|
|
|
switch state.Direction {
|
|
case gethmessage.IncomingMessage:
|
|
payload = state.Received.Payload
|
|
|
|
if state.Received.Src != nil {
|
|
from = gethcommon.ToHex(crypto.FromECDSAPub(state.Received.Src))
|
|
}
|
|
|
|
if state.Received.Dst != nil {
|
|
to = gethcommon.ToHex(crypto.FromECDSAPub(state.Received.Dst))
|
|
}
|
|
|
|
case gethmessage.OutgoingMessage:
|
|
from = state.Source.Sig
|
|
|
|
if len(state.Source.PublicKey) == 0 {
|
|
to = string(state.Source.PublicKey)
|
|
} else {
|
|
to = state.Source.TargetPeer
|
|
}
|
|
}
|
|
|
|
if state.Reason != nil {
|
|
stat.RejectionError = state.Reason.Error()
|
|
}
|
|
|
|
stat.Protocol = protocol
|
|
stat.Payload = payload
|
|
stat.FromDevice = from
|
|
stat.ToDevice = to
|
|
stat.Received = state.Timestamp
|
|
stat.Source = state.Source
|
|
stat.Envelope = state.Envelope.Data
|
|
stat.Status = state.Status.String()
|
|
stat.Type = state.Direction.String()
|
|
stat.Hash = state.Envelope.Hash().String()
|
|
stat.TimeSent = state.Envelope.Expiry - state.Envelope.TTL
|
|
|
|
statdata, err := json.Marshal(stat)
|
|
if err != nil {
|
|
log.Warn("failed to marshal common.MessageStat", "err", err)
|
|
return
|
|
}
|
|
|
|
encodedStat := base64.StdEncoding.EncodeToString(statdata)
|
|
log.Info("Message delivery notification", "state", encodedStat)
|
|
}
|