mirror of
https://github.com/42wim/matterbridge.git
synced 2024-11-24 03:32:02 -08:00
parent
0c19716f44
commit
29e29439ee
@ -3,6 +3,7 @@ package bmatrix
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"html"
|
"html"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
@ -82,20 +83,36 @@ func (b *Bmatrix) getDisplayName(mxid string) string {
|
|||||||
func (b *Bmatrix) cacheDisplayName(mxid string, displayName string) string {
|
func (b *Bmatrix) cacheDisplayName(mxid string, displayName string) string {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
|
|
||||||
// scan to delete old entries, to stop memory usage from becoming too high with old entries
|
// scan to delete old entries, to stop memory usage from becoming too high with old entries.
|
||||||
|
// In addition, we also detect if another user have the same username, and if so, we append their mxids to their usernames to differentiate them.
|
||||||
toDelete := []string{}
|
toDelete := []string{}
|
||||||
b.RLock()
|
conflict := false
|
||||||
for k, v := range b.NicknameMap {
|
|
||||||
if now.Sub(v.lastUpdated) > 10*time.Minute {
|
|
||||||
toDelete = append(toDelete, k)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
b.RUnlock()
|
|
||||||
|
|
||||||
b.Lock()
|
b.Lock()
|
||||||
|
for mxid, v := range b.NicknameMap {
|
||||||
|
// to prevent username reuse across matrix servers - or even on the same server, append
|
||||||
|
// the mxid to the username when there is a conflict
|
||||||
|
if v.displayName == displayName {
|
||||||
|
conflict = true
|
||||||
|
// TODO: it would be nice to be able to rename previous messages from this user.
|
||||||
|
// The current behavior is that only users with clashing usernames and *that have spoken since the bridge last started* will get their mxids shown, and I don't know if that's the expected behavior.
|
||||||
|
v.displayName = fmt.Sprintf("%s (%s)", displayName, mxid)
|
||||||
|
b.NicknameMap[mxid] = v
|
||||||
|
}
|
||||||
|
|
||||||
|
if now.Sub(v.lastUpdated) > 10*time.Minute {
|
||||||
|
toDelete = append(toDelete, mxid)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if conflict {
|
||||||
|
displayName = fmt.Sprintf("%s (%s)", displayName, mxid)
|
||||||
|
}
|
||||||
|
|
||||||
for _, v := range toDelete {
|
for _, v := range toDelete {
|
||||||
delete(b.NicknameMap, v)
|
delete(b.NicknameMap, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
b.NicknameMap[mxid] = NicknameCacheEntry{
|
b.NicknameMap[mxid] = NicknameCacheEntry{
|
||||||
displayName: displayName,
|
displayName: displayName,
|
||||||
lastUpdated: now,
|
lastUpdated: now,
|
||||||
|
Loading…
Reference in New Issue
Block a user