# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: # Copyright 2016 Florian Bruhin (The Compiler) # # This file is part of qutebrowser. # # qutebrowser is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # qutebrowser 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. # # You should have received a copy of the GNU General Public License # along with qutebrowser. If not, see . """Minimal flask webserver serving a Hello World via SSL. This script gets called as a QProcess from integration/conftest.py. """ import ssl import sys import logging import os.path import flask import webserver_sub app = flask.Flask(__name__) @app.route('/') def hello_world(): return "Hello World via SSL!" @app.after_request def log_request(response): return webserver_sub.log_request(response) @app.before_first_request def turn_off_logging(): # Turn off werkzeug logging after the startup message has been printed. logging.getLogger('werkzeug').setLevel(logging.ERROR) def main(): ssl_dir = os.path.join(os.path.abspath(os.path.dirname(__file__)), 'data', 'ssl') # WORKAROUND for https://github.com/PyCQA/pylint/issues/399 # pylint: disable=no-member, useless-suppression context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2) context.load_cert_chain(os.path.join(ssl_dir, 'cert.pem'), os.path.join(ssl_dir, 'key.pem')) app.run(port=int(sys.argv[1]), debug=False, ssl_context=context) if __name__ == '__main__': main()