mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 18:55:47 +00:00
75e0809f50
When sending messages in quick succession, it might be that multiple messages are batched together in datasync, resulting in a single large payload. This commit changes the behavior so that we can pass a max-message-size and we split the message in batches before sending. A more elegant way would be to split at the transport layer (i.e waku/whisper), but that would be incompatible with older client. We can still do that eventually to support larger messages.
43 lines
1.4 KiB
Go
43 lines
1.4 KiB
Go
package transport
|
|
|
|
import (
|
|
"context"
|
|
"crypto/ecdsa"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
)
|
|
|
|
type Transport interface {
|
|
Stop() error
|
|
|
|
JoinPrivate(publicKey *ecdsa.PublicKey) error
|
|
LeavePrivate(publicKey *ecdsa.PublicKey) error
|
|
JoinGroup(publicKeys []*ecdsa.PublicKey) error
|
|
LeaveGroup(publicKeys []*ecdsa.PublicKey) error
|
|
JoinPublic(chatID string) error
|
|
LeavePublic(chatID string) error
|
|
GetCurrentTime() uint64
|
|
MaxMessageSize() uint32
|
|
|
|
SendPublic(ctx context.Context, newMessage *types.NewMessage, chatName string) ([]byte, error)
|
|
SendPrivateWithSharedSecret(ctx context.Context, newMessage *types.NewMessage, publicKey *ecdsa.PublicKey, secret []byte) ([]byte, error)
|
|
SendPrivateWithPartitioned(ctx context.Context, newMessage *types.NewMessage, publicKey *ecdsa.PublicKey) ([]byte, error)
|
|
SendMessagesRequest(
|
|
ctx context.Context,
|
|
peerID []byte,
|
|
from, to uint32,
|
|
previousCursor []byte,
|
|
) (cursor []byte, err error)
|
|
|
|
Track(identifiers [][]byte, hash []byte, newMessage *types.NewMessage)
|
|
|
|
InitFilters(chatIDs []string, publicKeys []*ecdsa.PublicKey) ([]*Filter, error)
|
|
LoadFilters(filters []*Filter) ([]*Filter, error)
|
|
RemoveFilters(filters []*Filter) error
|
|
ResetFilters() error
|
|
Filters() []*Filter
|
|
LoadKeyFilters(*ecdsa.PrivateKey) (*Filter, error)
|
|
ProcessNegotiatedSecret(secret types.NegotiatedSecret) (*Filter, error)
|
|
RetrieveRawAll() (map[Filter][]*types.Message, error)
|
|
}
|