2017-05-26 10:14:24 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import os
|
2017-06-12 15:17:29 +01:00
|
|
|
#import sys
|
|
|
|
#sys.path.append(os.path.dirname(os.path.abspath(__file__)))
|
2017-05-26 10:14:24 +01:00
|
|
|
|
2017-06-12 15:17:29 +01:00
|
|
|
import asyncio
|
|
|
|
import uvloop
|
2017-05-26 10:14:24 +01:00
|
|
|
from sanic import Sanic
|
|
|
|
import sanic.response
|
|
|
|
from sanic.log import log as logging
|
|
|
|
from whoosh import index
|
|
|
|
from whoosh import qparser
|
|
|
|
import jinja2
|
|
|
|
import shared
|
|
|
|
|
|
|
|
def SearchHandler(query, tmpl):
|
|
|
|
response = sanic.response.text(
|
|
|
|
"You seem to have forgot to enter what you want to search for. Please try again.",
|
|
|
|
status=400
|
|
|
|
)
|
|
|
|
|
|
|
|
if not query:
|
|
|
|
return response
|
|
|
|
|
|
|
|
query = query.replace('+', ' AND ').replace(' -', ' NOT ')
|
|
|
|
ix = index.open_dir(os.path.abspath(os.path.join(
|
|
|
|
shared.config.get('target', 'builddir'),
|
|
|
|
shared.config.get('var', 'searchdb')
|
|
|
|
)))
|
|
|
|
|
|
|
|
qp = qparser.MultifieldParser(
|
2017-07-17 14:21:28 +01:00
|
|
|
["title", "content"],
|
2017-05-26 10:14:24 +01:00
|
|
|
schema = shared.schema
|
|
|
|
)
|
|
|
|
|
|
|
|
q = qp.parse(query)
|
|
|
|
r = ix.searcher().search(q, sortedby="weight", limit=100)
|
|
|
|
logging.info("results for '%s': %i", query, len(r))
|
2017-07-17 14:21:28 +01:00
|
|
|
results = {}
|
2017-05-26 10:14:24 +01:00
|
|
|
for result in r:
|
2017-07-17 14:21:28 +01:00
|
|
|
if result['url'] in results.keys():
|
|
|
|
continue
|
|
|
|
|
2017-05-26 10:14:24 +01:00
|
|
|
res = {
|
|
|
|
'title': result['title'],
|
2017-07-17 14:21:28 +01:00
|
|
|
#'url': result['url'],
|
2017-05-26 10:14:24 +01:00
|
|
|
'highlight': result.highlights("content"),
|
|
|
|
}
|
|
|
|
if 'img' in result:
|
|
|
|
res['img'] = result['img']
|
2017-07-17 14:21:28 +01:00
|
|
|
results[result['url']] = res
|
2017-05-26 10:14:24 +01:00
|
|
|
|
|
|
|
tvars = {
|
|
|
|
'term': query,
|
|
|
|
'posts': results,
|
|
|
|
}
|
|
|
|
|
|
|
|
logging.info("collected %i results to render", len(results))
|
|
|
|
response = sanic.response.html(tmpl.render(tvars), status=200)
|
|
|
|
return response
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
asyncio.set_event_loop_policy(uvloop.EventLoopPolicy())
|
|
|
|
app = Sanic()
|
|
|
|
|
|
|
|
|
|
|
|
jldr = jinja2.FileSystemLoader(
|
|
|
|
searchpath=shared.config.get('source', 'templatesdir')
|
|
|
|
)
|
|
|
|
jenv = jinja2.Environment(loader=jldr)
|
|
|
|
tmpl = jenv.get_template('searchresults.html')
|
|
|
|
|
2017-06-12 15:17:29 +01:00
|
|
|
@app.route("/search", methods=["GET"])
|
|
|
|
async def search(request):
|
2017-05-26 10:14:24 +01:00
|
|
|
query = request.args.get('s')
|
|
|
|
r = SearchHandler(query, tmpl)
|
|
|
|
return r
|
|
|
|
|
|
|
|
app.run(host="127.0.0.1", port=8001, debug=True)
|