This repository has been archived by the owner on Oct 25, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbot.py
executable file
·103 lines (82 loc) · 3.54 KB
/
bot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#!/usr/bin/env python3
import asyncio
import logging
import traceback
from datetime import datetime, timezone, timedelta
from wa_discord import WA_Discord
from wa_gamelist import WA_Gamelist
from wa_irc import WA_IRC
from wa_settings import WA_Settings
from wa_encoder import WA1252
from wa_http_redir import WA_HTTP_Redir
import codecs
# FUNCTIONS #
def fatal_handler(loop, context):
exception = context.get('exception')
logger.critical(f' ! {exception}')
logger.critical(' ! Encountered FATAL error. Notifying and shutting down.\n')
traceback.print_exception(type(exception), exception, exception.__traceback__)
loop.create_task(shutdown(f'Shutting down due to:```\n{exception}```'))
async def shutdown(message):
await discord.send_shutdown_message(message)
loop.stop()
async def irc_entry_help_handler(connection, message):
sender = message.prefix.nick
if message.command == 'QUIT':
channel = 'help'
else:
channel = message.parameters[0][1:].lower()
# only write join / part messages if user has written in #help
if sender in irc.activity[channel]:
# if not parting/quitting or written in a while, remove user from activity list
time_since_activity = datetime.now(timezone.utc) - irc.activity[channel][sender]
if message.command not in ('PART', 'QUIT') and time_since_activity > timedelta(minutes=5):
return irc.activity[channel].pop(sender, None)
# if parting/quitting, always show, and remove from activity list if quitting
if message.command == 'QUIT':
irc.activity[channel].pop(sender, None)
message = f'{sender} has {message.command.lower()} WormNET! [{message.parameters}]'
else:
message = f'{sender} has {message.command.lower()}ed the channel!'
return await discord.send_message(irc_channel=channel, sender=sender, message=message, action=True)
# MAIN #
try:
# REGISTER WA1252 CODEC #
codecs.register(WA1252.lookup)
# LOGGING SETUP #
logger = logging.getLogger('WA_Logger')
logging.basicConfig(format='%(asctime)s %(message)s', datefmt='%Y-%m-%d %H:%M:%S')
# ASYNCIO SETUP #
loop = asyncio.new_event_loop()
asyncio.set_event_loop(loop)
loop.set_exception_handler(fatal_handler)
# IRC SETUP #
irc = WA_IRC(loop=loop, **WA_Settings.WA_IRC)
loop.create_task(irc.connect())
# DISCORD SETUP #
discord = WA_Discord(**WA_Settings.WA_Discord)
loop.create_task(discord.update_userlists(irc.channels, interval=5))
loop.create_task(discord.run())
# LIST SETUP #
gamelist = WA_Gamelist(**WA_Settings.WA_Gamelist)
loop.create_task(gamelist.update(discord))
# HTTP LINK REDIR SETUP #
http_redir = WA_HTTP_Redir(loop=loop, **WA_Settings.WA_HTTP_Redir)
loop.create_task(http_redir.main())
# FINAL SETUP #
discord.forward_message = irc.send_message
irc.forward_message = discord.send_message
irc.commands['help'] = True
irc.commands['anythinggoes'] = False
irc.handlers['help']['PRIVMSG'] = irc.default_privmsg_handler
irc.handlers['help']['JOIN'] = irc_entry_help_handler
irc.handlers['help']['PART'] = irc_entry_help_handler
irc.handlers['help']['QUIT'] = irc_entry_help_handler
irc.handlers['anythinggoes']['PRIVMSG'] = irc.default_privmsg_handler
loop.run_forever() # this works, NICE!
except KeyboardInterrupt:
logger.critical(' ! Encountered KbdInterrupt. Shutting down.\n')
loop.create_task(shutdown(f'Shutting down at request of system'))
loop.run_forever()
except Exception as e:
print(e)