2021-06-21 13:56:00 +00:00
|
|
|
package streaming
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2021-09-01 16:29:25 +00:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/stream"
|
2021-06-21 13:56:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func (p *processor) StreamDelete(statusID string) error {
|
|
|
|
errs := []string{}
|
|
|
|
|
|
|
|
// we want to range through ALL streams for ALL accounts here to make sure it's very clear to everyone that the status has been deleted
|
|
|
|
p.streamMap.Range(func(k interface{}, v interface{}) bool {
|
|
|
|
// the key of this map should be an accountID (string)
|
|
|
|
accountID, ok := k.(string)
|
|
|
|
if !ok {
|
|
|
|
errs = append(errs, "key in streamMap was not a string!")
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// the value of the map should be a buncha streams
|
2021-09-01 16:29:25 +00:00
|
|
|
streamsForAccount, ok := v.(*stream.StreamsForAccount)
|
2021-06-21 13:56:00 +00:00
|
|
|
if !ok {
|
|
|
|
errs = append(errs, fmt.Sprintf("stream map error for account stream %s", accountID))
|
|
|
|
}
|
|
|
|
|
|
|
|
// lock the streams while we work on them
|
|
|
|
streamsForAccount.Lock()
|
|
|
|
defer streamsForAccount.Unlock()
|
2021-09-01 16:29:25 +00:00
|
|
|
for _, s := range streamsForAccount.Streams {
|
2021-06-21 13:56:00 +00:00
|
|
|
// lock each individual stream as we work on it
|
2021-09-01 16:29:25 +00:00
|
|
|
s.Lock()
|
|
|
|
defer s.Unlock()
|
|
|
|
if s.Connected {
|
|
|
|
s.Messages <- &stream.Message{
|
|
|
|
Stream: []string{s.Type},
|
2021-06-21 13:56:00 +00:00
|
|
|
Event: "delete",
|
|
|
|
Payload: statusID,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
})
|
|
|
|
|
|
|
|
if len(errs) != 0 {
|
|
|
|
return fmt.Errorf("one or more errors streaming status delete: %s", strings.Join(errs, ";"))
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|