瀏覽代碼

refactor password assignment logic

Divyansh Singh 2 年之前
父節點
當前提交
b7423c488e
共有 2 個文件被更改,包括 5 次插入2 次删除
  1. 1 1
      borgmatic/actions/restore.py
  2. 4 1
      borgmatic/hooks/postgresql.py

+ 1 - 1
borgmatic/actions/restore.py

@@ -72,7 +72,7 @@ def restore_single_database(
 ):  # pragma: no cover
 ):  # pragma: no cover
     '''
     '''
     Given (among other things) an archive name, a database hook name, the hostname,
     Given (among other things) an archive name, a database hook name, the hostname,
-    port, username and password as connection params,  and a configured database
+    port, username and password as connection params, and a configured database
     configuration dict, restore that database from the archive.
     configuration dict, restore that database from the archive.
     '''
     '''
     logger.info(
     logger.info(

+ 4 - 1
borgmatic/hooks/postgresql.py

@@ -30,7 +30,10 @@ def make_extra_environment(database, restore_connection_params=None):
     extra = dict()
     extra = dict()
 
 
     try:
     try:
-        extra['PGPASSWORD'] = restore_connection_params.get('password') or database['restore_password'] or database['password']
+        if restore_connection_params:
+            extra['PGPASSWORD'] = restore_connection_params.get('password') or database.get('restore_password', database['password'])
+        else:
+            extra['PGPASSWORD'] = database['password']
     except (AttributeError, KeyError):
     except (AttributeError, KeyError):
         pass
         pass