Simplify argument parsing (#459)
With the current state of automation scripts, this is not possible anymore to launch script with multiple auto configs.
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
import logging
|
||||
import urllib.parse
|
||||
|
||||
from common import dates, http, releasedata
|
||||
from common import dates, http
|
||||
from common.releasedata import ProductData, config_from_argv
|
||||
|
||||
"""Fetches EOL dates from the Red Hat Product Life Cycle Data API.
|
||||
|
||||
@@ -17,26 +18,26 @@ class Mapping:
|
||||
def get_field_for(self, phase_name: str) -> str | None:
|
||||
return self.fields_by_phase.get(phase_name.lower(), None)
|
||||
|
||||
for config in releasedata.list_configs_from_argv():
|
||||
with releasedata.ProductData(config.product) as product_data:
|
||||
name = urllib.parse.quote(config.url)
|
||||
mapping = Mapping(config.data["fields"])
|
||||
config = config_from_argv()
|
||||
with ProductData(config.product) as product_data:
|
||||
name = urllib.parse.quote(config.url)
|
||||
mapping = Mapping(config.data["fields"])
|
||||
|
||||
data = http.fetch_json('https://access.redhat.com/product-life-cycles/api/v1/products?name=' + name)
|
||||
data = http.fetch_json('https://access.redhat.com/product-life-cycles/api/v1/products?name=' + name)
|
||||
|
||||
for version in data["data"][0]["versions"]:
|
||||
version_name = version["name"]
|
||||
version_match = config.first_match(version_name)
|
||||
if not version_match:
|
||||
logging.warning(f"Ignoring version '{version_name}', config is {config}")
|
||||
for version in data["data"][0]["versions"]:
|
||||
version_name = version["name"]
|
||||
version_match = config.first_match(version_name)
|
||||
if not version_match:
|
||||
logging.warning(f"Ignoring version '{version_name}', config is {config}")
|
||||
continue
|
||||
|
||||
release = product_data.get_release(config.render(version_match))
|
||||
for phase in version["phases"]:
|
||||
field = mapping.get_field_for(phase["name"])
|
||||
if not field:
|
||||
logging.debug(f"Ignoring phase '{phase['name']}': not mapped")
|
||||
continue
|
||||
|
||||
release = product_data.get_release(config.render(version_match))
|
||||
for phase in version["phases"]:
|
||||
field = mapping.get_field_for(phase["name"])
|
||||
if not field:
|
||||
logging.debug(f"Ignoring phase '{phase['name']}': not mapped")
|
||||
continue
|
||||
|
||||
date = dates.parse_datetime(phase["date"])
|
||||
release.set_field(field, date)
|
||||
date = dates.parse_datetime(phase["date"])
|
||||
release.set_field(field, date)
|
||||
|
||||
Reference in New Issue
Block a user