Fix bridging messages to WhatsApp with relaybot. Fixes #191
This commit is contained in:
parent
c6b4f34c28
commit
46e53eca4d
31
portal.go
31
portal.go
@ -1192,6 +1192,7 @@ func (portal *Portal) preprocessMatrixMedia(sender *User, relaybotFormatted bool
|
|||||||
mxc, err := rawMXC.Parse()
|
mxc, err := rawMXC.Parse()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
portal.log.Errorln("Malformed content URL in %s: %v", eventID, err)
|
portal.log.Errorln("Malformed content URL in %s: %v", eventID, err)
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
data, err := portal.MainIntent().DownloadBytes(mxc)
|
data, err := portal.MainIntent().DownloadBytes(mxc)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -1276,10 +1277,11 @@ func (portal *Portal) addRelaybotFormat(sender *User, content *event.MessageEven
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waProto.WebMessageInfo {
|
func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) (*waProto.WebMessageInfo, *User) {
|
||||||
content := evt.Content.AsMessage()
|
content, ok := evt.Content.Parsed.(*event.MessageEventContent)
|
||||||
if content == nil {
|
if !ok {
|
||||||
return nil
|
portal.log.Debugfln("Failed to handle event %s: unexpected parsed content type %T", evt.ID, evt.Content.Parsed)
|
||||||
|
return nil, sender
|
||||||
}
|
}
|
||||||
|
|
||||||
ts := uint64(evt.Timestamp / 1000)
|
ts := uint64(evt.Timestamp / 1000)
|
||||||
@ -1313,7 +1315,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
portal.log.Debugln("Database says", sender.MXID, "not in chat and no relaybot, but trying to send anyway")
|
portal.log.Debugln("Database says", sender.MXID, "not in chat and no relaybot, but trying to send anyway")
|
||||||
} else {
|
} else {
|
||||||
portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot")
|
portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot")
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
relaybotFormatted = portal.addRelaybotFormat(sender, content)
|
relaybotFormatted = portal.addRelaybotFormat(sender, content)
|
||||||
@ -1348,7 +1350,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
case event.MsgImage:
|
case event.MsgImage:
|
||||||
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaImage)
|
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaImage)
|
||||||
if media == nil {
|
if media == nil {
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
info.Message.ImageMessage = &waProto.ImageMessage{
|
info.Message.ImageMessage = &waProto.ImageMessage{
|
||||||
Caption: &media.Caption,
|
Caption: &media.Caption,
|
||||||
@ -1363,7 +1365,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
case event.MsgVideo:
|
case event.MsgVideo:
|
||||||
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaVideo)
|
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaVideo)
|
||||||
if media == nil {
|
if media == nil {
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
duration := uint32(content.GetInfo().Duration)
|
duration := uint32(content.GetInfo().Duration)
|
||||||
info.Message.VideoMessage = &waProto.VideoMessage{
|
info.Message.VideoMessage = &waProto.VideoMessage{
|
||||||
@ -1380,7 +1382,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
case event.MsgAudio:
|
case event.MsgAudio:
|
||||||
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaAudio)
|
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaAudio)
|
||||||
if media == nil {
|
if media == nil {
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
duration := uint32(content.GetInfo().Duration)
|
duration := uint32(content.GetInfo().Duration)
|
||||||
info.Message.AudioMessage = &waProto.AudioMessage{
|
info.Message.AudioMessage = &waProto.AudioMessage{
|
||||||
@ -1395,7 +1397,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
case event.MsgFile:
|
case event.MsgFile:
|
||||||
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaDocument)
|
media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaDocument)
|
||||||
if media == nil {
|
if media == nil {
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
info.Message.DocumentMessage = &waProto.DocumentMessage{
|
info.Message.DocumentMessage = &waProto.DocumentMessage{
|
||||||
Url: &media.URL,
|
Url: &media.URL,
|
||||||
@ -1407,10 +1409,10 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) *waPr
|
|||||||
FileLength: &media.FileLength,
|
FileLength: &media.FileLength,
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
portal.log.Debugln("Unhandled Matrix event:", evt)
|
portal.log.Debugln("Unhandled Matrix event %s: unknown msgtype %s", evt.ID, content.MsgType)
|
||||||
return nil
|
return nil, sender
|
||||||
}
|
}
|
||||||
return info
|
return info, sender
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) wasMessageSent(sender *User, id string) bool {
|
func (portal *Portal) wasMessageSent(sender *User, id string) bool {
|
||||||
@ -1454,7 +1456,10 @@ func (portal *Portal) HandleMatrixMessage(sender *User, evt *event.Event) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
portal.log.Debugfln("Received event %s", evt.ID)
|
portal.log.Debugfln("Received event %s", evt.ID)
|
||||||
info := portal.convertMatrixMessage(sender, evt)
|
info, sender := portal.convertMatrixMessage(sender, evt)
|
||||||
|
if info == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
portal.markHandled(sender, info, evt.ID)
|
portal.markHandled(sender, info, evt.ID)
|
||||||
portal.log.Debugln("Sending event", evt.ID, "to WhatsApp")
|
portal.log.Debugln("Sending event", evt.ID, "to WhatsApp")
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user