forked from jcoby/pugbot
-
Notifications
You must be signed in to change notification settings - Fork 1
/
send.py
executable file
·57 lines (47 loc) · 1.39 KB
/
send.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
#!/usr/bin/python
import config
import irclib
import psycopg2
import sys
import time
irclib.DEBUG = 1
def checkConnection():
global connectTimer
if not server.is_connected():
connect()
server.join(config.channel)
def connect():
server.connect(config.network, config.port, nick, ircname = name)
def welcome(connection, event):
server.join("#tf2.pug")
nick = 'Pug-Messenger'
ip = ''
if len(sys.argv) == 2:
nick = sys.argv[1]
elif len(sys.argv) == 3:
nick = sys.argv[1]
ip = sys.argv[2]
# Create an IRC object
name = 'BOT'
irc = irclib.IRC()
# Create a server object, connect and join the channel
server = irc.server()
server.connect(config.network, config.port, nick, ircname = name, localaddress = ip)
irc.add_global_handler('welcome', welcome)
database = psycopg2.connect('dbname=tf2ib host=localhost user=tf2ib password=' + config.databasePassword)
cursor = database.cursor()
minuteTimer = time.time()
while 1:
cursor.execute('BEGIN;')
cursor.execute('LOCK TABLE messages;')
cursor.execute('SELECT * FROM messages LIMIT 1;')
for row in cursor.fetchall():
print row
print time.time()
cursor.execute('DELETE FROM messages WHERE id = %s', (row[0],))
server.send_raw(row[1])
cursor.execute('COMMIT;')
irc.process_once(0.2)
if time.time() - minuteTimer > 60:
minuteTimer = time.time()
checkConnection()