package streaming import ( "encoding/json" "errors" "fmt" "github.com/sirupsen/logrus" apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model" "github.com/superseriousbusiness/gotosocial/internal/gtsmodel" ) func (p *processor) StreamNotificationToAccount(n *apimodel.Notification, account *gtsmodel.Account) error { l := p.log.WithFields(logrus.Fields{ "func": "StreamNotificationToAccount", "account": account.ID, }) v, ok := p.streamMap.Load(account.ID) if !ok { // no open connections so nothing to stream return nil } streamsForAccount, ok := v.(*gtsmodel.StreamsForAccount) if !ok { return errors.New("stream map error") } notificationBytes, err := json.Marshal(n) if err != nil { return fmt.Errorf("error marshalling notification to json: %s", err) } streamsForAccount.Lock() defer streamsForAccount.Unlock() for _, stream := range streamsForAccount.Streams { stream.Lock() defer stream.Unlock() if stream.Connected { l.Debugf("streaming notification to stream id %s", stream.ID) stream.Messages <- >smodel.Message{ Stream: []string{stream.Type}, Event: "notification", Payload: string(notificationBytes), } } } return nil }