Skip to content

Commit

Permalink
fix: handle password param in postgres connection (#333)
Browse files Browse the repository at this point in the history
  • Loading branch information
nickzoic authored and jsstevenson committed Apr 24, 2024
1 parent 5cf81ed commit 8aada4d
Showing 1 changed file with 12 additions and 24 deletions.
36 changes: 12 additions & 24 deletions src/gene/database/postgresql.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,22 +57,22 @@ def __init__(self, db_url: Optional[str] = None, **db_args) -> None:
:raise DatabaseInitializationError: if initial setup fails
"""
if db_url:
conninfo = db_url
self.conninfo = db_url
elif "GENE_NORM_DB_URL" in os.environ:
conninfo = os.environ["GENE_NORM_DB_URL"]
self.conninfo = os.environ["GENE_NORM_DB_URL"]
else:
user = db_args.get("user", "postgres")
password = db_args.get("password", "")
db_name = db_args.get("db_name", "gene_normalizer")
if password:
conninfo = f"dbname={db_name} user={user} password={password}"
self.conninfo = f"postgresql://{user}:{password}@/{db_name}"
else:
conninfo = f"dbname={db_name} user={user}"
self.conninfo = f"postgresql://{user}@/{db_name}"

if db_args.get("silent") != True: # noqa: E712
click.echo(f"***Using Gene-Normalizer PostgreSQL connection: {conninfo}***")
click.echo(f"***Using Gene-Normalizer PostgreSQL connection: {self.conninfo}***")

self.conn = psycopg.connect(conninfo)
self.conn = psycopg.connect(self.conninfo)
self.initialize_db()
self._cached_sources = {}

Expand Down Expand Up @@ -792,16 +792,13 @@ def load_from_remote(self, url: Optional[str]) -> None:
tar.extractall(path=tempdir_path, members=[tar_dump_file])
dump_file = tempdir_path / tar_dump_file.name

if self.conn.info.password:
pw_param = f"-W {self.conn.info.password}"
else:
pw_param = "-w"

self.drop_db()
system_call = f"psql -d {self.conn.info.dbname} -U {self.conn.info.user} {pw_param} -f {dump_file.absolute()}" # noqa: E501
system_call = f"psql {self.conninfo} -f {dump_file.absolute()}"
result = os.system(system_call)
if result != 0:
raise DatabaseError(f"System call '{result}' returned failing exit code.")
raise DatabaseError(
f"System call '{system_call}' returned failing exit code {result}."
)

def export_db(self, output_directory: Path) -> None:
"""Dump DB to specified location.
Expand All @@ -818,18 +815,9 @@ def export_db(self, output_directory: Path) -> None:
) # noqa: E501
now = datetime.now().strftime("%Y%m%d%H%M%S")
output_location = output_directory / f"gene_norm_{now}.sql"
user = self.conn.info.user
host = self.conn.info.host
port = self.conn.info.port
database_name = self.conn.info.dbname
if self.conn.info.password:
pw_param = f"-W {self.conn.info.password}"
else:
pw_param = "-w"

system_call = f"pg_dump -E UTF8 -f {output_location} -U {user} {pw_param} -h {host} -p {port} {database_name}" # noqa: E501
system_call = f"pg_dump {self.conninfo} -E UTF8 -f {output_location}"
result = os.system(system_call)
if result != 0:
raise DatabaseError(
f"System call '{system_call}' returned failing exit code."
f"System call '{system_call}' returned failing exit code {result}."
)

0 comments on commit 8aada4d

Please sign in to comment.