summaryrefslogtreecommitdiff
path: root/teleirc/matterbridge/bridge/xmpp/helpers.go
diff options
context:
space:
mode:
authorMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
committerMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
commite9c24f4af7ed56760f6db7941827d09f6db9020b (patch)
tree62128c43b883ce5e3148113350978755779bb5de /teleirc/matterbridge/bridge/xmpp/helpers.go
parent58d5e7cfda4781d8a57ec52aefd02983835c301a (diff)
add matterbridge
Diffstat (limited to 'teleirc/matterbridge/bridge/xmpp/helpers.go')
-rw-r--r--teleirc/matterbridge/bridge/xmpp/helpers.go30
1 files changed, 30 insertions, 0 deletions
diff --git a/teleirc/matterbridge/bridge/xmpp/helpers.go b/teleirc/matterbridge/bridge/xmpp/helpers.go
new file mode 100644
index 0000000..eb6a536
--- /dev/null
+++ b/teleirc/matterbridge/bridge/xmpp/helpers.go
@@ -0,0 +1,30 @@
+package bxmpp
+
+import (
+ "regexp"
+
+ "github.com/42wim/matterbridge/bridge/config"
+)
+
+var pathRegex = regexp.MustCompile("[^a-zA-Z0-9]+")
+
+// GetAvatar constructs a URL for a given user-avatar if it is available in the cache.
+func getAvatar(av map[string]string, userid string, general *config.Protocol) string {
+ if hash, ok := av[userid]; ok {
+ // NOTE: This does not happen in bridge/helper/helper.go but messes up XMPP
+ id := pathRegex.ReplaceAllString(userid, "_")
+ return general.MediaServerDownload + "/" + hash + "/" + id + ".png"
+ }
+ return ""
+}
+
+func (b *Bxmpp) cacheAvatar(msg *config.Message) string {
+ fi := msg.Extra["file"][0].(config.FileInfo)
+ /* if we have a sha we have successfully uploaded the file to the media server,
+ so we can now cache the sha */
+ if fi.SHA != "" {
+ b.Log.Debugf("Added %s to %s in avatarMap", fi.SHA, msg.UserID)
+ b.avatarMap[msg.UserID] = fi.SHA
+ }
+ return ""
+}