blob: ec820bab2889ed1c2f45f9aced412a2e417e0299 [file] [log] [blame]
#! /usr/bin/python
# Copyright 2013 Linaro Limited
# Author Matt Hart <matthew.hart@linaro.org>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
# MA 02110-1301, USA.
import logging
import os
import sys
import optparse
from lavapdu.shared import get_daemon_logger
from lavapdu.shared import read_settings
import daemon
try:
import daemon.pidlockfile as pidlockfile
except ImportError:
from lockfile import pidlockfile
from lavapdu.socketserver import ListenerServer
if __name__ == '__main__':
pidfile = "/var/run/lavapdu-listen.pid"
logfile = "/var/log/lavapdu-listener.log"
conffile = "/etc/lavapdu/lavapdu.conf"
settings = read_settings(conffile)
usage = "Usage: %prog [--logfile] --[loglevel]"
description = "LAVA PDU request listener server," \
"host and port are handled in %s" % conffile
parser = optparse.OptionParser(usage=usage, description=description)
parser.add_option("--logfile", dest="logfile", action="store",
type="string", help="log file [%s]" % logfile)
parser.add_option("--loglevel", dest="loglevel", action="store",
type="string", help="logging level [INFO]")
parser.add_option("--purge", dest="purge", action="store_true")
(options, args) = parser.parse_args()
if options.logfile:
if os.path.exists(os.path.dirname(options.logfile)):
logfile = options.logfile
else:
print "No such directory for specified logfile '%s'" % logfile
open(logfile, 'w').close()
level = logging.DEBUG
daemon_settings = settings["daemon"]
if daemon_settings["logging_level"] == "DEBUG":
level = logging.DEBUG
if daemon_settings["logging_level"] == "WARNING":
level = logging.WARNING
if daemon_settings["logging_level"] == "ERROR":
level = logging.ERROR
if daemon_settings["logging_level"] == "INFO":
level = logging.INFO
client_logger, watched_file_handler = get_daemon_logger(
logfile,
loglevel=level,
log_format='%(asctime)s:%(levelname)s:%(name)s:%(message)s')
if isinstance(client_logger, Exception):
print("Fatal error creating client_logger: " + str(client_logger))
sys.exit(os.EX_OSERR)
# noinspection PyArgumentList
lockfile = pidlockfile.PIDLockFile(pidfile)
if lockfile.is_locked():
logging.error("PIDFile %s already locked" % pidfile)
sys.exit(os.EX_OSERR)
context = daemon.DaemonContext(
detach_process=True,
working_directory=os.getcwd(),
pidfile=lockfile,
files_preserve=[watched_file_handler.stream],
stderr=watched_file_handler.stream,
stdout=watched_file_handler.stream)
if options.purge:
settings["purge"] = True
with context:
logging.info("Running LAVA PDU Listener %s %s %d."
% (logfile,
daemon_settings['hostname'],
daemon_settings['port']))
ListenerServer(settings).start()