mirror of
https://github.com/status-im/status-go.git
synced 2025-01-26 22:50:40 +00:00
81d8ca82a2
Currently PFS messages are decrypted and therefore modified before being passed to the client. This make IDs computation difficult, as we pass the whole object to the client and expect the object be passed back once confirmed. This changes the behavior allowing confirmation by ID, which is passed to the client instead of the raw object. This is a breaking change, but status-react is already forward compatible.
68 lines
2.0 KiB
Go
68 lines
2.0 KiB
Go
package dedup
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/log"
|
|
whisper "github.com/status-im/whisper/whisperv6"
|
|
"github.com/syndtr/goleveldb/leveldb"
|
|
)
|
|
|
|
type keyPairProvider interface {
|
|
SelectedKeyPairID() string
|
|
}
|
|
|
|
// Deduplicator filters out already received messages for a current filter.
|
|
// It keeps a limited cache of the messages.
|
|
type Deduplicator struct {
|
|
keyPairProvider keyPairProvider
|
|
cache *cache
|
|
log log.Logger
|
|
}
|
|
|
|
type DeduplicateMessage struct {
|
|
DedupID []byte `json:"id"`
|
|
Message *whisper.Message `json:"message"`
|
|
}
|
|
|
|
// NewDeduplicator creates a new deduplicator
|
|
func NewDeduplicator(keyPairProvider keyPairProvider, db *leveldb.DB) *Deduplicator {
|
|
return &Deduplicator{
|
|
log: log.New("package", "status-go/services/sshext.deduplicator"),
|
|
keyPairProvider: keyPairProvider,
|
|
cache: newCache(db),
|
|
}
|
|
}
|
|
|
|
// Deduplicate receives a list of whisper messages and
|
|
// returns the list of the messages that weren't filtered previously for the
|
|
// specified filter.
|
|
func (d *Deduplicator) Deduplicate(messages []*whisper.Message) []DeduplicateMessage {
|
|
result := make([]DeduplicateMessage, 0)
|
|
selectedKeyPairID := d.keyPairProvider.SelectedKeyPairID()
|
|
|
|
for _, message := range messages {
|
|
if has, err := d.cache.Has(selectedKeyPairID, message); !has {
|
|
if err != nil {
|
|
d.log.Error("error while deduplicating messages: search cache failed", "err", err)
|
|
}
|
|
result = append(result, DeduplicateMessage{
|
|
DedupID: d.cache.KeyToday(selectedKeyPairID, message),
|
|
Message: message,
|
|
})
|
|
}
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
// AddMessages adds a message to the deduplicator DB, so it will be filtered
|
|
// out.
|
|
func (d *Deduplicator) AddMessages(messages []*whisper.Message) error {
|
|
return d.cache.Put(d.keyPairProvider.SelectedKeyPairID(), messages)
|
|
}
|
|
|
|
// AddMessageByID adds a message to the deduplicator DB, so it will be filtered
|
|
// out.
|
|
func (d *Deduplicator) AddMessageByID(messageIDs [][]byte) error {
|
|
return d.cache.PutIDs(messageIDs)
|
|
}
|