This repository has been archived by the owner on Nov 24, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 5
/
bhottu.py
executable file
·91 lines (83 loc) · 2.32 KB
/
bhottu.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
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# ===========================================================================
#
# File Name: bhottu.py
#
# Creation Date:
# Last Modified: Sat 05 Feb 2011 05:45:49 PM CET
#
# Author: gentoomen
#
# coding: UTF-8
#
# Description:
""" python ircbot for /g/sicp
platform is *nix
bhottu v2
"""
# ===========================================================================
# Copyright (c) gentoomen
#
# ___. .__ __ __
# \_ |__ | |__ _____/ |__/ |_ __ __
# | __ \| | \ / _ \ __\ __\ | \
# | \_\ \ Y ( <_> ) | | | | | /
# |___ /___| /\____/|__| |__| |____/
# \/ \/
import sys
import time
import signal
from config import *
from modules import *
from api import *
import ircbase
try:
from setproctitle import setproctitle
setproctitle("bhottu")
except ImportError:
pass
def sigint_handler(signum, frame):
"""Handles SIGINT signal (<C-c>). Quits program."""
#raise RuntimeError("Aborted.")
sys.exit(0)
def makeConnection():
tries = 0
while True:
try:
log.notice("Connecting to server %s:%i..." % (SERVER, PORT))
connect(SERVER, PORT, IS_SSL)
break
except:
if tries == 12:
log.critical("Failed to establish a connection, giving up")
return False
timeout = pow(2, tries)
log.notice("Connection failed, trying again in %i seconds" % timeout)
time.sleep(timeout)
tries += 1
log.notice("Success!")
return True
def main():
while True:
if not makeConnection():
break
startOutputThread()
while True:
event = readEvent()
if event == None:
break
incomingIrcEvent(event)
disconnect()
log.notice("Lost connection, reconnecting...")
if __name__ == "__main__":
signal.signal(signal.SIGINT, sigint_handler)
log.addLog(sys.stdout, STDOUT_LOGLEVEL, STDOUT_VERBOSE)
log.addLog(LOG_FILE, LOG_LEVEL, LOG_VERBOSE)
for god in GODS:
addRoot(god)
dbConnect(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_DATABASE)
ircbase.load(NICK, IDENT, MODE, REALNAME, [CHANNEL], NICK_PASS)
for module in ENABLED_MODULES:
loadModule(module)
main()