2020-01-13 19:17:30 +00:00
|
|
|
package transport
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/ecdsa"
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
2020-01-13 19:17:30 +00:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Transport interface {
|
|
|
|
Stop() error
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
JoinPrivate(publicKey *ecdsa.PublicKey) (*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
LeavePrivate(publicKey *ecdsa.PublicKey) error
|
2021-01-11 10:32:51 +00:00
|
|
|
JoinGroup(publicKeys []*ecdsa.PublicKey) ([]*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
LeaveGroup(publicKeys []*ecdsa.PublicKey) error
|
2021-01-11 10:32:51 +00:00
|
|
|
JoinPublic(chatID string) (*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
LeavePublic(chatID string) error
|
2020-01-20 16:44:32 +00:00
|
|
|
GetCurrentTime() uint64
|
2020-11-03 12:42:42 +00:00
|
|
|
MaxMessageSize() uint32
|
2020-01-13 19:17:30 +00:00
|
|
|
|
|
|
|
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)
|
2021-01-18 09:12:03 +00:00
|
|
|
SendPrivateOnPersonalTopic(ctx context.Context, newMessage *types.NewMessage, publicKey *ecdsa.PublicKey) ([]byte, error)
|
2021-01-11 10:32:51 +00:00
|
|
|
SendCommunityMessage(ctx context.Context, newMessage *types.NewMessage, publicKey *ecdsa.PublicKey) ([]byte, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
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)
|
2020-11-18 09:16:51 +00:00
|
|
|
InitPublicFilters(chatIDs []string) ([]*Filter, error)
|
2021-01-11 10:32:51 +00:00
|
|
|
InitCommunityFilters(pks []*ecdsa.PrivateKey) ([]*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
LoadFilters(filters []*Filter) ([]*Filter, error)
|
|
|
|
RemoveFilters(filters []*Filter) error
|
2020-12-22 17:12:03 +00:00
|
|
|
RemoveFilterByChatID(string) (*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
ResetFilters() error
|
2020-01-17 12:39:09 +00:00
|
|
|
Filters() []*Filter
|
2020-07-21 15:41:10 +00:00
|
|
|
LoadKeyFilters(*ecdsa.PrivateKey) (*Filter, error)
|
2020-01-13 19:17:30 +00:00
|
|
|
ProcessNegotiatedSecret(secret types.NegotiatedSecret) (*Filter, error)
|
|
|
|
RetrieveRawAll() (map[Filter][]*types.Message, error)
|
2020-12-15 14:43:41 +00:00
|
|
|
|
2021-01-08 15:21:25 +00:00
|
|
|
ConfirmMessagesProcessed([]string, uint64) error
|
|
|
|
CleanMessagesProcessed(uint64) error
|
|
|
|
|
2020-12-15 14:43:41 +00:00
|
|
|
SetEnvelopeEventsHandler(handler EnvelopeEventsHandler) error
|
2020-01-13 19:17:30 +00:00
|
|
|
}
|
2021-01-11 10:32:51 +00:00
|
|
|
|
|
|
|
func PubkeyToHex(key *ecdsa.PublicKey) string {
|
|
|
|
return types.EncodeHex(crypto.FromECDSAPub(key))
|
|
|
|
}
|