Files
weewx/bin/wee_reports
Tom Keffer 7bcb47fdcd Bug fix on wee_report for arbitrary time.
Fixed bug that was introduced in v3.6.0, which prevented wee_report from
working for anything other than the current time.
2016-11-24 16:29:53 -08:00

70 lines
2.1 KiB
Python
Executable File

#!/usr/bin/env python
#
# Copyright (c) 2009-2015 Tom Keffer <tkeffer@gmail.com>
#
# See the file LICENSE.txt for your rights.
#
"""Executable that can run all reports."""
import socket
import syslog
import optparse
import user.extensions #@UnusedImport
import weewx.station
import weewx.reportengine
import weecfg
from weeutil.weeutil import timestamp_to_string
description = """Run all reports defined in the specified configuration file.
Use this utility to run reports immediately instead of waiting for the end of
an archive interval."""
usage = """%prog: [config_file] [timestamp] [--config=CONFIG_FILE] [--help]"""
def main():
# Set defaults for the system logger:
syslog.openlog('wee_reports', syslog.LOG_PID | syslog.LOG_CONS)
# Create a command line parser:
parser = optparse.OptionParser(description=description, usage=usage)
# Add the various options:
parser.add_option("--config", dest="config_path", type=str, metavar="CONFIG_FILE",
help="Use the configuration file CONFIG_FILE")
# Now we are ready to parse the command line:
(options, args) = parser.parse_args()
config_path, config_dict = weecfg.read_config(options.config_path, args)
# If the user specified a time, retrieve it. Otherwise, set to None
gen_ts = int(args[0]) if args else None
print "Using configuration file %s" % config_path
if gen_ts is None:
print "Generating for all time"
else:
print "Generating for requested time", timestamp_to_string(gen_ts)
# Look for the debug flag. If set, ask for extra logging
weewx.debug = int(config_dict.get('debug', 0))
if weewx.debug:
syslog.setlogmask(syslog.LOG_UPTO(syslog.LOG_DEBUG))
else:
syslog.setlogmask(syslog.LOG_UPTO(syslog.LOG_INFO))
socket.setdefaulttimeout(10)
stn_info = weewx.station.StationInfo(**config_dict['Station'])
t = weewx.reportengine.StdReportEngine(config_dict, stn_info, gen_ts=gen_ts)
# Although the report engine inherits from Thread, we can just run it in the main thread:
t.run()
if __name__=="__main__" :
main()