mirror of
https://github.com/status-im/status-go.git
synced 2025-02-23 12:18:38 +00:00
* feat: send dm with cli * fix: send contact request works * feat: accept contact request * feat: send dm * fix: log * feat: more dm * fix: lint * refactor: fix comments * fix: more refactor * fix: refoctor more * fix: more refacotr * fix: refactor dm * fix: context from cli * fix: add light mode flag * fix: remove sleep when start node * fix: better log * fix: better logger * fix: lint * fix: comments * fix: const flags * fix: named logger * feat: inteactive mode * fix: send message in loop * fix: better context manage * feat: cli serve * fix: readme * extract to multi files * fix: status cli rpc * feat: create and login account * fix: missing messagess * fix: missing messages because data sync is not started. * feat: start http service * fix: lint * fix: more build instructions. * fix: review comments
80 lines
1.5 KiB
Go
80 lines
1.5 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"log"
|
|
"os"
|
|
"os/signal"
|
|
"sync"
|
|
"syscall"
|
|
|
|
"github.com/urfave/cli/v2"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
func serve(cCtx *cli.Context) error {
|
|
ctx, cancel := context.WithCancel(cCtx.Context)
|
|
|
|
go func() {
|
|
sig := make(chan os.Signal, 1)
|
|
signal.Notify(sig, syscall.SIGINT, syscall.SIGTERM)
|
|
<-sig
|
|
cancel()
|
|
}()
|
|
|
|
rawLogger, err := zap.NewDevelopment()
|
|
if err != nil {
|
|
log.Fatalf("Error initializing logger: %v", err)
|
|
}
|
|
logger = rawLogger.Sugar()
|
|
|
|
logger.Info("Running serve command, flags passed:")
|
|
for _, flag := range ServeFlags {
|
|
logger.Infof("-%s %v", flag.Names()[0], cCtx.Value(flag.Names()[0]))
|
|
}
|
|
|
|
name := cCtx.String(NameFlag)
|
|
port := cCtx.Int(PortFlag)
|
|
|
|
messenger, err := startMessenger(cCtx, name, port)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer stopMessenger(messenger)
|
|
|
|
// Retrieve for messages
|
|
var wg sync.WaitGroup
|
|
msgCh := make(chan string)
|
|
|
|
wg.Add(1)
|
|
go retrieveMessagesLoop(ctx, messenger, RetrieveInterval, msgCh, &wg)
|
|
|
|
// Send contact request from Alice to Bob, bob accept the request
|
|
dest := cCtx.String(AddFlag)
|
|
if dest != "" {
|
|
err := sendContactRequest(cCtx, messenger, dest)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
go func() {
|
|
msgID := <-msgCh
|
|
err = sendContactRequestAcceptance(cCtx, messenger, msgID)
|
|
if err != nil {
|
|
logger.Error(err)
|
|
return
|
|
}
|
|
}()
|
|
|
|
// Send message if mutual contact exists
|
|
sem := make(chan struct{}, 1)
|
|
wg.Add(1)
|
|
go sendMessageLoop(ctx, messenger, SendInterval, &wg, sem, cancel)
|
|
|
|
wg.Wait()
|
|
logger.Info("Exiting")
|
|
|
|
return nil
|
|
}
|