1
0

fix(typesense): reindex tasks when their position changed

This commit is contained in:
kolaente
2024-07-11 12:07:48 +02:00
parent 0b424fe95e
commit 471d0fcd4a
3 changed files with 52 additions and 1 deletions

View File

@ -70,6 +70,7 @@ func RegisterListeners() {
events.RegisterListener((&TaskDeletedEvent{}).Name(), &RemoveTaskFromTypesense{})
events.RegisterListener((&TaskCreatedEvent{}).Name(), &AddTaskToTypesense{})
events.RegisterListener((&TaskUpdatedEvent{}).Name(), &UpdateTaskInTypesense{})
events.RegisterListener((&TaskPositionsRecalculatedEvent{}).Name(), &UpdateTaskPositionsInTypesense{})
}
if config.WebhooksEnabled.GetBool() {
RegisterEventForWebhook(&TaskCreatedEvent{})
@ -607,6 +608,41 @@ func (l *UpdateTaskInTypesense) Handle(msg *message.Message) (err error) {
return reindexTasksInTypesense(s, task)
}
// UpdateTaskPositionsInTypesense represents a listener
type UpdateTaskPositionsInTypesense struct {
}
// Name defines the name for the UpdateTaskPositionsInTypesense listener
func (l *UpdateTaskPositionsInTypesense) Name() string {
return "typesense.task.position.update"
}
// Handle is executed when the event UpdateTaskPositionsInTypesense listens on is fired
func (l *UpdateTaskPositionsInTypesense) Handle(msg *message.Message) (err error) {
event := &TaskPositionsRecalculatedEvent{}
err = json.Unmarshal(msg.Payload, event)
if err != nil {
return err
}
taskIDs := []int64{}
for _, position := range event.NewTaskPositions {
taskIDs = append(taskIDs, position.TaskID)
}
s := db.NewSession()
defer s.Close()
tasks, err := GetTasksSimpleByIDs(s, taskIDs)
taskMap := make(map[int64]*Task, 1)
for _, task := range tasks {
taskMap[task.ID] = task
}
return reindexTasksInTypesense(s, taskMap)
}
// IncreaseAttachmentCounter represents a listener
type IncreaseAttachmentCounter struct {
}