commit 78d6c27c8940da32a6de8e64327c86f74fdaa2eb Author: adminoo <git@kadath.corp> Date: Wed Feb 4 12:59:22 2026 +0100 feat: freebsd log rotation config thingie commit 55af4e6c70122e679272ed247c26e04b1247f694 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 12:58:43 2026 +0100 feat: embed templates, static resolution commit 29c917f929a7378ec29c54315ee2e9f420747787 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 10:44:34 2026 +0100 feat: set log file path commit 294fd3d1549979eab63587ceec6ff5d0978e9afc Author: adminoo <git@kadath.corp> Date: Wed Feb 4 10:23:53 2026 +0100 feat: logging HTTP request commit c9ae80b240d58e1abed7ae3b7b2c3b283a31f1a1 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:54:05 2026 +0100 feat: freebsd-specific compile target and scripts commit 86ca154dedd19aa1fe5f571c445dcf17a8396bfa Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:25:16 2026 +0100 feat: mobile friendly CSS commit 199f4319e0b08a4b6d595d7eb3effb6db6c7beec Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:25:03 2026 +0100 feat: persisting rendered note commit 865e258237e45d7c542685a4653bcad3c5af259d Author: adminoo <git@kadath.corp> Date: Wed Feb 4 08:06:38 2026 +0100 fix: grouping notes by folder commit 242d1d074c92461f38212b033c7a9e383f9dc550 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 16:52:50 2026 +0100 feat: storage layer logic - Prune notes from db not matching current folder structure at start - Detect file system deletion on start by comparing in-db notes - Prevent updating of in-db notes at start if modification time is not newer - Delete by path commit d75d46bc1ab22bd990d0fdc307e571fe52f0dd99 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 15:27:07 2026 +0100 feat: group notes by root folders commit e1e25a938e717599332f7b40a449d9bb854b673a Author: adminoo <git@kadath.corp> Date: Tue Feb 3 14:24:37 2026 +0100 feat: size in kilobytes commit 61220272a2df2b66c2b8e356ba359ed01de3bd12 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 14:19:40 2026 +0100 feat: styling inputs
140 lines
2.7 KiB
Go
140 lines
2.7 KiB
Go
package storage
|
|
|
|
import (
|
|
"donniemarko/internal/note"
|
|
"fmt"
|
|
"strings"
|
|
)
|
|
|
|
type Storage interface {
|
|
GetAll() []*note.Note
|
|
Get(id string) (*note.Note, error)
|
|
Create(n *note.Note) error
|
|
Delete(id string)
|
|
DeleteByPath(path string)
|
|
Update(id string, n *note.Note)
|
|
Search(query string) []*note.Note
|
|
Count() int
|
|
AddTag(noteID, tag string) error
|
|
RemoveTag(noteID, tag string) error
|
|
GetTags(noteID string) []string
|
|
}
|
|
|
|
type NoteStorage struct {
|
|
Index map[string]*note.Note
|
|
}
|
|
|
|
func NewNoteStorage() *NoteStorage {
|
|
return &NoteStorage{Index: make(map[string]*note.Note)}
|
|
}
|
|
|
|
// GetAll returns all notes stored in the index
|
|
func (ns *NoteStorage) GetAll() []*note.Note {
|
|
var notes []*note.Note
|
|
|
|
for _, value := range ns.Index {
|
|
notes = append(notes, value)
|
|
}
|
|
return notes
|
|
}
|
|
|
|
func (ns *NoteStorage) Get(id string) (*note.Note, error) {
|
|
n, ok := ns.Index[id]
|
|
if ok {
|
|
return n, nil
|
|
}
|
|
return nil, fmt.Errorf("No note with id '%s'", id)
|
|
}
|
|
|
|
func (ns *NoteStorage) Create(n *note.Note) error {
|
|
ns.Index[n.ID] = n
|
|
return nil
|
|
}
|
|
|
|
func (ns *NoteStorage) Count() int {
|
|
return len(ns.Index)
|
|
}
|
|
|
|
func (ns *NoteStorage) Delete(id string) {
|
|
delete(ns.Index, id)
|
|
}
|
|
|
|
func (ns *NoteStorage) DeleteByPath(path string) {
|
|
for id, n := range ns.Index {
|
|
if n.Path == path {
|
|
delete(ns.Index, id)
|
|
}
|
|
}
|
|
}
|
|
|
|
func (ns *NoteStorage) Update(id string, n *note.Note) {
|
|
ns.Index[id] = n
|
|
}
|
|
|
|
func (ns *NoteStorage) Search(query string) []*note.Note {
|
|
results := []*note.Note{}
|
|
for _, note := range ns.Index {
|
|
lowContent := strings.ToLower(string(note.Content))
|
|
lowQuery := strings.ToLower(query)
|
|
if strings.Contains(lowContent, lowQuery) || tagsContain(note.Tags, lowQuery) {
|
|
results = append(results, note)
|
|
}
|
|
}
|
|
return results
|
|
}
|
|
|
|
func tagsContain(tags []string, query string) bool {
|
|
if query == "" {
|
|
return false
|
|
}
|
|
for _, tag := range tags {
|
|
if strings.Contains(strings.ToLower(tag), query) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (ns *NoteStorage) AddTag(noteID, tag string) error {
|
|
n, ok := ns.Index[noteID]
|
|
if !ok {
|
|
return fmt.Errorf("No note with id '%s'", noteID)
|
|
}
|
|
|
|
for _, existing := range n.Tags {
|
|
if existing == tag {
|
|
return nil
|
|
}
|
|
}
|
|
|
|
n.Tags = append(n.Tags, tag)
|
|
return nil
|
|
}
|
|
|
|
func (ns *NoteStorage) RemoveTag(noteID, tag string) error {
|
|
n, ok := ns.Index[noteID]
|
|
if !ok {
|
|
return fmt.Errorf("No note with id '%s'", noteID)
|
|
}
|
|
|
|
updated := n.Tags[:0]
|
|
for _, existing := range n.Tags {
|
|
if existing != tag {
|
|
updated = append(updated, existing)
|
|
}
|
|
}
|
|
n.Tags = updated
|
|
return nil
|
|
}
|
|
|
|
func (ns *NoteStorage) GetTags(noteID string) []string {
|
|
n, ok := ns.Index[noteID]
|
|
if !ok {
|
|
return []string{}
|
|
}
|
|
|
|
tags := make([]string, len(n.Tags))
|
|
copy(tags, n.Tags)
|
|
return tags
|
|
}
|