Compare commits
	
		
			35 Commits
		
	
	
		
			359149bdda
			...
			6-integer-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 81c19b552d | ||
|  | 0d609ade9a | ||
|  | 2b453f4b5e | ||
|  | 62904f4c09 | ||
|  | 35d5232d8e | ||
|  | 1c3b0ae0b5 | ||
|  | d2e8f77725 | ||
|  | 92e99e03ef | ||
|  | 903a512f99 | ||
|  | f385ee3a5a | ||
|  | 573f91e2f9 | ||
|  | 025a6475dd | ||
|  | 216775e68f | ||
|  | 403efb937b | ||
|  | 559a463140 | ||
|  | 2f73be9010 | ||
|  | b6184be32f | ||
|  | 70fa0619d4 | ||
|  | f83bb077c1 | ||
|  | 8a97e92458 | ||
|  | 68c879583a | ||
|  | 5eeb0c5eae | ||
|  | 3fa66f0289 | ||
|  | 79ec497614 | ||
|  | 767392a3bb | ||
|  | cb1b4ecc08 | ||
|  | 7ef44355ab | ||
|  | 12762f5027 | ||
|  | 28eb982e5e | ||
|  | 6a03aba4e9 | ||
|  | d7a2705fc2 | ||
|  | 1d174a1aef | ||
|  | 1491213ac3 | ||
|  | affec0c1bd | ||
|  | 1a820b7dd1 | 
							
								
								
									
										62
									
								
								.github/workflows/python-app.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								.github/workflows/python-app.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | |||||||
|  | # This workflow will install Python dependencies, run tests and lint with a single version of Python | ||||||
|  | # For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions | ||||||
|  |  | ||||||
|  | name: Python application | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: [ main ] | ||||||
|  |   pull_request: | ||||||
|  |     branches: [ main ] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |  | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v2 | ||||||
|  |     - name: Set up Python 3.9 | ||||||
|  |       uses: actions/setup-python@v2 | ||||||
|  |       with: | ||||||
|  |         python-version: 3.9 | ||||||
|  |     - name: Cache | ||||||
|  |       uses: actions/cache@v2.1.6 | ||||||
|  |       with: | ||||||
|  |         # A list of files, directories, and wildcard patterns to cache and restore | ||||||
|  |         path: .venv | ||||||
|  |         # An explicit key for restoring and saving the cache | ||||||
|  |         key: venv-cache-${{hashFiles('**/poetry.lock')}} | ||||||
|  |         restore-keys: | | ||||||
|  |           venv-cache-${{hashFiles('**/poetry.lock')}} | ||||||
|  |           venv-cache- | ||||||
|  |     - name: Python Poetry Action | ||||||
|  |       # You may pin to the exact commit or the version. | ||||||
|  |       # uses: abatilo/actions-poetry@8284d202bc272a8d0597e26e1c0b4a0d0c73db93 | ||||||
|  |       uses: abatilo/actions-poetry@v2.1.0 | ||||||
|  |       with: | ||||||
|  |         # The version of poetry to install | ||||||
|  |         poetry-version: 1.1.7 | ||||||
|  |     - name: Install dependencies | ||||||
|  |       run: | | ||||||
|  |         poetry config virtualenvs.in-project true | ||||||
|  |         poetry install | ||||||
|  |     - name: Lint with flake8 | ||||||
|  |       run: | | ||||||
|  |         # stop the build if there are Python syntax errors or undefined names | ||||||
|  |         poetry run flake8 . --count --exclude .git,.venv --select=E9,F63,F7,F82 --show-source --statistics | ||||||
|  |         # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide | ||||||
|  |         poetry run flake8 . --count --exclude .git,.venv  --exit-zero --max-complexity=10 --max-line-length=127 --statistics | ||||||
|  |     - name: Test with pytest | ||||||
|  |       run: | | ||||||
|  |         poetry run pytest | ||||||
|  |  | ||||||
|  |   validate: | ||||||
|  |     runs-on: "ubuntu-latest" | ||||||
|  |     steps: | ||||||
|  |       - uses: "actions/checkout@v2" | ||||||
|  |       - name: HACS validation | ||||||
|  |         uses: "hacs/action@main" | ||||||
|  |         with: | ||||||
|  |           category: "integration" | ||||||
|  |           ignore: brands wheels | ||||||
							
								
								
									
										48
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,5 +1,49 @@ | |||||||
| # Home Assistant Augsburg COVID-19 Tracker Integration | # Home Assistant Augsburg COVID-19 Tracker Integration | ||||||
|  |  | ||||||
| ## Requirements | ## Adding to your dashboard | ||||||
|  |  | ||||||
| Your system needs to have the `de_DE.utf8` locale installed in order to parse the dates from the scraped web response. | You can add an overview of the current infection and vaccination numbers to your dashboard | ||||||
|  | using the [multiple-entity-row](https://github.com/benct/lovelace-multiple-entity-row) card: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | type: entities | ||||||
|  | entities: | ||||||
|  |   - type: custom:multiple-entity-row | ||||||
|  |     entity: sensor.coronavirus_augsburg | ||||||
|  |     entities: | ||||||
|  |       - attribute: total_cases | ||||||
|  |         name: Cases | ||||||
|  |       - attribute: num_dead | ||||||
|  |         name: Deaths | ||||||
|  |       - attribute: num_recovered | ||||||
|  |         name: Recovered | ||||||
|  |       - attribute: num_infected | ||||||
|  |         name: Infected | ||||||
|  |     show_state: false | ||||||
|  |     icon: mdi:biohazard | ||||||
|  |     name: COVID-19 | ||||||
|  |     secondary_info: | ||||||
|  |       attribute: incidence | ||||||
|  |       unit: cases/100k | ||||||
|  |   - type: custom:multiple-entity-row | ||||||
|  |     entity: sensor.covid_19_vaccinations_augsburg | ||||||
|  |     entities: | ||||||
|  |       - attribute: ratio_vaccinated_once | ||||||
|  |         name: Once | ||||||
|  |         format: precision1 | ||||||
|  |         unit: '%' | ||||||
|  |       - attribute: ratio_vaccinated_full | ||||||
|  |         name: Fully | ||||||
|  |         format: precision1 | ||||||
|  |         unit: '%' | ||||||
|  |       - attribute: ratio_vaccinated_total | ||||||
|  |         name: Total | ||||||
|  |         format: precision1 | ||||||
|  |         unit: '%' | ||||||
|  |     show_state: false | ||||||
|  |     icon: mdi:needle | ||||||
|  |     name: COVID-19 Vaccinations | ||||||
|  |     secondary_info: | ||||||
|  |       attribute: date | ||||||
|  |       format: date | ||||||
|  | ``` | ||||||
|   | |||||||
| @@ -1,16 +1,18 @@ | |||||||
| """The corona_hessen component.""" | """The covid19_augsburg component.""" | ||||||
|  |  | ||||||
|  | from __future__ import annotations | ||||||
|  |  | ||||||
| import asyncio | import asyncio | ||||||
| import logging | import logging | ||||||
| import re |  | ||||||
| from datetime import timedelta | from datetime import timedelta | ||||||
|  | from typing import TYPE_CHECKING | ||||||
|  |  | ||||||
| from homeassistant.config_entries import ConfigEntry | if TYPE_CHECKING: | ||||||
| from homeassistant.core import HomeAssistant |     from homeassistant.config_entries import ConfigEntry | ||||||
| from homeassistant.helpers.update_coordinator import DataUpdateCoordinator |     from homeassistant.core import HomeAssistant | ||||||
|  |  | ||||||
| from .const import DOMAIN | from .const import DOMAIN | ||||||
| from .crawler import CovidCrawler, IncidenceData | from .crawler import CovidCrawler | ||||||
|  |  | ||||||
| _LOGGER = logging.getLogger(__name__) | _LOGGER = logging.getLogger(__name__) | ||||||
|  |  | ||||||
| @@ -18,8 +20,6 @@ __version__ = "0.1.0" | |||||||
|  |  | ||||||
| PLATFORMS = ["sensor"] | PLATFORMS = ["sensor"] | ||||||
|  |  | ||||||
| HYPHEN_PATTERN = re.compile(r"- (.)") |  | ||||||
|  |  | ||||||
|  |  | ||||||
| async def async_setup(hass: HomeAssistant, config: dict): | async def async_setup(hass: HomeAssistant, config: dict): | ||||||
|     """Set up the Coronavirus Augsburg component.""" |     """Set up the Coronavirus Augsburg component.""" | ||||||
| @@ -60,21 +60,26 @@ async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry): | |||||||
|     return unload_ok |     return unload_ok | ||||||
|  |  | ||||||
|  |  | ||||||
| async def get_coordinator(hass): | async def get_coordinator(hass: HomeAssistant): | ||||||
|  |     from homeassistant.helpers.update_coordinator import DataUpdateCoordinator | ||||||
|  |  | ||||||
|     """Get the data update coordinator.""" |     """Get the data update coordinator.""" | ||||||
|     if DOMAIN in hass.data: |     if DOMAIN in hass.data: | ||||||
|         return hass.data[DOMAIN] |         return hass.data[DOMAIN] | ||||||
|  |  | ||||||
|     async def async_get_data() -> IncidenceData: |     async def async_get_data() -> dict: | ||||||
|         crawler = CovidCrawler(hass) |         crawler = CovidCrawler(hass) | ||||||
|         return await crawler.crawl() |         return { | ||||||
|  |             "incidence": await crawler.crawl_incidence(), | ||||||
|  |             "vaccination": await crawler.crawl_vaccination(), | ||||||
|  |         } | ||||||
|  |  | ||||||
|     hass.data[DOMAIN] = DataUpdateCoordinator( |     hass.data[DOMAIN] = DataUpdateCoordinator( | ||||||
|         hass, |         hass, | ||||||
|         logging.getLogger(__name__), |         logging.getLogger(__name__), | ||||||
|         name=DOMAIN, |         name=DOMAIN, | ||||||
|         update_method=async_get_data, |         update_method=async_get_data, | ||||||
|         update_interval=timedelta(hours=6), |         update_interval=timedelta(hours=1), | ||||||
|     ) |     ) | ||||||
|     await hass.data[DOMAIN].async_refresh() |     await hass.data[DOMAIN].async_refresh() | ||||||
|     return hass.data[DOMAIN] |     return hass.data[DOMAIN] | ||||||
|   | |||||||
| @@ -15,6 +15,32 @@ def parse_num(s, t=int): | |||||||
|     return 0 |     return 0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def parse_date( | ||||||
|  |     day: int, month: str, year=datetime.datetime.now().year | ||||||
|  | ) -> datetime.date: | ||||||
|  |     """Parse a German medium-form date, e.g. 17. August into a datetime.date""" | ||||||
|  |     months = [ | ||||||
|  |         "Januar", | ||||||
|  |         "Februar", | ||||||
|  |         "März", | ||||||
|  |         "April", | ||||||
|  |         "Mai", | ||||||
|  |         "Juni", | ||||||
|  |         "Juli", | ||||||
|  |         "August", | ||||||
|  |         "September", | ||||||
|  |         "Oktober", | ||||||
|  |         "November", | ||||||
|  |         "Dezember", | ||||||
|  |     ] | ||||||
|  |     date = datetime.date( | ||||||
|  |         year=int(year), | ||||||
|  |         month=1 + months.index(month), | ||||||
|  |         day=parse_num(day), | ||||||
|  |     ) | ||||||
|  |     return date | ||||||
|  |  | ||||||
|  |  | ||||||
| @dataclass | @dataclass | ||||||
| class IncidenceData: | class IncidenceData: | ||||||
|     location: str |     location: str | ||||||
| @@ -26,84 +52,83 @@ class IncidenceData: | |||||||
|     num_dead: int = 0 |     num_dead: int = 0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @dataclass | ||||||
|  | class VaccinationData: | ||||||
|  |     date: str | ||||||
|  |  | ||||||
|  |     total_vaccinations: int = 0 | ||||||
|  |     num_vaccinated_once: int = 0 | ||||||
|  |     num_vaccinated_full: int = 0 | ||||||
|  |  | ||||||
|  |     ratio_vaccinated_once: float = 0.0 | ||||||
|  |     ratio_vaccinated_full: float = 0.0 | ||||||
|  |     ratio_vaccinated_total: float = 0.0 | ||||||
|  |  | ||||||
|  |  | ||||||
| class CovidCrawlerBase(ABC): | class CovidCrawlerBase(ABC): | ||||||
|     @abstractmethod |     @abstractmethod | ||||||
|     def crawl(self) -> IncidenceData: |     def crawl_incidence(self) -> IncidenceData: | ||||||
|  |         pass | ||||||
|  |  | ||||||
|  |     @abstractmethod | ||||||
|  |     def crawl_vaccination(self) -> VaccinationData: | ||||||
|         pass |         pass | ||||||
|  |  | ||||||
|  |  | ||||||
| class CovidCrawler(CovidCrawlerBase): | class CovidCrawler(CovidCrawlerBase): | ||||||
|     def __init__(self, hass=None) -> None: |     def __init__(self, hass=None) -> None: | ||||||
|         self.url = ( |  | ||||||
|             "https://www.augsburg.de/umwelt-soziales/gesundheit/coronavirus/fallzahlen" |  | ||||||
|         ) |  | ||||||
|         self.hass = hass |         self.hass = hass | ||||||
|  |  | ||||||
|     async def crawl(self) -> IncidenceData: |     async def _fetch(self, url: str) -> str: | ||||||
|  |         """Fetch a URL, using either the current Home Assistant instance or requests""" | ||||||
|  |  | ||||||
|  |         if self.hass: | ||||||
|  |             from homeassistant.helpers import aiohttp_client | ||||||
|  |  | ||||||
|  |             result = await aiohttp_client.async_get_clientsession(self.hass).get(url) | ||||||
|  |             soup = BeautifulSoup(await result.text(), "html.parser") | ||||||
|  |         else: | ||||||
|  |             import requests | ||||||
|  |  | ||||||
|  |             result = requests.get(url) | ||||||
|  |             result.raise_for_status() | ||||||
|  |             soup = BeautifulSoup(result.text, "html.parser") | ||||||
|  |         return soup | ||||||
|  |  | ||||||
|  |     async def crawl_incidence(self) -> IncidenceData: | ||||||
|         """ |         """ | ||||||
|         Fetch COVID-19 infection data from the target website. |         Fetch COVID-19 infection data from the target website. | ||||||
|         """ |         """ | ||||||
|  |  | ||||||
|         _log.info("Fetching COVID-19 data update") |         _log.info("Fetching COVID-19 data update") | ||||||
|  |  | ||||||
|         if self.hass: |         url = ( | ||||||
|             from homeassistant.helpers import aiohttp_client |             "https://www.augsburg.de/umwelt-soziales/gesundheit/coronavirus/fallzahlen" | ||||||
|  |         ) | ||||||
|  |         soup = await self._fetch(url) | ||||||
|  |  | ||||||
|             result = await aiohttp_client.async_get_clientsession(self.hass).get( |         match = soup.find(id="c1067628") | ||||||
|                 self.url |         text = match.text.strip() | ||||||
|             ) |  | ||||||
|             soup = BeautifulSoup(await result.text(), "html.parser") |  | ||||||
|         else: |  | ||||||
|             import requests |  | ||||||
|  |  | ||||||
|             result = requests.get(self.url) |  | ||||||
|             if not result.ok: |  | ||||||
|                 result.raise_for_status() |  | ||||||
|             soup = BeautifulSoup(result.text, "html.parser") |  | ||||||
|  |  | ||||||
|         match = soup.find(class_="frame--type-textpic") |  | ||||||
|         text = match.p.text |  | ||||||
|         _log.debug(f"Infection data text: {text}") |         _log.debug(f"Infection data text: {text}") | ||||||
|  |  | ||||||
|         matches = re.search(r"(\d+,\d+) Neuinfektion", text) |         matches = re.search(r"(\d+(,\d+)?)\sNeuinfektion", text) | ||||||
|         if not matches: |         if not matches: | ||||||
|             raise ValueError("Could not extract incidence from scraped web page") |             raise ValueError( | ||||||
|  |                 f"Could not extract incidence from scraped web page, {text=}" | ||||||
|  |             ) | ||||||
|  |  | ||||||
|         incidence = parse_num(matches.group(1), t=float) |         incidence = parse_num(matches.group(1), t=float) | ||||||
|         _log.debug(f"Parsed incidence: {incidence}") |         _log.debug(f"Parsed incidence: {incidence}") | ||||||
|  |  | ||||||
|         text = match.h2.text |         match = soup.find(id="c1052517") | ||||||
|         matches = re.search(r"\((\d+)\. (\w+)\)", text) |         text = match.text.strip() | ||||||
|  |         matches = re.search(r"Stand: (\d+)\. (\w+) (\d{4})", text) | ||||||
|         if not matches: |         if not matches: | ||||||
|             raise ValueError("Could not extract date from scraped web page") |             raise ValueError(f"Could not extract date from scraped web page, {text=}") | ||||||
|  |  | ||||||
|         months = [ |         date = parse_date(matches.group(1), matches.group(2), matches.group(3)) | ||||||
|             "Januar", |  | ||||||
|             "Februar", |  | ||||||
|             "März", |  | ||||||
|             "April", |  | ||||||
|             "Mai", |  | ||||||
|             "Juni", |  | ||||||
|             "Juli", |  | ||||||
|             "August", |  | ||||||
|             "September", |  | ||||||
|             "Oktober", |  | ||||||
|             "November", |  | ||||||
|             "Dezember", |  | ||||||
|         ] |  | ||||||
|         day = parse_num(matches.group(1)) |  | ||||||
|         month_name = matches.group(2) |  | ||||||
|         date = datetime.date( |  | ||||||
|             year=datetime.datetime.now().year, |  | ||||||
|             month=1 + months.index(month_name), |  | ||||||
|             day=day, |  | ||||||
|         ) |  | ||||||
|         _log.debug(f"Parsed date: {date}") |         _log.debug(f"Parsed date: {date}") | ||||||
|  |  | ||||||
|         match = match.find_next_sibling(class_="frame--type-textpic") |  | ||||||
|         text = match.text |  | ||||||
|         _log.debug(f"Infection counts text: {text}") |  | ||||||
|  |  | ||||||
|         regexes = [ |         regexes = [ | ||||||
|             r"Insgesamt: (?P<total_cases>[0-9.]+)", |             r"Insgesamt: (?P<total_cases>[0-9.]+)", | ||||||
|             r"genesen: (?P<num_recovered>[0-9.]+)", |             r"genesen: (?P<num_recovered>[0-9.]+)", | ||||||
| @@ -128,3 +153,50 @@ class CovidCrawler(CovidCrawlerBase): | |||||||
|         _log.debug(f"Result data: {result}") |         _log.debug(f"Result data: {result}") | ||||||
|  |  | ||||||
|         return result |         return result | ||||||
|  |  | ||||||
|  |     async def crawl_vaccination(self) -> VaccinationData: | ||||||
|  |         _log.info("Fetching COVID-19 vaccination data update") | ||||||
|  |         url = ( | ||||||
|  |             "https://www.augsburg.de/umwelt-soziales/gesundheit/coronavirus/impfzentrum" | ||||||
|  |         ) | ||||||
|  |         soup = await self._fetch(url) | ||||||
|  |  | ||||||
|  |         container_id = "c1088140" | ||||||
|  |         result = soup.find(id=container_id) | ||||||
|  |         text = re.sub(r"\s+", " ", result.text) | ||||||
|  |         regexes = [ | ||||||
|  |             r"(?P<total_vaccinations>\d+[.]\d+) Impfdosen", | ||||||
|  |             r"Weitere (?P<num_vaccinated_once>\d+[.]\d+) Personen haben die Erstimpfung erhalten", | ||||||
|  |             r"(?P<num_vaccinated_full>\d+[.]\d+) Personen sind bereits vollständig geimpft", | ||||||
|  |         ] | ||||||
|  |         values = {} | ||||||
|  |         for r in regexes: | ||||||
|  |             matches = re.search(r, text) | ||||||
|  |             if not matches: | ||||||
|  |                 continue | ||||||
|  |             values.update( | ||||||
|  |                 { | ||||||
|  |                     k: parse_num(v.replace(".", "")) | ||||||
|  |                     for k, v in matches.groupdict().items() | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |  | ||||||
|  |         matches = re.search(r"Stand (?P<day>\d+)\. (?P<month>\w+) (?P<year>\d+)", text) | ||||||
|  |         if not matches: | ||||||
|  |             raise ValueError(f"Could not extract date from scraped web page, {text=}") | ||||||
|  |  | ||||||
|  |         values["date"] = parse_date(**matches.groupdict()).strftime("%Y-%m-%d") | ||||||
|  |         result = VaccinationData(**values) | ||||||
|  |  | ||||||
|  |         # Total population in Augsburg as of 2020 | ||||||
|  |         # https://www.augsburg.de/fileadmin/user_upload/buergerservice_rathaus/rathaus/statisiken_und_geodaten/statistiken/Monitoring/Demografiemonitoring_der_Stadt_Augsburg_2021.pdf | ||||||
|  |         population = 299021 | ||||||
|  |  | ||||||
|  |         result.ratio_vaccinated_full = result.num_vaccinated_full / population * 100 | ||||||
|  |         result.ratio_vaccinated_once = result.num_vaccinated_once / population * 100 | ||||||
|  |         result.ratio_vaccinated_total = ( | ||||||
|  |             result.ratio_vaccinated_once + result.ratio_vaccinated_full | ||||||
|  |         ) | ||||||
|  |         _log.debug(f"Result data: {result}") | ||||||
|  |  | ||||||
|  |         return result | ||||||
|   | |||||||
| @@ -1,11 +1,16 @@ | |||||||
| from .crawler import CovidCrawler | from .crawler import CovidCrawler | ||||||
|  |  | ||||||
|  |  | ||||||
| def main(): | async def main(): | ||||||
|     crawler = CovidCrawler() |     crawler = CovidCrawler() | ||||||
|     result = crawler.crawl() |     result = await crawler.crawl_incidence() | ||||||
|  |     print(result) | ||||||
|  |  | ||||||
|  |     result = await crawler.crawl_vaccination() | ||||||
|     print(result) |     print(result) | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == "__main__": | if __name__ == "__main__": | ||||||
|     main() |     import asyncio | ||||||
|  |  | ||||||
|  |     asyncio.run(main()) | ||||||
|   | |||||||
| @@ -1,9 +1,10 @@ | |||||||
| { | { | ||||||
|     "domain": "covid19_augsburg", |     "domain": "covid19_augsburg", | ||||||
|     "name": "COVID-19 Augsburg", |     "name": "COVID-19 Augsburg", | ||||||
|     "version": "0.1.0", |     "version": "1.1.3", | ||||||
|     "config_flow": true, |     "config_flow": true, | ||||||
|     "documentation": "https://github.com/AdrianoKF/home-assistant-covid19-augsburg", |     "documentation": "https://github.com/AdrianoKF/home-assistant-covid19-augsburg", | ||||||
|  |     "issue_tracker": "https://github.com/AdrianoKF/home-assistant-covid19-augsburg/issues", | ||||||
|     "requirements": ["beautifulsoup4==4.8.2"], |     "requirements": ["beautifulsoup4==4.8.2"], | ||||||
|     "dependencies": [], |     "dependencies": [], | ||||||
|     "codeowners": ["@AdrianoKF"] |     "codeowners": ["@AdrianoKF"] | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | from dataclasses import asdict | ||||||
|  |  | ||||||
| from homeassistant.helpers.entity import Entity | from homeassistant.helpers.entity import Entity | ||||||
|  |  | ||||||
| from . import get_coordinator | from . import get_coordinator | ||||||
| @@ -7,7 +9,12 @@ async def async_setup_entry(hass, _, async_add_entities): | |||||||
|     """Defer sensor setup to the shared sensor module.""" |     """Defer sensor setup to the shared sensor module.""" | ||||||
|     coordinator = await get_coordinator(hass) |     coordinator = await get_coordinator(hass) | ||||||
|  |  | ||||||
|     async_add_entities([CoronaAugsburgSensor(coordinator)]) |     async_add_entities( | ||||||
|  |         [ | ||||||
|  |             CoronaAugsburgSensor(coordinator), | ||||||
|  |             CoronaAugsburgVaccinationSensor(coordinator), | ||||||
|  |         ] | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
| class CoronaAugsburgSensor(Entity): | class CoronaAugsburgSensor(Entity): | ||||||
| @@ -41,18 +48,59 @@ class CoronaAugsburgSensor(Entity): | |||||||
|  |  | ||||||
|     @property |     @property | ||||||
|     def state(self): |     def state(self): | ||||||
|         return self.coordinator.data.incidence |         return self.coordinator.data["incidence"].incidence | ||||||
|  |  | ||||||
|     @property |     @property | ||||||
|     def device_state_attributes(self): |     def device_state_attributes(self): | ||||||
|         return { |         data = self.coordinator.data["incidence"] | ||||||
|             "date": self.coordinator.data.date, |         return asdict(data) | ||||||
|             "incidence": self.coordinator.data.incidence, |  | ||||||
|             "total_cases": self.coordinator.data.total_cases, |     async def async_added_to_hass(self): | ||||||
|             "num_dead": self.coordinator.data.num_dead, |         """When entity is added to hass.""" | ||||||
|             "num_recovered": self.coordinator.data.num_recovered, |         self.coordinator.async_add_listener(self.async_write_ha_state) | ||||||
|             "num_infected": self.coordinator.data.num_infected, |  | ||||||
|         } |     async def async_will_remove_from_hass(self): | ||||||
|  |         """When entity will be removed from hass.""" | ||||||
|  |         self.coordinator.async_remove_listener(self.async_write_ha_state) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class CoronaAugsburgVaccinationSensor(Entity): | ||||||
|  |     """Representation of vaccination data for the city of Augsburg""" | ||||||
|  |  | ||||||
|  |     def __init__(self, coordinator): | ||||||
|  |         """Initialize sensor.""" | ||||||
|  |         self.coordinator = coordinator | ||||||
|  |         self._name = "COVID-19 Vaccinations Augsburg" | ||||||
|  |         self._state = None | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def available(self): | ||||||
|  |         return self.coordinator.last_update_success and self.coordinator.data | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def name(self): | ||||||
|  |         return self._name | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def unique_id(self): | ||||||
|  |         return self._name | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def icon(self): | ||||||
|  |         return "mdi:needle" | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def unit_of_measurement(self): | ||||||
|  |         return "" | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def state(self): | ||||||
|  |         return self.coordinator.data["vaccination"].total_vaccinations | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def device_state_attributes(self): | ||||||
|  |         data = self.coordinator.data["vaccination"] | ||||||
|  |         return asdict(data) | ||||||
|  |  | ||||||
|     async def async_added_to_hass(self): |     async def async_added_to_hass(self): | ||||||
|         """When entity is added to hass.""" |         """When entity is added to hass.""" | ||||||
|   | |||||||
							
								
								
									
										179
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										179
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							| @@ -34,6 +34,14 @@ doc = ["sphinx-rtd-theme", "sphinx-autodoc-typehints (>=1.2.0)"] | |||||||
| test = ["coverage[toml] (>=4.5)", "hypothesis (>=4.0)", "pytest (>=6.0)", "pytest-mock (>=3.6.1)", "trustme", "uvloop (<0.15)", "mock (>=4)", "uvloop (>=0.15)"] | test = ["coverage[toml] (>=4.5)", "hypothesis (>=4.0)", "pytest (>=6.0)", "pytest-mock (>=3.6.1)", "trustme", "uvloop (<0.15)", "mock (>=4)", "uvloop (>=0.15)"] | ||||||
| trio = ["trio (>=0.16)"] | trio = ["trio (>=0.16)"] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "appdirs" | ||||||
|  | version = "1.4.4" | ||||||
|  | description = "A small Python module for determining appropriate platform-specific dirs, e.g. a \"user data dir\"." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = "*" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "astral" | name = "astral" | ||||||
| version = "2.2" | version = "2.2" | ||||||
| @@ -113,6 +121,28 @@ soupsieve = {version = ">1.2", markers = "python_version >= \"3.0\""} | |||||||
| html5lib = ["html5lib"] | html5lib = ["html5lib"] | ||||||
| lxml = ["lxml"] | lxml = ["lxml"] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "black" | ||||||
|  | version = "21.6b0" | ||||||
|  | description = "The uncompromising code formatter." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=3.6.2" | ||||||
|  |  | ||||||
|  | [package.dependencies] | ||||||
|  | appdirs = "*" | ||||||
|  | click = ">=7.1.2" | ||||||
|  | mypy-extensions = ">=0.4.3" | ||||||
|  | pathspec = ">=0.8.1,<1" | ||||||
|  | regex = ">=2020.1.8" | ||||||
|  | toml = ">=0.10.1" | ||||||
|  |  | ||||||
|  | [package.extras] | ||||||
|  | colorama = ["colorama (>=0.4.3)"] | ||||||
|  | d = ["aiohttp (>=3.6.0)", "aiohttp-cors (>=0.4.0)"] | ||||||
|  | python2 = ["typed-ast (>=1.4.2)"] | ||||||
|  | uvloop = ["uvloop (>=0.15.2)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "certifi" | name = "certifi" | ||||||
| version = "2021.5.30" | version = "2021.5.30" | ||||||
| @@ -148,6 +178,17 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = "*" | python-versions = "*" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "click" | ||||||
|  | version = "8.0.1" | ||||||
|  | description = "Composable command line interface toolkit" | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=3.6" | ||||||
|  |  | ||||||
|  | [package.dependencies] | ||||||
|  | colorama = {version = "*", markers = "platform_system == \"Windows\""} | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "colorama" | name = "colorama" | ||||||
| version = "0.4.4" | version = "0.4.4" | ||||||
| @@ -267,6 +308,19 @@ category = "main" | |||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "isort" | ||||||
|  | version = "5.8.0" | ||||||
|  | description = "A Python utility / library to sort Python imports." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=3.6,<4.0" | ||||||
|  |  | ||||||
|  | [package.extras] | ||||||
|  | pipfile_deprecated_finder = ["pipreqs", "requirementslib"] | ||||||
|  | requirements_deprecated_finder = ["pipreqs", "pip-api"] | ||||||
|  | colors = ["colorama (>=0.4.3,<0.5.0)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "jinja2" | name = "jinja2" | ||||||
| version = "3.0.1" | version = "3.0.1" | ||||||
| @@ -313,6 +367,14 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.6" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "mypy-extensions" | ||||||
|  | version = "0.4.3" | ||||||
|  | description = "Experimental type system extensions for programs checked with the mypy typechecker." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = "*" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "packaging" | name = "packaging" | ||||||
| version = "20.9" | version = "20.9" | ||||||
| @@ -324,6 +386,14 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | |||||||
| [package.dependencies] | [package.dependencies] | ||||||
| pyparsing = ">=2.0.2" | pyparsing = ">=2.0.2" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "pathspec" | ||||||
|  | version = "0.8.1" | ||||||
|  | description = "Utility library for gitignore style pattern matching of file paths." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pluggy" | name = "pluggy" | ||||||
| version = "0.13.1" | version = "0.13.1" | ||||||
| @@ -440,6 +510,14 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*" | python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "regex" | ||||||
|  | version = "2021.4.4" | ||||||
|  | description = "Alternative regular expression module, to replace re." | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = "*" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "requests" | name = "requests" | ||||||
| version = "2.25.1" | version = "2.25.1" | ||||||
| @@ -516,6 +594,14 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = "*" | python-versions = "*" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "toml" | ||||||
|  | version = "0.10.2" | ||||||
|  | description = "Python Library for Tom's Obvious, Minimal Language" | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "typing-extensions" | name = "typing-extensions" | ||||||
| version = "3.10.0.0" | version = "3.10.0.0" | ||||||
| @@ -579,7 +665,7 @@ multidict = ">=4.0" | |||||||
| [metadata] | [metadata] | ||||||
| lock-version = "1.1" | lock-version = "1.1" | ||||||
| python-versions = "^3.9" | python-versions = "^3.9" | ||||||
| content-hash = "bcf730ba59ff4d0161f0696c90be110a7cf01cf01ea99f29f9a62c8ac2be1c2b" | content-hash = "75bc12a4b0c27215ca1678095226269daf82def2f5a1a5c4af38eca9edfe27f5" | ||||||
|  |  | ||||||
| [metadata.files] | [metadata.files] | ||||||
| aiohttp = [ | aiohttp = [ | ||||||
| @@ -625,6 +711,10 @@ anyio = [ | |||||||
|     {file = "anyio-3.1.0-py3-none-any.whl", hash = "sha256:5e335cef65fbd1a422bbfbb4722e8e9a9fadbd8c06d5afe9cd614d12023f6e5a"}, |     {file = "anyio-3.1.0-py3-none-any.whl", hash = "sha256:5e335cef65fbd1a422bbfbb4722e8e9a9fadbd8c06d5afe9cd614d12023f6e5a"}, | ||||||
|     {file = "anyio-3.1.0.tar.gz", hash = "sha256:43e20711a9d003d858d694c12356dc44ab82c03ccc5290313c3392fa349dad0e"}, |     {file = "anyio-3.1.0.tar.gz", hash = "sha256:43e20711a9d003d858d694c12356dc44ab82c03ccc5290313c3392fa349dad0e"}, | ||||||
| ] | ] | ||||||
|  | appdirs = [ | ||||||
|  |     {file = "appdirs-1.4.4-py2.py3-none-any.whl", hash = "sha256:a841dacd6b99318a741b166adb07e19ee71a274450e68237b4650ca1055ab128"}, | ||||||
|  |     {file = "appdirs-1.4.4.tar.gz", hash = "sha256:7d5d0167b2b1ba821647616af46a749d1c653740dd0d2415100fe26e27afdf41"}, | ||||||
|  | ] | ||||||
| astral = [ | astral = [ | ||||||
|     {file = "astral-2.2-py2.py3-none-any.whl", hash = "sha256:b9ef70faf32e81a8ba174d21e8f29dc0b53b409ef035f27e0749ddc13cb5982a"}, |     {file = "astral-2.2-py2.py3-none-any.whl", hash = "sha256:b9ef70faf32e81a8ba174d21e8f29dc0b53b409ef035f27e0749ddc13cb5982a"}, | ||||||
|     {file = "astral-2.2.tar.gz", hash = "sha256:e41d9967d5c48be421346552f0f4dedad43ff39a83574f5ff2ad32b6627b6fbe"}, |     {file = "astral-2.2.tar.gz", hash = "sha256:e41d9967d5c48be421346552f0f4dedad43ff39a83574f5ff2ad32b6627b6fbe"}, | ||||||
| @@ -671,6 +761,10 @@ beautifulsoup4 = [ | |||||||
|     {file = "beautifulsoup4-4.9.3-py3-none-any.whl", hash = "sha256:fff47e031e34ec82bf17e00da8f592fe7de69aeea38be00523c04623c04fb666"}, |     {file = "beautifulsoup4-4.9.3-py3-none-any.whl", hash = "sha256:fff47e031e34ec82bf17e00da8f592fe7de69aeea38be00523c04623c04fb666"}, | ||||||
|     {file = "beautifulsoup4-4.9.3.tar.gz", hash = "sha256:84729e322ad1d5b4d25f805bfa05b902dd96450f43842c4e99067d5e1369eb25"}, |     {file = "beautifulsoup4-4.9.3.tar.gz", hash = "sha256:84729e322ad1d5b4d25f805bfa05b902dd96450f43842c4e99067d5e1369eb25"}, | ||||||
| ] | ] | ||||||
|  | black = [ | ||||||
|  |     {file = "black-21.6b0-py3-none-any.whl", hash = "sha256:dfb8c5a069012b2ab1e972e7b908f5fb42b6bbabcba0a788b86dc05067c7d9c7"}, | ||||||
|  |     {file = "black-21.6b0.tar.gz", hash = "sha256:dc132348a88d103016726fe360cb9ede02cecf99b76e3660ce6c596be132ce04"}, | ||||||
|  | ] | ||||||
| certifi = [ | certifi = [ | ||||||
|     {file = "certifi-2021.5.30-py2.py3-none-any.whl", hash = "sha256:50b1e4f8446b06f41be7dd6338db18e0990601dce795c2b1686458aa7e8fa7d8"}, |     {file = "certifi-2021.5.30-py2.py3-none-any.whl", hash = "sha256:50b1e4f8446b06f41be7dd6338db18e0990601dce795c2b1686458aa7e8fa7d8"}, | ||||||
|     {file = "certifi-2021.5.30.tar.gz", hash = "sha256:2bbf76fd432960138b3ef6dda3dde0544f27cbf8546c458e60baf371917ba9ee"}, |     {file = "certifi-2021.5.30.tar.gz", hash = "sha256:2bbf76fd432960138b3ef6dda3dde0544f27cbf8546c458e60baf371917ba9ee"}, | ||||||
| @@ -692,24 +786,36 @@ cffi = [ | |||||||
|     {file = "cffi-1.14.5-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:48e1c69bbacfc3d932221851b39d49e81567a4d4aac3b21258d9c24578280058"}, |     {file = "cffi-1.14.5-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:48e1c69bbacfc3d932221851b39d49e81567a4d4aac3b21258d9c24578280058"}, | ||||||
|     {file = "cffi-1.14.5-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:69e395c24fc60aad6bb4fa7e583698ea6cc684648e1ffb7fe85e3c1ca131a7d5"}, |     {file = "cffi-1.14.5-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:69e395c24fc60aad6bb4fa7e583698ea6cc684648e1ffb7fe85e3c1ca131a7d5"}, | ||||||
|     {file = "cffi-1.14.5-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:9e93e79c2551ff263400e1e4be085a1210e12073a31c2011dbbda14bda0c6132"}, |     {file = "cffi-1.14.5-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:9e93e79c2551ff263400e1e4be085a1210e12073a31c2011dbbda14bda0c6132"}, | ||||||
|  |     {file = "cffi-1.14.5-cp36-cp36m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:24ec4ff2c5c0c8f9c6b87d5bb53555bf267e1e6f70e52e5a9740d32861d36b6f"}, | ||||||
|  |     {file = "cffi-1.14.5-cp36-cp36m-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:3c3f39fa737542161d8b0d680df2ec249334cd70a8f420f71c9304bd83c3cbed"}, | ||||||
|  |     {file = "cffi-1.14.5-cp36-cp36m-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:681d07b0d1e3c462dd15585ef5e33cb021321588bebd910124ef4f4fb71aef55"}, | ||||||
|     {file = "cffi-1.14.5-cp36-cp36m-win32.whl", hash = "sha256:58e3f59d583d413809d60779492342801d6e82fefb89c86a38e040c16883be53"}, |     {file = "cffi-1.14.5-cp36-cp36m-win32.whl", hash = "sha256:58e3f59d583d413809d60779492342801d6e82fefb89c86a38e040c16883be53"}, | ||||||
|     {file = "cffi-1.14.5-cp36-cp36m-win_amd64.whl", hash = "sha256:005a36f41773e148deac64b08f233873a4d0c18b053d37da83f6af4d9087b813"}, |     {file = "cffi-1.14.5-cp36-cp36m-win_amd64.whl", hash = "sha256:005a36f41773e148deac64b08f233873a4d0c18b053d37da83f6af4d9087b813"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:2894f2df484ff56d717bead0a5c2abb6b9d2bf26d6960c4604d5c48bbc30ee73"}, |     {file = "cffi-1.14.5-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:2894f2df484ff56d717bead0a5c2abb6b9d2bf26d6960c4604d5c48bbc30ee73"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:0857f0ae312d855239a55c81ef453ee8fd24136eaba8e87a2eceba644c0d4c06"}, |     {file = "cffi-1.14.5-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:0857f0ae312d855239a55c81ef453ee8fd24136eaba8e87a2eceba644c0d4c06"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:cd2868886d547469123fadc46eac7ea5253ea7fcb139f12e1dfc2bbd406427d1"}, |     {file = "cffi-1.14.5-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:cd2868886d547469123fadc46eac7ea5253ea7fcb139f12e1dfc2bbd406427d1"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:35f27e6eb43380fa080dccf676dece30bef72e4a67617ffda586641cd4508d49"}, |     {file = "cffi-1.14.5-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:35f27e6eb43380fa080dccf676dece30bef72e4a67617ffda586641cd4508d49"}, | ||||||
|  |     {file = "cffi-1.14.5-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:06d7cd1abac2ffd92e65c0609661866709b4b2d82dd15f611e602b9b188b0b69"}, | ||||||
|  |     {file = "cffi-1.14.5-cp37-cp37m-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:0f861a89e0043afec2a51fd177a567005847973be86f709bbb044d7f42fc4e05"}, | ||||||
|  |     {file = "cffi-1.14.5-cp37-cp37m-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:cc5a8e069b9ebfa22e26d0e6b97d6f9781302fe7f4f2b8776c3e1daea35f1adc"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-win32.whl", hash = "sha256:9ff227395193126d82e60319a673a037d5de84633f11279e336f9c0f189ecc62"}, |     {file = "cffi-1.14.5-cp37-cp37m-win32.whl", hash = "sha256:9ff227395193126d82e60319a673a037d5de84633f11279e336f9c0f189ecc62"}, | ||||||
|     {file = "cffi-1.14.5-cp37-cp37m-win_amd64.whl", hash = "sha256:9cf8022fb8d07a97c178b02327b284521c7708d7c71a9c9c355c178ac4bbd3d4"}, |     {file = "cffi-1.14.5-cp37-cp37m-win_amd64.whl", hash = "sha256:9cf8022fb8d07a97c178b02327b284521c7708d7c71a9c9c355c178ac4bbd3d4"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:8b198cec6c72df5289c05b05b8b0969819783f9418e0409865dac47288d2a053"}, |     {file = "cffi-1.14.5-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:8b198cec6c72df5289c05b05b8b0969819783f9418e0409865dac47288d2a053"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-manylinux1_i686.whl", hash = "sha256:ad17025d226ee5beec591b52800c11680fca3df50b8b29fe51d882576e039ee0"}, |     {file = "cffi-1.14.5-cp38-cp38-manylinux1_i686.whl", hash = "sha256:ad17025d226ee5beec591b52800c11680fca3df50b8b29fe51d882576e039ee0"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:6c97d7350133666fbb5cf4abdc1178c812cb205dc6f41d174a7b0f18fb93337e"}, |     {file = "cffi-1.14.5-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:6c97d7350133666fbb5cf4abdc1178c812cb205dc6f41d174a7b0f18fb93337e"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:8ae6299f6c68de06f136f1f9e69458eae58f1dacf10af5c17353eae03aa0d827"}, |     {file = "cffi-1.14.5-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:8ae6299f6c68de06f136f1f9e69458eae58f1dacf10af5c17353eae03aa0d827"}, | ||||||
|  |     {file = "cffi-1.14.5-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:04c468b622ed31d408fea2346bec5bbffba2cc44226302a0de1ade9f5ea3d373"}, | ||||||
|  |     {file = "cffi-1.14.5-cp38-cp38-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:06db6321b7a68b2bd6df96d08a5adadc1fa0e8f419226e25b2a5fbf6ccc7350f"}, | ||||||
|  |     {file = "cffi-1.14.5-cp38-cp38-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:293e7ea41280cb28c6fcaaa0b1aa1f533b8ce060b9e701d78511e1e6c4a1de76"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-win32.whl", hash = "sha256:b85eb46a81787c50650f2392b9b4ef23e1f126313b9e0e9013b35c15e4288e2e"}, |     {file = "cffi-1.14.5-cp38-cp38-win32.whl", hash = "sha256:b85eb46a81787c50650f2392b9b4ef23e1f126313b9e0e9013b35c15e4288e2e"}, | ||||||
|     {file = "cffi-1.14.5-cp38-cp38-win_amd64.whl", hash = "sha256:1f436816fc868b098b0d63b8920de7d208c90a67212546d02f84fe78a9c26396"}, |     {file = "cffi-1.14.5-cp38-cp38-win_amd64.whl", hash = "sha256:1f436816fc868b098b0d63b8920de7d208c90a67212546d02f84fe78a9c26396"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:1071534bbbf8cbb31b498d5d9db0f274f2f7a865adca4ae429e147ba40f73dea"}, |     {file = "cffi-1.14.5-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:1071534bbbf8cbb31b498d5d9db0f274f2f7a865adca4ae429e147ba40f73dea"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-manylinux1_i686.whl", hash = "sha256:9de2e279153a443c656f2defd67769e6d1e4163952b3c622dcea5b08a6405322"}, |     {file = "cffi-1.14.5-cp39-cp39-manylinux1_i686.whl", hash = "sha256:9de2e279153a443c656f2defd67769e6d1e4163952b3c622dcea5b08a6405322"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:6e4714cc64f474e4d6e37cfff31a814b509a35cb17de4fb1999907575684479c"}, |     {file = "cffi-1.14.5-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:6e4714cc64f474e4d6e37cfff31a814b509a35cb17de4fb1999907575684479c"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:158d0d15119b4b7ff6b926536763dc0714313aa59e320ddf787502c70c4d4bee"}, |     {file = "cffi-1.14.5-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:158d0d15119b4b7ff6b926536763dc0714313aa59e320ddf787502c70c4d4bee"}, | ||||||
|  |     {file = "cffi-1.14.5-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:1bf1ac1984eaa7675ca8d5745a8cb87ef7abecb5592178406e55858d411eadc0"}, | ||||||
|  |     {file = "cffi-1.14.5-cp39-cp39-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:df5052c5d867c1ea0b311fb7c3cd28b19df469c056f7fdcfe88c7473aa63e333"}, | ||||||
|  |     {file = "cffi-1.14.5-cp39-cp39-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:24a570cd11895b60829e941f2613a4f79df1a27344cbbb82164ef2e0116f09c7"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-win32.whl", hash = "sha256:afb29c1ba2e5a3736f1c301d9d0abe3ec8b86957d04ddfa9d7a6a42b9367e396"}, |     {file = "cffi-1.14.5-cp39-cp39-win32.whl", hash = "sha256:afb29c1ba2e5a3736f1c301d9d0abe3ec8b86957d04ddfa9d7a6a42b9367e396"}, | ||||||
|     {file = "cffi-1.14.5-cp39-cp39-win_amd64.whl", hash = "sha256:f2d45f97ab6bb54753eab54fffe75aaf3de4ff2341c9daee1987ee1837636f1d"}, |     {file = "cffi-1.14.5-cp39-cp39-win_amd64.whl", hash = "sha256:f2d45f97ab6bb54753eab54fffe75aaf3de4ff2341c9daee1987ee1837636f1d"}, | ||||||
|     {file = "cffi-1.14.5.tar.gz", hash = "sha256:fd78e5fee591709f32ef6edb9a015b4aa1a5022598e36227500c8f4e02328d9c"}, |     {file = "cffi-1.14.5.tar.gz", hash = "sha256:fd78e5fee591709f32ef6edb9a015b4aa1a5022598e36227500c8f4e02328d9c"}, | ||||||
| @@ -721,6 +827,10 @@ chardet = [ | |||||||
| ciso8601 = [ | ciso8601 = [ | ||||||
|     {file = "ciso8601-2.1.3.tar.gz", hash = "sha256:bdbb5b366058b1c87735603b23060962c439ac9be66f1ae91e8c7dbd7d59e262"}, |     {file = "ciso8601-2.1.3.tar.gz", hash = "sha256:bdbb5b366058b1c87735603b23060962c439ac9be66f1ae91e8c7dbd7d59e262"}, | ||||||
| ] | ] | ||||||
|  | click = [ | ||||||
|  |     {file = "click-8.0.1-py3-none-any.whl", hash = "sha256:fba402a4a47334742d782209a7c79bc448911afe1149d07bdabdf480b3e2f4b6"}, | ||||||
|  |     {file = "click-8.0.1.tar.gz", hash = "sha256:8c04c11192119b1ef78ea049e0a6f0463e4c48ef00a30160c704337586f3ad7a"}, | ||||||
|  | ] | ||||||
| colorama = [ | colorama = [ | ||||||
|     {file = "colorama-0.4.4-py2.py3-none-any.whl", hash = "sha256:9f47eda37229f68eee03b24b9748937c7dc3868f906e8ba69fbcbdd3bc5dc3e2"}, |     {file = "colorama-0.4.4-py2.py3-none-any.whl", hash = "sha256:9f47eda37229f68eee03b24b9748937c7dc3868f906e8ba69fbcbdd3bc5dc3e2"}, | ||||||
|     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, |     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, | ||||||
| @@ -765,6 +875,10 @@ idna = [ | |||||||
|     {file = "idna-2.10-py2.py3-none-any.whl", hash = "sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"}, |     {file = "idna-2.10-py2.py3-none-any.whl", hash = "sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"}, | ||||||
|     {file = "idna-2.10.tar.gz", hash = "sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6"}, |     {file = "idna-2.10.tar.gz", hash = "sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6"}, | ||||||
| ] | ] | ||||||
|  | isort = [ | ||||||
|  |     {file = "isort-5.8.0-py3-none-any.whl", hash = "sha256:2bb1680aad211e3c9944dbce1d4ba09a989f04e238296c87fe2139faa26d655d"}, | ||||||
|  |     {file = "isort-5.8.0.tar.gz", hash = "sha256:0a943902919f65c5684ac4e0154b1ad4fac6dcaa5d9f3426b732f1c8b5419be6"}, | ||||||
|  | ] | ||||||
| jinja2 = [ | jinja2 = [ | ||||||
|     {file = "Jinja2-3.0.1-py3-none-any.whl", hash = "sha256:1f06f2da51e7b56b8f238affdd6b4e2c61e39598a378cc49345bc1bd42a978a4"}, |     {file = "Jinja2-3.0.1-py3-none-any.whl", hash = "sha256:1f06f2da51e7b56b8f238affdd6b4e2c61e39598a378cc49345bc1bd42a978a4"}, | ||||||
|     {file = "Jinja2-3.0.1.tar.gz", hash = "sha256:703f484b47a6af502e743c9122595cc812b0271f661722403114f71a79d0f5a4"}, |     {file = "Jinja2-3.0.1.tar.gz", hash = "sha256:703f484b47a6af502e743c9122595cc812b0271f661722403114f71a79d0f5a4"}, | ||||||
| @@ -852,10 +966,18 @@ multidict = [ | |||||||
|     {file = "multidict-5.1.0-cp39-cp39-win_amd64.whl", hash = "sha256:7df80d07818b385f3129180369079bd6934cf70469f99daaebfac89dca288359"}, |     {file = "multidict-5.1.0-cp39-cp39-win_amd64.whl", hash = "sha256:7df80d07818b385f3129180369079bd6934cf70469f99daaebfac89dca288359"}, | ||||||
|     {file = "multidict-5.1.0.tar.gz", hash = "sha256:25b4e5f22d3a37ddf3effc0710ba692cfc792c2b9edfb9c05aefe823256e84d5"}, |     {file = "multidict-5.1.0.tar.gz", hash = "sha256:25b4e5f22d3a37ddf3effc0710ba692cfc792c2b9edfb9c05aefe823256e84d5"}, | ||||||
| ] | ] | ||||||
|  | mypy-extensions = [ | ||||||
|  |     {file = "mypy_extensions-0.4.3-py2.py3-none-any.whl", hash = "sha256:090fedd75945a69ae91ce1303b5824f428daf5a028d2f6ab8a299250a846f15d"}, | ||||||
|  |     {file = "mypy_extensions-0.4.3.tar.gz", hash = "sha256:2d82818f5bb3e369420cb3c4060a7970edba416647068eb4c5343488a6c604a8"}, | ||||||
|  | ] | ||||||
| packaging = [ | packaging = [ | ||||||
|     {file = "packaging-20.9-py2.py3-none-any.whl", hash = "sha256:67714da7f7bc052e064859c05c595155bd1ee9f69f76557e21f051443c20947a"}, |     {file = "packaging-20.9-py2.py3-none-any.whl", hash = "sha256:67714da7f7bc052e064859c05c595155bd1ee9f69f76557e21f051443c20947a"}, | ||||||
|     {file = "packaging-20.9.tar.gz", hash = "sha256:5b327ac1320dc863dca72f4514ecc086f31186744b84a230374cc1fd776feae5"}, |     {file = "packaging-20.9.tar.gz", hash = "sha256:5b327ac1320dc863dca72f4514ecc086f31186744b84a230374cc1fd776feae5"}, | ||||||
| ] | ] | ||||||
|  | pathspec = [ | ||||||
|  |     {file = "pathspec-0.8.1-py2.py3-none-any.whl", hash = "sha256:aa0cb481c4041bf52ffa7b0d8fa6cd3e88a2ca4879c533c9153882ee2556790d"}, | ||||||
|  |     {file = "pathspec-0.8.1.tar.gz", hash = "sha256:86379d6b86d75816baba717e64b1a3a3469deb93bb76d613c9ce79edc5cb68fd"}, | ||||||
|  | ] | ||||||
| pluggy = [ | pluggy = [ | ||||||
|     {file = "pluggy-0.13.1-py2.py3-none-any.whl", hash = "sha256:966c145cd83c96502c3c3868f50408687b38434af77734af1e9ca461a4081d2d"}, |     {file = "pluggy-0.13.1-py2.py3-none-any.whl", hash = "sha256:966c145cd83c96502c3c3868f50408687b38434af77734af1e9ca461a4081d2d"}, | ||||||
|     {file = "pluggy-0.13.1.tar.gz", hash = "sha256:15b2acde666561e1298d71b523007ed7364de07029219b604cf808bfa1c765b0"}, |     {file = "pluggy-0.13.1.tar.gz", hash = "sha256:15b2acde666561e1298d71b523007ed7364de07029219b604cf808bfa1c765b0"}, | ||||||
| @@ -902,22 +1024,73 @@ pyyaml = [ | |||||||
|     {file = "PyYAML-5.4.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bb4191dfc9306777bc594117aee052446b3fa88737cd13b7188d0e7aa8162185"}, |     {file = "PyYAML-5.4.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bb4191dfc9306777bc594117aee052446b3fa88737cd13b7188d0e7aa8162185"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:6c78645d400265a062508ae399b60b8c167bf003db364ecb26dcab2bda048253"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:6c78645d400265a062508ae399b60b8c167bf003db364ecb26dcab2bda048253"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:4e0583d24c881e14342eaf4ec5fbc97f934b999a6828693a99157fde912540cc"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:4e0583d24c881e14342eaf4ec5fbc97f934b999a6828693a99157fde912540cc"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:72a01f726a9c7851ca9bfad6fd09ca4e090a023c00945ea05ba1638c09dc3347"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux2014_s390x.whl", hash = "sha256:895f61ef02e8fed38159bb70f7e100e00f471eae2bc838cd0f4ebb21e28f8541"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-win32.whl", hash = "sha256:3bd0e463264cf257d1ffd2e40223b197271046d09dadf73a0fe82b9c1fc385a5"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-win32.whl", hash = "sha256:3bd0e463264cf257d1ffd2e40223b197271046d09dadf73a0fe82b9c1fc385a5"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-win_amd64.whl", hash = "sha256:e4fac90784481d221a8e4b1162afa7c47ed953be40d31ab4629ae917510051df"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-win_amd64.whl", hash = "sha256:e4fac90784481d221a8e4b1162afa7c47ed953be40d31ab4629ae917510051df"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:5accb17103e43963b80e6f837831f38d314a0495500067cb25afab2e8d7a4018"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:5accb17103e43963b80e6f837831f38d314a0495500067cb25afab2e8d7a4018"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:e1d4970ea66be07ae37a3c2e48b5ec63f7ba6804bdddfdbd3cfd954d25a82e63"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:e1d4970ea66be07ae37a3c2e48b5ec63f7ba6804bdddfdbd3cfd954d25a82e63"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:cb333c16912324fd5f769fff6bc5de372e9e7a202247b48870bc251ed40239aa"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux2014_s390x.whl", hash = "sha256:fe69978f3f768926cfa37b867e3843918e012cf83f680806599ddce33c2c68b0"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-win32.whl", hash = "sha256:dd5de0646207f053eb0d6c74ae45ba98c3395a571a2891858e87df7c9b9bd51b"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-win32.whl", hash = "sha256:dd5de0646207f053eb0d6c74ae45ba98c3395a571a2891858e87df7c9b9bd51b"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-win_amd64.whl", hash = "sha256:08682f6b72c722394747bddaf0aa62277e02557c0fd1c42cb853016a38f8dedf"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-win_amd64.whl", hash = "sha256:08682f6b72c722394747bddaf0aa62277e02557c0fd1c42cb853016a38f8dedf"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:d2d9808ea7b4af864f35ea216be506ecec180628aced0704e34aca0b040ffe46"}, |     {file = "PyYAML-5.4.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:d2d9808ea7b4af864f35ea216be506ecec180628aced0704e34aca0b040ffe46"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:8c1be557ee92a20f184922c7b6424e8ab6691788e6d86137c5d93c1a6ec1b8fb"}, |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:8c1be557ee92a20f184922c7b6424e8ab6691788e6d86137c5d93c1a6ec1b8fb"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:fd7f6999a8070df521b6384004ef42833b9bd62cfee11a09bda1079b4b704247"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux2014_s390x.whl", hash = "sha256:bfb51918d4ff3d77c1c856a9699f8492c612cde32fd3bcd344af9be34999bfdc"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-win32.whl", hash = "sha256:fa5ae20527d8e831e8230cbffd9f8fe952815b2b7dae6ffec25318803a7528fc"}, |     {file = "PyYAML-5.4.1-cp38-cp38-win32.whl", hash = "sha256:fa5ae20527d8e831e8230cbffd9f8fe952815b2b7dae6ffec25318803a7528fc"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-win_amd64.whl", hash = "sha256:0f5f5786c0e09baddcd8b4b45f20a7b5d61a7e7e99846e3c799b05c7c53fa696"}, |     {file = "PyYAML-5.4.1-cp38-cp38-win_amd64.whl", hash = "sha256:0f5f5786c0e09baddcd8b4b45f20a7b5d61a7e7e99846e3c799b05c7c53fa696"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:294db365efa064d00b8d1ef65d8ea2c3426ac366c0c4368d930bf1c5fb497f77"}, |     {file = "PyYAML-5.4.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:294db365efa064d00b8d1ef65d8ea2c3426ac366c0c4368d930bf1c5fb497f77"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:74c1485f7707cf707a7aef42ef6322b8f97921bd89be2ab6317fd782c2d53183"}, |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:74c1485f7707cf707a7aef42ef6322b8f97921bd89be2ab6317fd782c2d53183"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:d483ad4e639292c90170eb6f7783ad19490e7a8defb3e46f97dfe4bacae89122"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux2014_s390x.whl", hash = "sha256:fdc842473cd33f45ff6bce46aea678a54e3d21f1b61a7750ce3c498eedfe25d6"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-win32.whl", hash = "sha256:49d4cdd9065b9b6e206d0595fee27a96b5dd22618e7520c33204a4a3239d5b10"}, |     {file = "PyYAML-5.4.1-cp39-cp39-win32.whl", hash = "sha256:49d4cdd9065b9b6e206d0595fee27a96b5dd22618e7520c33204a4a3239d5b10"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-win_amd64.whl", hash = "sha256:c20cfa2d49991c8b4147af39859b167664f2ad4561704ee74c1de03318e898db"}, |     {file = "PyYAML-5.4.1-cp39-cp39-win_amd64.whl", hash = "sha256:c20cfa2d49991c8b4147af39859b167664f2ad4561704ee74c1de03318e898db"}, | ||||||
|     {file = "PyYAML-5.4.1.tar.gz", hash = "sha256:607774cbba28732bfa802b54baa7484215f530991055bb562efbed5b2f20a45e"}, |     {file = "PyYAML-5.4.1.tar.gz", hash = "sha256:607774cbba28732bfa802b54baa7484215f530991055bb562efbed5b2f20a45e"}, | ||||||
| ] | ] | ||||||
|  | regex = [ | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:619d71c59a78b84d7f18891fe914446d07edd48dc8328c8e149cbe0929b4e000"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:47bf5bf60cf04d72bf6055ae5927a0bd9016096bf3d742fa50d9bf9f45aa0711"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:281d2fd05555079448537fe108d79eb031b403dac622621c78944c235f3fcf11"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2010_i686.whl", hash = "sha256:bd28bc2e3a772acbb07787c6308e00d9626ff89e3bfcdebe87fa5afbfdedf968"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2010_x86_64.whl", hash = "sha256:7c2a1af393fcc09e898beba5dd59196edaa3116191cc7257f9224beaed3e1aa0"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:c38c71df845e2aabb7fb0b920d11a1b5ac8526005e533a8920aea97efb8ec6a4"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_i686.whl", hash = "sha256:96fcd1888ab4d03adfc9303a7b3c0bd78c5412b2bfbe76db5b56d9eae004907a"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_x86_64.whl", hash = "sha256:ade17eb5d643b7fead300a1641e9f45401c98eee23763e9ed66a43f92f20b4a7"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-win32.whl", hash = "sha256:e8e5b509d5c2ff12f8418006d5a90e9436766133b564db0abaec92fd27fcee29"}, | ||||||
|  |     {file = "regex-2021.4.4-cp36-cp36m-win_amd64.whl", hash = "sha256:11d773d75fa650cd36f68d7ca936e3c7afaae41b863b8c387a22aaa78d3c5c79"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:d3029c340cfbb3ac0a71798100ccc13b97dddf373a4ae56b6a72cf70dfd53bc8"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:18c071c3eb09c30a264879f0d310d37fe5d3a3111662438889ae2eb6fc570c31"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:4c557a7b470908b1712fe27fb1ef20772b78079808c87d20a90d051660b1d69a"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2010_i686.whl", hash = "sha256:01afaf2ec48e196ba91b37451aa353cb7eda77efe518e481707e0515025f0cd5"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2010_x86_64.whl", hash = "sha256:3a9cd17e6e5c7eb328517969e0cb0c3d31fd329298dd0c04af99ebf42e904f82"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:90f11ff637fe8798933fb29f5ae1148c978cccb0452005bf4c69e13db951e765"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_i686.whl", hash = "sha256:919859aa909429fb5aa9cf8807f6045592c85ef56fdd30a9a3747e513db2536e"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_x86_64.whl", hash = "sha256:339456e7d8c06dd36a22e451d58ef72cef293112b559010db3d054d5560ef439"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-win32.whl", hash = "sha256:67bdb9702427ceddc6ef3dc382455e90f785af4c13d495f9626861763ee13f9d"}, | ||||||
|  |     {file = "regex-2021.4.4-cp37-cp37m-win_amd64.whl", hash = "sha256:32e65442138b7b76dd8173ffa2cf67356b7bc1768851dded39a7a13bf9223da3"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:1e1c20e29358165242928c2de1482fb2cf4ea54a6a6dea2bd7a0e0d8ee321500"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux1_i686.whl", hash = "sha256:314d66636c494ed9c148a42731b3834496cc9a2c4251b1661e40936814542b14"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:6d1b01031dedf2503631d0903cb563743f397ccaf6607a5e3b19a3d76fc10480"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux2010_i686.whl", hash = "sha256:741a9647fcf2e45f3a1cf0e24f5e17febf3efe8d4ba1281dcc3aa0459ef424dc"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux2010_x86_64.whl", hash = "sha256:4c46e22a0933dd783467cf32b3516299fb98cfebd895817d685130cc50cd1093"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:e512d8ef5ad7b898cdb2d8ee1cb09a8339e4f8be706d27eaa180c2f177248a10"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_i686.whl", hash = "sha256:980d7be47c84979d9136328d882f67ec5e50008681d94ecc8afa8a65ed1f4a6f"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_x86_64.whl", hash = "sha256:ce15b6d103daff8e9fee13cf7f0add05245a05d866e73926c358e871221eae87"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-win32.whl", hash = "sha256:a91aa8619b23b79bcbeb37abe286f2f408d2f2d6f29a17237afda55bb54e7aac"}, | ||||||
|  |     {file = "regex-2021.4.4-cp38-cp38-win_amd64.whl", hash = "sha256:c0502c0fadef0d23b128605d69b58edb2c681c25d44574fc673b0e52dce71ee2"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:598585c9f0af8374c28edd609eb291b5726d7cbce16be6a8b95aa074d252ee17"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux1_i686.whl", hash = "sha256:ee54ff27bf0afaf4c3b3a62bcd016c12c3fdb4ec4f413391a90bd38bc3624605"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:7d9884d86dd4dd489e981d94a65cd30d6f07203d90e98f6f657f05170f6324c9"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux2010_i686.whl", hash = "sha256:bf5824bfac591ddb2c1f0a5f4ab72da28994548c708d2191e3b87dd207eb3ad7"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux2010_x86_64.whl", hash = "sha256:563085e55b0d4fb8f746f6a335893bda5c2cef43b2f0258fe1020ab1dd874df8"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:b9c3db21af35e3b3c05764461b262d6f05bbca08a71a7849fd79d47ba7bc33ed"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_i686.whl", hash = "sha256:3916d08be28a1149fb97f7728fca1f7c15d309a9f9682d89d79db75d5e52091c"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_x86_64.whl", hash = "sha256:fd45ff9293d9274c5008a2054ecef86a9bfe819a67c7be1afb65e69b405b3042"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-win32.whl", hash = "sha256:fa4537fb4a98fe8fde99626e4681cc644bdcf2a795038533f9f711513a862ae6"}, | ||||||
|  |     {file = "regex-2021.4.4-cp39-cp39-win_amd64.whl", hash = "sha256:97f29f57d5b84e73fbaf99ab3e26134e6687348e95ef6b48cfd2c06807005a07"}, | ||||||
|  |     {file = "regex-2021.4.4.tar.gz", hash = "sha256:52ba3d3f9b942c49d7e4bc105bb28551c44065f139a65062ab7912bef10c9afb"}, | ||||||
|  | ] | ||||||
| requests = [ | requests = [ | ||||||
|     {file = "requests-2.25.1-py2.py3-none-any.whl", hash = "sha256:c210084e36a42ae6b9219e00e48287def368a26d03a048ddad7bfee44f75871e"}, |     {file = "requests-2.25.1-py2.py3-none-any.whl", hash = "sha256:c210084e36a42ae6b9219e00e48287def368a26d03a048ddad7bfee44f75871e"}, | ||||||
|     {file = "requests-2.25.1.tar.gz", hash = "sha256:27973dd4a904a4f13b263a19c866c13b92a39ed1c964655f025f3f8d3d75b804"}, |     {file = "requests-2.25.1.tar.gz", hash = "sha256:27973dd4a904a4f13b263a19c866c13b92a39ed1c964655f025f3f8d3d75b804"}, | ||||||
| @@ -962,6 +1135,10 @@ text-unidecode = [ | |||||||
|     {file = "text-unidecode-1.3.tar.gz", hash = "sha256:bad6603bb14d279193107714b288be206cac565dfa49aa5b105294dd5c4aab93"}, |     {file = "text-unidecode-1.3.tar.gz", hash = "sha256:bad6603bb14d279193107714b288be206cac565dfa49aa5b105294dd5c4aab93"}, | ||||||
|     {file = "text_unidecode-1.3-py2.py3-none-any.whl", hash = "sha256:1311f10e8b895935241623731c2ba64f4c455287888b18189350b67134a822e8"}, |     {file = "text_unidecode-1.3-py2.py3-none-any.whl", hash = "sha256:1311f10e8b895935241623731c2ba64f4c455287888b18189350b67134a822e8"}, | ||||||
| ] | ] | ||||||
|  | toml = [ | ||||||
|  |     {file = "toml-0.10.2-py2.py3-none-any.whl", hash = "sha256:806143ae5bfb6a3c6e736a764057db0e6a0e05e338b5630894a5f779cabb4f9b"}, | ||||||
|  |     {file = "toml-0.10.2.tar.gz", hash = "sha256:b3bda1d108d5dd99f4a20d24d9c348e91c4db7ab1b749200bded2f839ccbe68f"}, | ||||||
|  | ] | ||||||
| typing-extensions = [ | typing-extensions = [ | ||||||
|     {file = "typing_extensions-3.10.0.0-py2-none-any.whl", hash = "sha256:0ac0f89795dd19de6b97debb0c6af1c70987fd80a2d62d1958f7e56fcc31b497"}, |     {file = "typing_extensions-3.10.0.0-py2-none-any.whl", hash = "sha256:0ac0f89795dd19de6b97debb0c6af1c70987fd80a2d62d1958f7e56fcc31b497"}, | ||||||
|     {file = "typing_extensions-3.10.0.0-py3-none-any.whl", hash = "sha256:779383f6086d90c99ae41cf0ff39aac8a7937a9283ce0a414e5dd782f4c94a84"}, |     {file = "typing_extensions-3.10.0.0-py3-none-any.whl", hash = "sha256:779383f6086d90c99ae41cf0ff39aac8a7937a9283ce0a414e5dd782f4c94a84"}, | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| [tool.poetry] | [tool.poetry] | ||||||
| name = "git add re" | name = "home_assistant_covid19_augsburg" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| description = "" | description = "" | ||||||
| authors = ["Adrian Rumpold <a.rumpold@gmail.com>"] | authors = ["Adrian Rumpold <a.rumpold@gmail.com>"] | ||||||
| @@ -16,6 +16,8 @@ requests = "^2.25.1" | |||||||
| pytest = "^5.2" | pytest = "^5.2" | ||||||
| flake8 = "^3.9.2" | flake8 = "^3.9.2" | ||||||
| homeassistant = "^2021.6.5" | homeassistant = "^2021.6.5" | ||||||
|  | black = "^21.6b0" | ||||||
|  | isort = "^5.8.0" | ||||||
|  |  | ||||||
| [build-system] | [build-system] | ||||||
| requires = ["poetry-core>=1.0.0"] | requires = ["poetry-core>=1.0.0"] | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								tests/test_example.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								tests/test_example.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | """Placeholder test suite to Pytest doesn't exit with error code | ||||||
|  |  | ||||||
|  | TODO: Remove once other tests have been added. | ||||||
|  | """ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_example(): | ||||||
|  |     assert True | ||||||
		Reference in New Issue
	
	Block a user