ISM rewrite part 5

This commit is contained in:
Tracker-Friendly 2025-01-08 10:28:58 +00:00
parent a02b0ba721
commit a77529f4f7
1 changed files with 21 additions and 0 deletions

21
main.go
View File

@ -93,6 +93,7 @@ const (
) )
var buffer = make(map[uuid.UUID]InterServiceMessage) var buffer = make(map[uuid.UUID]InterServiceMessage)
var waitingList = make(map[uuid.UUID]struct{})
var mutex = sync.Mutex{} var mutex = sync.Mutex{}
var arrived = make(chan uuid.UUID) var arrived = make(chan uuid.UUID)
var ispStarted = false var ispStarted = false
@ -127,6 +128,7 @@ func AwaitISMessage(id uuid.UUID, timeout time.Duration) (InterServiceMessage, e
mutex.Lock() mutex.Lock()
msg := buffer[id] msg := buffer[id]
delete(buffer, id) delete(buffer, id)
delete(waitingList, id)
mutex.Unlock() mutex.Unlock()
if msg.MessageType != Success { if msg.MessageType != Success {
return msg, msg.Message.(error) return msg, msg.Message.(error)
@ -161,6 +163,9 @@ func (s *ServiceInitializationInformation) SendISMessage(forService uuid.UUID, m
SentAt: time.Now(), SentAt: time.Now(),
Message: message, Message: message,
} }
mutex.Lock()
waitingList[id] = struct{}{}
mutex.Unlock()
s.Outbox <- msg s.Outbox <- msg
return id return id
} }
@ -182,3 +187,19 @@ func (s *ServiceInitializationInformation) GetDatabase() (Database, error) {
return response.Message.(Database), nil return response.Message.(Database), nil
} }
func (s *ServiceInitializationInformation) AcceptMessage() InterServiceMessage {
for {
<-arrived
mutex.Lock()
for id, msg := range buffer {
_, ok := waitingList[id]
if !ok {
delete(buffer, id)
mutex.Unlock()
return msg
}
}
mutex.Unlock()
}
}