 03c0011445
			
		
	
	03c0011445
	
	
	
		
			
			Added SQLite database for session management and user preferences storage, allowing users to have consistent settings across different sessions and devices. Backend changes: - Added SQLite database with users, sessions, and preferences tables - Implemented session-based authentication alongside JWT tokens - Created preference storage/retrieval API endpoints - Database migrations for schema setup - Session validation and cleanup functionality Frontend changes: - Added "Remember server" and "Remember username" checkboxes to login - Created preferences service for syncing settings with backend - Updated auth flow to handle session tokens and preferences - Store remembered values in LocalStorage (not database) for convenience Key features: - User preferences persist across sessions and devices - CalDAV passwords never stored, only passed through - Sessions expire after 24 hours - Remember checkboxes only affect local browser storage 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			16 lines
		
	
	
		
			526 B
		
	
	
	
		
			SQL
		
	
	
	
	
	
			
		
		
	
	
			16 lines
		
	
	
		
			526 B
		
	
	
	
		
			SQL
		
	
	
	
	
	
| -- Create sessions table
 | |
| CREATE TABLE IF NOT EXISTS sessions (
 | |
|     id TEXT PRIMARY KEY,
 | |
|     user_id TEXT NOT NULL,
 | |
|     token TEXT NOT NULL UNIQUE,
 | |
|     created_at TEXT NOT NULL,
 | |
|     expires_at TEXT NOT NULL,
 | |
|     last_accessed TEXT NOT NULL,
 | |
|     FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE
 | |
| );
 | |
| 
 | |
| -- Index for faster token lookups
 | |
| CREATE INDEX IF NOT EXISTS idx_sessions_token ON sessions(token);
 | |
| 
 | |
| -- Index for cleanup of expired sessions
 | |
| CREATE INDEX IF NOT EXISTS idx_sessions_expires_at ON sessions(expires_at); |