aboutsummaryrefslogtreecommitdiff
path: root/rpki/gui/decorators.py
blob: 75efeae09ebd44c92aff508bdf28941a9913812d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# Copyright (C) 2013  SPARTA, Inc. a Parsons Company
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND SPARTA DISCLAIMS ALL WARRANTIES WITH
# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
# AND FITNESS.  IN NO EVENT SHALL SPARTA BE LIABLE FOR ANY SPECIAL, DIRECT,
# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
# LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
# OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
# PERFORMANCE OF THIS SOFTWARE.

__version__ = '$Id$'

from django import http
from os import getenv


# Don't set this in production, ever.  Really.  You have been warned.
#
_allow_plain_http_for_testing = getenv("ALLOW_PLAIN_HTTP_FOR_TESTING") == "I solemnly swear that I am not running this in production"


def tls_required(f):
    """
    Decorator which returns a 500 error if the connection is not
    secured with TLS (https).
    """

    def _tls_required(request, *args, **kwargs):
        if not request.is_secure() and not _allow_plain_http_for_testing:
            return http.HttpResponseServerError(
                'This resource may only be accessed securely via https',
                content_type='text/plain')
        return f(request, *args, **kwargs)
    return _tls_required