| 
									
										
										
										
											2021-06-21 15:56:00 +02:00
										 |  |  | package streaming | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"strings" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-01 18:29:25 +02:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/stream" | 
					
						
							| 
									
										
										
										
											2021-06-21 15:56:00 +02: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 18:29:25 +02:00
										 |  |  | 		streamsForAccount, ok := v.(*stream.StreamsForAccount) | 
					
						
							| 
									
										
										
										
											2021-06-21 15:56:00 +02: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 18:29:25 +02:00
										 |  |  | 		for _, s := range streamsForAccount.Streams { | 
					
						
							| 
									
										
										
										
											2021-06-21 15:56:00 +02:00
										 |  |  | 			// lock each individual stream as we work on it | 
					
						
							| 
									
										
										
										
											2021-09-01 18:29:25 +02:00
										 |  |  | 			s.Lock() | 
					
						
							|  |  |  | 			defer s.Unlock() | 
					
						
							|  |  |  | 			if s.Connected { | 
					
						
							|  |  |  | 				s.Messages <- &stream.Message{ | 
					
						
							|  |  |  | 					Stream:  []string{s.Type}, | 
					
						
							| 
									
										
										
										
											2021-06-21 15:56:00 +02: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 | 
					
						
							|  |  |  | } |