From 3b1eaae929ccf31fdfa295c6a9bcd2039d47c881 Mon Sep 17 00:00:00 2001 From: dave Date: Mon, 1 May 2017 08:29:20 -0700 Subject: [PATCH] Support reading config from stdin --- bin/pyircbot | 9 ++++++--- pyircbot/pyircbot.py | 5 +++-- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/bin/pyircbot b/bin/pyircbot index 12cc955..cba1778 100755 --- a/bin/pyircbot +++ b/bin/pyircbot @@ -4,6 +4,7 @@ import logging import signal from argparse import ArgumentParser from pyircbot import PyIRCBot +from json import loads if __name__ == "__main__": @@ -16,6 +17,8 @@ if __name__ == "__main__": parser = ArgumentParser(description="Run pyircbot") parser.add_argument("-c", "--config", help="Path to config file", required=True) parser.add_argument("--debug", action="store_true", help="Dump raw irc network") + parser.add_argument("-q", "--quit-message", help="Quit message if killed by signal", + default="received signal {}") args = parser.parse_args() @@ -25,9 +28,9 @@ if __name__ == "__main__": if not args.config: log.critical("No bot config file specified (-c). Exiting.") - sys.exit(0) + sys.exit(1) - botconfig = PyIRCBot.load(args.config) + botconfig = loads(sys.stdin.read()) if args.config == "-" else PyIRCBot.load(args.config) log.debug(botconfig) @@ -35,7 +38,7 @@ if __name__ == "__main__": def signal_handler(signum, stack): print('Received:', signum) - bot.kill(message="received signal {}".format(signum)) + bot.kill(message=args.quit_message.format(signum)) signal.signal(signal.SIGINT, signal_handler) signal.signal(signal.SIGTERM, signal_handler) diff --git a/pyircbot/pyircbot.py b/pyircbot/pyircbot.py index 2c82b26..3764b54 100644 --- a/pyircbot/pyircbot.py +++ b/pyircbot/pyircbot.py @@ -12,6 +12,7 @@ from pyircbot.rpc import BotRPC from pyircbot.irccore import IRCCore from collections import namedtuple from socket import AF_INET, AF_INET6 +from json import load import os.path import asyncio @@ -370,7 +371,7 @@ class PyIRCBot(object): """ if filepath.endswith(".json"): - from json import load - return load(open(filepath, 'r')) + with open(filepath, 'r') as f: + return load(f) else: raise Exception("Unknown config format")