From 711548c0ba6e9a2b29bcb7d8f631b449e95604ec Mon Sep 17 00:00:00 2001 From: Sumner Evans Date: Fri, 4 Feb 2022 18:17:01 -0700 Subject: [PATCH] link previews: update to support a list Uses com.beeper.linkpreviews instead of com.beeper.linkpreview --- portal.go | 6 ++++-- urlpreview.go | 13 +++++++++---- 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/portal.go b/portal.go index 72958d0..a484516 100644 --- a/portal.go +++ b/portal.go @@ -1510,7 +1510,9 @@ func (portal *Portal) convertTextMessage(intent *appservice.IntentAPI, source *U } expiresIn = contextInfo.GetExpiration() - extraAttrs["com.beeper.linkpreview"] = portal.convertURLPreviewToBeeper(intent, source, msg.GetExtendedTextMessage()) + extraAttrs["com.beeper.linkpreviews"] = []*BeeperLinkPreview{ + portal.convertURLPreviewToBeeper(intent, source, msg.GetExtendedTextMessage()), + } } return &ConvertedMessage{ @@ -2253,7 +2255,7 @@ func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) (*waP if content.MsgType == event.MsgEmote && !relaybotFormatted { text = "/me " + text } - if ctxInfo.StanzaId != nil || ctxInfo.MentionedJid != nil || ctxInfo.Expiration != nil || evt.Content.Raw["com.beeper.linkpreview"] != nil { + if ctxInfo.StanzaId != nil || ctxInfo.MentionedJid != nil || ctxInfo.Expiration != nil || evt.Content.Raw["com.beeper.linkpreviews"] != nil { msg.ExtendedTextMessage = &waProto.ExtendedTextMessage{ Text: &text, ContextInfo: &ctxInfo, diff --git a/urlpreview.go b/urlpreview.go index ff5b8d9..f00d2df 100644 --- a/urlpreview.go +++ b/urlpreview.go @@ -115,12 +115,17 @@ func (portal *Portal) convertURLPreviewToBeeper(intent *appservice.IntentAPI, so } func (portal *Portal) convertURLPreviewToWhatsApp(sender *User, evt *event.Event, dest *waProto.ExtendedTextMessage) { - rawPreview := gjson.GetBytes(evt.Content.VeryRaw, `com\.beeper\.linkpreview`) - if !rawPreview.Exists() || !rawPreview.IsObject() { + rawPreview := gjson.GetBytes(evt.Content.VeryRaw, `com\.beeper\.linkpreviews`) + if !rawPreview.Exists() || !rawPreview.IsArray() { return } - var preview BeeperLinkPreview - if err := json.Unmarshal([]byte(rawPreview.Raw), &preview); err != nil || len(preview.MatchedURL) == 0 { + var previews []BeeperLinkPreview + if err := json.Unmarshal([]byte(rawPreview.Raw), &previews); err != nil { + return + } + // WhatsApp only supports a single preview. + preview := previews[0] + if len(preview.MatchedURL) == 0 { return }