Skip to main content

PostgreSQL backup & restore CLI

Project description

koggi

  • PostgreSQL backup & restore CLI (early foundation).

Quick start

postgresql backup & restore CLI

1. INSTALL

pip install koggi

2. save settings in project root

# project-root/.env
KOGGI_DEFAULT_DB_NAME=db_name
KOGGI_DEFAULT_DB_USER=postgres
KOGGI_DEFAULT_DB_PASSWORD=password
KOGGI_DEFAULT_DB_HOST=localhost
KOGGI_DEFAULT_DB_PORT=5432
KOGGI_DEFAULT_SSL_MODE=prefer
KOGGI_DEFAULT_BACKUP_DIR=./backups
KOGGI_DEFAULT_ALLOW_RESTORE=true

3. download binary files

koggi binaries download

4. backup

koggi pg backup

5. restore

koggi pg restore

rclone cloud backup & restore CLI

1. INSTALL

rclone is required for cloud backup features.

2. initialize settings

koggi rc init

Creates .koggi/rclone/setting.json interactively. You can specify remote name, project name, and files/glob patterns to backup.

3. backup

koggi rc backup

Uploads configured files to <remote>:<project_name>/<timestamp>.

  • Use --dry-run to preview the files that will be uploaded.

4. restore

koggi rc restore

Interactively select a remote backup to restore.

  • Safety: If restoring overwrites existing local files, the conflicting files are automatically archived into .koggi/backup/restore-YYYYMMDD_HHMMSS.zip before being replaced.

5. delete

koggi rc delete

Interactive menu to manage remote backups:

  • Delete a specific backup
  • Delete ALL backups
  • Keep recent N backups and delete the rest

DB configuration examples (PostgreSQL)

  • Prepare a .env with at least one profile (DEFAULT example):
KOGGI_DEFAULT_DB_NAME=example
KOGGI_DEFAULT_DB_USER=postgres
KOGGI_DEFAULT_DB_PASSWORD=secret
KOGGI_DEFAULT_DB_HOST=localhost
KOGGI_DEFAULT_DB_PORT=5432
KOGGI_DEFAULT_SSL_MODE=prefer
KOGGI_DEFAULT_BACKUP_DIR=./backups
  • .env (dev1 example):
KOGGI_DEV1_DB_NAME=example
KOGGI_DEV1_DB_USER=postgres
KOGGI_DEV1_DB_PASSWORD=secret
KOGGI_DEV1_DB_HOST=localhost
KOGGI_DEV1_DB_PORT=5432
KOGGI_DEV1_SSL_MODE=prefer
KOGGI_DEV1_BACKUP_DIR=./backups
KOGGI_DEFAULT_ALLOW_RESTORE=false
  • List profiles: koggi config list
  • Test connection: koggi config test DEFAULT
  • Create backup: koggi pg backup -p DEFAULT
  • Restore latest: koggi pg restore -p DEFAULT
  • Check binaries: koggi binaries which

Notes

  • Embedded binaries: Koggi can use packaged PostgreSQL tools.
    • Place binaries under src/koggi/_bin/<os>-<arch>/:
      • Example tags: windows-x86_64, darwin-arm64, linux-x86_64.
      • Required files: pg_dump[.exe], psql[.exe], pg_restore[.exe].
    • Or put them in cache: %LOCALAPPDATA%/koggi/bin/<tag>/ (Windows) or ~/.cache/koggi/bin/<tag>/ (Unix).
    • You can override via env: KOGGI_PG_DUMP, KOGGI_PSQL, KOGGI_PG_RESTORE.
  • If no embedded binary is found, Koggi falls back to system PATH.
  • This is Phase 1 scaffold based on plan.md; more features will follow.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

koggi-0.1.5.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

koggi-0.1.5-py3-none-any.whl (35.4 kB view details)

Uploaded Python 3

File details

Details for the file koggi-0.1.5.tar.gz.

File metadata

  • Download URL: koggi-0.1.5.tar.gz
  • Upload date:
  • Size: 24.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for koggi-0.1.5.tar.gz
Algorithm Hash digest
SHA256 4c594050567d04571f951c61d914c88e8391534bccda6a17f44593fefd0a9e47
MD5 3e6b212e9b98e36851e4b7c3b77a2859
BLAKE2b-256 2e750163bd5c550a09ed81d6fc826cb069beea4abc4b7c4f8f931a3980b6d0dc

See more details on using hashes here.

File details

Details for the file koggi-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: koggi-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 35.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for koggi-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 e9e469cbdd3b1be81875c515ea41bd4ad83123894ccea1cf87fe1e5e675ab124
MD5 293810ddf451bef777ca2bcbdffd8550
BLAKE2b-256 0d130b534c2c4ff157aee7222b8ca26bf654c679a970b686f7e06cd200bcd7fc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page