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

Re-add database user and password as settings, and rename from MYSQL_* to SQL_* #258

Merged
merged 21 commits into from
Apr 28, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
3417068
Re-add database user and password as settings, and rename from MYSQL_…
nickeopti Mar 9, 2022
8aa2281
Implement config settings deprecation system
nickeopti Mar 29, 2022
12d5043
Include the accidentally excluded MYSQL_PASSWORD in the deprecation map
nickeopti Mar 29, 2022
c24ff48
Merge main branch into fix-db-connection-settings
nickeopti Mar 29, 2022
c6f6b3b
Merge main branch into fix-db-connection-settings
nickeopti Mar 29, 2022
5b91dd0
Include postgres user/password settings as deprecated
nickeopti Mar 29, 2022
80006c6
Please flake8
nickeopti Mar 29, 2022
49ede5f
Add DeprecationWarning exception
nickeopti Apr 5, 2022
b9f3974
Handle deprecated settings in schema preload, and provide better warn…
nickeopti Apr 5, 2022
24d08a0
Adhere flake8 style guide
nickeopti Apr 5, 2022
285e4b1
Test usage of TC_SQL_* env var credentials
nickeopti Apr 5, 2022
3931a35
Test behaviour of handling of deprecated config settings
nickeopti Apr 5, 2022
2b2555f
Adhere to flake8 style guide
nickeopti Apr 5, 2022
e486b8b
Fix docstring
nickeopti Apr 5, 2022
de85eec
Add comment about when settings shall be removed
nickeopti Apr 27, 2022
05f1917
Improve deprecated setting warning message
nickeopti Apr 27, 2022
8acb448
Adhere to flake8 max line length
nickeopti Apr 27, 2022
3c562ca
Simply warnings for usage of deprecated fields
nickeopti Apr 27, 2022
3976649
Fetch settings once when creating URL instance
nickeopti Apr 27, 2022
4bee849
Update test for setting deprecated settings; for the simpler warnings
nickeopti Apr 27, 2022
a82d805
Update test to correspond to the new warning messages
nickeopti Apr 27, 2022
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: 6 additions & 6 deletions terracotta/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,11 +67,11 @@ class TerracottaSettings(NamedTuple):
#: CORS allowed origins for tiles endpoints
ALLOWED_ORIGINS_TILES: List[str] = [r'http[s]?://(localhost|127\.0\.0\.1):*']

#: MySQL database username (if not given in driver path)
MYSQL_USER: Optional[str] = None
#: SQL database username (if not given in driver path)
SQL_USER: Optional[str] = None

#: MySQL database password (if not given in driver path)
MYSQL_PASSWORD: Optional[str] = None
#: SQL database password (if not given in driver path)
SQL_PASSWORD: Optional[str] = None

#: Use a process pool for band retrieval in parallel
USE_MULTIPROCESSING: bool = True
Expand Down Expand Up @@ -123,8 +123,8 @@ class SettingSchema(Schema):
ALLOWED_ORIGINS_METADATA = fields.List(fields.String())
ALLOWED_ORIGINS_TILES = fields.List(fields.String())

MYSQL_USER = fields.String()
MYSQL_PASSWORD = fields.String()
SQL_USER = fields.String()
SQL_PASSWORD = fields.String()

USE_MULTIPROCESSING = fields.Boolean()

Expand Down
4 changes: 2 additions & 2 deletions terracotta/drivers/relational_meta_store.py
Original file line number Diff line number Diff line change
Expand Up @@ -115,8 +115,8 @@ def _parse_path(cls, connection_string: str) -> URL:

url = URL.create(
drivername=f'{cls.SQL_DIALECT}+{cls.SQL_DRIVER}',
username=con_params.username,
password=con_params.password,
username=con_params.username or terracotta.get_settings().SQL_USER,
password=con_params.password or terracotta.get_settings().SQL_PASSWORD,
nickeopti marked this conversation as resolved.
Show resolved Hide resolved
host=con_params.hostname,
port=con_params.port,
database=con_params.path[1:], # remove leading '/' from urlparse
Expand Down