diff options
| author | Peter Stone <thepeterstone@gmail.com> | 2026-01-12 09:27:16 -1000 |
|---|---|---|
| committer | Peter Stone <thepeterstone@gmail.com> | 2026-01-12 09:27:16 -1000 |
| commit | 9fe0998436488537a8a2e8ffeefb0c4424b41c60 (patch) | |
| tree | ce877f04e60a187c2bd0e481e80298ec5e7cdf80 /migrations | |
Initial commit: Personal Consolidation Dashboard (Phase 1 Complete)
Implemented a unified web dashboard aggregating tasks, notes, and meal planning:
Core Features:
- Trello integration (PRIMARY feature - boards, cards, lists)
- Todoist integration (tasks and projects)
- Obsidian integration (20 most recent notes)
- PlanToEat integration (optional - 7-day meal planning)
- Mobile-responsive web UI with auto-refresh (5 min)
- SQLite caching with 5-minute TTL
- AI agent endpoint with Bearer token authentication
Technical Implementation:
- Go 1.21+ backend with chi router
- Interface-based API client design for testability
- Parallel data fetching with goroutines
- Graceful degradation (partial data on API failures)
- .env file loading with godotenv
- Comprehensive test coverage (9/9 tests passing)
Bug Fixes:
- Fixed .env file not being loaded at startup
- Fixed nil pointer dereference with optional API clients (typed nil interface gotcha)
Documentation:
- START_HERE.md - Quick 5-minute setup guide
- QUICKSTART.md - Fast track setup
- SETUP_GUIDE.md - Detailed step-by-step instructions
- PROJECT_SUMMARY.md - Complete project overview
- CLAUDE.md - Guide for Claude Code instances
- AI_AGENT_ACCESS.md - AI agent design document
- AI_AGENT_SETUP.md - Claude.ai integration guide
- TRELLO_AUTH_UPDATE.md - New Power-Up auth process
Statistics:
- Binary: 17MB
- Code: 2,667 lines
- Tests: 5 unit + 4 acceptance tests (all passing)
- Dependencies: chi, sqlite3, godotenv
Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
Diffstat (limited to 'migrations')
| -rw-r--r-- | migrations/001_initial_schema.sql | 70 | ||||
| -rw-r--r-- | migrations/002_add_cache_metadata.sql | 17 |
2 files changed, 87 insertions, 0 deletions
diff --git a/migrations/001_initial_schema.sql b/migrations/001_initial_schema.sql new file mode 100644 index 0000000..26d1eac --- /dev/null +++ b/migrations/001_initial_schema.sql @@ -0,0 +1,70 @@ +-- Initial schema for Personal Consolidation Dashboard + +-- Tasks table (Todoist) +CREATE TABLE IF NOT EXISTS tasks ( + id TEXT PRIMARY KEY, + content TEXT NOT NULL, + description TEXT, + project_id TEXT, + project_name TEXT, + due_date DATETIME, + priority INTEGER DEFAULT 1, + completed BOOLEAN DEFAULT 0, + labels TEXT, -- JSON array + url TEXT, + created_at DATETIME DEFAULT CURRENT_TIMESTAMP, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP +); + +CREATE INDEX IF NOT EXISTS idx_tasks_due_date ON tasks(due_date); +CREATE INDEX IF NOT EXISTS idx_tasks_completed ON tasks(completed); +CREATE INDEX IF NOT EXISTS idx_tasks_project_id ON tasks(project_id); + +-- Notes table (Obsidian) +CREATE TABLE IF NOT EXISTS notes ( + filename TEXT PRIMARY KEY, + title TEXT NOT NULL, + content TEXT, + modified DATETIME NOT NULL, + path TEXT NOT NULL, + tags TEXT, -- JSON array + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP +); + +CREATE INDEX IF NOT EXISTS idx_notes_modified ON notes(modified DESC); + +-- Meals table (PlanToEat) +CREATE TABLE IF NOT EXISTS meals ( + id TEXT PRIMARY KEY, + recipe_name TEXT NOT NULL, + date DATE NOT NULL, + meal_type TEXT CHECK(meal_type IN ('breakfast', 'lunch', 'dinner', 'snack')), + recipe_url TEXT, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP +); + +CREATE INDEX IF NOT EXISTS idx_meals_date ON meals(date); +CREATE INDEX IF NOT EXISTS idx_meals_type ON meals(meal_type); + +-- Boards table (Trello) +CREATE TABLE IF NOT EXISTS boards ( + id TEXT PRIMARY KEY, + name TEXT NOT NULL, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP +); + +-- Cards table (Trello) +CREATE TABLE IF NOT EXISTS cards ( + id TEXT PRIMARY KEY, + name TEXT NOT NULL, + board_id TEXT NOT NULL, + list_id TEXT, + list_name TEXT, + due_date DATETIME, + url TEXT, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP, + FOREIGN KEY (board_id) REFERENCES boards(id) ON DELETE CASCADE +); + +CREATE INDEX IF NOT EXISTS idx_cards_board_id ON cards(board_id); +CREATE INDEX IF NOT EXISTS idx_cards_due_date ON cards(due_date); diff --git a/migrations/002_add_cache_metadata.sql b/migrations/002_add_cache_metadata.sql new file mode 100644 index 0000000..da6c0ce --- /dev/null +++ b/migrations/002_add_cache_metadata.sql @@ -0,0 +1,17 @@ +-- Cache metadata table for tracking API fetch times and TTL + +CREATE TABLE IF NOT EXISTS cache_metadata ( + key TEXT PRIMARY KEY, + last_fetch DATETIME NOT NULL, + ttl_minutes INTEGER NOT NULL DEFAULT 5, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP +); + +-- Pre-populate with cache keys +INSERT OR IGNORE INTO cache_metadata (key, last_fetch, ttl_minutes) VALUES + ('todoist_tasks', '2000-01-01 00:00:00', 5), + ('todoist_projects', '2000-01-01 00:00:00', 5), + ('obsidian_notes', '2000-01-01 00:00:00', 5), + ('plantoeat_meals', '2000-01-01 00:00:00', 5), + ('trello_boards', '2000-01-01 00:00:00', 5), + ('trello_cards', '2000-01-01 00:00:00', 5); |
