feat: up mention count for 1-1 messages each 2 min (#4035)

This commit is contained in:
Jonathan Rainville 2023-09-25 11:29:36 -04:00 committed by GitHub
parent ba5cd9c1a4
commit 2afe5a269d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 41 additions and 33 deletions

View File

@ -27,6 +27,13 @@ var chatColors = []string{
"#d37ef4", // purple "#d37ef4", // purple
} }
const (
// IncreaseUnviewedMessagesCountTimeoutMs
// this timeout indicates how long the time between received messages should be
// for a new message to increase the unviewed messages counter
IncreaseUnviewedMessagesCountTimeoutMs = 1000 * 60 * 2
)
type ChatType int type ChatType int
const ( const (
@ -391,6 +398,14 @@ func (c *Chat) UpdateFromMessage(message *common.Message, timesource common.Time
return nil return nil
} }
func (c *Chat) ShouldIncreaseMessageCount(message *common.Message) bool {
return c.LastMessage == nil ||
c.LastMessage.IsSystemMessage() ||
!c.LastMessage.New ||
c.LastMessage.Seen ||
message.Timestamp > c.LastMessage.Timestamp+IncreaseUnviewedMessagesCountTimeoutMs
}
func (c *Chat) UpdateFirstMessageTimestamp(timestamp uint32) bool { func (c *Chat) UpdateFirstMessageTimestamp(timestamp uint32) bool {
if timestamp == c.FirstMessageTimestamp { if timestamp == c.FirstMessageTimestamp {
return false return false

View File

@ -635,8 +635,6 @@ func (m *Message) PrepareContent(identity string) error {
func (m *Message) IsSystemMessage() bool { func (m *Message) IsSystemMessage() bool {
return m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_CONTENT_PRIVATE_GROUP || return m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_CONTENT_PRIVATE_GROUP ||
m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_GAP || m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_GAP ||
m.ContentType == protobuf.ChatMessage_CONTACT_REQUEST ||
m.ContentType == protobuf.ChatMessage_IDENTITY_VERIFICATION ||
m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_PINNED_MESSAGE || m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_PINNED_MESSAGE ||
m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_MUTUAL_EVENT_SENT || m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_MUTUAL_EVENT_SENT ||
m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_MUTUAL_EVENT_ACCEPTED || m.ContentType == protobuf.ChatMessage_SYSTEM_MESSAGE_MUTUAL_EVENT_ACCEPTED ||

View File

@ -4108,6 +4108,10 @@ func (m *Messenger) markAllRead(chatID string, clock uint64, shouldBeSynced bool
chat.UnviewedMessagesCount = 0 chat.UnviewedMessagesCount = 0
chat.UnviewedMentionsCount = 0 chat.UnviewedMentionsCount = 0
if chat.LastMessage != nil {
chat.LastMessage.Seen = true
}
// TODO(samyoul) remove storing of an updated reference pointer? // TODO(samyoul) remove storing of an updated reference pointer?
m.allChats.Store(chat.ID, chat) m.allChats.Store(chat.ID, chat)
return m.persistence.SaveChats([]*Chat{chat}) return m.persistence.SaveChats([]*Chat{chat})

View File

@ -367,10 +367,10 @@ func (s *MessengerEditMessageSuite) TestEditMessageWithMention() {
s.Require().NoError(err) s.Require().NoError(err)
s.Require().Len(response.Chats(), 1) s.Require().Len(response.Chats(), 1)
s.Require().Len(response.Messages(), 1) s.Require().Len(response.Messages(), 1)
// Make sure there is no mention at first // Make sure the message is not marked as Mentioned (chat still counts it because it's 1-1)
s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1)
s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 0)
s.Require().False(response.Messages()[0].Mentioned) s.Require().False(response.Messages()[0].Mentioned)
s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1)
s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 1)
ogMessage := sendResponse.Messages()[0] ogMessage := sendResponse.Messages()[0]
@ -407,9 +407,9 @@ func (s *MessengerEditMessageSuite) TestEditMessageWithMention() {
s.Require().NotEmpty(response.Messages()[0].EditedAt) s.Require().NotEmpty(response.Messages()[0].EditedAt)
s.Require().False(response.Messages()[0].New) s.Require().False(response.Messages()[0].New)
// Receiver (us) is now mentioned // Receiver (us) is now mentioned
s.Require().True(response.Messages()[0].Mentioned)
s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1) s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1)
s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 1) s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 1)
s.Require().True(response.Messages()[0].Mentioned)
// Edit the message again but remove the mention // Edit the message again but remove the mention
editedText = "edited text no mention" editedText = "edited text no mention"
@ -441,9 +441,9 @@ func (s *MessengerEditMessageSuite) TestEditMessageWithMention() {
s.Require().NotEmpty(response.Messages()[0].EditedAt) s.Require().NotEmpty(response.Messages()[0].EditedAt)
s.Require().False(response.Messages()[0].New) s.Require().False(response.Messages()[0].New)
// Receiver (us) is no longer mentioned // Receiver (us) is no longer mentioned
s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1) // We still have an unread message though
s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 0)
s.Require().False(response.Messages()[0].Mentioned) s.Require().False(response.Messages()[0].Mentioned)
s.Require().Equal(int(response.Chats()[0].UnviewedMessagesCount), 1) // We still have an unread message though
s.Require().Equal(int(response.Chats()[0].UnviewedMentionsCount), 1)
} }
func (s *MessengerEditMessageSuite) TestEditMessageWithLinkPreviews() { func (s *MessengerEditMessageSuite) TestEditMessageWithLinkPreviews() {

View File

@ -40,13 +40,6 @@ const (
requestAddressForTransactionDeclinedMessage = "Request address for transaction declined" requestAddressForTransactionDeclinedMessage = "Request address for transaction declined"
) )
const (
// IncreaseUnviewedMessagesCountTimeout
// this timeout indicates how long the time between received messages should be
// for a new message to increase the unviewed messages counter
IncreaseUnviewedMessagesCountTimeout = 1000 * 60 * 2
)
var ( var (
ErrMessageNotAllowed = errors.New("message from a non-contact") ErrMessageNotAllowed = errors.New("message from a non-contact")
ErrMessageForWrongChatType = errors.New("message for the wrong chat type") ErrMessageForWrongChatType = errors.New("message for the wrong chat type")
@ -1728,6 +1721,8 @@ func (m *Messenger) handleEditMessage(state *ReceivedMessageState, editMessage E
editedMessageHasMentions := editedMessage.Mentioned editedMessageHasMentions := editedMessage.Mentioned
// Messages in OneToOne chats increase the UnviewedMentionsCount whether or not they include a Mention
if !chat.OneToOne() {
if editedMessageHasMentions && !originalMessageMentioned && !editedMessage.Seen { if editedMessageHasMentions && !originalMessageMentioned && !editedMessage.Seen {
// Increase unviewed count when the edited message has a mention and didn't have one before // Increase unviewed count when the edited message has a mention and didn't have one before
chat.UnviewedMentionsCount++ chat.UnviewedMentionsCount++
@ -1737,6 +1732,8 @@ func (m *Messenger) handleEditMessage(state *ReceivedMessageState, editMessage E
chat.UnviewedMentionsCount-- chat.UnviewedMentionsCount--
needToSaveChat = true needToSaveChat = true
} }
}
if needToSaveChat { if needToSaveChat {
err := m.saveChat(chat) err := m.saveChat(chat)
if err != nil { if err != nil {
@ -3083,19 +3080,13 @@ func (m *Messenger) isMessageAllowedFrom(publicKey string, chat *Chat) (bool, er
} }
func (m *Messenger) updateUnviewedCounts(chat *Chat, message *common.Message) { func (m *Messenger) updateUnviewedCounts(chat *Chat, message *common.Message) {
if chat == nil { if chat.ShouldIncreaseMessageCount(message) {
return
}
if chat.LastMessage == nil ||
chat.LastMessage.IsSystemMessage() ||
!chat.LastMessage.New ||
message.Timestamp > chat.LastMessage.Timestamp+IncreaseUnviewedMessagesCountTimeout {
chat.UnviewedMessagesCount++ chat.UnviewedMessagesCount++
} if message.Mentioned || message.Replied || chat.OneToOne() {
if message.Mentioned || message.Replied {
chat.UnviewedMentionsCount++ chat.UnviewedMentionsCount++
} }
} }
}
func mapSyncAccountToAccount(message *protobuf.SyncAccount, accountOperability accounts.AccountOperable, accType accounts.AccountType) *accounts.Account { func mapSyncAccountToAccount(message *protobuf.SyncAccount, accountOperability accounts.AccountOperable, accType accounts.AccountType) *accounts.Account {
return &accounts.Account{ return &accounts.Account{