summaryrefslogtreecommitdiff
path: root/internal/processing/stream/delete.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/processing/stream/delete.go')
-rw-r--r--internal/processing/stream/delete.go34
1 files changed, 6 insertions, 28 deletions
diff --git a/internal/processing/stream/delete.go b/internal/processing/stream/delete.go
index d7745eef8..1c61b98d3 100644
--- a/internal/processing/stream/delete.go
+++ b/internal/processing/stream/delete.go
@@ -18,38 +18,16 @@
package stream
import (
- "fmt"
- "strings"
+ "context"
"github.com/superseriousbusiness/gotosocial/internal/stream"
)
// Delete streams the delete of the given statusID to *ALL* open streams.
-func (p *Processor) Delete(statusID string) error {
- errs := []string{}
-
- // get all account IDs with open streams
- accountIDs := []string{}
- p.streamMap.Range(func(k interface{}, _ interface{}) bool {
- key, ok := k.(string)
- if !ok {
- panic("streamMap key was not a string (account id)")
- }
-
- accountIDs = append(accountIDs, key)
- return true
+func (p *Processor) Delete(ctx context.Context, statusID string) {
+ p.streams.PostAll(ctx, stream.Message{
+ Payload: statusID,
+ Event: stream.EventTypeDelete,
+ Stream: stream.AllStatusTimelines,
})
-
- // stream the delete to every account
- for _, accountID := range accountIDs {
- if err := p.toAccount(statusID, stream.EventTypeDelete, stream.AllStatusTimelines, accountID); err != nil {
- errs = append(errs, err.Error())
- }
- }
-
- if len(errs) != 0 {
- return fmt.Errorf("one or more errors streaming status delete: %s", strings.Join(errs, ";"))
- }
-
- return nil
}