SQLite key-value store wrapper
Find a file
Claude 5f5157fb3b
Some checks failed
Security Scan / security (push) Successful in 14s
Test / test (push) Failing after 47s
ci: add Forgejo Actions test and security scan workflows
Uses reusable workflows from core/go-devops for Go testing
(with race detector and coverage) and security scanning
(govulncheck, gitleaks, trivy).

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-23 03:28:08 +00:00
.forgejo/workflows ci: add Forgejo Actions test and security scan workflows 2026-02-23 03:28:08 +00:00
docs docs: graduate TODO/FINDINGS into production documentation 2026-02-20 15:01:55 +00:00
bench_test.go bench: add supplemental benchmarks for GetAll scaling, parallel, TTL, Render 2026-02-20 04:53:52 +00:00
CLAUDE.md docs: graduate TODO/FINDINGS into production documentation 2026-02-20 15:01:55 +00:00
coverage_test.go refactor: apply go fix modernizers for Go 1.26 2026-02-22 21:00:17 +00:00
events.go feat(events): add reactive event hooks for store mutations 2026-02-20 08:25:03 +00:00
events_test.go refactor: apply go fix modernizers for Go 1.26 2026-02-22 21:00:17 +00:00
go.mod chore: sync workspace dependency versions 2026-02-22 21:42:03 +00:00
go.sum chore: sync workspace dependency versions 2026-02-22 21:42:03 +00:00
README.md docs: add README with quick start and docs links 2026-02-20 15:11:20 +00:00
scope.go feat(scope): add namespace isolation with quota enforcement 2026-02-20 08:19:11 +00:00
scope_test.go refactor: apply go fix modernizers for Go 1.26 2026-02-22 21:00:17 +00:00
store.go refactor: apply go fix modernizers for Go 1.26 2026-02-22 21:00:17 +00:00
store_test.go refactor: apply go fix modernizers for Go 1.26 2026-02-22 21:00:17 +00:00

go-store

Group-namespaced SQLite key-value store with TTL expiry, namespace isolation, quota enforcement, and a reactive event system. Backed by a pure-Go SQLite driver (no CGO), uses WAL mode for concurrent reads, and enforces a single connection to ensure pragma consistency. Supports scoped stores for multi-tenant use, Watch/Unwatch subscriptions, and OnChange callbacks — the designed integration point for go-ws real-time streaming.

Module: forge.lthn.ai/core/go-store Licence: EUPL-1.2 Language: Go 1.25

Quick Start

import "forge.lthn.ai/core/go-store"

st, err := store.New("/path/to/store.db")  // or store.New(":memory:")
defer st.Close()

st.Set("config", "theme", "dark")
st.SetWithTTL("session", "token", "abc123", 24*time.Hour)
val, err := st.Get("config", "theme")

// Watch for mutations
w := st.Watch("config", "*")
defer st.Unwatch(w)
for e := range w.Ch { fmt.Println(e.Type, e.Key) }

// Scoped store for tenant isolation
sc, _ := store.NewScoped(st, "tenant-42")
sc.Set("prefs", "locale", "en-GB")

Documentation

  • Architecture — storage layer, group/key model, TTL expiry, event system, namespace isolation
  • Development Guide — prerequisites, test patterns, benchmarks, adding methods
  • Project History — completed phases, known limitations, future considerations

Build & Test

go test ./...
go test -race ./...
go test -bench=. ./...
go build ./...

Licence

European Union Public Licence 1.2 — see LICENCE for details.