Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: 🐛 use PGPASSWORD environment variable if available #35

Closed
wants to merge 3 commits into from
Closed
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
30 changes: 24 additions & 6 deletions cjdb/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@
from cjdb.modules.utils import get_db_engine, get_db_psycopg_conn
from cjdb.resources import strings as s

def get_password(ctx, param, value):
if value is None and 'PGPASSWORD' in os.environ:
return os.environ['PGPASSWORD']
else:
return click.prompt("Password for database user", hide_input=True)


@click.group()
@click.version_option(
Expand All @@ -33,8 +39,9 @@ def cjdb(ctx):
@click.option("--user", "-U", type=str, required=True, help=s.user_help)
@click.password_option(
help=s.password_help,
prompt="Password for database user",
confirmation_prompt=False
prompt=False,
confirmation_prompt=False,
callback=get_password
)
@click.option("--database", "-d",
type=str,
Expand Down Expand Up @@ -83,6 +90,14 @@ def cjdb(ctx):
default=False,
help=s.transform_help,
)
@click.option(
"--skip-post-import",
"-S",
"skip_post_import",
is_flag=True,
default=False,
help="Skip post import functions",
)
def import_cj(
filepath,
host,
Expand All @@ -96,7 +111,8 @@ def import_cj(
partial_indexed_attributes,
ignore_repeated_file,
overwrite,
transform
transform,
skip_post_import # add this parameter
):
"""Import CityJSONL files to a PostgreSQL database.
Example of cli command:
Expand All @@ -115,7 +131,8 @@ def import_cj(
partial_indexed_attributes,
ignore_repeated_file,
overwrite,
transform
transform,
skip_post_import
) as imp:
imp.run_import()

Expand All @@ -127,8 +144,9 @@ def import_cj(
@click.option("--user", "-U", type=str, default="postgres", help=s.user_help)
@click.password_option(
help=s.password_help,
prompt="Password for database user",
confirmation_prompt=False
prompt=False,
confirmation_prompt=False,
callback=get_password
)
@click.option("--database", "-d",
type=str,
Expand Down
9 changes: 6 additions & 3 deletions cjdb/modules/importer.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ def __init__(self, file="stdin"):
class Importer:
def __init__(self, engine, filepath, db_schema, input_srid,
indexed_attributes, partial_indexed_attributes,
ignore_repeated_file, overwrite, transform):
ignore_repeated_file, overwrite, transform, skip_post_import):
self.engine = engine
self.filepath = filepath
self.db_schema = db_schema
Expand All @@ -55,6 +55,7 @@ def __init__(self, engine, filepath, db_schema, input_srid,
self.max_id = 0
self.processed = dict()
self.transform = transform
self.skip_post_import = skip_post_import

# get allowed types for validation
self.city_object_types = get_city_object_types()
Expand All @@ -74,9 +75,11 @@ def run_import(self) -> None:
self.prepare_database()
self.max_id = CjObjectModel.get_max_id(self.session)
self.parse_cityjson()
self.session.commit()
# post import operations like clustering, indexing...
self.post_import()
if not self.skip_post_import:
self.post_import()
else:
logger.info("Post import was skipped.")
self.session.commit()

def prepare_database(self) -> None:
Expand Down