-
Notifications
You must be signed in to change notification settings - Fork 66
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
safely convert ini parameters to bool, int, list and dict #104
base: master
Are you sure you want to change the base?
Changes from 10 commits
3d49b8d
1855c90
2daf286
04482bb
d69eb19
398b9d1
01f883a
16c4dd8
38ed887
8bcc9f0
62110dc
80863e8
c33729e
ee3042d
37d6880
656744f
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
image: python:latest | ||
|
||
variables: | ||
PIP_CACHE_DIR: "$CI_PROJECT_DIR/.cache/pip" | ||
# | ||
PUBLIC_REGISTRY_PROJECT_ID: 32304092 | ||
|
||
cache: | ||
paths: | ||
- .cache/pip | ||
- venv/ | ||
|
||
stages: | ||
- check | ||
- deploy | ||
|
||
before_script: | ||
- python -V # Print out python version for debugging | ||
|
||
ruff: | ||
stage: check | ||
script: | ||
- pip install ruff | ||
- ruff check --output-format=gitlab --output-file gl-code-quality-report.json pyramid_celery | ||
artifacts: | ||
reports: | ||
codequality: gl-code-quality-report.json | ||
|
||
# test: | ||
# script: | ||
# - pip install . | ||
# - flake8 --exit-zero --format gl-codeclimate --output-file examples-report.json --tee examples/ | ||
# - python -m json.tool < examples-report.json | ||
|
||
deploy_local: | ||
stage: deploy | ||
script: | ||
- env | ||
- pip install twine build | ||
- python -m build -w | ||
- TWINE_PASSWORD=${CI_JOB_TOKEN} TWINE_USERNAME=gitlab-ci-token python -m twine upload --repository-url ${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/pypi dist/* | ||
|
||
deploy_public: | ||
stage: deploy | ||
script: | ||
- env | ||
- pip install twine build | ||
- python -m build -w | ||
- TWINE_PASSWORD=${CI_JOB_TOKEN} TWINE_USERNAME=gitlab-ci-token python -m twine upload --repository-url ${CI_API_V4_URL}/projects/${PUBLIC_REGISTRY_PROJECT_ID}/packages/pypi dist/* |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,7 @@ | ||
import datetime | ||
import json | ||
import pyjson5 as json5 | ||
from pyjson5 import Json5DecoderException as JSONDecodeError | ||
import celery.loaders.base | ||
import celery.schedules | ||
import configparser | ||
|
@@ -91,6 +93,25 @@ def get_route_config(parser, section): | |
return config | ||
|
||
|
||
def safe_conversion(value): | ||
"""convert a string to a more specific type""" | ||
try: | ||
newval= json5.loads(value) | ||
#print("JSON DECODED", type(newval), newval) | ||
return newval | ||
except JSONDecodeError: | ||
pass | ||
|
||
if value.lower() in ("true", "false"): | ||
return bool(value) | ||
Comment on lines
+97
to
+98
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. For this, I suggest using There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I did consider this, however, this is trying to replicate what you might use in celeryconfig.py, but with values you would find in the ini file. For example in celeryconfig.py you might write Pyramid asbool will also convert integer and other values to a boolean which may or may not work similarly to setting them celeryconfig.py There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good point about the integer. Better to stay safe with the explicit bool-like strings. 👍 |
||
try: | ||
if float(value).is_integer(): | ||
return int(value) | ||
return float(value) | ||
except ValueError: | ||
return value | ||
|
||
|
||
class INILoader(celery.loaders.base.BaseLoader): | ||
ConfigParser = configparser.SafeConfigParser | ||
|
||
|
@@ -106,7 +127,7 @@ def read_configuration(self, fail_silently=True): | |
config_dict = {} | ||
|
||
for key, value in self.parser.items('celery'): | ||
config_dict[key] = value | ||
config_dict[key] = safe_conversion(value) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Might need to consider applying this to other structures below? |
||
|
||
if celery_version.major > 6: | ||
# TODO: Check for invalid settings | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should probably try using
json.load
as fallback ifpyjson5
is not installed.The imports should also handle missing
pyjson5
from installed packages.I don't think it is necessary for
pyramid_celery
to inject this new dependency.