3
0
mirror of https://github.com/jlu5/PyLink.git synced 2025-01-12 05:02:33 +01:00

everything: Improve logging

This commit is contained in:
James Lu 2015-07-05 13:44:48 -07:00
parent 54dff7a15a
commit 211decd2aa
6 changed files with 29 additions and 33 deletions

View File

@ -83,12 +83,12 @@ class Irc():
log.error('Failed to load plugin %r: the plugin could not be found.', plugin) log.error('Failed to load plugin %r: the plugin could not be found.', plugin)
else: else:
log.error('Failed to load plugin %r: import error %s', plugin, str(e)) log.error('Failed to load plugin %r: import error %s', plugin, str(e))
print("loaded plugins: %s" % self.loaded) log.info("loaded plugins: %s", self.loaded)
if __name__ == '__main__': if __name__ == '__main__':
print('PyLink starting...') log.info('PyLink starting...')
if conf['login']['password'] == 'changeme': if conf['login']['password'] == 'changeme':
print("You have not set the login details correctly! Exiting...") log.critical("You have not set the login details correctly! Exiting...")
sys.exit(2) sys.exit(2)
protoname = conf['server']['protocol'] protoname = conf['server']['protocol']

View File

@ -6,12 +6,13 @@ import logging
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
import utils import utils
from conf import conf from conf import conf
from log import log
@utils.add_cmd @utils.add_cmd
def debug(irc, source, args): def debug(irc, source, args):
print('user index: %s' % irc.users) log.debug('user index: %s' % irc.users)
print('server index: %s' % irc.servers) log.debug('server index: %s' % irc.servers)
print('channels index: %s' % irc.channels) log.debug('channels index: %s' % irc.channels)
utils.msg(irc, source, 'Debug info printed to console.') utils.msg(irc, source, 'Debug info printed to console.')
@utils.add_cmd @utils.add_cmd

View File

@ -2,11 +2,12 @@
import sys, os import sys, os
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
import utils import utils
from log import log
def hook_join(irc, source, command, args): def hook_join(irc, source, command, args):
channel = args['channel'] channel = args['channel']
users = args['users'] users = args['users']
print('%s joined channel %s (JOIN hook caught)' % (users, channel)) log.info('%s joined channel %s (JOIN hook caught)' % (users, channel))
utils.add_hook(hook_join, 'JOIN') utils.add_hook(hook_join, 'JOIN')
def hook_privmsg(irc, source, command, args): def hook_privmsg(irc, source, command, args):
@ -14,5 +15,5 @@ def hook_privmsg(irc, source, command, args):
text = args['text'] text = args['text']
if utils.isChannel(channel) and irc.pseudoclient.nick in text: if utils.isChannel(channel) and irc.pseudoclient.nick in text:
utils.msg(irc, channel, 'hi there!') utils.msg(irc, channel, 'hi there!')
print('%s said my name on channel %s (PRIVMSG hook caught)' % (source, channel)) log.info('%s said my name on channel %s (PRIVMSG hook caught)' % (source, channel))
utils.add_hook(hook_privmsg, 'PRIVMSG') utils.add_hook(hook_privmsg, 'PRIVMSG')

View File

@ -417,11 +417,11 @@ def handle_events(irc, data):
hook_cmd = command hook_cmd = command
if command in hook_map: if command in hook_map:
hook_cmd = hook_map[command] hook_cmd = hook_map[command]
print('Parsed args %r received from %s handler (calling hook %s)' % (parsed_args, command, hook_cmd)) log.debug('Parsed args %r received from %s handler (calling hook %s)', parsed_args, command, hook_cmd)
# Iterate over hooked functions, catching errors accordingly # Iterate over hooked functions, catching errors accordingly
for hook_func in utils.command_hooks[hook_cmd]: for hook_func in utils.command_hooks[hook_cmd]:
try: try:
print('Calling function %s' % hook_func) log.debug('Calling function %s', hook_func)
hook_func(irc, numeric, command, parsed_args) hook_func(irc, numeric, command, parsed_args)
except Exception: except Exception:
# We don't want plugins to crash our servers... # We don't want plugins to crash our servers...

View File

@ -1,6 +1,7 @@
import sys import sys
import os import os
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
from log import log
import main import main
import classes import classes
@ -35,12 +36,12 @@ class FakeIRC(main.Irc):
def run(self, data): def run(self, data):
"""Queues a message to the fake IRC server.""" """Queues a message to the fake IRC server."""
print('-> ' + data) log.debug('-> ' + data)
self.proto.handle_events(self, data) self.proto.handle_events(self, data)
def send(self, data): def send(self, data):
self.messages.append(data) self.messages.append(data)
print('<- ' + data) log.debug('<- ' + data)
def takeMsgs(self): def takeMsgs(self):
"""Returns a list of messages sent by the protocol module since """Returns a list of messages sent by the protocol module since

View File

@ -2,6 +2,8 @@ import string
import re import re
from collections import defaultdict from collections import defaultdict
from log import log
global bot_commands, command_hooks global bot_commands, command_hooks
# This should be a mapping of command names to functions # This should be a mapping of command names to functions
bot_commands = {} bot_commands = {}
@ -98,13 +100,12 @@ def parseModes(irc, target, args):
return ValueError('No modes supplied in parseModes query: %r' % modes) return ValueError('No modes supplied in parseModes query: %r' % modes)
args = args[1:] args = args[1:]
if usermodes: if usermodes:
log.debug('Using irc.umodes for this query: %s', irc.umodes)
supported_modes = irc.umodes supported_modes = irc.umodes
else: else:
log.debug('Using irc.cmodes for this query: %s', irc.cmodes)
supported_modes = irc.cmodes supported_modes = irc.cmodes
print('supported modes: %s' % supported_modes)
res = [] res = []
for x in ('A', 'B', 'C', 'D'):
print('%s modes: %s' % (x, supported_modes['*'+x]))
for mode in modestring: for mode in modestring:
if mode in '+-': if mode in '+-':
prefix = mode prefix = mode
@ -112,62 +113,54 @@ def parseModes(irc, target, args):
arg = None arg = None
if mode in (supported_modes['*A'] + supported_modes['*B']): if mode in (supported_modes['*A'] + supported_modes['*B']):
# Must have parameter. # Must have parameter.
print('%s: Must have parameter.' % mode) log.debug('%s: This mode must have parameter.', mode)
arg = args.pop(0) arg = args.pop(0)
elif mode in irc.prefixmodes and not usermodes: elif mode in irc.prefixmodes and not usermodes:
# We're setting a prefix mode on someone (e.g. +o user1) # We're setting a prefix mode on someone (e.g. +o user1)
print('%s: prefixmode.' % mode) log.debug('%s: This mode is a prefix mode.', mode)
arg = args.pop(0) arg = args.pop(0)
elif prefix == '+' and mode in supported_modes['*C']: elif prefix == '+' and mode in supported_modes['*C']:
# Only has parameter when setting. # Only has parameter when setting.
print('%s: Only has parameter when setting.' % mode) log.debug('%s: Only has parameter when setting.', mode)
arg = args.pop(0) arg = args.pop(0)
res.append((prefix + mode, arg)) res.append((prefix + mode, arg))
return res return res
def applyModes(irc, target, changedmodes): def applyModes(irc, target, changedmodes):
usermodes = not isChannel(target) usermodes = not isChannel(target)
print('usermodes? %s' % usermodes) log.debug('usermodes? %s' % usermodes)
if usermodes: if usermodes:
modelist = irc.users[target].modes modelist = irc.users[target].modes
else: else:
modelist = irc.channels[target].modes modelist = irc.channels[target].modes
print('Initial modelist: %s' % modelist) log.debug('(%s) Applying modes %r on %s (initial modelist: %s)', irc.name, changedmodes, target, modelist)
print('Changedmodes: %r' % changedmodes)
for mode in changedmodes: for mode in changedmodes:
if not usermodes: if not usermodes:
pmode = '' pmode = ''
for m in ('owner', 'admin', 'op', 'halfop', 'voice'): for m in ('owner', 'admin', 'op', 'halfop', 'voice'):
if m in irc.cmodes and mode[0][1] == irc.cmodes[m]: if m in irc.cmodes and mode[0][1] == irc.cmodes[m]:
pmode = m+'s' pmode = m+'s'
print('pmode? %s' % pmode)
if pmode: if pmode:
print('pmode == True')
print(mode)
print(irc.channels[target].prefixmodes)
pmodelist = irc.channels[target].prefixmodes[pmode] pmodelist = irc.channels[target].prefixmodes[pmode]
print(pmodelist) log.debug('(%s) Initial prefixmodes list: %s', irc.name, irc.channels[target].prefixmodes)
print('Initial pmodelist: %s' % pmodelist)
if mode[0][0] == '+': if mode[0][0] == '+':
pmodelist.add(mode[1]) pmodelist.add(mode[1])
print('+')
else: else:
pmodelist.discard(mode[1]) pmodelist.discard(mode[1])
print('-') log.debug('(%s) Final prefixmodes list: %s', irc.name, irc.channels[target].prefixmodes)
print('Final pmodelist: %s' % pmodelist)
if mode[0][1] in irc.prefixmodes: if mode[0][1] in irc.prefixmodes:
# Ignore other prefix modes such as InspIRCd's +Yy # Ignore other prefix modes such as InspIRCd's +Yy
continue continue
if mode[0][0] == '+': if mode[0][0] == '+':
# We're adding a mode # We're adding a mode
modelist.add(mode) modelist.add(mode)
print('Adding mode %r' % str(mode)) log.debug('(%s) Adding mode %r on %s', irc.name, mode, target)
else: else:
# We're removing a mode # We're removing a mode
mode[0] = mode[0].replace('-', '+') mode[0] = mode[0].replace('-', '+')
modelist.discard(mode) modelist.discard(mode)
print('Removing mode %r' % str(mode)) log.debug('(%s) Removing mode %r on %s', irc.name, mode, target)
print('Final modelist: %s' % modelist) log.debug('Final modelist: %s' % modelist)
def joinModes(modes): def joinModes(modes):
modelist = '' modelist = ''