]> jfr.im git - erebus.git/blame - erebus.py
Added DB usage, fixed error in config.py, added __str__ __repr__ to Bot, BotConnection
[erebus.git] / erebus.py
CommitLineData
f4f6442e
JR
1#!/usr/bin/python
2
3#TODO: tons
4
82696467
JR
5import os, sys, select, MySQLdb, MySQLdb.cursors
6import bot, config
f4f6442e
JR
7
8class Erebus(object):
9c935294
JR
9 bots = {}
10 fds = {}
11 mods = {}
12 msghandlers = {}
13
14 class User(object):
15 chans = []
ab7c0c0b 16
9c935294
JR
17 def __init__(self, nick, auth=None):
18 self.nick = nick
19 self.auth = auth
ab7c0c0b 20
9c935294
JR
21 if auth is not None:
22 self.checklevel()
ab7c0c0b 23
9c935294
JR
24 def authed(self, auth):
25 self.auth = auth
26 self.checklevel()
ab7c0c0b 27
9c935294 28 def checklevel(self): self.level = 9999 #TODO get level from db
f9767f79 29
9c935294
JR
30 def __str__(self): return self.nick
31 def __repr__(self): return "<User %r>" % (self.nick)
f9767f79 32
9c935294
JR
33 class Channel(object):
34 users = []
35 voices = []
36 ops = []
ab7c0c0b 37
9c935294
JR
38 def __init__(self, name):
39 self.name = name
ab7c0c0b 40
9c935294
JR
41 def userjoin(self, user, level=None):
42 if user not in self.users: self.users.append(user)
43 if level == 'op' and user not in self.ops: self.ops.append(user)
44 if level == 'voice' and user not in self.voices: self.voices.append(user)
45 def userpart(self, user):
46 if user in self.ops: self.ops.remove(user)
47 if user in self.voices: self.voices.remove(user)
48 if user in self.users: self.users.remove(user)
ab7c0c0b 49
9c935294
JR
50 def userop(self, user):
51 if user in self.users and user not in self.ops: self.ops.append(user)
52 def uservoice(self, user):
53 if user in self.users and user not in self.voices: self.voices.append(user)
54 def userdeop(self, user):
55 if user in self.ops: self.ops.remove(user)
56 def userdevoice(self, user):
57 if user in self.voices: self.voices.remove(user)
58
59 def __str__(self): return self.name
60 def __repr__(self): return "<Channel %r>" % (self.name)
61
62 def __init__(self):
c5f1f47b
JR
63 if os.name == "posix":
64 self.potype = "poll"
65 self.po = select.poll()
66 else: # f.e. os.name == "nt" (Windows)
67 self.potype = "select"
68 self.fdlist = []
9c935294
JR
69
70 def newbot(self, nick, user, bind, server, port, realname, chans):
71 if bind is None: bind = ''
72 obj = bot.Bot(self, nick, user, bind, server, port, realname, chans)
73 self.bots[nick.lower()] = obj
ab7c0c0b 74
9c935294 75 def newfd(self, obj, fileno):
9c935294 76 self.fds[fileno] = obj
c5f1f47b
JR
77 if self.potype == "poll":
78 self.po.register(fileno, select.POLLIN)
79 elif self.potype == "select":
80 self.fdlist.append(fileno)
ab7c0c0b 81
f9767f79 82 def bot(self, name): #get Bot() by name (nick)
9c935294 83 return self.bots[name.lower()]
f9767f79 84 def fd(self, fileno): #get Bot() by fd/fileno
9c935294
JR
85 return self.fds[fileno]
86
f9767f79 87 def user(self, nick): #TODO #get User() by nick
9c935294 88 return self.User(nick.lower())
f9767f79 89 def channel(self, name): #TODO #get Channel() by name
9c935294
JR
90 return self.Channel(name.lower())
91
92 def poll(self):
c5f1f47b
JR
93 if self.potype == "poll":
94 return [fd for (fd, ev) in self.po.poll()]
95 elif self.potype == "select":
96 return select.select(self.fdlist, [], [])[0]
9c935294
JR
97
98 def connectall(self):
99 for bot in self.bots.itervalues():
100 if bot.conn.state == 0:
101 bot.connect()
102
103 #module functions
104 def modlist(self): pass
105 def hasmod(self, name): pass
106 def loadmod(self, name): pass
107 def unloadmod(self, name): pass
108 def reloadmod(self, name): pass
109
110 #bind functions
111 def bind(self, word, handler): pass
112 def addbind(self, word, handler): pass
113 def rmbind(self, word, handler): pass
114 def getbind(self, word, handler): pass
115
82696467 116cfg = config.Config('bot.config')
f4f6442e 117main = Erebus()
f4f6442e
JR
118
119def setup():
82696467
JR
120 main.db = MySQLdb.connect(host=cfg.dbhost, user=cfg.dbuser, passwd=cfg.dbpass, db=cfg.dbname, cursorclass=MySQLdb.cursors.DictCursor)
121 c = main.db.cursor()
122 c.execute("SELECT nick, user, bind FROM bots WHERE active = 1")
123 rows = c.fetchall()
124 c.close()
125 for row in rows:
126 c2 = main.db.cursor()
127 c2.execute("SELECT chname FROM chans WHERE bot = %s AND active = 1", (row['nick'],))
128 chans = [chdic['chname'] for chdic in c2.fetchall()]
129 c2.close()
130 main.newbot(row['nick'], row['user'], row['bind'], cfg.host, cfg.port, cfg.realname, chans)
131 main.connectall()
f4f6442e
JR
132
133def loop():
9c935294 134 poready = main.poll()
c5f1f47b 135 for fileno in poready:
9c935294 136 main.fd(fileno).getdata()
f4f6442e
JR
137
138if __name__ == '__main__':
139 setup()
9c935294 140 while True: loop()