2017-10-27 10:29:33 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
from sanic import Sanic
|
|
|
|
import sanic.response
|
2017-11-30 17:02:06 +00:00
|
|
|
from sanic.log import log as logging
|
2017-10-27 10:29:33 +01:00
|
|
|
import validators
|
|
|
|
import urllib.parse
|
2017-10-30 09:24:46 +00:00
|
|
|
import shared
|
2017-10-27 10:29:33 +01:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2017-11-30 17:02:06 +00:00
|
|
|
#logging_format = "[%(asctime)s] %(process)d-%(levelname)s "
|
|
|
|
#logging_format += "%(module)s::%(funcName)s():l%(lineno)d: "
|
|
|
|
#logging_format += "%(message)s"
|
2017-10-27 10:29:33 +01:00
|
|
|
|
2017-11-30 17:02:06 +00:00
|
|
|
#logging.basicConfig(
|
|
|
|
#format=logging_format,
|
|
|
|
#level=logging.DEBUG
|
|
|
|
#)
|
|
|
|
#log = logging.getLogger()
|
2017-10-27 10:29:33 +01:00
|
|
|
|
|
|
|
# log_config=None prevents creation of access_log and error_log files
|
|
|
|
# since I'm running this from systemctl it already goes into syslog
|
|
|
|
app = Sanic('router', log_config=None)
|
|
|
|
# this is ok to be read-only
|
2017-10-30 09:24:46 +00:00
|
|
|
sdb = shared.SearchDB()
|
2017-10-27 10:29:33 +01:00
|
|
|
|
|
|
|
@app.route("/oauth1", methods=["GET"])
|
|
|
|
async def oauth1(request):
|
|
|
|
token = request.args.get('oauth_token')
|
|
|
|
verifier = request.args.get('oauth_verifier')
|
2017-11-30 17:02:06 +00:00
|
|
|
logging.info("incoming oauth request: token was %s ; verifier was %s", token, verifier)
|
2017-10-27 10:29:33 +01:00
|
|
|
tokendb = shared.TokenDB()
|
|
|
|
tokendb.update_token(
|
|
|
|
token,
|
|
|
|
verifier=verifier
|
|
|
|
)
|
2017-11-30 17:02:06 +00:00
|
|
|
return sanic.response.text("OK", status=200)
|
2017-10-27 10:29:33 +01:00
|
|
|
|
|
|
|
@app.route("/search", methods=["GET"])
|
|
|
|
async def search(request):
|
|
|
|
query = request.args.get('s')
|
|
|
|
r = sdb.html(query)
|
|
|
|
response = sanic.response.html(r, status=200)
|
|
|
|
return response
|
|
|
|
|
2017-11-30 17:02:06 +00:00
|
|
|
@app.route("/micropub", methods=["POST", "GET"])
|
2017-10-27 10:29:33 +01:00
|
|
|
async def micropub(request):
|
|
|
|
return sanic.response.text("Not Implemented", status=501)
|
|
|
|
|
|
|
|
@app.route("/webmention", methods=["POST"])
|
|
|
|
async def webmention(request):
|
|
|
|
source = request.form.get('source')
|
|
|
|
target = request.form.get('target')
|
|
|
|
|
|
|
|
# validate urls
|
|
|
|
if not validators.url(source):
|
|
|
|
return sanic.response.text('Invalide source url', status=400)
|
|
|
|
if not validators.url(target):
|
|
|
|
return sanic.response.text('Invalide target url', status=400)
|
|
|
|
|
|
|
|
# check if our site is actually the target for the webmention
|
|
|
|
_target = urllib.parse.urlparse(target)
|
|
|
|
if _target.hostname not in shared.config.get('site', 'domains'):
|
|
|
|
return sanic.response.text('target domain is not me', status=400)
|
|
|
|
|
|
|
|
# ignore selfpings
|
|
|
|
_source = urllib.parse.urlparse(source)
|
|
|
|
if _source.hostname in shared.config.get('site', 'domains'):
|
|
|
|
return sanic.response.text('selfpings are not allowed', status=400)
|
|
|
|
|
|
|
|
# it is unfortunate that I need to init this every time, but
|
|
|
|
# otherwise it'll become read-only for reasons I'm yet to grasp
|
|
|
|
# the actual parsing will be done at site generation time
|
2017-10-30 09:24:46 +00:00
|
|
|
wdb = shared.WebmentionQueue()
|
2017-11-30 17:02:06 +00:00
|
|
|
wdb.queue(source, target)
|
2017-10-27 15:56:05 +01:00
|
|
|
|
|
|
|
# telegram notification, if set
|
2017-10-29 19:11:01 +00:00
|
|
|
shared.notify(
|
|
|
|
'incoming webmention from %s to %s' % (
|
|
|
|
source,
|
|
|
|
target
|
2017-10-27 15:56:05 +01:00
|
|
|
)
|
2017-10-29 19:11:01 +00:00
|
|
|
)
|
2017-10-27 10:29:33 +01:00
|
|
|
response = sanic.response.text("Accepted", status=202)
|
|
|
|
return response
|
|
|
|
|
2017-11-30 17:02:06 +00:00
|
|
|
app.run(host="127.0.0.1", port=8008, log_config=None)
|