monolith/legacy/main.py

132 lines
3.9 KiB
Python
Raw Permalink Normal View History

import json
import pickle
from os import urandom
from os.path import exists
2022-07-21 12:40:09 +00:00
from string import digits
from redis import StrictRedis
# List of errors ZNC can give us
2022-07-21 12:39:41 +00:00
ZNCErrors = ["Error:", "Unable to load", "does not exist", "doesn't exist"]
2019-10-13 11:38:44 +00:00
2022-07-29 07:32:39 +00:00
configPath = "conf/live/"
templateConfigPath = "conf/templates/"
certPath = "conf/cert/"
filemap = {
# JSON configs
"config": ["config.json", "configuration", "json"],
"help": ["help.json", "command help", "json"],
"counters": ["counters.json", "counters file", "json"],
"tokens": ["tokens.json", "authentication tokens", "json"],
"aliasdata": ["aliasdata.json", "data for alias generation", "json"],
"alias": ["alias.json", "provisioned alias data", "json"],
2019-12-28 17:50:38 +00:00
"irc": ["irc.json", "IRC network definitions", "json"],
2020-11-01 19:54:24 +00:00
"blacklist": ["blacklist.json", "IRC channel blacklist", "json"],
# Binary (pickle) configs
2022-07-21 12:39:41 +00:00
"network": ["network.dat", "network list", "pickle"],
}
# Connections to the plain-text interface
connections = {}
# Connections to the JSON interface
relayConnections = {}
# Mapping of network names to Protocol (IRCClient) instances
IRCPool = {}
# Mapping of network names to Reactor instances
# Needed for calling .disconnect()
ReactorPool = {}
# Mapping of network names to Factory instances
# Needed for calling .stopTrying()
FactoryPool = {}
# Temporary store for channels allocated after a LIST
# Will get purged as the instances fire up and pop() from
# their respective keys in here
TempChan = {}
# Mapping of command names to their functions
CommandMap = {}
# Incremented by 1 for each event reaching modules.counters.event()
# and cloned into lastMinuteSample every minute
runningSample = 0
lastMinuteSample = 0
# Generate 16-byte hex key for message checksums
hashKey = urandom(16)
lastEvents = {}
2022-07-21 12:40:05 +00:00
# Get networks that are currently online and dedupliate
def liveNets():
networks = set()
for i in IRCPool.keys():
2022-07-21 12:40:05 +00:00
networks.add("".join([x for x in i if x not in digits]))
return networks
2022-07-21 12:39:41 +00:00
def saveConf(var):
if var in ("help", "aliasdata"):
2022-07-29 16:28:19 +00:00
return # no need to save this
if filemap[var][2] == "json":
2022-07-21 12:39:41 +00:00
with open(configPath + filemap[var][0], "w") as f:
json.dump(globals()[var], f, indent=4)
elif filemap[var][2] == "pickle":
2022-07-21 12:39:41 +00:00
with open(configPath + filemap[var][0], "wb") as f:
pickle.dump(globals()[var], f)
else:
raise Exception("invalid format")
2022-07-21 12:39:41 +00:00
def loadConf(var):
if filemap[var][2] == "json":
filename = configPath + filemap[var][0]
# Only take the help from the templates
if var in ("help", "aliasdata"):
filename = templateConfigPath + filemap[var][0]
if not exists(filename):
# Load the template config
if var == "config":
filename = templateConfigPath + filemap[var][0]
else:
# Everything else should be blank
globals()[var] = {}
return
with open(filename, "r") as f:
globals()[var] = json.load(f)
if var == "alias":
# This is a workaround to convert all the keys into integers since JSON
# turns them into strings...
# Dammit Jason!
global alias
2022-07-21 12:39:41 +00:00
alias = {int(x): y for x, y in alias.items()}
elif filemap[var][2] == "pickle":
try:
2022-07-21 12:39:41 +00:00
with open(configPath + filemap[var][0], "rb") as f:
globals()[var] = pickle.load(f)
except FileNotFoundError:
globals()[var] = {}
else:
raise Exception("invalid format")
2022-07-21 12:39:41 +00:00
def initConf():
for i in filemap.keys():
loadConf(i)
2022-07-21 12:39:41 +00:00
def initMain():
global r, g
initConf()
2022-07-21 12:40:03 +00:00
r = StrictRedis(
2022-07-21 12:40:05 +00:00
unix_socket_path=config["RedisSocket"], db=config["RedisDBEphemeral"] # noqa
2022-07-21 12:40:03 +00:00
) # Ephemeral - flushed on quit
2022-09-05 06:20:30 +00:00
g = StrictRedis(
unix_socket_path=config["RedisSocket"], db=config["RedisDBPersistent"]
) # noqa