forked from MirrorHub/mautrix-whatsapp
backfill: add option to only sync unread state if chat is younger than threshold
Signed-off-by: Sumner Evans <sumner@beeper.com>
This commit is contained in:
parent
eadc774160
commit
433d901658
4 changed files with 10 additions and 0 deletions
|
@ -63,6 +63,7 @@ type BridgeConfig struct {
|
||||||
DoublePuppetBackfill bool `yaml:"double_puppet_backfill"`
|
DoublePuppetBackfill bool `yaml:"double_puppet_backfill"`
|
||||||
RequestFullSync bool `yaml:"request_full_sync"`
|
RequestFullSync bool `yaml:"request_full_sync"`
|
||||||
MaxInitialConversations int `yaml:"max_initial_conversations"`
|
MaxInitialConversations int `yaml:"max_initial_conversations"`
|
||||||
|
UnreadHoursThreshold int `yaml:"unread_hours_threshold"`
|
||||||
|
|
||||||
Immediate struct {
|
Immediate struct {
|
||||||
WorkerCount int `yaml:"worker_count"`
|
WorkerCount int `yaml:"worker_count"`
|
||||||
|
|
|
@ -52,6 +52,7 @@ func DoUpgrade(helper *up.Helper) {
|
||||||
helper.Copy(up.Str, "bridge", "history_sync", "media_requests", "request_method")
|
helper.Copy(up.Str, "bridge", "history_sync", "media_requests", "request_method")
|
||||||
helper.Copy(up.Int, "bridge", "history_sync", "media_requests", "request_local_time")
|
helper.Copy(up.Int, "bridge", "history_sync", "media_requests", "request_local_time")
|
||||||
helper.Copy(up.Int, "bridge", "history_sync", "max_initial_conversations")
|
helper.Copy(up.Int, "bridge", "history_sync", "max_initial_conversations")
|
||||||
|
helper.Copy(up.Int, "bridge", "history_sync", "unread_hours_threshold")
|
||||||
helper.Copy(up.Int, "bridge", "history_sync", "immediate", "worker_count")
|
helper.Copy(up.Int, "bridge", "history_sync", "immediate", "worker_count")
|
||||||
helper.Copy(up.Int, "bridge", "history_sync", "immediate", "max_events")
|
helper.Copy(up.Int, "bridge", "history_sync", "immediate", "max_events")
|
||||||
helper.Copy(up.List, "bridge", "history_sync", "deferred")
|
helper.Copy(up.List, "bridge", "history_sync", "deferred")
|
||||||
|
|
|
@ -149,6 +149,12 @@ bridge:
|
||||||
# provisioning endpoint is used or when a message comes in from that
|
# provisioning endpoint is used or when a message comes in from that
|
||||||
# chat.
|
# chat.
|
||||||
max_initial_conversations: -1
|
max_initial_conversations: -1
|
||||||
|
# If this value is greater than 0, then if the conversation's last
|
||||||
|
# message was more than this number of hours ago, then the conversation
|
||||||
|
# will automatically be marked it as read.
|
||||||
|
# Conversations that have a last message that is less than this number
|
||||||
|
# of hours ago will have their unread status synced from WhatsApp.
|
||||||
|
unread_hours_threshold: 0
|
||||||
# Settings for immediate backfills. These backfills should generally be
|
# Settings for immediate backfills. These backfills should generally be
|
||||||
# small and their main purpose is to populate each of the initial chats
|
# small and their main purpose is to populate each of the initial chats
|
||||||
# (as configured by max_initial_conversations) with a few messages so
|
# (as configured by max_initial_conversations) with a few messages so
|
||||||
|
|
|
@ -292,6 +292,8 @@ func (user *User) backfillInChunks(req *database.Backfill, conv *database.Histor
|
||||||
|
|
||||||
if !conv.MarkedAsUnread && conv.UnreadCount == 0 {
|
if !conv.MarkedAsUnread && conv.UnreadCount == 0 {
|
||||||
user.markSelfReadFull(portal)
|
user.markSelfReadFull(portal)
|
||||||
|
} else if user.bridge.Config.Bridge.HistorySync.UnreadHoursThreshold > 0 && conv.LastMessageTimestamp.Before(time.Now().Add(time.Duration(-user.bridge.Config.Bridge.HistorySync.UnreadHoursThreshold)*time.Hour)) {
|
||||||
|
user.markSelfReadFull(portal)
|
||||||
} else if user.bridge.Config.Bridge.SyncManualMarkedUnread {
|
} else if user.bridge.Config.Bridge.SyncManualMarkedUnread {
|
||||||
user.markUnread(portal, true)
|
user.markUnread(portal, true)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue