2020-01-20 20:56:06 +00:00
|
|
|
package ext
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"encoding/hex"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"math/big"
|
|
|
|
"time"
|
|
|
|
|
2022-01-17 03:42:11 +00:00
|
|
|
"github.com/status-im/status-go/services/browsers"
|
2022-09-14 10:46:11 +00:00
|
|
|
"github.com/status-im/status-go/services/wallet"
|
2022-01-17 03:42:11 +00:00
|
|
|
|
2021-08-26 20:25:43 +00:00
|
|
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/ethereum/go-ethereum/log"
|
|
|
|
"github.com/ethereum/go-ethereum/rlp"
|
|
|
|
|
2022-09-14 10:46:11 +00:00
|
|
|
ethcommon "github.com/ethereum/go-ethereum/common"
|
2020-07-14 14:07:19 +00:00
|
|
|
"github.com/status-im/status-go/eth-node/crypto"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
"github.com/status-im/status-go/mailserver"
|
2022-03-23 18:47:00 +00:00
|
|
|
"github.com/status-im/status-go/multiaccounts/settings"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/status-im/status-go/protocol"
|
2020-09-01 13:27:01 +00:00
|
|
|
"github.com/status-im/status-go/protocol/common"
|
2020-11-18 09:16:51 +00:00
|
|
|
"github.com/status-im/status-go/protocol/communities"
|
feat: introduce messenger APIs to extract discord channels
As part of the new Discord <-> Status Community Import functionality,
we're adding an API that extracts all discord categories and channels
from a previously exported discord export file.
These APIs can be used in clients to show the user what categories and
channels will be imported later on.
There are two APIs:
1. `Messenger.ExtractDiscordCategoriesAndChannels(filesToimport
[]string) (*MessengerResponse, map[string]*discord.ImportError)`
This takes a list of exported discord export (JSON) files (typically one per
channel), reads them, and extracts the categories and channels into
dedicated data structures (`[]DiscordChannel` and `[]DiscordCategory`)
It also returns the oldest message timestamp found in all extracted
channels.
The API is synchronous and returns the extracted data as
a `*MessengerResponse`. This allows to make the API available
status-go's RPC interface.
The error case is a `map[string]*discord.ImportError` where each key
is a file path of a JSON file that we tried to extract data from, and
the value a `discord.ImportError` which holds an error message and an
error code, allowing for distinguishing between "critical" errors and
"non-critical" errors.
2. `Messenger.RequestExtractDiscordCategoriesAndChannels(filesToImport
[]string)`
This is the asynchronous counterpart to
`ExtractDiscordCategoriesAndChannels`. The reason this API has been
added is because discord servers can have a lot of message and
channel data, which causes `ExtractDiscordCategoriesAndChannels` to
block the thread for too long, making apps potentially feel like they
are stuck.
This API runs inside a go routine, eventually calls
`ExtractDiscordCategoriesAndChannels`, and then emits a newly
introduced `DiscordCategoriesAndChannelsExtractedSignal` that clients
can react to.
Failure of extraction has to be determined by the
`discord.ImportErrors` emitted by the signal.
**A note about exported discord history files**
We expect users to export their discord histories via the
[DiscordChatExporter](https://github.com/Tyrrrz/DiscordChatExporter/wiki/GUI%2C-CLI-and-Formats-explained#exportguild)
tool. The tool allows to export the data in different formats, such as
JSON, HTML and CSV.
We expect users to have their data exported as JSON.
Closes: https://github.com/status-im/status-desktop/issues/6690
2022-07-13 09:33:53 +00:00
|
|
|
"github.com/status-im/status-go/protocol/discord"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/status-im/status-go/protocol/encryption/multidevice"
|
2020-07-27 12:27:48 +00:00
|
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
2020-07-22 07:41:40 +00:00
|
|
|
"github.com/status-im/status-go/protocol/pushnotificationclient"
|
2021-01-11 10:32:51 +00:00
|
|
|
"github.com/status-im/status-go/protocol/requests"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/status-im/status-go/protocol/transport"
|
2020-10-27 17:35:28 +00:00
|
|
|
"github.com/status-im/status-go/protocol/urls"
|
2022-07-05 19:49:44 +00:00
|
|
|
"github.com/status-im/status-go/protocol/verification"
|
2020-01-20 20:56:06 +00:00
|
|
|
"github.com/status-im/status-go/services/ext/mailservers"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// defaultRequestTimeout is the default request timeout in seconds
|
|
|
|
defaultRequestTimeout = 10
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// ErrInvalidMailServerPeer is returned when it fails to parse enode from params.
|
|
|
|
ErrInvalidMailServerPeer = errors.New("invalid mailServerPeer value")
|
|
|
|
// ErrInvalidSymKeyID is returned when it fails to get a symmetric key.
|
|
|
|
ErrInvalidSymKeyID = errors.New("invalid symKeyID value")
|
|
|
|
// ErrInvalidPublicKey is returned when public key can't be extracted
|
|
|
|
// from MailServer's nodeID.
|
|
|
|
ErrInvalidPublicKey = errors.New("can't extract public key")
|
|
|
|
// ErrPFSNotEnabled is returned when an endpoint PFS only is called but
|
|
|
|
// PFS is disabled
|
|
|
|
ErrPFSNotEnabled = errors.New("pfs not enabled")
|
|
|
|
)
|
|
|
|
|
|
|
|
// -----
|
|
|
|
// PAYLOADS
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// MessagesRequest is a RequestMessages() request payload.
|
|
|
|
type MessagesRequest struct {
|
|
|
|
// MailServerPeer is MailServer's enode address.
|
|
|
|
MailServerPeer string `json:"mailServerPeer"`
|
|
|
|
|
|
|
|
// From is a lower bound of time range (optional).
|
|
|
|
// Default is 24 hours back from now.
|
|
|
|
From uint32 `json:"from"`
|
|
|
|
|
|
|
|
// To is a upper bound of time range (optional).
|
|
|
|
// Default is now.
|
|
|
|
To uint32 `json:"to"`
|
|
|
|
|
|
|
|
// Limit determines the number of messages sent by the mail server
|
|
|
|
// for the current paginated request
|
|
|
|
Limit uint32 `json:"limit"`
|
|
|
|
|
|
|
|
// Cursor is used as starting point for paginated requests
|
|
|
|
Cursor string `json:"cursor"`
|
|
|
|
|
2021-07-21 19:02:50 +00:00
|
|
|
// StoreCursor is used as starting point for WAKUV2 paginatedRequests
|
|
|
|
StoreCursor *StoreRequestCursor `json:"storeCursor"`
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
// Topic is a regular Whisper topic.
|
|
|
|
// DEPRECATED
|
|
|
|
Topic types.TopicType `json:"topic"`
|
|
|
|
|
|
|
|
// Topics is a list of Whisper topics.
|
|
|
|
Topics []types.TopicType `json:"topics"`
|
|
|
|
|
|
|
|
// SymKeyID is an ID of a symmetric key to authenticate to MailServer.
|
|
|
|
// It's derived from MailServer password.
|
|
|
|
SymKeyID string `json:"symKeyID"`
|
|
|
|
|
|
|
|
// Timeout is the time to live of the request specified in seconds.
|
|
|
|
// Default is 10 seconds
|
|
|
|
Timeout time.Duration `json:"timeout"`
|
|
|
|
|
|
|
|
// Force ensures that requests will bypass enforced delay.
|
|
|
|
Force bool `json:"force"`
|
|
|
|
}
|
|
|
|
|
2021-06-16 20:19:45 +00:00
|
|
|
type StoreRequestCursor struct {
|
|
|
|
Digest []byte `json:"digest"`
|
|
|
|
ReceivedTime float64 `json:"receivedTime"`
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (r *MessagesRequest) SetDefaults(now time.Time) {
|
|
|
|
// set From and To defaults
|
|
|
|
if r.To == 0 {
|
|
|
|
r.To = uint32(now.UTC().Unix())
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.From == 0 {
|
|
|
|
oneDay := uint32(86400) // -24 hours
|
|
|
|
if r.To < oneDay {
|
|
|
|
r.From = 0
|
|
|
|
} else {
|
|
|
|
r.From = r.To - oneDay
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.Timeout == 0 {
|
|
|
|
r.Timeout = defaultRequestTimeout
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// MessagesResponse is a response for requestMessages2 method.
|
|
|
|
type MessagesResponse struct {
|
|
|
|
// Cursor from the response can be used to retrieve more messages
|
|
|
|
// for the previous request.
|
|
|
|
Cursor string `json:"cursor"`
|
|
|
|
|
|
|
|
// Error indicates that something wrong happened when sending messages
|
|
|
|
// to the requester.
|
|
|
|
Error error `json:"error"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----
|
|
|
|
// PUBLIC API
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// PublicAPI extends whisper public API.
|
|
|
|
type PublicAPI struct {
|
|
|
|
service *Service
|
|
|
|
eventSub mailservers.EnvelopeEventSubscriber
|
|
|
|
log log.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewPublicAPI returns instance of the public API.
|
|
|
|
func NewPublicAPI(s *Service, eventSub mailservers.EnvelopeEventSubscriber) *PublicAPI {
|
|
|
|
return &PublicAPI{
|
|
|
|
service: s,
|
|
|
|
eventSub: eventSub,
|
|
|
|
log: log.New("package", "status-go/services/sshext.PublicAPI"),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RetryConfig specifies configuration for retries with timeout and max amount of retries.
|
|
|
|
type RetryConfig struct {
|
|
|
|
BaseTimeout time.Duration
|
|
|
|
// StepTimeout defines duration increase per each retry.
|
|
|
|
StepTimeout time.Duration
|
|
|
|
MaxRetries int
|
|
|
|
}
|
|
|
|
|
|
|
|
func WaitForExpiredOrCompleted(requestID types.Hash, events chan types.EnvelopeEvent, timeout time.Duration) (*types.MailServerResponse, error) {
|
|
|
|
expired := fmt.Errorf("request %x expired", requestID)
|
|
|
|
after := time.NewTimer(timeout)
|
|
|
|
defer after.Stop()
|
|
|
|
for {
|
|
|
|
var ev types.EnvelopeEvent
|
|
|
|
select {
|
|
|
|
case ev = <-events:
|
|
|
|
case <-after.C:
|
|
|
|
return nil, expired
|
|
|
|
}
|
|
|
|
if ev.Hash != requestID {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
switch ev.Event {
|
|
|
|
case types.EventMailServerRequestCompleted:
|
|
|
|
data, ok := ev.Data.(*types.MailServerResponse)
|
|
|
|
if ok {
|
|
|
|
return data, nil
|
|
|
|
}
|
|
|
|
return nil, errors.New("invalid event data type")
|
|
|
|
case types.EventMailServerRequestExpired:
|
|
|
|
return nil, expired
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type Author struct {
|
|
|
|
PublicKey types.HexBytes `json:"publicKey"`
|
|
|
|
Alias string `json:"alias"`
|
|
|
|
Identicon string `json:"identicon"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type Metadata struct {
|
|
|
|
DedupID []byte `json:"dedupId"`
|
|
|
|
EncryptionID types.HexBytes `json:"encryptionId"`
|
|
|
|
MessageID types.HexBytes `json:"messageId"`
|
|
|
|
Author Author `json:"author"`
|
|
|
|
}
|
|
|
|
|
2020-04-14 11:49:03 +00:00
|
|
|
func (api *PublicAPI) LeaveGroupChat(ctx Context, chatID string, remove bool) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.LeaveGroupChat(ctx, chatID, remove)
|
2020-01-20 20:56:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) CreateGroupChatWithMembers(ctx Context, name string, members []string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateGroupChatWithMembers(ctx, name, members)
|
|
|
|
}
|
|
|
|
|
2020-08-07 13:49:37 +00:00
|
|
|
func (api *PublicAPI) CreateGroupChatFromInvitation(name string, chatID string, adminPK string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateGroupChatFromInvitation(name, chatID, adminPK)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) AddMembersToGroupChat(ctx Context, chatID string, members []string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AddMembersToGroupChat(ctx, chatID, members)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) RemoveMemberFromGroupChat(ctx Context, chatID string, member string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RemoveMemberFromGroupChat(ctx, chatID, member)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) AddAdminsToGroupChat(ctx Context, chatID string, members []string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AddAdminsToGroupChat(ctx, chatID, members)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) ConfirmJoiningGroup(ctx context.Context, chatID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ConfirmJoiningGroup(ctx, chatID)
|
|
|
|
}
|
|
|
|
|
2020-04-14 11:48:32 +00:00
|
|
|
func (api *PublicAPI) ChangeGroupChatName(ctx Context, chatID string, name string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ChangeGroupChatName(ctx, chatID, name)
|
|
|
|
}
|
|
|
|
|
2020-08-07 13:49:37 +00:00
|
|
|
func (api *PublicAPI) SendGroupChatInvitationRequest(ctx Context, chatID string, adminPK string, message string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendGroupChatInvitationRequest(ctx, chatID, adminPK, message)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetGroupChatInvitations() ([]*protocol.GroupChatInvitation, error) {
|
|
|
|
return api.service.messenger.GetGroupChatInvitations()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendGroupChatInvitationRejection(ctx Context, invitationRequestID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendGroupChatInvitationRejection(ctx, invitationRequestID)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) LoadFilters(parent context.Context, chats []*transport.Filter) ([]*transport.Filter, error) {
|
|
|
|
return api.service.messenger.LoadFilters(chats)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SaveChat(parent context.Context, chat *protocol.Chat) error {
|
|
|
|
return api.service.messenger.SaveChat(chat)
|
|
|
|
}
|
|
|
|
|
2021-06-30 12:44:49 +00:00
|
|
|
func (api *PublicAPI) SaveMessages(parent context.Context, messages []*common.Message) error {
|
|
|
|
return api.service.messenger.SaveMessages(messages)
|
|
|
|
}
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) CreateOneToOneChat(parent context.Context, request *requests.CreateOneToOneChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateOneToOneChat(request)
|
|
|
|
}
|
|
|
|
|
2021-03-25 15:15:22 +00:00
|
|
|
func (api *PublicAPI) CreatePublicChat(parent context.Context, request *requests.CreatePublicChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreatePublicChat(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) CreateProfileChat(parent context.Context, request *requests.CreateProfileChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateProfileChat(request)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) Chats(parent context.Context) []*protocol.Chat {
|
|
|
|
return api.service.messenger.Chats()
|
|
|
|
}
|
|
|
|
|
2021-09-07 14:05:36 +00:00
|
|
|
func (api *PublicAPI) ChatsPreview(parent context.Context) []*protocol.ChatPreview {
|
|
|
|
return api.service.messenger.ChatsPreview()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) Chat(parent context.Context, chatID string) *protocol.Chat {
|
|
|
|
return api.service.messenger.Chat(chatID)
|
2021-08-16 11:04:35 +00:00
|
|
|
}
|
|
|
|
|
2021-04-07 12:57:14 +00:00
|
|
|
func (api *PublicAPI) ActiveChats(parent context.Context) []*protocol.Chat {
|
|
|
|
return api.service.messenger.ActiveChats()
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) DeleteChat(parent context.Context, chatID string) error {
|
|
|
|
return api.service.messenger.DeleteChat(chatID)
|
|
|
|
}
|
|
|
|
|
2022-07-06 16:16:19 +00:00
|
|
|
func (api *PublicAPI) MuteCommunityCategory(communityID string, categoryID string) error {
|
|
|
|
return api.service.messenger.SetMutePropertyOnChatsByCategory(communityID, categoryID, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) UnmuteCommunityCategory(communityID string, categoryID string) error {
|
|
|
|
return api.service.messenger.SetMutePropertyOnChatsByCategory(communityID, categoryID, false)
|
|
|
|
}
|
|
|
|
|
2020-06-26 07:46:14 +00:00
|
|
|
func (api *PublicAPI) MuteChat(parent context.Context, chatID string) error {
|
|
|
|
return api.service.messenger.MuteChat(chatID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) UnmuteChat(parent context.Context, chatID string) error {
|
|
|
|
return api.service.messenger.UnmuteChat(chatID)
|
|
|
|
}
|
|
|
|
|
2021-12-06 12:44:40 +00:00
|
|
|
func (api *PublicAPI) BlockContact(parent context.Context, contactID string) (*protocol.MessengerResponse, error) {
|
2021-11-05 15:11:10 +00:00
|
|
|
api.log.Info("blocking contact", "contact", contactID)
|
|
|
|
return api.service.messenger.BlockContact(contactID)
|
2020-01-20 20:56:06 +00:00
|
|
|
}
|
|
|
|
|
2022-04-08 20:14:37 +00:00
|
|
|
// This function is the same as the one above, but used only on the desktop side, since at the end it doesn't set
|
|
|
|
// `Added` flag to `false`, but only `Blocked` to `true`
|
|
|
|
func (api *PublicAPI) BlockContactDesktop(parent context.Context, contactID string) (*protocol.MessengerResponse, error) {
|
|
|
|
api.log.Info("blocking contact", "contact", contactID)
|
|
|
|
return api.service.messenger.BlockContactDesktop(contactID)
|
|
|
|
}
|
|
|
|
|
2021-10-25 07:18:28 +00:00
|
|
|
func (api *PublicAPI) UnblockContact(parent context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.UnblockContact(contactID)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) Contacts(parent context.Context) []*protocol.Contact {
|
|
|
|
return api.service.messenger.Contacts()
|
|
|
|
}
|
|
|
|
|
2020-06-04 13:32:47 +00:00
|
|
|
func (api *PublicAPI) GetContactByID(parent context.Context, id string) *protocol.Contact {
|
|
|
|
return api.service.messenger.GetContactByID(id)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) RemoveFilters(parent context.Context, chats []*transport.Filter) error {
|
|
|
|
return api.service.messenger.RemoveFilters(chats)
|
|
|
|
}
|
|
|
|
|
|
|
|
// EnableInstallation enables an installation for multi-device sync.
|
|
|
|
func (api *PublicAPI) EnableInstallation(installationID string) error {
|
|
|
|
return api.service.messenger.EnableInstallation(installationID)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DisableInstallation disables an installation for multi-device sync.
|
|
|
|
func (api *PublicAPI) DisableInstallation(installationID string) error {
|
|
|
|
return api.service.messenger.DisableInstallation(installationID)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetOurInstallations returns all the installations available given an identity
|
|
|
|
func (api *PublicAPI) GetOurInstallations() []*multidevice.Installation {
|
|
|
|
return api.service.messenger.Installations()
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetInstallationMetadata sets the metadata for our own installation
|
|
|
|
func (api *PublicAPI) SetInstallationMetadata(installationID string, data *multidevice.InstallationMetadata) error {
|
|
|
|
return api.service.messenger.SetInstallationMetadata(installationID, data)
|
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// Communities returns a list of communities that are stored
|
2020-11-18 09:16:51 +00:00
|
|
|
func (api *PublicAPI) Communities(parent context.Context) ([]*communities.Community, error) {
|
|
|
|
return api.service.messenger.Communities()
|
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// JoinedCommunities returns a list of communities that the user has joined
|
2020-11-18 09:16:51 +00:00
|
|
|
func (api *PublicAPI) JoinedCommunities(parent context.Context) ([]*communities.Community, error) {
|
|
|
|
return api.service.messenger.JoinedCommunities()
|
|
|
|
}
|
|
|
|
|
2022-06-24 13:40:12 +00:00
|
|
|
// CommunityTags return the list of possible community tags
|
|
|
|
func (api *PublicAPI) CommunityTags(parent context.Context) map[string]string {
|
|
|
|
return requests.TagsEmojies
|
|
|
|
}
|
|
|
|
|
2022-06-02 12:17:52 +00:00
|
|
|
// CuratedCommunities returns the list of curated communities stored in the smart contract. If a community is
|
|
|
|
// already known by the node, its description will be returned and and will asynchronously retrieve the
|
|
|
|
// description for the communities it does not know
|
|
|
|
func (api *PublicAPI) CuratedCommunities(parent context.Context) (*communities.KnownCommunitiesResponse, error) {
|
|
|
|
return api.service.messenger.CuratedCommunities()
|
|
|
|
}
|
|
|
|
|
2022-09-20 19:57:39 +00:00
|
|
|
// SpectateCommunity spectates community with the given ID
|
|
|
|
// Meaning user is only a spectator, not a member
|
|
|
|
func (api *PublicAPI) SpectateCommunity(parent context.Context, communityID types.HexBytes) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SpectateCommunity(communityID)
|
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// JoinCommunity joins a community with the given ID
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) JoinCommunity(parent context.Context, communityID types.HexBytes) (*protocol.MessengerResponse, error) {
|
2021-07-22 17:41:49 +00:00
|
|
|
return api.service.messenger.JoinCommunity(parent, communityID)
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// LeaveCommunity leaves a commuity with the given ID
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) LeaveCommunity(parent context.Context, communityID types.HexBytes) (*protocol.MessengerResponse, error) {
|
2020-11-18 09:16:51 +00:00
|
|
|
return api.service.messenger.LeaveCommunity(communityID)
|
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// CreateCommunity creates a new community with the provided description
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) CreateCommunity(request *requests.CreateCommunity) (*protocol.MessengerResponse, error) {
|
2022-07-19 09:31:52 +00:00
|
|
|
return api.service.messenger.CreateCommunity(request, true)
|
2021-05-18 19:32:15 +00:00
|
|
|
}
|
2020-11-18 09:16:51 +00:00
|
|
|
|
2021-05-18 19:32:15 +00:00
|
|
|
// EditCommunity edits an existing community with the provided description
|
|
|
|
func (api *PublicAPI) EditCommunity(request *requests.EditCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.EditCommunity(request)
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// ExportCommunity exports the private key of the community with given ID
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) ExportCommunity(id types.HexBytes) (types.HexBytes, error) {
|
2020-11-18 09:16:51 +00:00
|
|
|
key, err := api.service.messenger.ExportCommunity(id)
|
|
|
|
if err != nil {
|
2021-01-11 10:32:51 +00:00
|
|
|
return nil, err
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
2021-01-11 10:32:51 +00:00
|
|
|
return crypto.FromECDSA(key), nil
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// ImportCommunity imports a community with the given private key in hex
|
2021-07-22 17:41:49 +00:00
|
|
|
func (api *PublicAPI) ImportCommunity(ctx context.Context, hexPrivateKey string) (*protocol.MessengerResponse, error) {
|
2020-11-18 09:16:51 +00:00
|
|
|
// Strip the 0x from the beginning
|
|
|
|
privateKey, err := crypto.HexToECDSA(hexPrivateKey[2:])
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-07-22 17:41:49 +00:00
|
|
|
return api.service.messenger.ImportCommunity(ctx, privateKey)
|
2020-11-18 09:16:51 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-12-17 14:36:09 +00:00
|
|
|
// CreateCommunityChat creates a community chat in the given community
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) CreateCommunityChat(communityID types.HexBytes, c *protobuf.CommunityChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateCommunityChat(communityID, c)
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
|
|
|
|
2021-07-30 17:05:44 +00:00
|
|
|
// EditCommunityChat edits a community chat in the given community
|
2021-06-01 12:13:17 +00:00
|
|
|
func (api *PublicAPI) EditCommunityChat(communityID types.HexBytes, chatID string, c *protobuf.CommunityChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.EditCommunityChat(communityID, chatID, c)
|
|
|
|
}
|
|
|
|
|
2021-07-30 17:05:44 +00:00
|
|
|
// DeleteCommunityChat deletes a community chat in the given community
|
|
|
|
func (api *PublicAPI) DeleteCommunityChat(communityID types.HexBytes, chatID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeleteCommunityChat(communityID, chatID)
|
|
|
|
}
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
// InviteUsersToCommunity invites the users with pks to the community with ID
|
|
|
|
func (api *PublicAPI) InviteUsersToCommunity(request *requests.InviteUsersToCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.InviteUsersToCommunity(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ShareCommunity share the community with a set of users
|
|
|
|
func (api *PublicAPI) ShareCommunity(request *requests.ShareCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ShareCommunity(request)
|
2020-11-18 09:16:51 +00:00
|
|
|
}
|
|
|
|
|
2022-02-24 16:08:44 +00:00
|
|
|
// ShareImageMessage share the selected chat image with a set of users
|
|
|
|
func (api *PublicAPI) ShareImageMessage(request *requests.ShareImageMessage) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ShareImageMessage(request)
|
|
|
|
}
|
|
|
|
|
2020-12-21 15:10:52 +00:00
|
|
|
// RemoveUserFromCommunity removes the user with pk from the community with ID
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) RemoveUserFromCommunity(communityID types.HexBytes, userPublicKey string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RemoveUserFromCommunity(communityID, userPublicKey)
|
|
|
|
}
|
|
|
|
|
2021-06-30 13:29:43 +00:00
|
|
|
// SetCommunityMuted sets the community's muted value
|
|
|
|
func (api *PublicAPI) SetCommunityMuted(communityID types.HexBytes, muted bool) error {
|
|
|
|
return api.service.messenger.SetMuted(communityID, muted)
|
|
|
|
}
|
|
|
|
|
2021-03-19 09:15:45 +00:00
|
|
|
// BanUserFromCommunity removes the user with pk from the community with ID
|
|
|
|
func (api *PublicAPI) BanUserFromCommunity(request *requests.BanUserFromCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.BanUserFromCommunity(request)
|
|
|
|
}
|
|
|
|
|
2022-06-23 07:12:15 +00:00
|
|
|
// UnbanUserFromCommunity removes the user's pk from the community ban list
|
|
|
|
func (api *PublicAPI) UnbanUserFromCommunity(request *requests.UnbanUserFromCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.UnbanUserFromCommunity(request)
|
|
|
|
}
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
// MyPendingRequestsToJoin returns the pending requests for the logged in user
|
|
|
|
func (api *PublicAPI) MyPendingRequestsToJoin() ([]*communities.RequestToJoin, error) {
|
|
|
|
return api.service.messenger.MyPendingRequestsToJoin()
|
|
|
|
}
|
|
|
|
|
|
|
|
// PendingRequestsToJoinForCommunity returns the pending requests to join for a given community
|
|
|
|
func (api *PublicAPI) PendingRequestsToJoinForCommunity(id types.HexBytes) ([]*communities.RequestToJoin, error) {
|
|
|
|
return api.service.messenger.PendingRequestsToJoinForCommunity(id)
|
|
|
|
}
|
|
|
|
|
2022-08-04 07:44:35 +00:00
|
|
|
// DeclinedRequestsToJoinForCommunity returns the declined requests to join for a given community
|
|
|
|
func (api *PublicAPI) DeclinedRequestsToJoinForCommunity(id types.HexBytes) ([]*communities.RequestToJoin, error) {
|
|
|
|
return api.service.messenger.DeclinedRequestsToJoinForCommunity(id)
|
|
|
|
}
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
// AcceptRequestToJoinCommunity accepts a pending request to join a community
|
|
|
|
func (api *PublicAPI) AcceptRequestToJoinCommunity(request *requests.AcceptRequestToJoinCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptRequestToJoinCommunity(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeclineRequestToJoinCommunity accepts a pending request to join a community
|
|
|
|
func (api *PublicAPI) DeclineRequestToJoinCommunity(request *requests.DeclineRequestToJoinCommunity) error {
|
|
|
|
return api.service.messenger.DeclineRequestToJoinCommunity(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// RequestToJoinCommunity requests to join a particular community
|
|
|
|
func (api *PublicAPI) RequestToJoinCommunity(request *requests.RequestToJoinCommunity) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RequestToJoinCommunity(request)
|
2020-12-21 15:10:52 +00:00
|
|
|
}
|
|
|
|
|
2021-05-23 13:34:17 +00:00
|
|
|
// CreateCommunityCategory creates a category within a particular community
|
|
|
|
func (api *PublicAPI) CreateCommunityCategory(request *requests.CreateCommunityCategory) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.CreateCommunityCategory(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ReorderCommunityCategories is used to change the order of the categories of a community
|
|
|
|
func (api *PublicAPI) ReorderCommunityCategories(request *requests.ReorderCommunityCategories) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ReorderCommunityCategories(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ReorderCommunityChat allows changing the order of the chat or switching its category
|
|
|
|
func (api *PublicAPI) ReorderCommunityChat(request *requests.ReorderCommunityChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ReorderCommunityChat(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// EditCommunityCategory modifies a category within a particular community
|
|
|
|
func (api *PublicAPI) EditCommunityCategory(request *requests.EditCommunityCategory) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.EditCommunityCategory(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteCommunityCategory deletes a category within a particular community and removes this category from any chat that has it
|
|
|
|
func (api *PublicAPI) DeleteCommunityCategory(request *requests.DeleteCommunityCategory) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeleteCommunityCategory(request)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
type ApplicationMessagesResponse struct {
|
2020-09-01 13:27:01 +00:00
|
|
|
Messages []*common.Message `json:"messages"`
|
|
|
|
Cursor string `json:"cursor"`
|
2020-01-20 20:56:06 +00:00
|
|
|
}
|
|
|
|
|
2021-08-31 08:49:39 +00:00
|
|
|
type MarkMessagSeenResponse struct {
|
|
|
|
Count uint64 `json:"count"`
|
|
|
|
CountWithMentions uint64 `json:"countWithMentions"`
|
|
|
|
}
|
|
|
|
|
2021-05-14 21:22:50 +00:00
|
|
|
type ApplicationPinnedMessagesResponse struct {
|
2021-06-08 15:23:32 +00:00
|
|
|
PinnedMessages []*common.PinnedMessage `json:"pinnedMessages"`
|
|
|
|
Cursor string `json:"cursor"`
|
2021-05-14 21:22:50 +00:00
|
|
|
}
|
|
|
|
|
2021-07-22 17:41:49 +00:00
|
|
|
type ApplicationStatusUpdatesResponse struct {
|
|
|
|
StatusUpdates []protocol.UserStatus `json:"statusUpdates"`
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) ChatMessages(chatID, cursor string, limit int) (*ApplicationMessagesResponse, error) {
|
|
|
|
messages, cursor, err := api.service.messenger.MessageByChatID(chatID, cursor, limit)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ApplicationMessagesResponse{
|
|
|
|
Messages: messages,
|
|
|
|
Cursor: cursor,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-11-05 13:48:20 +00:00
|
|
|
func (api *PublicAPI) MessageByMessageID(messageID string) (*common.Message, error) {
|
|
|
|
return api.service.messenger.MessageByID(messageID)
|
|
|
|
}
|
|
|
|
|
2021-08-19 19:47:03 +00:00
|
|
|
func (api *PublicAPI) AllMessagesFromChatWhichMatchTerm(chatID, searchTerm string, caseSensitive bool) (*ApplicationMessagesResponse, error) {
|
2021-08-04 19:31:44 +00:00
|
|
|
messages, err := api.service.messenger.AllMessageByChatIDWhichMatchTerm(chatID, searchTerm, caseSensitive)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ApplicationMessagesResponse{
|
|
|
|
Messages: messages,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-08-19 19:47:03 +00:00
|
|
|
func (api *PublicAPI) AllMessagesFromChatsAndCommunitiesWhichMatchTerm(communityIds []string, chatIds []string, searchTerm string, caseSensitive bool) (*ApplicationMessagesResponse, error) {
|
|
|
|
messages, err := api.service.messenger.AllMessagesFromChatsAndCommunitiesWhichMatchTerm(communityIds, chatIds, searchTerm, caseSensitive)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ApplicationMessagesResponse{
|
|
|
|
Messages: messages,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-05-14 21:22:50 +00:00
|
|
|
func (api *PublicAPI) ChatPinnedMessages(chatID, cursor string, limit int) (*ApplicationPinnedMessagesResponse, error) {
|
2021-06-08 15:23:32 +00:00
|
|
|
pinnedMessages, cursor, err := api.service.messenger.PinnedMessageByChatID(chatID, cursor, limit)
|
2021-05-14 21:22:50 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ApplicationPinnedMessagesResponse{
|
2021-06-08 15:23:32 +00:00
|
|
|
PinnedMessages: pinnedMessages,
|
|
|
|
Cursor: cursor,
|
2021-05-14 21:22:50 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-07-22 17:41:49 +00:00
|
|
|
func (api *PublicAPI) StatusUpdates() (*ApplicationStatusUpdatesResponse, error) {
|
|
|
|
statusUpdates, err := api.service.messenger.StatusUpdates()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &ApplicationStatusUpdatesResponse{
|
|
|
|
StatusUpdates: statusUpdates,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-01-14 22:15:13 +00:00
|
|
|
func (api *PublicAPI) StartMessenger() (*protocol.MessengerResponse, error) {
|
2020-01-29 19:40:06 +00:00
|
|
|
return api.service.StartMessenger()
|
|
|
|
}
|
|
|
|
|
2021-07-22 17:41:49 +00:00
|
|
|
func (api *PublicAPI) SetUserStatus(ctx context.Context, status int, customText string) error {
|
|
|
|
return api.service.messenger.SetUserStatus(ctx, status, customText)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) DeleteMessage(id string) error {
|
|
|
|
return api.service.messenger.DeleteMessage(id)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeleteMessagesByChatID(id string) error {
|
|
|
|
return api.service.messenger.DeleteMessagesByChatID(id)
|
|
|
|
}
|
|
|
|
|
2021-08-31 08:49:39 +00:00
|
|
|
func (api *PublicAPI) MarkMessagesSeen(chatID string, ids []string) (*MarkMessagSeenResponse, error) {
|
|
|
|
count, withMentions, err := api.service.messenger.MarkMessagesSeen(chatID, ids)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
response := &MarkMessagSeenResponse{Count: count, CountWithMentions: withMentions}
|
|
|
|
return response, nil
|
2020-01-20 20:56:06 +00:00
|
|
|
}
|
|
|
|
|
2020-02-26 12:31:48 +00:00
|
|
|
func (api *PublicAPI) MarkAllRead(chatID string) error {
|
|
|
|
return api.service.messenger.MarkAllRead(chatID)
|
|
|
|
}
|
|
|
|
|
2021-09-20 06:33:36 +00:00
|
|
|
func (api *PublicAPI) MarkAllReadInCommunity(communityID string) ([]string, error) {
|
|
|
|
return api.service.messenger.MarkAllReadInCommunity(communityID)
|
|
|
|
}
|
|
|
|
|
2021-10-25 10:25:37 +00:00
|
|
|
func (api *PublicAPI) AddContact(ctx context.Context, request *requests.AddContact) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AddContact(ctx, request)
|
2020-12-22 10:49:25 +00:00
|
|
|
}
|
|
|
|
|
2022-01-18 16:31:34 +00:00
|
|
|
func (api *PublicAPI) SendContactRequest(ctx context.Context, request *requests.SendContactRequest) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendContactRequest(ctx, request)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) AcceptContactRequest(ctx context.Context, request *requests.AcceptContactRequest) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptContactRequest(ctx, request)
|
|
|
|
}
|
|
|
|
|
2022-06-17 16:20:43 +00:00
|
|
|
func (api *PublicAPI) AcceptLatestContactRequestForContact(ctx context.Context, request *requests.AcceptLatestContactRequestForContact) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptLatestContactRequestForContact(ctx, request)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DismissLatestContactRequestForContact(ctx context.Context, request *requests.DismissLatestContactRequestForContact) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DismissLatestContactRequestForContact(ctx, request)
|
|
|
|
}
|
|
|
|
|
2022-01-18 16:31:34 +00:00
|
|
|
func (api *PublicAPI) RetractContactRequest(ctx context.Context, request *requests.RetractContactRequest) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RetractContactRequest(request)
|
|
|
|
}
|
|
|
|
|
2021-11-22 17:21:27 +00:00
|
|
|
func (api *PublicAPI) RejectContactRequest(ctx context.Context, request *requests.RejectContactRequest) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RejectContactRequest(ctx, request)
|
|
|
|
}
|
|
|
|
|
2022-01-18 16:31:34 +00:00
|
|
|
func (api *PublicAPI) DismissContactRequest(ctx context.Context, request *requests.DismissContactRequest) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DismissContactRequest(ctx, request)
|
|
|
|
}
|
|
|
|
|
2020-12-22 10:49:25 +00:00
|
|
|
func (api *PublicAPI) RemoveContact(ctx context.Context, pubKey string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RemoveContact(ctx, pubKey)
|
|
|
|
}
|
|
|
|
|
2021-10-25 10:25:37 +00:00
|
|
|
func (api *PublicAPI) SetContactLocalNickname(ctx context.Context, request *requests.SetContactLocalNickname) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SetContactLocalNickname(request)
|
2021-10-25 07:18:28 +00:00
|
|
|
}
|
|
|
|
|
2021-03-25 15:15:22 +00:00
|
|
|
func (api *PublicAPI) ClearHistory(request *requests.ClearHistory) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.ClearHistory(request)
|
2020-12-22 10:49:25 +00:00
|
|
|
}
|
|
|
|
|
2021-03-25 15:15:22 +00:00
|
|
|
func (api *PublicAPI) DeactivateChat(request *requests.DeactivateChat) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeactivateChat(request)
|
2020-12-22 10:49:25 +00:00
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) UpdateMessageOutgoingStatus(id, newOutgoingStatus string) error {
|
|
|
|
return api.service.messenger.UpdateMessageOutgoingStatus(id, newOutgoingStatus)
|
|
|
|
}
|
|
|
|
|
2020-09-01 13:27:01 +00:00
|
|
|
func (api *PublicAPI) SendChatMessage(ctx context.Context, message *common.Message) (*protocol.MessengerResponse, error) {
|
2020-01-20 20:56:06 +00:00
|
|
|
return api.service.messenger.SendChatMessage(ctx, message)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) ReSendChatMessage(ctx context.Context, messageID string) error {
|
|
|
|
return api.service.messenger.ReSendChatMessage(ctx, messageID)
|
|
|
|
}
|
|
|
|
|
2020-12-01 09:43:46 +00:00
|
|
|
func (api *PublicAPI) SendChatMessages(ctx context.Context, messages []*common.Message) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendChatMessages(ctx, messages)
|
|
|
|
}
|
|
|
|
|
2021-06-08 06:07:45 +00:00
|
|
|
func (api *PublicAPI) EditMessage(ctx context.Context, request *requests.EditMessage) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.EditMessage(ctx, request)
|
|
|
|
}
|
|
|
|
|
2021-07-26 21:06:32 +00:00
|
|
|
func (api *PublicAPI) DeleteMessageAndSend(ctx context.Context, messageID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeleteMessageAndSend(ctx, messageID)
|
|
|
|
}
|
|
|
|
|
2022-09-28 11:42:17 +00:00
|
|
|
func (api *PublicAPI) DeleteMessageForMeAndSync(ctx context.Context, chatID string, messageID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeleteMessageForMeAndSync(ctx, chatID, messageID)
|
|
|
|
}
|
|
|
|
|
2021-05-14 21:22:50 +00:00
|
|
|
func (api *PublicAPI) SendPinMessage(ctx context.Context, message *common.PinMessage) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendPinMessage(ctx, message)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) RequestTransaction(ctx context.Context, chatID, value, contract, address string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RequestTransaction(ctx, chatID, value, contract, address)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) RequestAddressForTransaction(ctx context.Context, chatID, from, value, contract string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RequestAddressForTransaction(ctx, chatID, from, value, contract)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeclineRequestAddressForTransaction(ctx context.Context, messageID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeclineRequestAddressForTransaction(ctx, messageID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeclineRequestTransaction(ctx context.Context, messageID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.DeclineRequestTransaction(ctx, messageID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) AcceptRequestAddressForTransaction(ctx context.Context, messageID, address string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptRequestAddressForTransaction(ctx, messageID, address)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendTransaction(ctx context.Context, chatID, value, contract, transactionHash string, signature types.HexBytes) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendTransaction(ctx, chatID, value, contract, transactionHash, signature)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) AcceptRequestTransaction(ctx context.Context, transactionHash, messageID string, signature types.HexBytes) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptRequestTransaction(ctx, transactionHash, messageID, signature)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendContactUpdates(ctx context.Context, name, picture string) error {
|
|
|
|
return api.service.messenger.SendContactUpdates(ctx, name, picture)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendContactUpdate(ctx context.Context, contactID, name, picture string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendContactUpdate(ctx, contactID, name, picture)
|
|
|
|
}
|
|
|
|
|
2022-02-17 15:13:10 +00:00
|
|
|
func (api *PublicAPI) SetDisplayName(ctx context.Context, displayName string) error {
|
|
|
|
return api.service.messenger.SetDisplayName(displayName)
|
|
|
|
}
|
|
|
|
|
2022-07-05 19:49:44 +00:00
|
|
|
func (api *PublicAPI) MarkAsTrusted(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.MarkAsTrusted(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) MarkAsUntrustworthy(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.MarkAsUntrustworthy(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) RemoveTrustStatus(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.RemoveTrustStatus(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetTrustStatus(ctx context.Context, contactID string) (verification.TrustStatus, error) {
|
|
|
|
return api.service.messenger.GetTrustStatus(contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendContactVerificationRequest(ctx context.Context, contactID string, challenge string) error {
|
|
|
|
return api.service.messenger.SendContactVerificationRequest(ctx, contactID, challenge)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetVerificationRequestFrom(ctx context.Context, contactID string) (*verification.Request, error) {
|
|
|
|
return api.service.messenger.GetVerificationRequestFrom(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetReceivedVerificationRequests(ctx context.Context) ([]*verification.Request, error) {
|
|
|
|
return api.service.messenger.GetReceivedVerificationRequests(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetVerificationRequestSentTo(ctx context.Context, contactID string) (*verification.Request, error) {
|
|
|
|
return api.service.messenger.GetVerificationRequestSentTo(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) CancelVerificationRequest(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.CancelVerificationRequest(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) AcceptContactVerificationRequest(ctx context.Context, contactID string, response string) error {
|
|
|
|
return api.service.messenger.AcceptContactVerificationRequest(ctx, contactID, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeclineContactVerificationRequest(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.DeclineContactVerificationRequest(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) VerifiedTrusted(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.VerifiedTrusted(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) VerifiedUntrustworthy(ctx context.Context, contactID string) error {
|
|
|
|
return api.service.messenger.VerifiedUntrustworthy(ctx, contactID)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func (api *PublicAPI) SendPairInstallation(ctx context.Context) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendPairInstallation(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SyncDevices(ctx context.Context, name, picture string) error {
|
|
|
|
return api.service.messenger.SyncDevices(ctx, name, picture)
|
|
|
|
}
|
|
|
|
|
2022-06-08 18:39:53 +00:00
|
|
|
func (api *PublicAPI) AddBookmark(ctx context.Context, bookmark browsers.Bookmark) error {
|
|
|
|
return api.service.messenger.AddBookmark(ctx, bookmark)
|
|
|
|
}
|
|
|
|
|
2022-08-24 14:05:35 +00:00
|
|
|
func (api *PublicAPI) AddBrowser(ctx context.Context, browser browsers.Browser) error {
|
|
|
|
return api.service.messenger.AddBrowser(ctx, browser)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetBrowsers(ctx context.Context) (browsers []*browsers.Browser, err error) {
|
|
|
|
return api.service.messenger.GetBrowsers(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeleteBrowser(ctx context.Context, id string) error {
|
|
|
|
return api.service.messenger.DeleteBrowser(ctx, id)
|
|
|
|
}
|
|
|
|
|
2022-06-08 18:39:53 +00:00
|
|
|
func (api *PublicAPI) RemoveBookmark(ctx context.Context, url string) error {
|
|
|
|
return api.service.messenger.RemoveBookmark(ctx, url)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) UpdateBookmark(ctx context.Context, oldURL string, bookmark browsers.Bookmark) error {
|
|
|
|
return api.service.messenger.UpdateBookmark(ctx, oldURL, bookmark)
|
2022-01-17 03:42:11 +00:00
|
|
|
}
|
|
|
|
|
2020-03-20 08:32:13 +00:00
|
|
|
func (api *PublicAPI) SignMessageWithChatKey(ctx context.Context, message string) (types.HexBytes, error) {
|
|
|
|
return api.service.messenger.SignMessage(message)
|
|
|
|
}
|
|
|
|
|
2022-07-22 08:10:47 +00:00
|
|
|
// wallet connect session apis
|
|
|
|
func (api *PublicAPI) AddWalletConnectSession(ctx context.Context, request *requests.AddWalletConnectSession) error {
|
|
|
|
return api.service.messenger.AddWalletConnectSession(request)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetWalletConnectSession(ctx context.Context) ([]protocol.WalletConnectSession, error) {
|
|
|
|
return api.service.messenger.GetWalletConnectSession()
|
|
|
|
}
|
2020-07-14 14:07:19 +00:00
|
|
|
|
2022-07-22 08:10:47 +00:00
|
|
|
func (api *PublicAPI) DestroyWalletConnectSession(ctx context.Context, PeerID string) error {
|
|
|
|
return api.service.messenger.DestroyWalletConnectSession(PeerID)
|
|
|
|
}
|
|
|
|
|
2022-09-14 10:46:11 +00:00
|
|
|
// Saved Addresses APIs
|
|
|
|
func (api *PublicAPI) UpsertSavedAddress(ctx context.Context, sa wallet.SavedAddress) error {
|
|
|
|
if sa.ChainID == 0 {
|
|
|
|
sa.ChainID = api.service.rpcClient.UpstreamChainID
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.service.messenger.UpsertSavedAddress(ctx, sa)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DeleteSavedAddress(ctx context.Context, chainID uint64, address ethcommon.Address) error {
|
|
|
|
if chainID == 0 {
|
|
|
|
chainID = api.service.rpcClient.UpstreamChainID
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.service.messenger.DeleteSavedAddress(ctx, chainID, address)
|
|
|
|
}
|
|
|
|
|
2022-07-22 08:10:47 +00:00
|
|
|
// PushNotifications server endpoints
|
2020-07-22 07:41:40 +00:00
|
|
|
func (api *PublicAPI) StartPushNotificationsServer() error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsServerEnabled, true)
|
2020-07-17 11:41:49 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-07-22 07:41:40 +00:00
|
|
|
return api.service.messenger.StartPushNotificationsServer()
|
2020-07-14 14:07:19 +00:00
|
|
|
}
|
|
|
|
|
2020-07-22 07:41:40 +00:00
|
|
|
func (api *PublicAPI) StopPushNotificationsServer() error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsServerEnabled, false)
|
2020-07-17 11:41:49 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-07-22 07:41:40 +00:00
|
|
|
return api.service.messenger.StopPushNotificationsServer()
|
2020-07-14 14:07:19 +00:00
|
|
|
}
|
|
|
|
|
2020-07-22 07:41:40 +00:00
|
|
|
// PushNotification client endpoints
|
2020-07-14 14:07:19 +00:00
|
|
|
|
2020-07-30 08:24:30 +00:00
|
|
|
func (api *PublicAPI) RegisterForPushNotifications(ctx context.Context, deviceToken string, apnTopic string, tokenType protobuf.PushNotificationRegistration_TokenType) error {
|
|
|
|
return api.service.messenger.RegisterForPushNotifications(ctx, deviceToken, apnTopic, tokenType)
|
2020-07-14 14:07:19 +00:00
|
|
|
}
|
|
|
|
|
2020-07-30 13:37:32 +00:00
|
|
|
func (api *PublicAPI) UnregisterFromPushNotifications(ctx context.Context) error {
|
2020-07-15 12:43:15 +00:00
|
|
|
return api.service.messenger.UnregisterFromPushNotifications(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DisableSendingNotifications(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.SendPushNotifications, false)
|
2020-07-15 12:43:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.service.messenger.DisableSendingPushNotifications()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) EnableSendingNotifications(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.SendPushNotifications, true)
|
2020-07-15 12:43:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return api.service.messenger.EnableSendingPushNotifications()
|
|
|
|
}
|
|
|
|
|
2020-07-17 11:41:49 +00:00
|
|
|
func (api *PublicAPI) EnablePushNotificationsFromContactsOnly(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsFromContactsOnly, true)
|
2020-07-17 11:41:49 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return api.service.messenger.EnablePushNotificationsFromContactsOnly()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DisablePushNotificationsFromContactsOnly(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsFromContactsOnly, false)
|
2020-07-17 11:41:49 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return api.service.messenger.DisablePushNotificationsFromContactsOnly()
|
|
|
|
}
|
|
|
|
|
2020-09-03 07:30:03 +00:00
|
|
|
func (api *PublicAPI) EnablePushNotificationsBlockMentions(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsBlockMentions, true)
|
2020-09-03 07:30:03 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return api.service.messenger.EnablePushNotificationsBlockMentions()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DisablePushNotificationsBlockMentions(ctx context.Context) error {
|
2022-03-23 18:47:00 +00:00
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.PushNotificationsBlockMentions, false)
|
2020-09-03 07:30:03 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return api.service.messenger.DisablePushNotificationsBlockMentions()
|
|
|
|
}
|
|
|
|
|
2020-07-22 07:41:40 +00:00
|
|
|
func (api *PublicAPI) AddPushNotificationsServer(ctx context.Context, publicKeyBytes types.HexBytes) error {
|
2020-07-14 14:07:19 +00:00
|
|
|
publicKey, err := crypto.UnmarshalPubkey(publicKeyBytes)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-08-20 09:05:39 +00:00
|
|
|
// this is coming from a user, so it has to be a custom server
|
|
|
|
return api.service.messenger.AddPushNotificationsServer(ctx, publicKey, pushnotificationclient.ServerTypeCustom)
|
2020-07-14 14:07:19 +00:00
|
|
|
}
|
|
|
|
|
2020-07-17 11:41:49 +00:00
|
|
|
func (api *PublicAPI) RemovePushNotificationServer(ctx context.Context, publicKeyBytes types.HexBytes) error {
|
|
|
|
publicKey, err := crypto.UnmarshalPubkey(publicKeyBytes)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.service.messenger.RemovePushNotificationServer(ctx, publicKey)
|
|
|
|
}
|
|
|
|
|
2020-08-20 09:05:39 +00:00
|
|
|
func (api *PublicAPI) GetPushNotificationsServers() ([]*pushnotificationclient.PushNotificationServer, error) {
|
|
|
|
return api.service.messenger.GetPushNotificationsServers()
|
2020-07-16 08:36:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) RegisteredForPushNotifications() (bool, error) {
|
|
|
|
return api.service.messenger.RegisteredForPushNotifications()
|
|
|
|
}
|
|
|
|
|
2020-07-27 12:27:48 +00:00
|
|
|
// Emoji
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendEmojiReaction(ctx context.Context, chatID, messageID string, emojiID protobuf.EmojiReaction_Type) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendEmojiReaction(ctx, chatID, messageID, emojiID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SendEmojiReactionRetraction(ctx context.Context, emojiReactionID string) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.SendEmojiReactionRetraction(ctx, emojiReactionID)
|
|
|
|
}
|
|
|
|
|
2020-07-27 15:57:01 +00:00
|
|
|
func (api *PublicAPI) EmojiReactionsByChatID(chatID string, cursor string, limit int) ([]*protocol.EmojiReaction, error) {
|
|
|
|
return api.service.messenger.EmojiReactionsByChatID(chatID, cursor, limit)
|
|
|
|
}
|
|
|
|
|
2021-11-05 13:48:20 +00:00
|
|
|
func (api *PublicAPI) EmojiReactionsByChatIDMessageID(chatID string, messageID string) ([]*protocol.EmojiReaction, error) {
|
|
|
|
return api.service.messenger.EmojiReactionsByChatIDMessageID(chatID, messageID)
|
|
|
|
}
|
|
|
|
|
2020-10-27 17:35:28 +00:00
|
|
|
// Urls
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetLinkPreviewWhitelist() []urls.Site {
|
|
|
|
return urls.LinkPreviewWhitelist()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) GetLinkPreviewData(link string) (previewData urls.LinkPreviewData, err error) {
|
|
|
|
return urls.GetLinkPreviewData(link)
|
|
|
|
}
|
|
|
|
|
2021-01-11 10:32:51 +00:00
|
|
|
func (api *PublicAPI) EnsVerified(pk, ensName string) error {
|
|
|
|
return api.service.messenger.ENSVerified(pk, ensName)
|
|
|
|
}
|
|
|
|
|
2021-09-17 09:02:04 +00:00
|
|
|
func (api *PublicAPI) RequestCommunityInfoFromMailserver(communityID string) (*communities.Community, error) {
|
2021-04-19 12:09:46 +00:00
|
|
|
return api.service.messenger.RequestCommunityInfoFromMailserver(communityID)
|
|
|
|
}
|
|
|
|
|
2022-02-14 21:49:14 +00:00
|
|
|
func (api *PublicAPI) RequestCommunityInfoFromMailserverAsync(communityID string) error {
|
|
|
|
return api.service.messenger.RequestCommunityInfoFromMailserverAsync(communityID)
|
|
|
|
}
|
|
|
|
|
2021-04-07 12:57:14 +00:00
|
|
|
func (api *PublicAPI) UnreadActivityCenterNotificationsCount() (uint64, error) {
|
|
|
|
return api.service.messenger.UnreadActivityCenterNotificationsCount()
|
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) MarkAllActivityCenterNotificationsRead(ctx context.Context) error {
|
|
|
|
return api.service.messenger.MarkAllActivityCenterNotificationsRead(ctx)
|
2021-04-07 12:57:14 +00:00
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) MarkActivityCenterNotificationsRead(ctx context.Context, ids []types.HexBytes) error {
|
|
|
|
_, err := api.service.messenger.MarkActivityCenterNotificationsRead(ctx, ids, true)
|
|
|
|
return err
|
2021-06-11 16:47:53 +00:00
|
|
|
}
|
|
|
|
|
2021-09-24 10:57:15 +00:00
|
|
|
func (api *PublicAPI) MarkActivityCenterNotificationsUnread(ids []types.HexBytes) error {
|
|
|
|
return api.service.messenger.MarkActivityCenterNotificationsUnread(ids)
|
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) AcceptAllActivityCenterNotifications(ctx context.Context) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptAllActivityCenterNotifications(ctx)
|
2021-04-07 12:57:14 +00:00
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) AcceptActivityCenterNotifications(ctx context.Context, ids []types.HexBytes) (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.AcceptActivityCenterNotifications(ctx, ids, true)
|
2021-04-07 12:57:14 +00:00
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) DismissAllActivityCenterNotifications(ctx context.Context) error {
|
|
|
|
return api.service.messenger.DismissAllActivityCenterNotifications(ctx)
|
2021-04-07 12:57:14 +00:00
|
|
|
}
|
|
|
|
|
2021-12-02 14:23:02 +00:00
|
|
|
func (api *PublicAPI) DismissActivityCenterNotifications(ctx context.Context, ids []types.HexBytes) error {
|
|
|
|
_, err := api.service.messenger.DismissActivityCenterNotifications(ctx, ids, true)
|
|
|
|
return err
|
2021-04-07 12:57:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) ActivityCenterNotifications(cursor string, limit uint64) (*protocol.ActivityCenterPaginationResponse, error) {
|
|
|
|
return api.service.messenger.ActivityCenterNotifications(cursor, limit)
|
|
|
|
}
|
|
|
|
|
2021-03-25 15:15:22 +00:00
|
|
|
func (api *PublicAPI) RequestAllHistoricMessages() (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RequestAllHistoricMessages()
|
|
|
|
}
|
|
|
|
|
2022-01-31 10:33:56 +00:00
|
|
|
func (api *PublicAPI) RequestAllHistoricMessagesWithRetries() (*protocol.MessengerResponse, error) {
|
|
|
|
return api.service.messenger.RequestAllHistoricMessagesWithRetries()
|
|
|
|
}
|
|
|
|
|
2022-01-12 16:02:01 +00:00
|
|
|
func (api *PublicAPI) DisconnectActiveMailserver() {
|
|
|
|
api.service.messenger.DisconnectActiveMailserver()
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
// Echo is a method for testing purposes.
|
|
|
|
func (api *PublicAPI) Echo(ctx context.Context, message string) (string, error) {
|
|
|
|
return message, nil
|
|
|
|
}
|
|
|
|
|
2021-03-25 15:15:22 +00:00
|
|
|
func (api *PublicAPI) FillGaps(chatID string, messageIDs []string) error {
|
|
|
|
return api.service.messenger.FillGaps(chatID, messageIDs)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SyncChatFromSyncedFrom(chatID string) (uint32, error) {
|
|
|
|
return api.service.messenger.SyncChatFromSyncedFrom(chatID)
|
|
|
|
}
|
|
|
|
|
2021-08-26 20:25:43 +00:00
|
|
|
// BloomFilter returns the current bloom filter bytes
|
|
|
|
func (api *PublicAPI) BloomFilter() string {
|
|
|
|
return hexutil.Encode(api.service.messenger.BloomFilter())
|
|
|
|
}
|
|
|
|
|
2021-11-22 13:40:14 +00:00
|
|
|
func (api *PublicAPI) StartDiscV5() error {
|
|
|
|
return api.service.messenger.StartDiscV5()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) StopDiscV5() error {
|
|
|
|
return api.service.messenger.StopDiscV5()
|
|
|
|
}
|
|
|
|
|
2022-03-08 15:25:00 +00:00
|
|
|
func (api *PublicAPI) GetCommunitiesSettings() ([]communities.CommunitySettings, error) {
|
|
|
|
return api.service.messenger.GetCommunitiesSettings()
|
|
|
|
}
|
|
|
|
|
2022-03-21 14:18:36 +00:00
|
|
|
func (api *PublicAPI) EnableCommunityHistoryArchiveProtocol() error {
|
|
|
|
return api.service.messenger.EnableCommunityHistoryArchiveProtocol()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DisableCommunityHistoryArchiveProtocol() error {
|
|
|
|
return api.service.messenger.DisableCommunityHistoryArchiveProtocol()
|
|
|
|
}
|
|
|
|
|
2021-09-10 17:06:06 +00:00
|
|
|
func (api *PublicAPI) AddStorePeer(address string) (string, error) {
|
2021-08-30 14:57:28 +00:00
|
|
|
return api.service.messenger.AddStorePeer(address)
|
|
|
|
}
|
|
|
|
|
2021-09-10 17:06:06 +00:00
|
|
|
func (api *PublicAPI) AddRelayPeer(address string) (string, error) {
|
2021-08-30 14:57:28 +00:00
|
|
|
return api.service.messenger.AddRelayPeer(address)
|
|
|
|
}
|
|
|
|
|
2021-09-10 17:06:06 +00:00
|
|
|
func (api *PublicAPI) DialPeer(address string) error {
|
|
|
|
return api.service.messenger.DialPeer(address)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) DialPeerByID(peerID string) error {
|
|
|
|
return api.service.messenger.DialPeerByID(peerID)
|
|
|
|
}
|
|
|
|
|
2021-08-30 14:57:28 +00:00
|
|
|
func (api *PublicAPI) DropPeer(peerID string) error {
|
|
|
|
return api.service.messenger.DropPeer(peerID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) Peers() map[string][]string {
|
|
|
|
return api.service.messenger.Peers()
|
|
|
|
}
|
|
|
|
|
2022-03-23 18:47:00 +00:00
|
|
|
func (api *PublicAPI) ChangeIdentityImageShowTo(showTo settings.ProfilePicturesShowToType) error {
|
|
|
|
err := api.service.accountsDB.SaveSettingField(settings.ProfilePicturesShowTo, showTo)
|
2021-10-07 15:02:01 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return api.service.messenger.PublishIdentityImage()
|
|
|
|
}
|
|
|
|
|
2021-10-11 15:39:52 +00:00
|
|
|
func (api *PublicAPI) BackupData() (uint64, error) {
|
|
|
|
return api.service.messenger.BackupData(context.Background())
|
|
|
|
}
|
|
|
|
|
2022-02-08 16:23:04 +00:00
|
|
|
func (api *PublicAPI) ImageServerURL() string {
|
|
|
|
return api.service.messenger.ImageServerURL()
|
|
|
|
}
|
|
|
|
|
2022-01-31 10:33:56 +00:00
|
|
|
func (api *PublicAPI) ToggleUseMailservers(value bool) error {
|
|
|
|
return api.service.messenger.ToggleUseMailservers(value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) SetPinnedMailservers(pinnedMailservers map[string]string) error {
|
|
|
|
return api.service.messenger.SetPinnedMailservers(pinnedMailservers)
|
|
|
|
}
|
|
|
|
|
feat: introduce messenger APIs to extract discord channels
As part of the new Discord <-> Status Community Import functionality,
we're adding an API that extracts all discord categories and channels
from a previously exported discord export file.
These APIs can be used in clients to show the user what categories and
channels will be imported later on.
There are two APIs:
1. `Messenger.ExtractDiscordCategoriesAndChannels(filesToimport
[]string) (*MessengerResponse, map[string]*discord.ImportError)`
This takes a list of exported discord export (JSON) files (typically one per
channel), reads them, and extracts the categories and channels into
dedicated data structures (`[]DiscordChannel` and `[]DiscordCategory`)
It also returns the oldest message timestamp found in all extracted
channels.
The API is synchronous and returns the extracted data as
a `*MessengerResponse`. This allows to make the API available
status-go's RPC interface.
The error case is a `map[string]*discord.ImportError` where each key
is a file path of a JSON file that we tried to extract data from, and
the value a `discord.ImportError` which holds an error message and an
error code, allowing for distinguishing between "critical" errors and
"non-critical" errors.
2. `Messenger.RequestExtractDiscordCategoriesAndChannels(filesToImport
[]string)`
This is the asynchronous counterpart to
`ExtractDiscordCategoriesAndChannels`. The reason this API has been
added is because discord servers can have a lot of message and
channel data, which causes `ExtractDiscordCategoriesAndChannels` to
block the thread for too long, making apps potentially feel like they
are stuck.
This API runs inside a go routine, eventually calls
`ExtractDiscordCategoriesAndChannels`, and then emits a newly
introduced `DiscordCategoriesAndChannelsExtractedSignal` that clients
can react to.
Failure of extraction has to be determined by the
`discord.ImportErrors` emitted by the signal.
**A note about exported discord history files**
We expect users to export their discord histories via the
[DiscordChatExporter](https://github.com/Tyrrrz/DiscordChatExporter/wiki/GUI%2C-CLI-and-Formats-explained#exportguild)
tool. The tool allows to export the data in different formats, such as
JSON, HTML and CSV.
We expect users to have their data exported as JSON.
Closes: https://github.com/status-im/status-desktop/issues/6690
2022-07-13 09:33:53 +00:00
|
|
|
func (api *PublicAPI) RequestExtractDiscordChannelsAndCategories(filesToImport []string) {
|
|
|
|
api.service.messenger.RequestExtractDiscordChannelsAndCategories(filesToImport)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (api *PublicAPI) ExtractDiscordChannelsAndCategories(filesToImport []string) (*protocol.MessengerResponse, map[string]*discord.ImportError) {
|
|
|
|
return api.service.messenger.ExtractDiscordChannelsAndCategories(filesToImport)
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
// -----
|
|
|
|
// HELPER
|
|
|
|
// -----
|
|
|
|
|
|
|
|
// MakeMessagesRequestPayload makes a specific payload for MailServer
|
|
|
|
// to request historic messages.
|
|
|
|
// DEPRECATED
|
|
|
|
func MakeMessagesRequestPayload(r MessagesRequest) ([]byte, error) {
|
|
|
|
cursor, err := hex.DecodeString(r.Cursor)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("invalid cursor: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(cursor) > 0 && len(cursor) != mailserver.CursorLength {
|
|
|
|
return nil, fmt.Errorf("invalid cursor size: expected %d but got %d", mailserver.CursorLength, len(cursor))
|
|
|
|
}
|
|
|
|
|
|
|
|
payload := mailserver.MessagesRequestPayload{
|
2020-11-23 07:18:53 +00:00
|
|
|
Lower: r.From,
|
|
|
|
Upper: r.To,
|
|
|
|
// We need to pass bloom filter for
|
|
|
|
// backward compatibility
|
2020-01-20 20:56:06 +00:00
|
|
|
Bloom: createBloomFilter(r),
|
2020-11-23 07:18:53 +00:00
|
|
|
Topics: topicsToByteArray(r.Topics),
|
2020-01-20 20:56:06 +00:00
|
|
|
Limit: r.Limit,
|
|
|
|
Cursor: cursor,
|
|
|
|
// Client must tell the MailServer if it supports batch responses.
|
|
|
|
// This can be removed in the future.
|
|
|
|
Batch: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
return rlp.EncodeToBytes(payload)
|
|
|
|
}
|
|
|
|
|
2020-11-23 07:18:53 +00:00
|
|
|
func topicsToByteArray(topics []types.TopicType) [][]byte {
|
|
|
|
|
|
|
|
var response [][]byte
|
|
|
|
for idx := range topics {
|
|
|
|
response = append(response, topics[idx][:])
|
|
|
|
}
|
|
|
|
|
|
|
|
return response
|
|
|
|
}
|
|
|
|
|
2020-01-20 20:56:06 +00:00
|
|
|
func createBloomFilter(r MessagesRequest) []byte {
|
|
|
|
if len(r.Topics) > 0 {
|
|
|
|
return topicsToBloom(r.Topics...)
|
|
|
|
}
|
|
|
|
return types.TopicToBloom(r.Topic)
|
|
|
|
}
|
|
|
|
|
|
|
|
func topicsToBloom(topics ...types.TopicType) []byte {
|
|
|
|
i := new(big.Int)
|
|
|
|
for _, topic := range topics {
|
|
|
|
bloom := types.TopicToBloom(topic)
|
|
|
|
i.Or(i, new(big.Int).SetBytes(bloom[:]))
|
|
|
|
}
|
|
|
|
|
|
|
|
combined := make([]byte, types.BloomFilterSize)
|
|
|
|
data := i.Bytes()
|
|
|
|
copy(combined[types.BloomFilterSize-len(data):], data[:])
|
|
|
|
|
|
|
|
return combined
|
|
|
|
}
|
|
|
|
|
|
|
|
// TopicsToBloom squashes all topics into a single bloom filter.
|
|
|
|
func TopicsToBloom(topics ...types.TopicType) []byte {
|
|
|
|
return topicsToBloom(topics...)
|
|
|
|
}
|