Compare commits

..

No commits in common. "6bedb3a17d5d2508ae5e5ee3dc1a472118d4b5bd" and "47cced4e75ab0620e6da4dc87586c76beb33352e" have entirely different histories.

2 changed files with 46 additions and 10 deletions

View File

@ -1,10 +1,12 @@
package api package api
import ( import (
"fmt"
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec" "git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
authm "git.solsynth.dev/hypernet/passport/pkg/authkit/models" authm "git.solsynth.dev/hypernet/passport/pkg/authkit/models"
"git.solsynth.dev/hypernet/messaging/pkg/internal/database" "git.solsynth.dev/hypernet/messaging/pkg/internal/database"
"git.solsynth.dev/hypernet/messaging/pkg/internal/models"
"github.com/gofiber/fiber/v2" "github.com/gofiber/fiber/v2"
) )
@ -14,6 +16,35 @@ func getWhatsNew(c *fiber.Ctx) error {
} }
user := c.Locals("user").(authm.Account) user := c.Locals("user").(authm.Account)
var lookupRange []uint
var lookupPivots []int
var ignoreRange []uint
var channelMembers []models.ChannelMember
if err := database.C.Where("account_id = ?", user.ID).
Select("id", "channel_id", "reading_anchor").
Find(&channelMembers).Error; err != nil {
return fiber.NewError(fiber.StatusInternalServerError, fmt.Sprintf("unable to get channel identity of you: %v", err))
} else {
for _, member := range channelMembers {
if member.ReadingAnchor == nil {
continue
}
lookupRange = append(lookupRange, member.ChannelID)
lookupPivots = append(lookupPivots, *member.ReadingAnchor)
ignoreRange = append(ignoreRange, member.ID)
}
}
tx := database.C
tx = tx.Where("channel_id IN ?", lookupRange)
tx = tx.Where("sender_id NOT IN ?", ignoreRange)
countTx := tx
var count int64
if err := countTx.Model(&models.Event{}).Count(&count).Error; err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
}
var result []struct { var result []struct {
ChannelID uint `json:"channel_id"` ChannelID uint `json:"channel_id"`
UnreadMessageCount int `json:"count"` UnreadMessageCount int `json:"count"`
@ -21,7 +52,7 @@ func getWhatsNew(c *fiber.Ctx) error {
if err := database.C.Table("channel_members cm"). if err := database.C.Table("channel_members cm").
Select("cm.channel_id, COUNT(m.id) AS unread_message_count"). Select("cm.channel_id, COUNT(m.id) AS unread_message_count").
Joins("JOIN messages m ON m.channel_id = cm.channel_id"). Joins("JOIN messages m ON m.channel_id = cm.channel_id").
Where("m.id > cm.reading_anchor AND cm.account_id = ?", user.ID). Where("m.id > cm.reading_anchor AND cm.account_id = ?", 1).
Group("cm.channel_id"). Group("cm.channel_id").
Scan(&result).Error; err != nil { Scan(&result).Error; err != nil {
return fiber.NewError(fiber.StatusInternalServerError, err.Error()) return fiber.NewError(fiber.StatusInternalServerError, err.Error())

View File

@ -4,6 +4,7 @@ import (
"git.solsynth.dev/hypernet/messaging/pkg/internal/database" "git.solsynth.dev/hypernet/messaging/pkg/internal/database"
"git.solsynth.dev/hypernet/messaging/pkg/internal/models" "git.solsynth.dev/hypernet/messaging/pkg/internal/models"
"github.com/rs/zerolog/log" "github.com/rs/zerolog/log"
"github.com/samber/lo"
"gorm.io/gorm" "gorm.io/gorm"
) )
@ -21,15 +22,19 @@ func FlushReadingAnchor() {
if len(readingAnchorQueue) == 0 { if len(readingAnchorQueue) == 0 {
return return
} }
idSet := lo.Uniq(lo.Map(lo.Keys(readingAnchorQueue), func(item uint, _ int) uint {
return item
}))
var pairs []map[string]any
for k, v := range readingAnchorQueue { for k, v := range readingAnchorQueue {
if err := database.C.Model(&models.ChannelMember{}). pairs = append(pairs, map[string]any{
Where("id = ?", k). "id": k,
Updates(map[string]any{ "reading_anchor": gorm.Expr("GREATEST(reading_anchor, ?)", v),
"reading_anchor": gorm.Expr("GREATEST(reading_anchor, ?)", v), })
}).Error; err != nil { }
log.Error().Err(err).Msg("An error occurred when flushing reading anchor...") if err := database.C.Model(&models.ChannelMember{}).
return Where("id IN ?", idSet).
} Updates(pairs).Error; err != nil {
log.Error().Err(err).Msg("An error occurred when flushing reading anchor...")
} }
clear(readingAnchorQueue)
} }