Metadata-Version: 2.4
Name: pgdock
Version: 1.0.0
Summary: PostgreSQL Docker Instance Manager CLI. Create, manage, and backup PostgreSQL instances with automatic credential generation, health monitoring, and cross-platform support.
Author: pgdock
Author-email: Matija <your-email@example.com>
Project-URL: Homepage, https://github.com/matija2209/pgdock
Project-URL: Repository, https://github.com/matija2209/pgdock
Project-URL: Issues, https://github.com/matija2209/pgdock/issues
Project-URL: Documentation, https://github.com/matija2209/pgdock#readme
Keywords: postgresql,docker,cli,database,postgres,docker-compose,backup,instance-manager
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Database
Classifier: Topic :: System :: Systems Administration
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Environment :: Console
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: typer>=0.12.0
Requires-Dist: pyyaml>=6.0
Requires-Dist: jinja2>=3.1.0
Requires-Dist: rich>=13.0.0
Requires-Dist: click>=8.0.0
Dynamic: author
Dynamic: license-file
Dynamic: requires-python

# PgDock - PostgreSQL Docker Instance Manager

[![PyPI version](https://badge.fury.io/py/pgdock.svg)](https://badge.fury.io/py/pgdock)
[![Test](https://github.com/matija2209/pgdock/actions/workflows/test.yml/badge.svg)](https://github.com/matija2209/pgdock/actions/workflows/test.yml)
[![Publish to PyPI](https://github.com/matija2209/pgdock/actions/workflows/publish.yml/badge.svg)](https://github.com/matija2209/pgdock/actions/workflows/publish.yml)

A CLI tool for managing PostgreSQL Docker instances with automatic credential generation, health checking, and backup capabilities.

## Features

- **Easy Instance Management**: Create, start, stop, and destroy PostgreSQL instances with simple commands
- **Automatic Setup**: Generates secure credentials, picks free ports, and handles Docker Compose configuration
- **Health Monitoring**: Built-in health checks with timeout handling
- **Backup & Restore**: Built-in backup functionality with retention policies
- **Multiple Formats**: Human-readable output and JSON support
- **Cross-Platform**: Works on macOS and Ubuntu with Docker Desktop or Docker Engine

## Installation

### Via pip (recommended)

```bash
pip install pgdock
```

### Development Installation

```bash
git clone https://github.com/matija2209/pgdock.git
cd pgdock
pip install -e .
```

#### WSL/Linux PATH Setup

If `pgdock` command is not found after installation, add the user bin directory to your PATH:

```bash
# Add to PATH temporarily
export PATH="$HOME/.local/bin:$PATH"

# Make it permanent (choose your shell)
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.bashrc  # for bash
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.zshrc   # for zsh

# Reload your shell configuration
source ~/.bashrc  # or source ~/.zshrc
```

### Requirements

- Python 3.10+
- Docker Engine (Ubuntu) or Docker Desktop (macOS)
- Docker Compose v2 (or legacy docker-compose)

## Quick Start

### Create a New Instance

```bash
# Create with auto-generated name and credentials
pgdock create

# Create with custom name
pgdock create --name mydb

# Create with specific version and port
pgdock create --name mydb --version 16 --port 5433
```

### Connect to Your Database

```bash
# Get connection details
pgdock creds mydb

# Get connection string in JSON format
pgdock creds mydb --json

# Copy connection string to clipboard
pgdock creds mydb --copy

# Connect with psql using the connection string
psql "$(pgdock creds mydb --json | jq -r .connectionString)"
```

### List All Instances

```bash
pgdock list
```

### Check Instance Status

```bash
pgdock status mydb
```

## Command Reference

### `pgdock create`

Create and start a new PostgreSQL instance.

```bash
pgdock create [OPTIONS]
```

**Options:**
- `--name TEXT`: Instance name (auto-generated if not provided)
- `--version TEXT`: PostgreSQL version (default: "latest")
- `--db-name TEXT`: Database name (defaults to instance name)
- `--user TEXT`: Database user (auto-generated if not provided)
- `--password TEXT`: Database password (auto-generated if not provided)
- `--port INTEGER`: Host port (auto-picked if not provided)
- `--wait/--no-wait`: Wait for container to be healthy (default: --wait)
- `--json-out PATH`: Save credentials to JSON file
- `--no-pgpass`: Skip updating ~/.pgpass
- `--timeout INTEGER`: Health check timeout in seconds (default: 90)
- `--copy`: Copy connection string to clipboard

**Example:**
```bash
pgdock create --name myapp --version 15 --port 5433 --copy
```

### `pgdock list`

List all PostgreSQL instances with their status.

```bash
pgdock list
```

### `pgdock status`

Show detailed status of a PostgreSQL instance.

```bash
pgdock status INSTANCE_NAME
```

### `pgdock creds`

Show credentials for a PostgreSQL instance.

```bash
pgdock creds INSTANCE_NAME [OPTIONS]
```

**Options:**
- `--json`: Output in JSON format
- `--copy`: Copy connection string to clipboard

### `pgdock start/stop`

Start or stop a PostgreSQL instance.

```bash
pgdock start INSTANCE_NAME
pgdock stop INSTANCE_NAME
```

### `pgdock destroy`

Destroy a PostgreSQL instance.

```bash
pgdock destroy INSTANCE_NAME [OPTIONS]
```

**Options:**
- `--purge-volume`: Also remove the data volume
- `--remove-config`: Also remove instance configuration files
- `--force`: Skip confirmation prompts

### `pgdock backup`

Create a backup of a PostgreSQL instance.

```bash
pgdock backup INSTANCE_NAME DEST_DIR [OPTIONS]
```

**Options:**
- `--format TEXT`: Backup format: "sql" or "custom" (default: "sql")
- `--retention-days INTEGER`: Delete backups older than N days
- `--json`: Output result in JSON format

**Example:**
```bash
pgdock backup mydb ./backups --format custom --retention-days 30
```

### `pgdock logs`

Show logs for a PostgreSQL instance.

```bash
pgdock logs INSTANCE_NAME [OPTIONS]
```

**Options:**
- `--follow, -f`: Follow log output
- `--lines, -n INTEGER`: Number of lines to show

## Configuration

### Environment Variables

- `PGDOCK_HOME`: Override default home directory (`~/.pgdock`)

### Instance Storage

pgdock stores instance configurations in `~/.pgdock/instances/`. Each instance has:

- `compose.yml`: Docker Compose configuration
- `metadata.json`: Instance metadata and credentials

### PostgreSQL Credentials

- **Automatic ~/.pgpass Updates**: pgdock automatically updates your `~/.pgpass` file
- **Secure Generation**: Passwords are 20 characters with URL-safe characters
- **Username Pattern**: `u_<8_random_chars>`

## Backup and Retention

pgdock includes built-in backup functionality:

```bash
# Create SQL backup
pgdock backup mydb /path/to/backups

# Create custom format backup with retention
pgdock backup mydb /path/to/backups --format custom --retention-days 7

# JSON output for scripting
pgdock backup mydb /path/to/backups --json
```

**Backup Filename Format**: `{instance_name}_{YYYYMMDD_HHMMSS}.{ext}`

**Retention Policy**: Automatically deletes backups older than specified days, only affecting files matching the instance name pattern.

## Troubleshooting

### Command Not Found (WSL/Linux)

If `pgdock` command is not found after installation:

```bash
# Check if ~/.local/bin is in your PATH
echo $PATH | grep -q "$HOME/.local/bin" && echo "✓ In PATH" || echo "✗ Not in PATH"

# Add to PATH temporarily
export PATH="$HOME/.local/bin:$PATH"

# Make it permanent
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.bashrc  # bash
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.zshrc   # zsh

# Reload shell
source ~/.bashrc  # or source ~/.zshrc
```

### Docker Permission Issues (Linux)

If you get "Docker daemon not running or not accessible" error on Linux:

```bash
# Add your user to the docker group
sudo usermod -aG docker $USER

# Apply the group change (requires re-login or newgrp)
newgrp docker

# Verify Docker access
docker info

# Now pgdock should work
pgdock create --name test
```

**Note**: You may need to log out and back in for group changes to take effect.

### Docker Compose Version Issues

pgdock requires Docker Compose v2. If you get compose-related errors:

```bash
# Check your Docker Compose version
docker compose version

# If you only have legacy docker-compose, upgrade Docker Desktop or install Compose v2:
# For Ubuntu/Debian:
sudo apt-get update
sudo apt-get install docker-compose-plugin

# For other systems, follow: https://docs.docker.com/compose/install/
```

pgdock supports both `docker compose` (v2, recommended) and `docker-compose` (legacy, with warning).

### WSL Networking

If you need to access pgdock instances from outside WSL:

```powershell
# In Windows PowerShell (as Administrator)
# Replace 172.27.16.146 with your WSL IP (get it with: wsl hostname -I)
netsh interface portproxy add v4tov4 listenport=5400 listenaddress=0.0.0.0 connectport=5400 connectaddress=172.27.16.146

# List current port forwards
netsh interface portproxy show v4tov4

# Remove port forward when no longer needed
netsh interface portproxy delete v4tov4 listenport=5400 listenaddress=0.0.0.0
```

### Port Conflicts

pgdock automatically finds free ports starting from 5400. To use a specific port:

```bash
pgdock create --port 5433
```

### Health Check Timeouts

If instances fail to start:

1. Check Docker container logs: `pgdock logs instance_name`
2. Verify port availability
3. Check Docker daemon status
4. Increase timeout: `pgdock create --timeout 120`

### Docker Compose Version

pgdock supports both:
- `docker compose` (v2, recommended)
- `docker-compose` (legacy, with warning)

## Migration from Manual Docker Setup

If you're migrating from a manual Docker Compose setup to pgdock:

1. **Stop existing containers**:
   ```bash
   docker compose down
   ```

2. **Install pgdock**:
   ```bash
   pip install pgdock
   ```

3. **Create new managed instance**:
   ```bash
   pgdock create --name mydb --port 5432
   ```

4. **Migrate data** (if needed):
   ```bash
   # Export from old container
   docker exec old_container pg_dump -U user dbname > backup.sql
   
   # Import to new instance  
   psql "$(pgdock creds mydb --json | jq -r .connectionString)" < backup.sql
   ```

## Testing Your Instance

After creating a pgdock instance, verify it's working correctly:

### Quick Connection Test

```bash
# Get connection details
pgdock creds mydb

# Test connection with psql (remove ?schema=public if you get URI errors)
psql "postgresql://user:password@localhost:port/database" -c "SELECT version();"

# Or use the JSON output to get connection string
CONNECTION_STRING=$(pgdock creds mydb --json | jq -r .connectionString | sed 's/?schema=public//')
psql "$CONNECTION_STRING" -c "SELECT version();"
```

### Comprehensive Instance Test

```bash
# 1. Check instance status
pgdock status mydb

# 2. Test database connection
pgdock creds mydb --json | jq -r .connectionString | sed 's/?schema=public//' | xargs -I {} psql {} -c "SELECT current_database(), current_user, version();"

# 3. Create a test table and insert data
CONNECTION_STRING=$(pgdock creds mydb --json | jq -r .connectionString | sed 's/?schema=public//')
psql "$CONNECTION_STRING" << EOF
CREATE TABLE test_table (id SERIAL PRIMARY KEY, name TEXT, created_at TIMESTAMP DEFAULT NOW());
INSERT INTO test_table (name) VALUES ('pgdock test'), ('connection verified');
SELECT * FROM test_table;
DROP TABLE test_table;
EOF

# 4. Test backup functionality
mkdir -p ./test-backups
pgdock backup mydb ./test-backups --format sql
ls -la ./test-backups/

# 5. Check container logs
pgdock logs mydb --lines 20
```

### External Access Testing

If you need external access (VPS, cloud instance):

```bash
# Test from another machine (replace with your server IP)
psql "postgresql://user:password@YOUR_SERVER_IP:5400/database" -c "SELECT version();"

# Example with actual values:
psql "postgresql://u_56ocdyl4:TbCnRR9UiI0SBROW7O1C@23.88.102.236:5400/pg_smart_wolf" -c "SELECT version();"
```

**Expected Output:**
```
                                   version                                    
-----------------------------------------------------------------------------
PostgreSQL 17.5 (Debian 17.5-1.pgdg120+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 12.2.0-14) 12.2.0, 64-bit
(1 row)
```

### Testing Network Connectivity

```bash
# Test port connectivity
telnet localhost 5400  # or your server IP

# Check if port is open
nmap -p 5400 localhost  # or your server IP

# For Docker containers, check port mapping
docker port pgdock-mydb
```

## Examples

### Development Workflow

```bash
# Create a development database
pgdock create --name devdb --version 15

# Get connection details for your app
pgdock creds devdb --json

# Check if it's running
pgdock status devdb

# Create a backup before making changes
pgdock backup devdb ./backups

# View recent logs
pgdock logs devdb --lines 50

# Stop when done
pgdock stop devdb
```

### Production-like Setup

```bash
# Create production-like instance
pgdock create --name proddb --version 16 --port 5432

# Create daily backups with retention
pgdock backup proddb /var/backups/postgres --retention-days 30

# Monitor health
pgdock status proddb
```

### Multiple Instances

```bash
# Create multiple versions for testing
pgdock create --name test-pg14 --version 14
pgdock create --name test-pg15 --version 15
pgdock create --name test-pg16 --version 16

# List all instances
pgdock list

# Connect to specific version
psql "$(pgdock creds test-pg15 --json | jq -r .connectionString)"
```

## Contributing

1. Fork the repository
2. Create a feature branch
3. Make your changes
4. Add tests if applicable
5. Submit a pull request

## License

[License Type] - see LICENSE file for details.
