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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
|
#!/usr/bin/python
# -*- Encoding: UTF-8 -*-
###
# Copyright (c) 2006,2007 Dennis Kaarsemaker
# Copyright (C) 2008 Terence Simpson <tsimpson@ubuntu.com> (stdin on irc.freenode.net)
# Copyright (C) 2010 Elián Hanisch <lambdae2@gmail.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of version 2 of the GNU General Public License as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
###
import sys, os, sqlite, urllib2, re, time
from math import ceil
from commoncgi import send_page, form, quote
### Variables
NUM_PER_PAGE=50.0
# Directory of the factoids database
datadir = '/home/m4v/ircbot/kubot/data'
#datadir = '/home/m4v/dev/ircbot/scratDev/data'
# Database name (without .db)
default_database = 'Factos.sqlite'
#default_database = 'Factos2.sqlite'
#### You shouldn't have to change anything under this line ###
# Initialize
database = default_database
order_by = 'request_count DESC'
page = 0
search = ''
facts = []
total = 0
channel = 'global'
table = 'factos'
table_dict = {}
sort_dict = {
'created_at DESC':'Fecha -',
'created_at ASC':'Fecha +',
'name DESC': 'Nombre -',
'name ASC': 'Nombre +',
'request_count DESC': 'Popularidad -',
'request_count ASC':'Popularidad +',
}
# Read POST
#if 'db' in form:
# databases = [file for file in os.listdir(datadir)]
# db = form['db'].value
# if db in databases:
# database = db
if 'page' in form:
try:
page = int(form['page'].value)
except:
pass
if 'order' in form:
if form['order'].value in sort_dict:
order_by = form['order'].value
if 'search' in form:
search = form['search'].value
db = sqlite.connect(os.path.join(datadir, database + '.db'))
cursor = db.cursor()
# get tables
query_tables = "SELECT type,tbl_name FROM sqlite_master"
cursor.execute(query_tables)
for tbl in cursor.fetchall():
if tbl[0] == 'table' and tbl[1].startswith('factos_'):
tbl = tbl[1]
if tbl == 'factos_#scratbot': continue # #scratbot is a testing channel
chan = tbl[len('factos_')+1:]
table_dict[chan] = tbl
if 'channel' in form:
chan = form['channel'].value
if chan in table_dict:
channel = chan
table = table_dict[chan]
# sort links
print '<br />Ordenar por<br />·'
for sort in ('created_at DESC', 'created_at ASC', 'name DESC', 'name ASC', 'request_count DESC',
'request_count ASC'):
print ' <a href="factos.cgi?db=%s&search=%s&order=%s&page=0&channel=%s">%s</a> ·' % (database, search,
sort, channel, sort_dict[sort])
# channel links
print '<br />Canales<br />·'
print ' <a href="factos.cgi?db=%s&search=%s&order=%s&page=0&channel=%s">%s</a> ·' %(database,
search, order_by, 'global', 'global')
for chan in sorted(table_dict):
print ' <a href="factos.cgi?db=%s&search=%s&order=%s&page=0&channel=%s">#%s</a> ·' %(database,
search, order_by, chan, chan)
print '<br />'
# Note: Fact modes
# 1 - disabled
# 2 - locked
# 4 - alias
# Select factoids
if search:
keys = [urllib2.unquote(x.strip()) for x in search.split() if len(x.strip()) >=2][:5]
if not keys:
keys = ['']
query = "SELECT name,data,created_by,created_at,request_count FROM '%s' "\
"WHERE NOT (flags & 1 OR flags & 4) AND (" %table
count = "SELECT COUNT(name) FROM '%s' WHERE NOT (flags & 1 OR flags & 4) AND " %table
bogus = False
for k in keys:
k = repr('%' + k + '%')
if bogus:
query1 += ' OR '
query2 += ' OR '
query += "name LIKE %s OR data LIKE %s" % (k, k)
count += "name LIKE %s OR data LIKE %s" % (k, k)
bogus=True
query += ') ORDER BY %s LIMIT %d, %d' % (order_by, NUM_PER_PAGE*page, NUM_PER_PAGE)
cursor.execute(query)
facts = cursor.fetchall()
cursor.execute(count)
total = cursor.fetchall()[0][0]
else:
query = "SELECT name,data,created_by,created_at,request_count FROM '%s' "\
"WHERE NOT (flags & 1 OR flags & 4) ORDER BY %s" %(table, order_by)
# FIXME due to a limitation of how request_count is done, must fetch all fact until it's
# fixed
#LIMIT %d, %d" %(table,
# order_by, page*NUM_PER_PAGE, NUM_PER_PAGE)
count = "SELECT COUNT(*) FROM '%s' WHERE NOT (flags & 1 OR flags & 4)" %table
cursor.execute(query)
facts = cursor.fetchall()
cursor.execute(count)
total = cursor.fetchall()[0][0]
# Pagination links
npages = int(ceil(total / float(NUM_PER_PAGE)))
print '·'
for i in range(npages):
print '<a href="factos.cgi?db=%s&search=%s&order=%s&page=%s&channel=%s">%d</a> ·' \
%(database, search, order_by, i, channel, i+1)
print '<table cellspacing="0"><tr><th>Facto</th><th>Contenido</th><th>Autor</th></tr>'
url_re = re.compile('(?P<url>(https?://[^\s)>]+|www[^\s)>]+))')
def format_data(s):
s = quote(s)
s = stripcolor(s)
return url_re.sub(link, s)
def link(match):
url = match.group('url')
txt = url
if len(txt) > 30:
txt = txt[:20] + '…' + txt[-10:]
return '<a href="%s">%s</a>' % (url, txt)
_stripcolorre = re.compile(r'\x03(?:\d{1,2},\d{1,2}|\d{1,2}|,\d{1,2}|)')
def stripcolor(s):
return _stripcolorre.sub('', s)
date_string = lambda t: time.strftime('%d/%m/%y %H:%M', time.localtime(int(t)))
def format_alias(L):
if isinstance(L, list):
return ' <br />'.join(L)
return L
facts = [ list(f) for f in facts ]
for f in facts:
query = "SELECT name,data,created_by,created_at,request_count FROM factos WHERE " \
"(flags & 4) AND NOT (flags & 1) AND data='%s'" %f[0]
cursor.execute(query)
alias = cursor.fetchall()
if alias:
alias = list(alias)
alias.append(f)
# sort alias by count, so the most used shows first
alias.sort(key=lambda x: x[4])
alias.reverse()
f[4] = sum([a[4] for a in alias]) # sum all request counts
# make a list of all names
f[0] = [a[0] for a in alias]
# sort (this is due to a limitation of how facts are counted in the bot)
order_by = order_by.split()
if order_by[0] == 'request_count':
facts.sort(key=lambda x: x[4])
if order_by[1] == 'DESC':
facts.reverse()
if len(facts) > NUM_PER_PAGE:
facts = facts[page*NUM_PER_PAGE:(page+1)*NUM_PER_PAGE]
i = 0
for f in facts:
names = f[0]
names = format_alias(names)
data = format_data(f[1])
author = f[2]
query_author = "SELECT host FROM usuarios WHERE user_id='%s'" %author
cursor.execute(query_author)
author = cursor.fetchall()[0][0]
author = author[:author.find('!')]
date = date_string(f[3])
count = f[4]
print '<tr',
if i % 2:
print ' class="bg2"',
i += 1
print '><td>%s</td><td>%s</td><td><b>%s</b><br />Agregado el: %s' \
'<br />Usado %s veces</td>' %(names, data, author, date, count)
print '</table>'
send_page('factoids.tmpl')
# vim:set shiftwidth=4 softtabstop=4 tabstop=4 expandtab textwidth=100:
|