]>
jfr.im git - erebus.git/blob - erebus.py
3 # Erebus IRC bot - Author: John Runyon
8 import os
, sys
, select
, MySQLdb
, MySQLdb
.cursors
9 import bot
, config
, ctlmod
20 def __init__(self
, nick
, auth
=None):
28 return self
.auth
is not None
30 def authed(self
, auth
):
31 if auth
== '0': auth
= None
40 c
.execute("SELECT level FROM users WHERE auth = %s", (self
.auth
,))
43 self
.glevel
= row
['level']
49 self
.chans
.append(chan
)
51 self
.chans
.remove(chan
)
53 def __str__(self
): return self
.nick
54 def __repr__(self
): return "<User %r (%d)>" % (self
.nick
,self
.glevel
)
56 class Channel(object):
57 def __init__(self
, name
, bot
, levels
={}):
66 def userjoin(self
, user
, level
=None):
67 if user
not in self
.users
: self
.users
.append(user
)
68 if level
== 'op' and user
not in self
.ops
: self
.ops
.append(user
)
69 if level
== 'voice' and user
not in self
.voices
: self
.voices
.append(user
)
70 def userpart(self
, user
):
71 if user
in self
.ops
: self
.ops
.remove(user
)
72 if user
in self
.voices
: self
.voices
.remove(user
)
73 if user
in self
.users
: self
.users
.remove(user
)
75 def userop(self
, user
):
76 if user
in self
.users
and user
not in self
.ops
: self
.ops
.append(user
)
77 def uservoice(self
, user
):
78 if user
in self
.users
and user
not in self
.voices
: self
.voices
.append(user
)
79 def userdeop(self
, user
):
80 if user
in self
.ops
: self
.ops
.remove(user
)
81 def userdevoice(self
, user
):
82 if user
in self
.voices
: self
.voices
.remove(user
)
84 def __str__(self
): return self
.name
85 def __repr__(self
): return "<Channel %r>" % (self
.name
)
87 def __init__(self
, trigger
):
88 self
.trigger
= trigger
89 if os
.name
== "posix":
91 self
.po
= select
.poll()
92 else: # f.e. os.name == "nt" (Windows)
93 self
.potype
= "select"
96 def newbot(self
, nick
, user
, bind
, server
, port
, realname
):
97 if bind
is None: bind
= ''
98 obj
= bot
.Bot(self
, nick
, user
, bind
, server
, port
, realname
)
99 self
.bots
[nick
.lower()] = obj
101 def newfd(self
, obj
, fileno
):
102 self
.fds
[fileno
] = obj
103 if self
.potype
== "poll":
104 self
.po
.register(fileno
, select
.POLLIN
)
105 elif self
.potype
== "select":
106 self
.fdlist
.append(fileno
)
108 def bot(self
, name
): #get Bot() by name (nick)
109 return self
.bots
[name
.lower()]
110 def fd(self
, fileno
): #get Bot() by fd/fileno
111 return self
.fds
[fileno
]
113 def user(self
, nick
):
115 if nick
in self
.users
:
116 return self
.users
[nick
]
118 user
= self
.User(nick
)
119 self
.users
[nick
] = user
121 def channel(self
, name
): #get Channel() by name
122 if name
.lower() in self
.chans
:
123 return self
.chans
[name
.lower()]
127 def newchannel(self
, bot
, name
, levels
={}):
128 chan
= self
.Channel(name
.lower(), bot
, levels
)
129 self
.chans
[name
.lower()] = chan
133 if self
.potype
== "poll":
134 return [fd
for (fd
, ev
) in self
.po
.poll()]
135 elif self
.potype
== "select":
136 return select
.select(self
.fdlist
, [], [])[0]
138 def connectall(self
):
139 for bot
in self
.bots
.itervalues():
140 if bot
.conn
.state
== 0:
144 def hook(self
, word
, handler
):
145 self
.msghandlers
[word
] = handler
146 def unhook(self
, word
):
147 del self
.msghandlers
[word
]
148 def hashook(self
, word
):
149 return word
in self
.msghandlers
150 def gethook(self
, word
):
151 return self
.msghandlers
[word
]
156 cfg
= config
.Config('bot.config')
157 main
= Erebus(cfg
.trigger
)
159 autoloads
= [mod
for mod
, yes
in cfg
.items('autoloads') if int(yes
) == 1]
160 for mod
in autoloads
:
161 ctlmod
.load(main
, mod
)
163 main
.db
= MySQLdb
.connect(host
=cfg
.dbhost
, user
=cfg
.dbuser
, passwd
=cfg
.dbpass
, db
=cfg
.dbname
, cursorclass
=MySQLdb
.cursors
.DictCursor
)
165 c
.execute("SELECT nick, user, bind FROM bots WHERE active = 1")
169 main
.newbot(row
['nick'], row
['user'], row
['bind'], cfg
.host
, cfg
.port
, cfg
.realname
)
173 poready
= main
.poll()
174 for fileno
in poready
:
175 for line
in main
.fd(fileno
).getdata():
176 main
.fd(fileno
).parse(line
)
178 if __name__
== '__main__':