planner/plan/storage/storage.go

102 lines
1.7 KiB
Go
Raw Normal View History

2024-09-30 07:34:40 +02:00
package storage
2024-10-03 07:32:48 +02:00
import (
"errors"
"sort"
2024-10-07 11:11:18 +02:00
"time"
2024-09-30 07:34:40 +02:00
2024-10-03 07:32:48 +02:00
"go-mod.ewintr.nl/planner/item"
)
var (
ErrNotFound = errors.New("not found")
)
type LocalID interface {
2024-12-29 09:32:49 +01:00
FindOne(lid int) (string, error)
2024-10-03 07:32:48 +02:00
FindAll() (map[string]int, error)
2024-10-07 11:11:18 +02:00
FindOrNext(id string) (int, error)
2024-10-03 07:32:48 +02:00
Next() (int, error)
Store(id string, localID int) error
Delete(id string) error
}
2024-10-07 11:11:18 +02:00
type Sync interface {
FindAll() ([]item.Item, error)
Store(i item.Item) error
DeleteAll() error
LastUpdate() (time.Time, error)
}
2024-12-29 09:32:49 +01:00
type TaskListParams struct {
2025-01-04 11:03:57 +01:00
HasRecurrer bool
HasDate bool
From item.Date
To item.Date
Project string
2024-12-29 09:32:49 +01:00
}
2024-12-24 08:00:23 +01:00
type Task interface {
Store(task item.Task) error
2024-12-29 09:32:49 +01:00
FindOne(id string) (item.Task, error)
FindMany(params TaskListParams) ([]item.Task, error)
2024-09-30 07:34:40 +02:00
Delete(id string) error
2025-01-05 12:17:57 +01:00
Projects() (map[string]int, error)
2024-09-30 07:34:40 +02:00
}
2024-10-03 07:32:48 +02:00
2024-12-29 09:32:49 +01:00
func Match(tsk item.Task, params TaskListParams) bool {
2025-01-04 11:03:57 +01:00
if params.HasRecurrer && tsk.Recurrer == nil {
2024-12-29 09:32:49 +01:00
return false
}
2025-01-04 11:03:57 +01:00
if params.HasDate && tsk.Date.IsZero() {
return false
}
if !params.From.IsZero() && params.From.After(tsk.Date) {
return false
}
if !params.To.IsZero() && tsk.Date.After(params.To) {
return false
2024-12-29 09:32:49 +01:00
}
2024-12-31 09:22:03 +01:00
if params.Project != "" && params.Project != tsk.Project {
return false
}
2024-12-29 09:32:49 +01:00
return true
}
2024-10-03 07:32:48 +02:00
func NextLocalID(used []int) int {
if len(used) == 0 {
return 1
}
sort.Ints(used)
usedMax := 1
for _, u := range used {
if u > usedMax {
usedMax = u
}
}
var limit int
for limit = 1; limit <= len(used) || limit < usedMax; limit *= 10 {
}
newId := used[len(used)-1] + 1
if newId < limit {
return newId
}
usedMap := map[int]bool{}
for _, u := range used {
usedMap[u] = true
}
for i := 1; i < limit; i++ {
if _, ok := usedMap[i]; !ok {
return i
}
}
return limit
}