import shutil
import requests
import logging,coloredlogs
from py2Lib import bit
import Util.MachineProductCfg as MPC
import records.LFRecord as LFR
import gzip
from os import remove
import xml.dom.minidom
l = logging.getLogger(__name__)
coloredlogs.install()
geocodes = []
coopIds = []
for i in MPC.getPrimaryLocations():
coopIds.append(LFR.getCoopId(i))
geocodes.append(LFR.getLatLong(i).replace('/', ','))
apiKey = "21d8a80b3d6b444998a80b3d6b1449d3"
def getData(coopId, geocode):
fetchUrl = f"https://api.weather.com/v2/indices/wateringNeeds/daypart/7day?geocode={geocode}&language=en-US&format=xml&apiKey={apiKey}"
res = requests.get(fetchUrl)
if res.status_code != 200:
l.error("DO NOT REPORT THE ERROR BELOW")
l.error(f"Failed to write WateringNeeds record -- Status code {res.status_code}")
return
data = res.text
newData = data[63:-26]
i2Doc = f'\n \n {newData}\n {coopId}\n '
f = open('./.temp/WateringNeeds.i2m', 'a')
f.write(i2Doc)
f.close()
def makeRecord():
l.info("Writing WateringNeeds record.")
header = ''
footer = ''
with open('./.temp/WateringNeeds.i2m', 'a') as doc:
doc.write(header)
for (x, y) in zip(coopIds, geocodes):
getData(x,y)
with open('./.temp/WateringNeeds.i2m', 'a') as end:
end.write(footer)
dom = xml.dom.minidom.parse('./.temp/WateringNeeds.i2m')
xmlPretty = dom.toprettyxml(indent= " ")
with open('./.temp/WateringNeeds.i2m', 'w') as g:
g.write(xmlPretty[23:])
g.close()
# Compresss i2m to gzip
with open ('./.temp/WateringNeeds.i2m', 'rb') as f_in:
with gzip.open('./.temp/WateringNeeds.gz', 'wb') as f_out:
shutil.copyfileobj(f_in, f_out)
file = "./.temp/WateringNeeds.gz"
command = ''
bit.sendFile([file], [command], 1, 0)
remove('./.temp/WateringNeeds.i2m')
remove('./.temp/WateringNeeds.gz')