bitbot-3.11-fork/start.py

88 lines
2.8 KiB
Python
Raw Normal View History

2016-03-29 11:56:58 +00:00
#!/usr/bin/env python3
import argparse, os, sys, time
from src import Config, Database, EventManager, Exports, IRCBot
from src import IRCLineHandler, Logging, ModuleManager
2016-03-29 11:56:58 +00:00
def bool_input(s):
result = input("%s (Y/n): " % s)
return not result or result[0].lower() in ["", "y"]
directory = os.path.dirname(os.path.realpath(__file__))
arg_parser = argparse.ArgumentParser(
description="Python3 event-driven modular IRC bot")
arg_parser.add_argument("--config", "-c",
help="Location of the JSON config file",
default=os.path.join(directory, "bot.conf"))
arg_parser.add_argument("--database", "-d",
help="Location of the sqlite3 database file",
default=os.path.join(directory, "databases", "bot.db"))
arg_parser.add_argument("--log", "-l",
help="Location of the main log file",
default=os.path.join(directory, "logs", "bot.log"))
arg_parser.add_argument("--verbose", "-v", action="store_true")
args = arg_parser.parse_args()
log = Logging.Log(args.log)
config = Config.Config(args.config).load_config()
database = Database.Database(log, args.database)
events = events = EventManager.EventHook(log)
exports = exports = Exports.Exports()
2016-03-29 11:56:58 +00:00
bot = IRCBot.Bot()
bot.modules = modules = ModuleManager.ModuleManager(bot, events, exports,
os.path.join(directory, "modules"))
bot.line_handler = IRCLineHandler.LineHandler(bot, events)
bot.log = log
bot.config = config
bot.database = database
bot._events = events
bot._exports = exports
bot.args = args
bot._events.on("timer.reconnect").hook(bot.reconnect)
bot._events.on("boot.done").hook(bot.setup_timers)
whitelist = bot.get_setting("module-whitelist", [])
blacklist = bot.get_setting("module-blacklist", [])
bot.modules.load_modules(whitelist=whitelist, blacklist=blacklist)
2016-03-29 11:56:58 +00:00
servers = []
for server_id, alias in bot.database.servers.get_all():
server = bot.add_server(server_id, connect=False)
if not server == None:
servers.append(server)
if len(servers):
bot._events.on("boot.done").call()
for server in servers:
if not bot.connect(server):
sys.stderr.write("failed to connect to '%s', exiting\r\n" % (
str(server)))
sys.exit(1)
bot.run()
2016-03-29 11:56:58 +00:00
else:
try:
if bool_input("no servers found, add one?"):
alias = input("alias: ")
2016-03-29 11:56:58 +00:00
hostname = input("hostname: ")
port = int(input("port: "))
tls = bool_input("tls?")
password = input("password?: ")
ipv4 = bool_input("ipv4?")
nickname = input("nickname: ")
username = input("username: ")
realname = input("realname: ")
bot.database.servers.add(alias, hostname, port, password, ipv4,
2016-03-29 11:56:58 +00:00
tls, nickname, username, realname)
except KeyboardInterrupt:
print()
pass