Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions docs/docu.md
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,18 @@ Labels are used to control each containers backup.
`db-backup-runner.dump_args = <additional args>`
: Additional arguments for the `dump` command.

`db-backup-runner.user = <user>`
: Database user for, default from `env` variables.

`db-backup-runner.database = <database>`
: Database name for, default from `env` variables.

`db-backup-runner.restore_binary = <custom binary name or path>`
: If the default command doesn't work.

`db-backup-runner.restore_args = <additional args>`
: Additional arguments for the `restore` command.

`db-backup-runner.min_file_size = <number>`
: A sanity check is done for the file size, this can be changed per container (default: 200)

Expand Down
27 changes: 17 additions & 10 deletions src/db_backup_runner/provider/_postgres.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
import click


from db_backup_runner.provider import BackupProviderBase


Expand All @@ -10,26 +7,36 @@ class PostgresBackupProvider(BackupProviderBase):
name = "postgres"
default_dump_binary = "pg_dump"
# default_dump_binary = "pg_dumpall"
default_dump_args = "-Fc -U USER"
default_dump_args = "-Fc -U USER DATABASE"
default_restore_binary = "pg_restore"
default_restore_args = "-Fc -U USER -d DATABASE"
plain_file_extension = ".dump"

def dump(self) -> str:
"""Overwrite dump method with custom postgres dump"""
env = self.get_container_env()
user = env.get("POSTGRES_USER") or "postgres"
user = self.get_container_label("user", env.get("POSTGRES_USER") or "postgres")
assert user is not None
database_env = (
env.get("POSTGRES_DATABASE", env.get("POSTGRES_DB")) or "postgres"
)
database = self.get_container_label("database", database_env)
assert database is not None

return f"{self.get_dump_binary()} {self.get_dump_args()}".replace("USER", user)
return f"{self.get_dump_binary()} {self.get_dump_args()}".replace(
"USER", user
).replace("DATABASE", database)

def get_restore_args(self) -> str:
"""Overwrite restore args with custom postgres arguments"""
env = self.get_container_env()
user = env.get("POSTGRES_USER") or "postgres"
# TODO get database from label or argument
database = env.get("POSTGRES_DATABASE") or click.style(
"DATABASE", fg="green", bold=True
user = self.get_container_label("user", env.get("POSTGRES_USER") or "postgres")
assert user is not None
database_env = (
env.get("POSTGRES_DATABASE", env.get("POSTGRES_DB")) or "postgres"
)
database = self.get_container_label("database", database_env)
assert database is not None
return (
(self.get_container_label("restore_args", self.default_restore_args) or "")
.replace("USER", user)
Expand Down
Loading