150 lines
3.8 KiB
Go
150 lines
3.8 KiB
Go
package main
|
|
|
|
import (
|
|
"bufio"
|
|
"context"
|
|
"os"
|
|
"strings"
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
"github.com/status-im/status-go/protocol/common"
|
|
"github.com/status-im/status-go/protocol/protobuf"
|
|
"github.com/status-im/status-go/protocol/requests"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
func (cli *StatusCLI) sendContactRequest(cCtx *cli.Context, toID string) error {
|
|
cli.logger.Info("send contact request, contact public key: ", toID)
|
|
request := &requests.SendContactRequest{
|
|
ID: toID,
|
|
Message: "Hello!",
|
|
}
|
|
resp, err := cli.messenger.SendContactRequest(cCtx.Context, request)
|
|
cli.logger.Info("function SendContactRequest response.messages: ", resp.Messages())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (cli *StatusCLI) sendContactRequestAcceptance(cCtx *cli.Context, msgID string) error {
|
|
cli.logger.Info("accept contact request, message ID: ", msgID)
|
|
resp, err := cli.messenger.AcceptContactRequest(cCtx.Context, &requests.AcceptContactRequest{ID: types.Hex2Bytes(msgID)})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
cli.logger.Info("function AcceptContactRequest response: ", resp.Messages())
|
|
|
|
return nil
|
|
}
|
|
|
|
func (cli *StatusCLI) sendDirectMessage(ctx context.Context, text string) error {
|
|
if len(cli.messenger.MutualContacts()) == 0 {
|
|
return nil
|
|
}
|
|
chat := cli.messenger.Chat(cli.messenger.MutualContacts()[0].ID)
|
|
cli.logger.Info("will send message to contact: ", chat.ID)
|
|
|
|
clock, timestamp := chat.NextClockAndTimestamp(cli.messenger.GetTransport())
|
|
inputMessage := common.NewMessage()
|
|
inputMessage.ChatId = chat.ID
|
|
inputMessage.LocalChatID = chat.ID
|
|
inputMessage.Clock = clock
|
|
inputMessage.Timestamp = timestamp
|
|
inputMessage.MessageType = protobuf.MessageType_ONE_TO_ONE
|
|
inputMessage.ContentType = protobuf.ChatMessage_TEXT_PLAIN
|
|
inputMessage.Text = text
|
|
|
|
resp, err := cli.messenger.SendChatMessage(ctx, inputMessage)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, message := range resp.Messages() {
|
|
cli.logger.Infof("sent message: %v (ID=%v)", message.Text, message.ID)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (cli *StatusCLI) retrieveMessagesLoop(ctx context.Context, tick time.Duration, msgCh chan string, wg *sync.WaitGroup) {
|
|
defer wg.Done()
|
|
|
|
ticker := time.NewTicker(tick)
|
|
defer ticker.Stop()
|
|
|
|
cli.logger.Info("retrieve messages...")
|
|
|
|
for {
|
|
select {
|
|
case <-ticker.C:
|
|
response, err := cli.messenger.RetrieveAll()
|
|
if err != nil {
|
|
cli.logger.Error("failed to retrieve raw messages", "err", err)
|
|
continue
|
|
}
|
|
if response == nil {
|
|
continue
|
|
}
|
|
for _, message := range response.Messages() {
|
|
cli.logger.Infof("message received: %v (ID=%v)", message.Text, message.ID)
|
|
if message.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_MUTUAL_EVENT_SENT {
|
|
msgCh <- message.ID
|
|
}
|
|
}
|
|
case <-ctx.Done():
|
|
return
|
|
}
|
|
}
|
|
}
|
|
|
|
func (cli *StatusCLI) sendMessageLoop(ctx context.Context, tick time.Duration, wg *sync.WaitGroup, sem chan struct{}, cancel context.CancelFunc) {
|
|
defer wg.Done()
|
|
|
|
ticker := time.NewTicker(tick)
|
|
defer ticker.Stop()
|
|
|
|
reader := bufio.NewReader(os.Stdin)
|
|
for {
|
|
select {
|
|
case <-ticker.C:
|
|
if len(cli.messenger.MutualContacts()) == 0 {
|
|
continue
|
|
}
|
|
sem <- struct{}{}
|
|
cli.logger.Info("Enter your message to send: (type 'quit' or 'q' to exit)")
|
|
message, err := reader.ReadString('\n')
|
|
if err != nil {
|
|
<-sem
|
|
cli.logger.Error("failed to read input", err)
|
|
continue
|
|
}
|
|
|
|
message = strings.TrimSpace(message)
|
|
if message == "quit" || message == "q" || strings.Contains(message, "\x03") {
|
|
cancel()
|
|
<-sem
|
|
return
|
|
}
|
|
if message == "" {
|
|
<-sem
|
|
continue
|
|
}
|
|
|
|
err = cli.sendDirectMessage(ctx, message)
|
|
time.Sleep(WaitingInterval)
|
|
<-sem
|
|
if err != nil {
|
|
cli.logger.Error("failed to send direct message: ", err)
|
|
continue
|
|
}
|
|
case <-ctx.Done():
|
|
return
|
|
}
|
|
}
|
|
}
|