import shutil
import logging,coloredlogs
import datetime
from py2Lib import bit
import Util.MachineProductCfg as MPC
import records.LFRecord as LFR
import gzip
from os import remove
import xml.dom.minidom
import aiohttp, aiofiles, asyncio
l = logging.getLogger(__name__)
coloredlogs.install()
geocodes = []
tideStations = []
for i in MPC.getTideStations():
tideStations.append(i)
geocodes.append(LFR.getLatLong(i))
# Open the config file and make it accessible via "cfg"
import json
with open("conf.json", "r") as file:
cfg = json.load(file)
apiKey = cfg["twcApiKey"]
async def getData(tideStation, geocode):
today = datetime.date.today()
startDate = today.strftime('%Y%m%d')
endDate_unformatted = datetime.datetime.strptime(startDate, '%Y%m%d') + datetime.timedelta(days=5)
endDate = endDate_unformatted.strftime('%Y%m%d')
data = ""
fetchUrl = f"https://api.weather.com/v1/geocode/{geocode}/forecast/tides.xml?language=en-US&units=e&startDate={startDate}&endDate={endDate}&apiKey={apiKey}"
async with aiohttp.ClientSession() as s:
async with s.get(fetchUrl) as r:
if r.status != 200:
l.error(f"Failed to write TideForecast -- status code {r.status}")
return
data = await r.text()
newData = data[53:-16]
i2Doc = f'\n \n {newData}\n {tideStation}\n '
async with aiofiles.open('./.temp/TidesForecast.i2m', 'a') as f:
await f.write(i2Doc)
await f.close()
async def makeRecord():
loop = asyncio.get_running_loop()
if len(tideStations) < 1:
l.debug("Skipping TidesForecast -- No locations.")
return
l.info("Writing TidesForecast record.")
header = ''
footer = ''
async with aiofiles.open('./.temp/TidesForecast.i2m', 'a') as doc:
await doc.write(header)
for (x, y) in zip(tideStations, geocodes):
await getData(x,y)
async with aiofiles.open('./.temp/TidesForecast.i2m', 'a') as end:
await end.write(footer)
dom = xml.dom.minidom.parse('./.temp/TidesForecast.i2m')
xmlPretty = dom.toprettyxml(indent= " ")
async with aiofiles.open('./.temp/TidesForecast.i2m', 'w') as g:
await g.write(xmlPretty[23:])
await g.close()
# Compresss i2m to gzip
with open ('./.temp/TidesForecast.i2m', 'rb') as f_in:
with gzip.open('./.temp/TidesForecast.gz', 'wb') as f_out:
shutil.copyfileobj(f_in, f_out)
file = "./.temp/TidesForecast.gz"
command = ''
bit.sendFile([file], [command], 1, 0)
remove('./.temp/TidesForecast.i2m')
remove('./.temp/TidesForecast.gz')