X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=stevens_renderer.py;h=95a6d54c35d296339073f2cea938836eb92f0f96;hb=5ea88ab72e175e2d4f57ae8645ca6f825549a7a9;hp=18f300b2e1b7aed53bdb412ec975e0c9eeab891e;hpb=d6990436e08a57ce211b10058dc61fb223cb94ec;p=kiosk.git diff --git a/stevens_renderer.py b/stevens_renderer.py index 18f300b..95a6d54 100644 --- a/stevens_renderer.py +++ b/stevens_renderer.py @@ -1,45 +1,132 @@ -import renderer +#!/usr/bin/env python3 + +import json +import logging +import requests +from typing import Dict + import file_writer -import http.client -import xml.etree.ElementTree as ET - -class stevens_pass_conditions_renderer(renderer.debuggable_abstaining_renderer): - def __init__(self, name_to_timeout_dict, feed_site, feed_uris): - 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): - return "stevens" - - def periodic_render(self, key): - f = file_writer.file_writer('stevens-conditions_1_86400.html') - 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("

%s


" % item.text) - f.write('') - elif item.tag == "item": - for x in item.getchildren(): - if x.tag == "description": - text = x.text - text = text.replace("Stevens Pass US2
", "") - text = text.replace("

", "
") - text = text.replace("Elevation Meters:1238
", "") - f.write('

\n%s\n' % text) - f.close() - return True - f.close() +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) + + def render_conditions(mp: Dict[str, str], conditions: Dict[str, str]) -> str: + ret = f""" + + + + + + + + + + + + +""" + if "restrictionOne" in conditions and "restrictionTwo" in conditions: + ret += """ + + +
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 += "
" + return ret + + def render_forecast(forecasts: Dict[str, str]) -> str: + ret = "" + fc = forecasts["forecast"]["forecastData"] + for n, f in enumerate(fc): + color = "" + if n % 2 == 0: + color = ' BGCOLOR="#dfefff"' + ret += f""" + + + {f['forecastText']} +""" + ret += "
{f['periodText']}
" + return ret + + def render_image(cameras: Dict[str, str]) -> str: + for camera in cameras: + if camera["cameraId"] == 8063: + return f""" +

+ + + +
+ {camera['cameraLabel']} ({camera['direction']}) +
""" + return "" + + def periodic_render(self, unused: str) -> bool: + page = requests.get(stevens_renderer.URL) + if page.status_code == 200: + contents = json.loads(page.content) + mp = contents["mountainPass"] + conditions = contents["condition"] + cameras = contents["cameras"] + forecasts = contents["stationForecasts"][0] + with file_writer.file_writer("stevens-conditions_5_3000.html") as f: + f.write( + f""" +

Stevens Pass Conditions:

+
+ + + + + + + + +
+ {stevens_renderer.render_conditions(mp, conditions)} + + {stevens_renderer.render_image(cameras)} +
+ {stevens_renderer.render_forecast(forecasts)} +
""" + ) + return True return False + + +# Test: +# test = stevens_renderer({"Test", 123}) +# test.periodic_render("Test")