···
"github.com/bluesky-social/indigo/events"
"github.com/bluesky-social/indigo/lex/util"
···
func (s *Server) handleSyncSubscribeRepos(e echo.Context) error {
14
+
ctx := e.Request().Context()
15
+
logger := s.logger.With("component", "subscribe-repos-websocket")
conn, err := websocket.Upgrade(e.Response().Writer, e.Request(), e.Response().Header(), 1<<10, 1<<10)
19
+
logger.Error("unable to establish websocket with relay", "err", err)
18
-
s.logger.Info("new connection", "ua", e.Request().UserAgent())
20
-
ctx := e.Request().Context()
ident := e.RealIP() + "-" + e.Request().UserAgent()
24
+
logger = logger.With("ident", ident)
25
+
logger.Info("new connection established")
evts, cancel, err := s.evtman.Subscribe(ctx, ident, func(evt *events.XRPCStreamEvent) bool {
···
wc, err := conn.NextWriter(websocket.BinaryMessage)
39
+
logger.Error("error writing message to relay", "err", err)
43
+
if ctx.Err() != nil {
44
+
logger.Error("context error", "err", err)
header.Op = events.EvtKindErrorFrame
···
58
-
return fmt.Errorf("unrecognized event kind")
66
+
logger.Warn("unrecognized event kind")
if err := header.MarshalCBOR(wc); err != nil {
62
-
return fmt.Errorf("failed to write header: %w", err)
71
+
logger.Error("failed to write header to relay", "err", err)
if err := obj.MarshalCBOR(wc); err != nil {
66
-
return fmt.Errorf("failed to write event: %w", err)
76
+
logger.Error("failed to write event to relay", "err", err)
if err := wc.Close(); err != nil {
70
-
return fmt.Errorf("failed to flush-close our event write: %w", err)
81
+
logger.Error("failed to flush-close our event write", "err", err)
86
+
// we should tell the relay to request a new crawl at this point if we got disconnected
87
+
// use a new context since the old one might be cancelled at this point
88
+
ctx, cancel = context.WithTimeout(context.Background(), 10*time.Second)
90
+
if err := s.requestCrawl(ctx); err != nil {
91
+
logger.Error("error requesting crawls", "err", err)