X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=stevens_renderer.py;h=95a6d54c35d296339073f2cea938836eb92f0f96;hb=ea1ee5f817c01c3736a64d73d496cf35cbd383e5;hp=6d8768ee387a12ecd50dfb68471bb2d8d97c27ef;hpb=c06bfef53f70551e7920bc4facce27f47b89e2ba;p=kiosk.git diff --git a/stevens_renderer.py b/stevens_renderer.py index 6d8768e..95a6d54 100644 --- a/stevens_renderer.py +++ b/stevens_renderer.py @@ -1,55 +1,132 @@ #!/usr/bin/env python3 -import http.client -from typing import List, Dict -import xml.etree.ElementTree as ET +import json +import logging +import requests +from typing import Dict -import renderer import file_writer +import renderer + + +logger = logging.getLogger(__name__) + + +class stevens_renderer(renderer.abstaining_renderer): + URL = "https://wsdot.com/Travel/Real-time/Service/api/MountainPass/Details/10" + def __init__(self, name_to_timeout_dict: Dict[str, int]) -> None: + super().__init__(name_to_timeout_dict) -class stevens_pass_conditions_renderer(renderer.debuggable_abstaining_renderer): - """Renders a page about Stevens Pass conditions.""" - - def __init__( - self, name_to_timeout_dict: Dict[str, int], feed_site: str, feed_uris: List[str] - ) -> None: - super(stevens_pass_conditions_renderer, self).__init__( - name_to_timeout_dict, False - ) - self.feed_site = feed_site - self.feed_uris = feed_uris - - def debug_prefix(self) -> str: - return "stevens" - - def periodic_render(self, key: str) -> bool: - with file_writer.file_writer("stevens-conditions_1_86400.html") as f: - for uri in self.feed_uris: - self.conn = http.client.HTTPSConnection(self.feed_site) - self.conn.request("GET", uri, None, {"Accept-Charset": "utf-8"}) - response = self.conn.getresponse() - if response.status == 200: - raw = response.read() - rss = ET.fromstring(raw) - channel = rss[0] - for item in channel.getchildren(): - if item.tag == "title": - f.write(f"
\n%s\n" % text) - return True + def render_conditions(mp: Dict[str, str], conditions: Dict[str, str]) -> str: + ret = f""" +
Temp: | +{conditions['temperature']}°{conditions['temperatureUnit'][0]} | +
Weather: | +{conditions['weather']} | +
Roadway: | +{conditions['roadCondition']} | +
Restrictions: | +"""
+ count = 0
+ msg = conditions["restrictionOne"].get("publicPage", "no restrictions")
+ if msg.lower() != "no restrictions":
+ count += 1
+ msg = conditions["restrictionTwo"].get("publicPage", "no restrictions")
+ if msg.lower() != "no restrictions":
+ count += 1
+ if count == 2:
+ ret += f"""
+ {conditions['restrictionOne']['travelDirectionName']}:
+ {conditions['restrictionOne']['publicPage']} + {conditions['restrictionTwo']['travelDirectionName']}: + {conditions['restrictionTwo']['publicPage']}""" + elif count == 1: + msg = conditions["restrictionOne"].get("publicPage", "no restrictions") + if msg.lower() != "no restrictions": + ret += f""" + {conditions['restrictionOne']['travelDirectionName']}: + {conditions['restrictionOne']['publicPage']} """ + else: + ret += f""" + {conditions['restrictionTwo']['travelDirectionName']}: + {conditions['restrictionTwo']['publicPage']} """ + else: + ret += """None. """ + ret += " |
{f['periodText']} | +{f['forecastText']} | +
+ {stevens_renderer.render_conditions(mp, conditions)} + | ++ {stevens_renderer.render_image(cameras)} + | +
+ {stevens_renderer.render_forecast(forecasts)} + | +