Files
@ 8b7294a804a0
Branch filter:
Location: kallithea/rhodecode/lib/middleware/https_fixup.py - annotation
8b7294a804a0
2.5 KiB
text/x-python
Update CONTRIBUTORS with new contributors from RhodeCode v2.2.5
04c9bb9ca6d6 04c9bb9ca6d6 04c9bb9ca6d6 04c9bb9ca6d6 04c9bb9ca6d6 04c9bb9ca6d6 6832ef664673 04c9bb9ca6d6 04c9bb9ca6d6 89efedac4e6c 04c9bb9ca6d6 04c9bb9ca6d6 a671db5bdd58 a671db5bdd58 a671db5bdd58 a671db5bdd58 6832ef664673 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 6832ef664673 1e757ac98988 a671db5bdd58 1e757ac98988 8ecfed1d8f8b 110a00c181de 2723276285ae 1e757ac98988 2723276285ae 110a00c181de 1e757ac98988 110a00c181de 04c9bb9ca6d6 1e757ac98988 1e757ac98988 c394a564ab71 4ed55c851d1c c394a564ab71 4ed55c851d1c 4ed55c851d1c 4ed55c851d1c 4ed55c851d1c 4ed55c851d1c 4ed55c851d1c 4ed55c851d1c 04c9bb9ca6d6 1e757ac98988 2723276285ae 2723276285ae 6832ef664673 1e757ac98988 1e757ac98988 f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be f0851f37d6be 04c9bb9ca6d6 f0851f37d6be 110a00c181de 110a00c181de 787f1d157984 f0851f37d6be f0851f37d6be | # -*- coding: utf-8 -*-
"""
rhodecode.lib.middleware.https_fixup
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
middleware to handle https correctly
:created_on: May 23, 2010
:author: marcink
:copyright: (C) 2010-2012 Marcin Kuzminski <marcin@python-works.com>
:license: GPLv3, see COPYING for more details.
"""
# This program 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.
#
# 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.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from rhodecode.lib.utils2 import str2bool
class HttpsFixup(object):
def __init__(self, app, config):
self.application = app
self.config = config
def __call__(self, environ, start_response):
self.__fixup(environ)
debug = str2bool(self.config.get('debug'))
is_ssl = environ['wsgi.url_scheme'] == 'https'
def custom_start_response(status, headers, exc_info=None):
if is_ssl and str2bool(self.config.get('use_htsts')) and not debug:
headers.append(('Strict-Transport-Security',
'max-age=8640000; includeSubDomains'))
return start_response(status, headers, exc_info)
return self.application(environ, custom_start_response)
def __fixup(self, environ):
"""
Function to fixup the environ as needed. In order to use this
middleware you should set this header inside your
proxy ie. nginx, apache etc.
"""
# DETECT PROTOCOL !
if 'HTTP_X_URL_SCHEME' in environ:
proto = environ.get('HTTP_X_URL_SCHEME')
elif 'HTTP_X_FORWARDED_SCHEME' in environ:
proto = environ.get('HTTP_X_FORWARDED_SCHEME')
elif 'HTTP_X_FORWARDED_PROTO' in environ:
proto = environ.get('HTTP_X_FORWARDED_PROTO')
else:
proto = 'http'
org_proto = proto
# if we have force, just override
if str2bool(self.config.get('force_https')):
proto = 'https'
environ['wsgi.url_scheme'] = proto
environ['wsgi._org_proto'] = org_proto
|