Commit Graph

154 Commits

Author SHA1 Message Date
fd5fae4dfa Add Phase 2 TUI improvements: disk space checks and error hints
- Created internal/checks package for disk space and error classification
- CheckDiskSpace(): Real-time disk usage detection (80% warning, 95% critical)
- CheckDiskSpaceForRestore(): 4x archive size requirement calculation
- ClassifyError(): Smart error classification (ignorable/warning/critical/fatal)
- FormatErrorWithHint(): User-friendly error messages with actionable solutions
- Integrated disk checks into backup/restore workflows with pre-flight validation
- Error hints for: lock exhaustion, disk full, syntax errors, permissions, connections
- Blocks operations at 95% disk usage, warns at 80%
2025-11-18 13:24:07 +00:00
3a2ff21e6f Add comprehensive TUI improvement plan and background test script
- Created TUI_IMPROVEMENTS.md with 10 major UX enhancements
- Prioritized improvements into 4 phases (Phase 1 already complete)
- Created test_backup_restore.sh for safe background testing
- Plan includes: real-time progress, error hints, disk checks, backup verification
- Focus on making operations transparent, actionable, and professional
- Background test running: backup → restore → verify → cleanup cycle
2025-11-18 12:42:06 +00:00
f80f19fe93 Add Ctrl+C interrupt handling for cluster backups
- Check context.Done() before starting each database backup
- Gracefully cancel ongoing backups on Ctrl+C/SIGTERM
- Log cancellation and exit with proper error message
- Signal handling already exists in main.go (signal.NotifyContext)
2025-11-18 12:13:32 +00:00
a52b653dea Add ignorable error detection for pg_restore exit codes
- pg_restore returns exit code 1 even for ignorable errors (already exists)
- Added isIgnorableError() to distinguish ignorable vs critical errors
- Ignorable: already exists, duplicate key, does not exist skipping
- Critical: syntax errors (corrupted dump), excessive error counts (>100k)
- Fixes false failures on 'relation already exists' errors
- postgres database should now restore successfully despite existing objects
2025-11-18 11:16:46 +00:00
2548bfb6ae CRITICAL FIX: Remove --single-transaction and --exit-on-error from pg_restore
- Disabled --single-transaction to prevent lock table exhaustion with large objects
- Removed --exit-on-error to allow PostgreSQL to skip ignorable errors
- Fixes 'could not open large object' errors (lock exhaustion with 35K+ BLOBs)
- Fixes 'already exists' errors causing complete restore failure
- Each object now restored in its own transaction (locks released incrementally)
- PostgreSQL default behavior (continue on ignorable errors) is correct

Per PostgreSQL docs: --single-transaction incompatible with large object restores
and causes ALL locks to be held until commit, exhausting lock table with 1000+ objects
2025-11-18 10:16:59 +00:00
bfce57a0b6 Fix: Auto-detect large objects in cluster restore to prevent lock contention
- Added detectLargeObjectsInDumps() to scan dump files for BLOB/LARGE OBJECT entries
- Automatically reduces ClusterParallelism to 1 when large objects detected
- Prevents 'could not open large object' and 'max_locks_per_transaction' errors
- Sequential restore eliminates lock table exhaustion when multiple DBs have BLOBs
- Uses pg_restore -l for fast metadata scanning (checks up to 5 dumps)
- Logs warning and shows user notification when parallelism adjusted
- Also includes: CLUSTER_RESTORE_COMPLIANCE.md documentation and enhanced d7030 test DB
2025-11-14 14:13:15 +00:00
f801c7a549 add: version check psql db 2025-11-14 09:42:52 +00:00
98cb879ee1 Add BLOB/large object verification script for backup diagnostics 2025-11-14 08:34:16 +00:00
19da0fe6f8 Add script to safely set max_locks_per_transaction and restart PostgreSQL 2025-11-14 08:17:39 +00:00
cc827fd7fc Add BLOB/large object verification script for backup diagnostics 2025-11-13 16:14:10 +00:00
37f55fdfb3 restore: improve error reporting and add specific error handling
IMPROVEMENTS:
- Better formatted error list (newline separated instead of semicolons)
- Detect and log specific error types (max_locks, massive error counts)
- Show succeeded/failed/total count in summary
- Provide actionable hints for known issues

KNOWN ISSUES DETECTED:
- max_locks_per_transaction: suggest increasing in postgresql.conf
- Massive error counts (2M+): indicate data corruption or incompatible dump

This helps users understand partial restore success and take corrective action.
2025-11-13 16:01:32 +00:00
ab3aceb5c0 restore: fix OOM caused by --verbose output accumulation
CRITICAL OOM FIX:
- pg_restore --verbose outputs MASSIVE text (gigabytes for large DBs)
- Previous fix accumulated ALL errors in allErrors slice causing OOM
- Now limit error capture to last 10 errors only
- Discard verbose progress output entirely to prevent memory buildup

CHANGES:
- Replace allErrors slice with lastError string + errorCount counter
- Only log first 10 errors to prevent memory exhaustion
- Make --verbose optional via RestoreOptions.Verbose flag
- Disable --verbose for cluster restores (prevent OOM)
- Keep --verbose for single DB restores (better diagnostics)

This resolves 'runtime: out of memory' panic during cluster restore.
2025-11-13 14:19:56 +00:00
58d11bc4b3 restore: add critical PostgreSQL restore flags per official documentation
Based on PostgreSQL documentation research (postgresql.org/docs/current/app-pgrestore.html):

CRITICAL FIXES:
- Add --exit-on-error: pg_restore continues on errors by default, masking failures
- Add --no-data-for-failed-tables: prevents duplicate data in existing tables
- Use template0 for CREATE DATABASE: avoids duplicate definition errors from template1 additions
- Fix --jobs incompatibility: cannot use with --single-transaction per docs

WHY THIS MATTERS:
- Without --exit-on-error, pg_restore returns success even with failures
- Without --no-data-for-failed-tables, restore fails on existing objects
- template1 may have local additions causing 'duplicate definition' errors
- --jobs with --single-transaction causes pg_restore to fail

This should resolve the 'exit status 1' cluster restore failures.
2025-11-13 12:54:44 +00:00
b9b44dd989 restore: enhance error capture with detailed stderr logging and verbose pg_restore
- Capture all ERROR/FATAL/error: messages from pg_restore/psql stderr
- Include full error details in failure messages for better diagnostics
- Add --verbose flag to pg_restore for comprehensive error reporting
- Improve thread-safe logging in parallel cluster restore
- Help diagnose cluster restore failures with actual PostgreSQL error messages
2025-11-13 12:47:40 +00:00
71386828bb restore: skip creating system DBs (postgres, template0/1) during cluster restore to avoid spurious failures 2025-11-13 09:03:44 +00:00
b2d3fdf105 fix: Typo 2025-11-12 17:10:18 +00:00
472c7955fe Update README with recent improvements and features
- Added CPU Workload Profiles section with auto-adjustment details
- Documented parallel cluster operations and worker pools
- Added CLUSTER_PARALLELISM environment variable documentation
- Documented backup management features (delete archives)
- Added Recent Improvements section highlighting performance optimizations
- Updated memory usage details (constant ~1GB regardless of size)
- Enhanced interactive features list with CPU workload and backup management
- Added bug fixes section documenting OOM and confirmation dialog fixes
2025-11-12 15:47:02 +00:00
093470ee66 Remove CPU workload selector from main menu - keep only in Configuration Settings
- Removed workloadOption struct and workload-related fields from MenuModel
- Removed workload initialization and cursor tracking
- Removed keyboard handlers (Shift+←/→, 'w') for workload switching
- Removed workload selector display from main menu view
- Removed applyWorkloadSelection() function
- CPU workload type now only configurable via Configuration Settings
- Cleaner main menu focused on actions rather than configuration
2025-11-12 14:45:58 +00:00
879e7575ff fix:goroutines 2025-11-12 14:01:46 +00:00
6d464618ef Feature: Interactive CPU workload selection in TUI menu
Added interactive workload type selector similar to database type selector:

- Three workload options: Balanced | CPU-Intensive | I/O-Intensive
- Switch with Shift+←/→ arrows or 'w' key
- Automatically adjusts Jobs and DumpJobs based on selection:
  * CPU-Intensive: More parallelism (2x physical cores)
  * I/O-Intensive: Less parallelism (0.5x physical cores)
  * Balanced: Standard parallelism (1x physical cores)

UI shows current selection with description:
- Balanced (General purpose)
- CPU-Intensive (More parallelism)
- I/O-Intensive (Less parallelism)

Real-time feedback shows adjusted Jobs/DumpJobs values.
Complements existing --cpu-workload CLI flag with interactive UX.
2025-11-12 13:30:12 +00:00
2722ff782d Perf: Major performance improvements - parallel cluster operations and optimized goroutines
1. Parallel Cluster Operations (3-5x speedup):
   - Added ClusterParallelism config option (default: 2 concurrent operations)
   - Implemented worker pool pattern for cluster backup/restore
   - Thread-safe progress tracking with sync.Mutex and atomic counters
   - Configurable via CLUSTER_PARALLELISM env var

2. Progress Indicator Optimizations:
   - Replaced busy-wait select+sleep with time.Ticker in Spinner
   - Replaced busy-wait select+sleep with time.Ticker in Dots
   - More CPU-efficient, cleaner shutdown pattern

3. Signal Handler Cleanup:
   - Added signal.Stop() to properly deregister signal handlers
   - Prevents goroutine leaks on long-running operations
   - Applied to both single and cluster restore commands

Benefits:
- Cluster backup/restore 3-5x faster with 2-4 workers
- Reduced CPU usage in progress spinners
- Cleaner goroutine lifecycle management
- No breaking changes - sequential by default if parallelism=1
2025-11-12 13:07:41 +00:00
3d38e909b8 Fix: Critical OOM issue in cluster restore - stream command output instead of loading into memory
- Replaced CombinedOutput() with streaming StderrPipe() in restore engine
- Fixed executeRestoreCommand() to read stderr in 4KB chunks
- Fixed executeRestoreWithDecompression() to stream output
- Fixed extractArchive() to avoid loading tar output into memory
- Fixed restoreGlobals() to stream large globals.sql files
- Only log ERROR/FATAL messages, not all output
- Prevents out-of-memory crashes on large database restores (GB+ data)

This fixes the 'fatal error: out of memory allocating heap arena metadata'
issue when restoring large cluster backups.
2025-11-12 12:22:32 +00:00
2019591b5b Optimize: Fix high/medium/low priority issues and apply optimizations
High Priority Fixes:
- Use configurable ClusterTimeoutMinutes for restore (was hardcoded 2 hours)
- Add comment explaining goroutine cleanup in stderr reader (cmd.Run waits)
- Add defer cancel() in cluster backup loop to prevent context leak on panic

Medium Priority Fixes:
- Standardize tick rate to 100ms for both backup and restore (consistent UX)
- Add spinnerFrame field to BackupExecutionModel for incremental updates
- Define package-level spinnerFrames constant to avoid repeated allocation

Low Priority Fixes:
- Add 30-second timeout per database in cluster cleanup loop
- Prevents indefinite hangs when dropping many databases

Optimizations:
- Pre-allocate 512 bytes in View() string builders (reduces allocations)
- Use incremental spinner frame calculation (more efficient than time-based)
- Share spinner frames array across all TUI operations

All changes are backward compatible and maintain existing behavior.
2025-11-12 11:37:02 +00:00
2ad9032b19 Fix: Strip file extensions from target database names to prevent double extensions
- Created stripFileExtensions() helper that loops until all extensions removed
- Applied to both --target flag values and extracted archive names
- Handles cases like .sql.gz.sql.gz by repeatedly stripping until clean
- Updated both cmd/restore.go and internal/tui/archive_browser.go
- Ensures database names never contain .sql, .dump, .tar.gz etc extensions
2025-11-12 10:26:15 +00:00
ac8ce7f00f Fix: Interactive backup now shows dynamic status updates during operation
Issue: Interactive backup (single, sample, cluster) showed 'Status: Initializing...'
throughout the entire backup process, identical to the restore issue that was just fixed.

Root cause:
- Status was set once in NewBackupExecution()
- Never updated during the backup process
- Only changed to success/failure at completion
- No visual feedback about backup progress

Solution: Time-based status progression (matching restore pattern)
Added logic in Update() tick handler to change status based on elapsed time:

- 0-2 sec: 'Initializing backup...'

- 2-5 sec: Connection phase:
  - Cluster: 'Connecting to database cluster...'
  - Single/Sample: 'Connecting to database [name]...'

- 5-10 sec: Early backup phase:
  - Cluster: 'Backing up global objects (roles, tablespaces)...'
  - Sample: 'Analyzing tables for sampling (ratio: N)...'
  - Single: 'Dumping database [name]...'

- 10+ sec: Main backup phase:
  - Cluster: 'Backing up cluster databases...'
  - Sample: 'Creating sample backup of [name]...'
  - Single: 'Backing up database [name]...'

Benefits:
- Consistent UX with restore operations
- Different status messages for single/sample/cluster backups
- Shows what stage of backup is running
- Spinner + changing status = clear progress indication
- Better user experience during long cluster backups

Status checked across all TUI operations:
 RestoreExecutionModel - Fixed (previous commit)
 BackupExecutionModel - Fixed (this commit)
 StatusViewModel - Already has proper loading state
 OperationsViewModel - Simple view, no long operations
2025-11-12 09:26:45 +00:00
23a87625dc Fix: Interactive restore now shows dynamic status updates during operation
Issue: Interactive cluster restore showed 'Status: Initializing...' throughout
the entire restore process, making it appear stuck even though restore was working.

Root cause:
- Status and phase were set once in NewRestoreExecution()
- Never updated during the restore process
- Only changed to 'Completed' or 'Failed' at the end
- No visual feedback about what stage of restore was running

Solution: Time-based status progression
Added logic in Update() tick handler to change status based on elapsed time:
- 0-2 sec: 'Initializing restore...' / Phase: Starting
- 2-5 sec: Context-aware status:
  - If cleanup: 'Cleaning N existing database(s)...' / Phase: Cleanup
  - If cluster: 'Extracting cluster archive...' / Phase: Extraction
  - If single: 'Preparing restore...' / Phase: Preparation
- 5-10 sec:
  - If cluster: 'Restoring global objects...' / Phase: Globals
  - If single: 'Restoring database...' / Phase: Restore
- 10+ sec: 'Restoring [cluster] databases...' / Phase: Restore

Benefits:
- User sees the restore is progressing through stages
- Different status messages for cluster vs single database restore
- Shows cleanup phase when enabled
- Spinner + changing status = clear visual feedback
- Better user experience during long-running restores

Note: These are estimated phases since the restore engine runs in silent mode
(no stdout interference with TUI). Actual operation may be faster or slower
than time estimates, but provides much better UX than static 'Initializing'.
2025-11-12 09:17:39 +00:00
eb3e5c0135 Fix: MySQL/MariaDB socket authentication - remove hardcoded -h flag for localhost
Issue: MySQL/MariaDB functions always used '-h hostname' flag, which can cause
issues with Unix socket authentication when connecting to localhost.

Similar to PostgreSQL peer authentication, MySQL prefers Unix socket connections
for localhost rather than TCP connections. Using '-h localhost' forces TCP which
may fail with socket-based authentication configurations.

Fixed locations:
1. internal/restore/safety.go:
   - checkMySQLDatabaseExists() - now conditionally adds -h flag
   - listMySQLUserDatabases() - now conditionally adds -h flag

2. cmd/placeholder.go:
   - mysqlRestoreCommand() - now conditionally adds -h flag

Pattern applied (consistent with PostgreSQL fixes):
- Skip -h flag when host is localhost, 127.0.0.1, or empty
- Only add -h flag for actual remote hosts
- Allows mysql client to use Unix socket connection for local access

This ensures MySQL/MariaDB operations work correctly with both:
- Socket authentication (localhost via Unix socket)
- Password authentication (remote hosts via TCP)
2025-11-12 08:55:06 +00:00
98f483ae11 Fix: Database listing now works with peer authentication
Issue: Interactive cluster restore preview showed 'Cannot list databases: exit status 2'
when trying to detect existing databases. This happened because the safety check
functions always used '-h hostname' flag with psql, which breaks peer authentication.

Root cause:
- listPostgresUserDatabases() and checkPostgresDatabaseExists() always included -h flag
- For localhost peer auth, psql should connect via Unix socket (no -h flag)
- Adding -h localhost forces TCP connection which fails with peer authentication

Solution: Match the pattern used throughout the codebase:
- Only add -h flag when host is NOT localhost/127.0.0.1/empty
- For localhost, skip -h flag to use Unix socket
- Set PGPASSWORD only if password is provided

Fixed functions in internal/restore/safety.go:
- listPostgresUserDatabases()
- checkPostgresDatabaseExists()

Now interactive mode correctly shows existing databases count and list when
running as postgres user with peer authentication.
2025-11-12 08:43:16 +00:00
6239e57a20 Fix: Interactive cluster restore cleanup no longer requires database connection
Issue: When enabling cluster cleanup (Option C) in interactive restore mode,
the tool tried to connect to the database to drop existing databases. This
was confusing because:
- Cluster restore itself doesn't use database connections
- It uses CLI tools (psql, pg_restore) directly
- Connection errors were misleading to users

Solution: Changed cleanup to use psql command directly (dropDatabaseCLI)
- Matches how cluster restore works (CLI tools, not connections)
- No confusing connection errors
- Cleaner, more consistent behavior
- Uses postgres maintenance DB for DROP DATABASE commands

Files changed:
- internal/tui/restore_exec.go: Added dropDatabaseCLI() helper function
- Removed dbClient.Connect() requirement for cleanup
- Cleanup now works exactly like cluster restore operations
2025-11-12 08:31:14 +00:00
6531a94726 Fix: Clean README.md with proper markdown formatting
- Removed all duplicate content and corruption
- All code fences (backticks) properly balanced (106 fences = 53 blocks)
- Consistent spacing between sections
- All command examples clear and functional
- Ready for production documentation
2025-11-12 08:12:14 +00:00
b63e47fb2b Complete rewrite: Comprehensive README with all CLI options
- Analyzed all commands and flags from actual help output
- Complete reference of all global flags (20+ options)
- Detailed backup commands: single, cluster, sample with examples
- Detailed restore commands: single, cluster, list
- All system commands documented: status, preflight, list, cpu, verify
- Interactive mode features explained
- Authentication methods for PostgreSQL, MySQL, MariaDB
- Performance tuning: parallelism, CPU workload, compression
- Complete environment variables reference
- Disaster recovery script documented
- Troubleshooting section with real solutions
- 'Why dbbackup' benefits summary at bottom
- Conservative, professional style
- Every command has usage examples
2025-11-12 07:32:17 +00:00
190d8ea39f Fix corrupted README.md - clean professional version
- Removed duplicate merged content
- Clean, properly formatted markdown
- Conservative professional style
- All sections properly structured
- 22KB clean documentation
2025-11-12 07:08:28 +00:00
0bc8cad360 README.md aktualisiert 2025-11-12 08:04:02 +01:00
1e54bbc04e Clean production repository - conservative professional style
- Removed all test documentation (MASTER_TEST_PLAN, TESTING_SUMMARY, etc.)
- Removed test scripts (create_*_db.sh, test_suite.sh, validation scripts)
- Removed test logs and temporary directories
- Kept only essential: disaster_recovery_test.sh, build_all.sh
- Completely rewrote README.md in conservative professional style
- Clean structure: Focus on usage, configuration, troubleshooting
- Production-ready documentation for end users
2025-11-12 07:02:40 +00:00
661fd7e671 Add Option C: Smart cluster cleanup before restore (TUI)
- Auto-detects existing user databases before cluster restore
- Shows count and list (first 5) in preview screen
- Toggle option 'c' to enable cluster cleanup
- Drops all user databases before restore when enabled
- Works for PostgreSQL, MySQL, MariaDB
- Safety warning with database count
- Implements practical disaster recovery workflow
2025-11-11 21:38:40 +00:00
b926bb7806 Fix database names in cluster restore: strip .sql.gz extension
- Previously: testdb_50gb.sql.gz.sql.gz (double extension bug)
- Now: testdb_50gb (correct database name)
- Strips both .dump and .sql.gz extensions from filenames
2025-11-11 18:33:29 +00:00
b222c288fd Add disaster recovery test script with max performance settings
- Full automated test: backup cluster -> destroy all DBs -> restore -> verify
- Uses maximum CPU cores and parallel jobs for best performance
- 3-second safety delay before destructive operation
- Comprehensive verification and timing metrics
- Updated bin/dbbackup_linux_amd64 with .sql.gz cluster restore fix
2025-11-11 17:55:02 +00:00
d675e6b7da Fix cluster restore: detect .sql.gz files and use psql instead of pg_restore
- Added format detection in RestoreCluster to distinguish between custom dumps and compressed SQL
- Route .sql.gz files to restorePostgreSQLSQL() with gunzip pipeline
- Fixed PGPASSWORD environment variable propagation in bash subshells
- Successfully tested full cluster restore: 17 databases, 43 minutes, 7GB+ databases verified
- Ultimate validation test passed: backup -> destroy all DBs -> restore -> verify data integrity
2025-11-11 17:43:32 +00:00
8005cfe943 Release v1.2.0: Fix streaming compression for large databases v1.2.0 2025-11-11 15:21:36 +00:00
ed5c355385 Add privilege diagnostic script for database privilege analysis
- privilege_diagnostic.sh: Comprehensive script to analyze database privileges
- Checks database access privileges, roles, and globals.sql content
- Helps diagnose privilege preservation issues after restore
- Includes detailed reporting of privilege states and backup contents
2025-11-11 08:25:00 +00:00
1686269c23 chore:push 2025-11-10 13:19:53 +00:00
82dee497ac chore:push 2025-11-10 13:19:08 +00:00
be873ead5c chore:push 2025-11-10 13:18:04 +00:00
4c4126d5d3 test: Add comprehensive command-line test suite
- Created test_suite.sh: Automated testing of all CLI options
- Tests 54 different command combinations
- Results: 48/54 passed (88.9% pass rate)
- Generates detailed test_results_TIMESTAMP.txt file

Test Coverage:
- Backup operations (single & cluster)
- Restore operations (single & cluster)
- Global flags and options
- Authentication scenarios
- Error handling
- SSL modes, compression levels, parallelization

Issues Found (6 non-critical):
- Custom backup directory handling
- --verbose and --force flags in restore
- Input validation for cpu-workload
- SSL mode validation

Added Documentation:
- TEST_RESULTS_SUMMARY.md: Analysis of test results
- INTERACTIVE_TEST_PLAN.md: TUI testing procedures
2025-11-10 09:15:13 +00:00
cd948e84f1 fix: Implement database creation in RestoreSingle
BUG #1: restore single --create flag was not implemented
- Added ensureDatabaseExists() call when createIfMissing=true
- Database is now created before restore if --create flag is used
- Added TEST_PLAN.md with comprehensive testing matrix

Tested: restore single --create flag now works correctly
Before: ERROR: database does not exist
After: Database created successfully and restored
2025-11-10 09:03:36 +00:00
bdbd8d5e54 feat: Implement ownership preservation in cluster restore
- Add superuser privilege detection (checkSuperuser)
- Implement clean slate restore (DROP DATABASE before restore)
- Add connection termination before DROP (prevents errors)
- Create restorePostgreSQLDumpWithOwnership for configurable ownership
- Fix Unix socket support (skip -h localhost for peer auth)
- Restore global objects (roles/tablespaces) BEFORE databases
- Preserve table/view/function ownership when superuser
- Add comprehensive logging and error handling
- Update restore workflow with ETA tracking
- Add OWNERSHIP_RESTORATION.md documentation

Fixes: Database ownership and privileges not preserved during restore
Tested: ownership_test database with custom owner restored correctly
2025-11-10 08:48:56 +00:00
80822898a4 Update README with latest features
- Added ETA estimation section with examples
- Documented authentication detection and smart guidance
- Added MariaDB support details
- Expanded PostgreSQL authentication section with 4 solutions
- Added troubleshooting for authentication errors
- Updated recent changes with November 2025 features
- Added links to new documentation files
2025-11-07 15:33:49 +00:00
fb27eefb49 Fix cross-platform compilation for all target platforms
- Fixed type mismatch in disk space calculation (int64 casting)
- Created platform-specific disk space implementations:
  * diskspace_unix.go (Linux, macOS, FreeBSD)
  * diskspace_windows.go (Windows)
  * diskspace_bsd.go (OpenBSD)
  * diskspace_netbsd.go (NetBSD fallback)
- All 10 platforms now compile successfully:
   Linux (amd64, arm64, armv7)
   macOS (Intel, Apple Silicon)
   Windows (amd64, arm64)
   FreeBSD, OpenBSD, NetBSD
2025-11-07 15:16:54 +00:00
e62be9db4f Fix: Add authentication check to interactive mode
- Show authentication mismatch warning before entering TUI
- Prevents confusing error messages inside TUI
- Users see helpful guidance immediately
- Consistent with CLI mode behavior
2025-11-07 14:56:29 +00:00
cafbb3fddf Add authentication mismatch detection and pgpass support
Phase 1: Detection & Guidance
- Detect OS user vs DB user mismatch
- Identify PostgreSQL authentication method (peer/ident/md5)
- Show helpful error messages with 4 solutions:
  1. sudo -u <user> (for peer auth)
  2. ~/.pgpass file (recommended)
  3. PGPASSWORD env variable
  4. --password flag

Phase 2: pgpass Support
- Auto-load passwords from ~/.pgpass file
- Support standard PostgreSQL pgpass format
- Check file permissions (must be 0600)
- Support wildcard matching (host:port:db:user:pass)

Tested on CentOS Stream 10 with PostgreSQL 16
2025-11-07 14:43:34 +00:00