From 6d640e54454edfb9826f5e13da688eb66a67d3b5 Mon Sep 17 00:00:00 2001 From: 5ila5 <5ila5@users.noreply.github.com> Date: Fri, 27 Dec 2024 00:03:18 +0100 Subject: [PATCH] fix recycleapp_be only trying one zip-code id even if one zipcode has multiple ids --- .../source/recycleapp_be.py | 33 ++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/custom_components/waste_collection_schedule/waste_collection_schedule/source/recycleapp_be.py b/custom_components/waste_collection_schedule/waste_collection_schedule/source/recycleapp_be.py index 24d2c024f..d6c2371a4 100644 --- a/custom_components/waste_collection_schedule/waste_collection_schedule/source/recycleapp_be.py +++ b/custom_components/waste_collection_schedule/waste_collection_schedule/source/recycleapp_be.py @@ -36,6 +36,16 @@ "street": "Th. De Beckerstraat", "house_number": 1, }, + "9180 Lokeren, Abelendreef 1": { + "postcode": 9180, + "street": "Abelendreef", + "house_number": 1, + }, + "8700 Abeelstraat 1": { + "postcode": 8700, + "street": "Abeelstraat", + "house_number": 1, + }, } _LOGGER = logging.getLogger(__name__) @@ -68,8 +78,29 @@ def fetch(self): items = r.json()["items"] if len(items) == 0: raise SourceArgumentNotFound("postcode", self._postcode) - zipcodeId = items[0]["id"] + for item in items: + error = None + if not item["available"]: + continue + zipcodeId = item["id"] + try: + entries = self._fetch_zipcode(zipcodeId, url, headers) + if entries: + return entries + except SourceArgumentNotFound as e: + error = e + + if error: + raise error + raise Exception( + "No data found for the postcode" + + (", tired multiple zipcode, entries" if len(items) > 1 else "") + ) + + def _fetch_zipcode( + self, zipcodeId: str, url: str, headers: dict[str, str] + ) -> list[Collection]: params = {"q": self._steet_search, "zipcodes": zipcodeId} r = requests.post(f"{url}/streets", params=params, headers=headers) r.raise_for_status()