From 413b12c2e27a6360e6ddded8ca9904d013bd2374 Mon Sep 17 00:00:00 2001 From: Toni Spets Date: Tue, 19 Dec 2023 13:28:34 +0200 Subject: [PATCH] Prevent creating portals for non-backfillable conversations Defer initializing portal on backfill until there are messages. --- historysync.go | 40 +++++++++++++++++++++++----------------- 1 file changed, 23 insertions(+), 17 deletions(-) diff --git a/historysync.go b/historysync.go index bd160779..332f9221 100644 --- a/historysync.go +++ b/historysync.go @@ -21,6 +21,7 @@ import ( "encoding/base64" "fmt" "strings" + "sync" "time" "github.com/rs/zerolog" @@ -452,26 +453,29 @@ func (user *User) storeHistorySync(evt *waProto.HistorySync) { continue } totalMessageCount += len(conv.GetMessages()) - portal := user.GetPortalByJID(jid) log := log.With(). - Str("chat_jid", portal.Key.JID.String()). + Str("chat_jid", jid.String()). Int("msg_count", len(conv.GetMessages())). Logger() - historySyncConversation := user.bridge.DB.HistorySync.NewConversationWithValues( - user.MXID, - conv.GetId(), - &portal.Key, - getConversationTimestamp(conv), - conv.GetMuteEndTime(), - conv.GetArchived(), - conv.GetPinned(), - conv.GetDisappearingMode().GetInitiator(), - conv.GetEndOfHistoryTransferType(), - conv.EphemeralExpiration, - conv.GetMarkedAsUnread(), - conv.GetUnreadCount()) - historySyncConversation.Upsert() + initPortal := sync.OnceFunc(func() { + portal := user.GetPortalByJID(jid) + historySyncConversation := user.bridge.DB.HistorySync.NewConversationWithValues( + user.MXID, + conv.GetId(), + &portal.Key, + getConversationTimestamp(conv), + conv.GetMuteEndTime(), + conv.GetArchived(), + conv.GetPinned(), + conv.GetDisappearingMode().GetInitiator(), + conv.GetEndOfHistoryTransferType(), + conv.EphemeralExpiration, + conv.GetMarkedAsUnread(), + conv.GetUnreadCount()) + historySyncConversation.Upsert() + }) + var minTime, maxTime time.Time var minTimeIndex, maxTimeIndex int @@ -479,7 +483,7 @@ func (user *User) storeHistorySync(evt *waProto.HistorySync) { unsupportedTypes := 0 for i, rawMsg := range conv.GetMessages() { // Don't store messages that will just be skipped. - msgEvt, err := user.Client.ParseWebMessage(portal.Key.JID, rawMsg.GetMessage()) + msgEvt, err := user.Client.ParseWebMessage(jid, rawMsg.GetMessage()) if err != nil { log.Warn().Err(err). Int("msg_index", i). @@ -503,6 +507,8 @@ func (user *User) storeHistorySync(evt *waProto.HistorySync) { continue } + initPortal() + message, err := user.bridge.DB.HistorySync.NewMessageWithValues(user.MXID, conv.GetId(), msgEvt.Info.ID, rawMsg) if err != nil { log.Error().Err(err).