aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBohdan Horbeshko <bodqhrohro@gmail.com>2022-01-29 08:19:33 +0300
committerBohdan Horbeshko <bodqhrohro@gmail.com>2022-01-29 08:19:33 +0300
commitf052d633ac722371271c4d621fa3046c4201956f (patch)
tree3995a648d542cb9ed69a37f58636e4964cf373f9
parent540c6cd546ccadbb2c32e435d1fdcb5af24a1360 (diff)
Fix concurrent map writes in presence queue
-rw-r--r--xmpp/component.go2
-rw-r--r--xmpp/gateway/gateway.go4
2 files changed, 6 insertions, 0 deletions
diff --git a/xmpp/component.go b/xmpp/component.go
index 4f5ad79..fb5732e 100644
--- a/xmpp/component.go
+++ b/xmpp/component.go
@@ -90,7 +90,9 @@ func heartbeat(component *xmpp.Component) {
if err != nil {
gateway.LogBadPresence(presence)
} else {
+ gateway.QueueLock.Lock()
delete(gateway.Queue, key)
+ gateway.QueueLock.Unlock()
}
}
diff --git a/xmpp/gateway/gateway.go b/xmpp/gateway/gateway.go
index a4f3aca..779c6fe 100644
--- a/xmpp/gateway/gateway.go
+++ b/xmpp/gateway/gateway.go
@@ -3,6 +3,7 @@ package gateway
import (
"encoding/xml"
"strings"
+ "sync"
"dev.narayana.im/narayana/telegabber/xmpp/extensions"
@@ -14,6 +15,7 @@ import (
// Queue stores presences to send later
var Queue = make(map[string]*stanza.Presence)
+var QueueLock = sync.Mutex{}
// Jid stores the component's JID object
var Jid *stanza.Jid
@@ -178,7 +180,9 @@ func SendPresence(component *xmpp.Component, to string, args ...args.V) error {
return err
}
} else {
+ QueueLock.Lock()
Queue[presence.From+presence.To] = &presence
+ QueueLock.Unlock()
}
return nil