2022-08-22 19:33:48 +00:00
|
|
|
diff --git a/portal.go b/portal.go
|
2022-09-25 19:06:33 +00:00
|
|
|
index d93ad17..198a12c 100644
|
2022-08-22 19:33:48 +00:00
|
|
|
--- a/portal.go
|
|
|
|
+++ b/portal.go
|
|
|
|
@@ -874,7 +874,7 @@ func (portal *Portal) sendMatrixMessage(intent *appservice.IntentAPI, eventType
|
|
|
|
|
|
|
|
func (portal *Portal) handleMatrixMessages(msg portalMatrixMessage) {
|
|
|
|
switch msg.evt.Type {
|
|
|
|
- case event.EventMessage:
|
|
|
|
+ case event.EventMessage, event.EventSticker:
|
|
|
|
portal.handleMatrixMessage(msg.user, msg.evt)
|
|
|
|
case event.EventRedaction:
|
|
|
|
portal.handleMatrixRedaction(msg.user, msg.evt)
|
2022-09-25 19:06:33 +00:00
|
|
|
@@ -1138,13 +1138,20 @@ func (portal *Portal) handleMatrixMessage(sender *User, evt *event.Event) {
|
2022-08-22 19:33:48 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
sendReq.Content = portal.parseMatrixHTML(sender, content)
|
|
|
|
- case event.MsgAudio, event.MsgFile, event.MsgImage, event.MsgVideo:
|
|
|
|
+ case event.MsgAudio, event.MsgFile, event.MsgImage, event.MsgVideo, "": // MsgType is empty when the message is a sticker
|
|
|
|
data, err := portal.downloadMatrixAttachment(content)
|
|
|
|
if err != nil {
|
|
|
|
go portal.sendMessageMetrics(evt, err, "Error downloading media in")
|
2022-09-25 19:06:33 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // extract file suffix from mime type
|
|
|
|
+ mimeParts := strings.Split(content.Info.MimeType, "/")
|
|
|
|
+
|
|
|
|
+ if content.MsgType == "" && !strings.HasSuffix(content.Body, "." + mimeParts[1]) {
|
|
|
|
+ content.Body += mimeParts[1]
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
sendReq.Files = []*discordgo.File{{
|
|
|
|
Name: content.Body,
|
|
|
|
ContentType: content.Info.MimeType,
|