Source code for sarracenia.flowcb.poll.airnow

"""
Posts updated files of airnowtech. 
Compatible with Python 3.5+.

usage:
	in an sr3 poll configuration file:

	pollUrl http://files.airnowtech.org/?prefix=airnow/today/

	callback airnow

STATUS: unknown... need some authentication, or perhaps the method has changed.
        does not seem to work out of the box.
"""

import datetime
import logging
import paramiko
import requests
import sarracenia
from sarracenia.flowcb import FlowCB

logger = logging.getLogger(__name__)


[docs] class Airnow(FlowCB): def poll(self): sleep = self.o.scheduled_interval gathered_messages = [] for Hours in range(1, 3): last_hour_date_time = datetime.datetime.now() - datetime.timedelta( hours=Hours) Filename = 'HourlyData_%s.dat' % last_hour_date_time.strftime( '%Y%m%d%H') logger.debug("poll_airnow_http Filename: %s" % Filename) URL = self.o.pollUrl + '/' + Filename logger.info('INFO %s ' % URL) #resp = requests.get(self.o.pollUrl + '/' + Filename) resp = requests.get(URL) if resp.ok: mtime = datetime.datetime.strptime(resp.headers['last-modified'],\ '%a, %d %b %Y %H:%M:%S %Z') last_poll = datetime.datetime.utcnow() + datetime.timedelta( seconds=-sleep) logger.info(mtime) logger.info(last_poll) fakeStat = paramiko.SFTPAttributes() fakeStat.st_size = int(resp.headers['content-length']) # convert datetime to numeric timestamp from beginning of POSIX epoch. fakeStat.st_mtime = mtime.timestamp() fakeStat.st_atime = mtime.timestamp() fakeStat.st_mode = 0o644 m = sarracenia.Message.fromFileInfo(Filename, self.o, fakeStat) gathered_messages.append(m) logger.info('mtime: %s last_pollL %s' % (mtime, last_poll)) return gathered_messages