patch From: Krytarik Raido <krytarik@gmail.com>

This commit is contained in:
Nicolas Coevoet 2020-11-24 20:22:16 +00:00
parent 9ce973e926
commit 2060b4f8c6

387
server.py
View File

@ -1,13 +1,6 @@
import http.server import os, re, time, base64
import os
import time
import base64
import re
import supybot.utils as utils import supybot.utils as utils
import sqlite3 import http.server, sqlite3
import collections
import urllib.parse
from io import StringIO
host = 'http://domain.tld' host = 'http://domain.tld'
port = 80 port = 80
@ -16,11 +9,11 @@ webpath = '/bantracker'
username = 'username' username = 'username'
password = 'password' password = 'password'
filename = '/home/botaccount/data/networkname/ChanTracker.db' filename = '/home/botaccount/data/networkname/ChanTracker.db'
channels = [] # empty to allows view of all channels recorded, otherwise restrict the views to channels channels = [] # empty to allow view of all channels recorded, otherwise restrict the views to channels
# usage python server.py # usage python server.py
auth = '%s:%s' % (username,password) auth = '%s:%s' % (username,password)
base64string = base64.b64encode(auth.encode('UTF-8')) base64string = base64.b64encode(auth.encode('utf-8')).decode('utf-8')
def timeElapsed(elapsed, short=False, leadingZeroes=False, years=True, def timeElapsed(elapsed, short=False, leadingZeroes=False, years=True,
weeks=True, days=True, hours=True, minutes=True, seconds=True): weeks=True, days=True, hours=True, minutes=True, seconds=True):
@ -65,21 +58,35 @@ def timeElapsed(elapsed, short=False, leadingZeroes=False, years=True,
else: else:
return format('%L', ret) return format('%L', ret)
class MyHandler( http.server.BaseHTTPRequestHandler ): class MyHandler(http.server.BaseHTTPRequestHandler):
server_version= "Ircd-Seven/1.1"
if not standalone: if not standalone:
def log_request(self, *args): def log_request(self, *args):
pass # disable logging pass # disable logging
def do_GET( self ): def do_GET(self):
self.page( self.path ) self.page(self.path)
def page(self, query):
def write(subtitle, body):
page = [
'<html style="text-align:center;font-size:1.2em;">',
'<head>\n<title>BanTracker%s</title>' % (' &raquo; %s' % subtitle if subtitle else ''),
'<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />',
'<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css"></link>',
'</head>\n<body style="margin:0.5em;width:98%;margin-left:auto;margin-right:auto;text-align:left;" class="container">'
] + body + ['</body>\n</html>']
self.send_response(200)
self.send_header("Content-type","text/html")
full = '\n'.join(page)
print('HTML lines %s' % len(full))
self.send_header("Content-length",len(full))
self.end_headers()
self.wfile.write(full.encode('utf-8'))
def page (self,query):
if standalone: if standalone:
h = '%s:%s/' % (host,port) h = '%s:%s/' % (host,port)
else: else:
h = '%s/' % webpath h = '%s/' % webpath
body = []
if not query: if not query:
return return
if query.startswith('/?username='): if query.startswith('/?username='):
@ -93,287 +100,260 @@ class MyHandler( http.server.BaseHTTPRequestHandler ):
if aa[0] == 'password': if aa[0] == 'password':
p = aa[1] p = aa[1]
if u and p: if u and p:
raw = base64.encodebytes(bytes('%s:%s' % (u,p), 'UTF-8'))[:-1] raw = base64.b64encode('%s:%s'.encode('utf-8') % (u,p)).decode('utf-8')
if not raw == base64string: if raw != base64string:
query = '' query = ''
else: else:
query = '/?hash=%s' % base64string.decode('UTF-8') query = '/?hash=%s' % base64string
if not query.startswith('/?hash='): if not query.startswith('/?hash='):
body.append('<html>\n<head>\n<title>ChanTracker</title>\n') subtitle = ''
body.append('<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\n') body = [
body.append("</head>\n<body>\n") '<form action="%s">' % h,
body.append('<form action="%s">\n' % h) '<p>Username: <input name="username" /></p>',
body.append('<p>Username:<input name="username" /></p>\n') '<p>Password: <input name="password" type="password"/></p>',
body.append('<p>Password:<input name="password" type="password"/></p>\n') '<button type="submit" class="btn btn-default">Login</button>',
body.append('<input type="submit" value="Login" />\n') '</form>'
body.append("</form>\n") ]
body.append("</body>\n<html>\n") write(subtitle, body)
self.send_response(200)
self.send_header("Content-type","text/html")
full = ''.join(body)
self.send_header("Content-length",str(len(full)))
self.end_headers()
self.wfile.write(full.encode('UTF-8'))
return return
if query.startswith('/?hash='):
a = query.split('&')[0]
a = a.replace('/?hash=','')
query = query.replace('%3D','=') query = query.replace('%3D','=')
query = query.replace('/?hash=%s' % base64string.decode('UTF-8'),'/') query = query.replace('/?hash=%s' % base64string,'')
q = '?hash=%s' % base64string.decode('UTF-8') query = query.lstrip('&')
query = urllib.parse.unquote( query ) q = '?hash=%s' % base64string
query = utils.web.urlunquote(query)
subtitle = ''
body = [
'<div class="row"><div class="col-xs-6">',
'<form action="%s" class="form">' % q,
'<div class="input-group">',
'<input type="hidden" name="hash" value="%s">' % base64string,
'<input name="search" class="form-control" />',
'<span class="input-group-btn"><button type="submit" class="btn btn-default">Search</button></span>',
'</div></form></div></div>',
'<div class="clearfix"></div>'
]
if not query:
write(subtitle, body)
return
print(query) print(query)
body.append('<html style="text-align:center;font-size:1.2em;">\n<head>\n<title>BanTracker - %s</title>\n' % query) subtitle = query
body.append('<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />\n')
body.append('<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css"></link>\n')
# body.append('<script src="http://www.kryogenix.org/code/browser/sorttable/sorttable.js"></script>\n')
body.append('</head>\n<body style="margin:0.5em;width:98%;margin-left:auto;margin-right:auto;text-align:left;" class="container">\n')
body.append('<div class="row"><div class="col-xs-6">\n')
body.append('<form action="%s" class="form">\n' % q)
body.append('<div class="input-group">')
body.append('<input type="hidden" name="hash" value="%s">' % base64string.decode('UTF-8'))
body.append('<input name="search" class="form-control" />\n')
body.append('<span class="input-group-btn"><button type="submit" class="btn btn-default">Search</button></span>\n')
body.append('</div></form></div></div>\n')
body.append('<div class="clearfix"></div>\n')
db = self._getbandb() db = self._getbandb()
c = db.cursor() c = db.cursor()
if query:
ar = [] ar = []
if query.startswith('/&id='): if query.startswith('id='):
search = query.split('/&id=')[1] search = query.split('=')[1]
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=? ORDER BY id DESC""",(search,)) si = int(search)
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=?""",(si,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
ban = r[0] ban = r[0]
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban (id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban
if not len(channels) or channel in channels: if not channels or channel in channels:
body.append('<h3>#%s</h3>\n' % id) body.extend([
body.append('<p>#%s by %s in %s : +%s : %s</p>\n' % (id,oper,channel,kind,mask)) '<h3>#%d</h3>' % id,
body.append('<p>Begin at %s</p>\n' % time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(begin_at)))) '<p>#%d by <a href="%s%s&%s">%s</a>' % (id,h,q,utils.web.urlencode({'oper':oper}),oper),
'in <a href="%s%s&channel=%s">%s</a>:' % (h,q,channel.split('#')[1],channel),
'+%s <a href="%s%s&%s">%s</a></p>' % (kind,h,q,utils.web.urlencode({'mask':mask}),mask),
'<p>Begin at %s</p>' % time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(begin_at)))
])
was = float(begin_at) == float(end_at) was = float(begin_at) == float(end_at)
if was: if was:
was = 'forever' was = 'forever'
else: else:
was = timeElapsed(float(end_at) - float(begin_at)) was = timeElapsed(float(end_at) - float(begin_at))
body.append('<p>Original duration : %s</p>\n' % was) body.append('<p>Original duration: %s</p>' % was)
if not removed_at: if not removed_at:
if was != 'forever': if was != 'forever':
body.append('<p>%s</p>\n' % 'It will expire in %s' % timeElapsed(float(end_at) - time.time())) body.append('<p>It will expire in %s</p>' % timeElapsed(float(end_at) - time.time()))
else: else:
body.append('<p>%s</p>\n' % 'Removed after %s on %s by %s' % (timeElapsed(float(removed_at)-float(begin_at)),time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(removed_at))),removed_by)) body.extend(['<p>Removed after %s' % timeElapsed(float(removed_at)-float(begin_at)),
c.execute("""SELECT full, log FROM nicks WHERE ban_id=?""",(id,)) 'on %s' % time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(removed_at))),
'by <a href="%s%s&%s">%s</a></p>' % (h,q,utils.web.urlencode({'removed_by':removed_by}),removed_by)])
c.execute("""SELECT full,log FROM nicks WHERE ban_id=?""",(id,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
users = r body.append('<h3>Logs</h3>')
body.append('<h3>Logs</h3>\n') for nick in r:
for u in users: (full,log) = nick
(full,log) = u body.append('<p>for %s</p>' % full)
body.append('<p>for %s</p>\n' % full)
if log != '': if log != '':
body.append('<ul>\n') body.append('<ul>')
for line in log.split('\n'): for line in log.split('\n'):
if line != '': if line != '':
body.append('<li>%s</li>\n' % line) body.append('<li>%s</li>' % line)
body.append('</ul>\n') body.append('</ul>')
c.execute("""SELECT oper, at, comment FROM comments WHERE ban_id=?""",(id,)) c.execute("""SELECT oper,at,comment FROM comments WHERE ban_id=?""",(id,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
body.append('<h3>Comments</h3>\n') body.extend(['<h3>Comments</h3>', '<ul>'])
body.append('<ul>\n') for comment in r:
comments = r (oper,at,com) = comment
for com in comments:
(oper,at,comment) = com
s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(at))) s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(at)))
body.append('<li>%s by %s : %s</li>\n' % (s,oper,comment)) body.append('<li>%s by %s: %s</li>' % (s,oper,com))
body.append('</ul>\n') body.append('</ul>')
elif query.startswith('/&channel='): c.close()
search = '#'+query.split('/&channel=')[1] write(subtitle, body)
return
elif query.startswith('channel='):
search = '#'+query.split('=')[1]
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE channel=? ORDER BY id DESC""",(search,)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE channel=? ORDER BY id DESC""",(search,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r ar.extend(r)
for ban in bans: elif query.startswith('removed_by='):
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban search = query.split('=')[1]
ar.append([int(id),channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by])
elif query.startswith('/&removed_by='):
search = query.split('/&removed_by=')[1]
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE removed_by=? ORDER BY id DESC""",(search,)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE removed_by=? ORDER BY id DESC""",(search,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r ar.extend(r)
for ban in bans: elif query.startswith('oper='):
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban search = query.split('=')[1]
ar.append([int(id),channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by])
elif query.startswith('/&oper='):
search = query.split('/&oper=')[1]
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE oper=? ORDER BY id DESC""",(search,)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE oper=? ORDER BY id DESC""",(search,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r ar.extend(r)
for ban in bans: elif query.startswith('mask='):
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban search = query.split('=')[1]
ar.append([int(id),channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by]) sg = '*%s*' % search
elif query.startswith('/&mask='): sl = '%%%s%%' % search
search = query.split('/&mask=')[1] c.execute("""SELECT ban_id,full FROM nicks WHERE full GLOB ? OR full LIKE ? OR log GLOB ? OR log LIKE ? ORDER BY ban_id DESC""",(sg,sl,sg,sl))
glob = '*%s*' % search r = c.fetchall()
like = '%'+search+'%'
c.execute("""SELECT ban_id, full FROM nicks WHERE full GLOB ? OR full LIKE ? OR log GLOB ? OR log LIKE ? ORDER BY ban_id DESC""",(glob,like,glob,like))
L = [] L = []
a = {} a = {}
r = c.fetchall()
if len(r): if len(r):
bans = r
d = {} d = {}
for ban in bans: for ban in r:
(id,full) = ban (id,full) = ban
if not id in d: if id not in d:
d[id] = id d[id] = id
for id in d: for id in d:
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=? ORDER BY id DESC""",(int(id),)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=?""",(id,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r for ban in r:
for ban in bans: a[ban[0]] = ban
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE mask GLOB ? OR mask LIKE ? ORDER BY id DESC""",(sg,sl))
a[str(id)] = ban
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE mask GLOB ? OR mask LIKE ? ORDER BY id DESC""",(glob,like))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r for ban in r:
for ban in bans: a[ban[0]] = ban
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban
a[str(id)] = ban
if len(a): if len(a):
ar = [] ar = []
for ban in a: for ban in list(a.keys()):
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = a[ban] ar.append(a[ban])
ar.append([int(id),channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by]) ar.sort(key=lambda x: x[0], reverse=True)
def sort_function (item): elif query.startswith('search='):
return item[0] search = query.split('=')[1]
ar.sort(key=sort_function)
ar.sort(reverse=True)
elif query.startswith('/&search='):
search = query.split('/&search=')[1]
search = search.replace('+','*') search = search.replace('+','*')
print(search) print(search)
if search: if search:
s = '*%s*' % search if not re.match(r'^[0-9]+$', search):
qu = '%'+search+'%' sg = '*%s*' % search
c.execute("""SELECT ban_id, full FROM nicks WHERE full GLOB ? OR full LIKE ? OR log GLOB ? OR log LIKE ? ORDER BY ban_id DESC""",(s,qu,s,qu)) sl = '%%%s%%' % search
si = None
c.execute("""SELECT ban_id,full FROM nicks WHERE full GLOB ? OR full LIKE ? OR log GLOB ? OR log LIKE ? ORDER BY ban_id DESC""",(sg,sl,sg,sl))
r = c.fetchall()
else:
si = int(search)
r = []
L = [] L = []
a = {} a = {}
r = c.fetchall()
if len(r): if len(r):
bans = r
d = {} d = {}
for ban in bans: for ban in r:
(id,full) = ban (id,full) = ban
if not id in d: if id not in d:
d[id] = id d[id] = id
for id in d: for id in d:
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=? ORDER BY id DESC""",(int(id),)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=?""",(id,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r for ban in r:
for ban in bans: a[ban[0]] = ban
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban if not si:
a[id] = ban c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE mask GLOB ? OR mask LIKE ? OR channel GLOB ? OR channel LIKE ? OR oper GLOB ? OR oper LIKE ? ORDER BY id DESC""",(sg,sl,sg,sl,sg,sl))
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE mask GLOB ? OR mask LIKE ? OR channel GLOB ? OR channel LIKE ? OR oper GLOB ? OR oper LIKE ? ORDER BY id DESC""",(s,qu,s,qu,s,qu)) else:
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=?""",(si,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r for ban in r:
for ban in bans: a[ban[0]] = ban
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban if not si:
a[id] = ban c.execute("""SELECT ban_id, comment FROM comments WHERE comment GLOB ? OR comment LIKE ? ORDER BY ban_id DESC""",(sg,sl))
c.execute("""SELECT ban_id, comment FROM comments WHERE comment GLOB ? OR comment LIKE ? ORDER BY ban_id DESC""",(s,qu))
r = c.fetchall() r = c.fetchall()
else:
r = []
d = {} d = {}
if len(r): if len(r):
bans = r for ban in r:
for ban in bans:
(id,full) = ban (id,full) = ban
d[id] = id d[id] = id
for id in d: for id in d:
if not id in a: if id not in a:
c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=? ORDER BY id DESC LIMIT 1""",(int(id),)) c.execute("""SELECT id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by FROM bans WHERE id=?""",(id,))
r = c.fetchall() r = c.fetchall()
if len(r): if len(r):
bans = r for ban in r:
for ban in bans: a[ban[0]] = ban
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban
a[id] = ban
if len(a): if len(a):
ar = [] ar = []
for ban in a: for ban in list(a.keys()):
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = a[ban] ar.append(a[ban])
ar.append([int(id),channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by]) ar.sort(key=lambda x: x[0], reverse=True)
def sort_function (item):
return item[0]
ar.sort(key=sort_function)
ar.sort(reverse=True)
else:
body.append('<p>nothing found</p>\n')
if len(ar): if len(ar):
print('found %s results' % len(ar)) print('Found %s results' % len(ar))
i = 0 body.extend([
body.append('<h3>results <small>%s</small></h3>' % search) '<h3>Results <small>%s</small></h3>' % search,
body.append('<div class="row"><div class="col-xs-12"><table class="table table-bordered sortable">\n') '<div class="row"><div class="col-xs-12"><table class="table table-bordered sortable">',
body.append('<thead><tr><th>ID</th><th>Channel</th><th>Operator</th><th>Kind</th><th>Target</th><th>Begin date</th><th>End date</th><th>Removed date</th><th>Removed by</th></tr></thead>\n') '<thead><tr><th>ID</th><th>Channel</th><th>Operator</th><th>Type</th><th>Mask</th><th>Begin date</th><th>End date</th><th>Removed</th><th>Removed by</th></tr></thead>',
body.append('<tbody>\n') '<tbody>'
while i < len(ar): ])
(id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ar[i] for ban in ar:
if not len(channels) or channel in channels: (id,channel,oper,kind,mask,begin_at,end_at,removed_at,removed_by) = ban
body.append('<tr>\n') if not channels or channel in channels:
body.append('<td><a href="%s%s&id=%s">%s</a></td>\n' % (h,q,id,id))
body.append('<td><a href="%s%s&channel=%s">%s</a></td>\n' % (h,q,channel.split('#')[1],channel))
body.append('<td><a href="%s%s&%s">%s</a></td>\n' % (h,q,urllib.parse.urlencode({'oper':oper}),oper))
body.append('<td>+%s</td>\n' % kind)
body.append('<td><a href="%s%s&%s">%s</a></td>\n' % (h,q,urllib.parse.urlencode({'mask':mask}),mask))
s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(begin_at))) s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(begin_at)))
body.append('<td>%s</td>\n' % s) body.extend([
'<tr>',
'<td><a href="%s%s&id=%d">%d</a></td>' % (h,q,id,id),
'<td><a href="%s%s&channel=%s">%s</a></td>' % (h,q,channel.split('#')[1],channel),
'<td><a href="%s%s&%s">%s</a></td>' % (h,q,utils.web.urlencode({'oper':oper}),oper),
'<td>+%s</td>' % kind,
'<td><a href="%s%s&%s">%s</a></td>' % (h,q,utils.web.urlencode({'mask':mask}),mask),
'<td>%s</td>' % s
])
if end_at and end_at != begin_at: if end_at and end_at != begin_at:
s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(end_at))) s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(end_at)))
body.append( '<td>%s</td>\n' % s) body.append('<td>%s</td>' % s)
else: else:
body.append( '<td></td>') body.append('<td></td>')
if removed_at: if removed_at:
s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(removed_at))) s = time.strftime('%Y-%m-%d %H:%M:%S GMT',time.gmtime(float(removed_at)))
body.append( '<td>%s</td>' % s) body.append('<td>%s</td>' % s)
else: else:
body.append( '<td></td>\n' ) body.append('<td></td>')
if removed_by: if removed_by:
body.append( '<td><a href="%s%s&%s">%s</a></td>\n' % (h,q,urllib.parse.urlencode({'removed_by':removed_by}),removed_by)) body.append('<td><a href="%s%s&%s">%s</a></td>' % (h,q,utils.web.urlencode({'removed_by':removed_by}),removed_by))
else: else:
body.append( '<td></td>\n') body.append('<td></td>')
# affected = '' # affected = ''
# try: # try:
# c.execute("""SELECT full, log FROM nicks WHERE ban_id=?""",(id,)) # c.execute("""SELECT full, log FROM nicks WHERE ban_id=?""",(id,))
# affected = len(c.fetchall()) # affected = len(c.fetchall())
# except: # except:
# affected = '' # affected = ''
# body.append( '<td>%s</td>\n' % affected) # body.append('<td>%s</td>' % affected)
body.append( '</tr>\n') body.append('</tr>')
i = i+1 body.extend(['</tbody>', '</table></div>'])
body.append('</tbody>\n') else:
body.append('</table></div>\n') body.append('<p>Nothing found</p>')
body.append("</body></html>")
self.send_response(200)
self.send_header("Content-type","text/html")
full = ''.join(body)
print('html lines %s' % len(full))
self.send_header("Content-length",len(full))
self.end_headers()
self.wfile.write(full.encode('UTF-8'))
c.close() c.close()
write(subtitle, body)
def _getbandb (self): def _getbandb(self):
if os.path.exists(filename): if os.path.exists(filename):
db = sqlite3.connect(filename,timeout=10) db = sqlite3.connect(filename,timeout=10)
db.text_factory = str
return db return db
db = sqlite3.connect(filename) db = sqlite3.connect(filename)
db.text_factory = str
c = db.cursor() c = db.cursor()
c.execute("""CREATE TABLE bans ( c.execute("""CREATE TABLE bans (
id INTEGER PRIMARY KEY, id INTEGER PRIMARY KEY,
@ -401,10 +381,9 @@ class MyHandler( http.server.BaseHTTPRequestHandler ):
db.commit() db.commit()
return db return db
def httpd(handler_class=MyHandler, server_address = ('', port), ): def httpd(handler_class=MyHandler, server_address=('', port)):
srvr = http.server.HTTPServer(server_address, handler_class) srvr = http.server.HTTPServer(server_address, handler_class)
srvr.serve_forever() srvr.serve_forever()
if __name__ == "__main__": if __name__ == "__main__":
httpd( ) httpd()