Use new API for Vasttrafik (#102570)

pull/102913/head
Magnus Larsson 2023-10-27 16:49:01 +02:00 committed by GitHub
parent 3f56ca49c6
commit a516f32bbd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 33 additions and 15 deletions

View File

@ -5,5 +5,5 @@
"documentation": "https://www.home-assistant.io/integrations/vasttrafik", "documentation": "https://www.home-assistant.io/integrations/vasttrafik",
"iot_class": "cloud_polling", "iot_class": "cloud_polling",
"loggers": ["vasttrafik"], "loggers": ["vasttrafik"],
"requirements": ["vtjp==0.1.14"] "requirements": ["vtjp==0.2.1"]
} }

View File

@ -1,7 +1,7 @@
"""Support for Västtrafik public transport.""" """Support for Västtrafik public transport."""
from __future__ import annotations from __future__ import annotations
from datetime import timedelta from datetime import datetime, timedelta
import logging import logging
import vasttrafik import vasttrafik
@ -22,6 +22,9 @@ ATTR_ACCESSIBILITY = "accessibility"
ATTR_DIRECTION = "direction" ATTR_DIRECTION = "direction"
ATTR_LINE = "line" ATTR_LINE = "line"
ATTR_TRACK = "track" ATTR_TRACK = "track"
ATTR_FROM = "from"
ATTR_TO = "to"
ATTR_DELAY = "delay"
CONF_DEPARTURES = "departures" CONF_DEPARTURES = "departures"
CONF_FROM = "from" CONF_FROM = "from"
@ -32,7 +35,6 @@ CONF_SECRET = "secret"
DEFAULT_DELAY = 0 DEFAULT_DELAY = 0
MIN_TIME_BETWEEN_UPDATES = timedelta(seconds=120) MIN_TIME_BETWEEN_UPDATES = timedelta(seconds=120)
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend( PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
@ -101,7 +103,7 @@ class VasttrafikDepartureSensor(SensorEntity):
if location.isdecimal(): if location.isdecimal():
station_info = {"station_name": location, "station_id": location} station_info = {"station_name": location, "station_id": location}
else: else:
station_id = self._planner.location_name(location)[0]["id"] station_id = self._planner.location_name(location)[0]["gid"]
station_info = {"station_name": location, "station_id": station_id} station_info = {"station_name": location, "station_id": station_id}
return station_info return station_info
@ -143,20 +145,36 @@ class VasttrafikDepartureSensor(SensorEntity):
self._attributes = {} self._attributes = {}
else: else:
for departure in self._departureboard: for departure in self._departureboard:
line = departure.get("sname") service_journey = departure.get("serviceJourney", {})
if "cancelled" in departure: line = service_journey.get("line", {})
if departure.get("isCancelled"):
continue continue
if not self._lines or line in self._lines: if not self._lines or line.get("shortName") in self._lines:
if "rtTime" in departure: if "estimatedOtherwisePlannedTime" in departure:
self._state = departure["rtTime"] try:
self._state = datetime.fromisoformat(
departure["estimatedOtherwisePlannedTime"]
).strftime("%H:%M")
except ValueError:
self._state = departure["estimatedOtherwisePlannedTime"]
else: else:
self._state = departure["time"] self._state = None
stop_point = departure.get("stopPoint", {})
params = { params = {
ATTR_ACCESSIBILITY: departure.get("accessibility"), ATTR_ACCESSIBILITY: "wheelChair"
ATTR_DIRECTION: departure.get("direction"), if line.get("isWheelchairAccessible")
ATTR_LINE: departure.get("sname"), else None,
ATTR_TRACK: departure.get("track"), ATTR_DIRECTION: service_journey.get("direction"),
ATTR_LINE: line.get("shortName"),
ATTR_TRACK: stop_point.get("platform"),
ATTR_FROM: stop_point.get("name"),
ATTR_TO: self._heading["station_name"]
if self._heading
else "ANY",
ATTR_DELAY: self._delay.seconds // 60 % 60,
} }
self._attributes = {k: v for k, v in params.items() if v} self._attributes = {k: v for k, v in params.items() if v}

View File

@ -2682,7 +2682,7 @@ volvooncall==0.10.3
vsure==2.6.6 vsure==2.6.6
# homeassistant.components.vasttrafik # homeassistant.components.vasttrafik
vtjp==0.1.14 vtjp==0.2.1
# homeassistant.components.vulcan # homeassistant.components.vulcan
vulcan-api==2.3.0 vulcan-api==2.3.0