You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							44 lines
						
					
					
						
							917 B
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							44 lines
						
					
					
						
							917 B
						
					
					
				| package agent | |
| 
 | |
| import ( | |
| 	"fmt" | |
| 	"github.com/seaweedfs/seaweedfs/weed/pb/mq_agent_pb" | |
| ) | |
| 
 | |
| func (a *MessageQueueAgent) PublishRecord(stream mq_agent_pb.SeaweedMessagingAgent_PublishRecordServer) error { | |
| 	m, err := stream.Recv() | |
| 	if err != nil { | |
| 		return err | |
| 	} | |
| 	sessionId := SessionId(m.SessionId) | |
| 	a.publishersLock.RLock() | |
| 	publisherEntry, found := a.publishers[sessionId] | |
| 	a.publishersLock.RUnlock() | |
| 	if !found { | |
| 		return fmt.Errorf("publish session id %d not found", sessionId) | |
| 	} | |
| 	defer func() { | |
| 		a.publishersLock.Lock() | |
| 		delete(a.publishers, sessionId) | |
| 		a.publishersLock.Unlock() | |
| 	}() | |
| 
 | |
| 	if m.Value != nil { | |
| 		if err := publisherEntry.entry.PublishRecord(m.Key, m.Value); err != nil { | |
| 			return err | |
| 		} | |
| 	} | |
| 
 | |
| 	for { | |
| 		m, err = stream.Recv() | |
| 		if err != nil { | |
| 			return err | |
| 		} | |
| 		if m.Value == nil { | |
| 			continue | |
| 		} | |
| 		if err := publisherEntry.entry.PublishRecord(m.Key, m.Value); err != nil { | |
| 			return err | |
| 		} | |
| 	} | |
| }
 |