#28359 closed New feature (wontfix)
SecurityMiddleware's SECURE_SSL_HOST only affects unsecure requests
Reported by: | Matthias Kestenholz | Owned by: | |
---|---|---|---|
Component: | HTTP handling | Version: | dev |
Severity: | Normal | Keywords: | |
Cc: | Carl Meyer | Triage Stage: | Unreviewed |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description (last modified by )
For search engine optimization purposes it is preferable to have a single domain serving all requests. We have a custom middleware in most projects which handles this but dropped the middleware for sites using SSL:
from django.conf import settings from django.http import HttpResponsePermanentRedirect def force_domain(get_response): if settings.DEBUG or not settings.FORCE_DOMAIN: return get_response def middleware(request): if request.method != 'GET': return get_response(request) if request.get_host() != settings.FORCE_DOMAIN: target = 'http%s://%s%s' % ( request.is_secure() and 's' or '', settings.FORCE_DOMAIN, request.get_full_path()) return HttpResponsePermanentRedirect(target) return get_response(request) return middleware
We noticed today that setting SECURE_SSL_HOST = 'example.com'
does not redirect requests to https://www.example.com
It seems to me that setting SECURE_SSL_REDIRECT
and SECURE_SSL_HOST
should also handle the case where 1. a request already uses a secure connection but 2. the host does not equal SECURE_SSL_HOST
.
Change History (11)
comment:1 by , 8 years ago
Description: | modified (diff) |
---|
comment:2 by , 8 years ago
Has patch: | set |
---|
comment:3 by , 8 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
HI I'd like to work on this issue, but I am a newbie to open source, I am currently a computer engineering undergraduate, I am confident that I'll be able to contribute but I need some mentoring, Mr Matthias Kestenholz can you please help me
comment:4 by , 8 years ago
You could help review the proposed feature itself and also the pull request: https://github.com/django/django/pull/8698
A good idea would also be to follow the ticket triaging steps as documented here: https://docs.djangoproject.com/en/dev/internals/contributing/triaging-tickets/#unreviewed
comment:5 by , 8 years ago
Description: | modified (diff) |
---|
I'm not sure if using SecurityMiddelware
to do canonical URL redirection (not a security-related thing, really) is a proper separation of concerns.
Also, doesn't the patch have the possibility to be backwards incompatible? Currently with SECURE_SSL_HOST
set, I think it's possible to directly access different secure subdomains. I believe this proposal prohibits that as all secure requests will be redirected to SECURE_SSL_HOST
.
comment:6 by , 8 years ago
Yes, the patch would probably be backwards incompatible for the use case you describe. I also agree that this does not have much to do with security, but maybe neither has the SECURE_SSL_HOST
functionality at all.
I'd think that, in a scenario where there are multiple valid SSL hosts, you'd rather want to keep the domain (which means that SECURE_SSL_HOST
would not be set), OR that you'd want a next
parameter for a post login redirect (which means that the standard SecurityMiddleware
would have to be replaced or augmented anyway)
(Sorry for not replying earlier, I still am on vacation.)
comment:7 by , 8 years ago
Owner: | removed |
---|---|
Status: | assigned → new |
comment:8 by , 8 years ago
Cc: | added |
---|---|
Easy pickings: | unset |
Carl, any input about the intended use case of SECURE_SSL_HOST
? I didn't find any details in the django-secure commit.
comment:9 by , 8 years ago
The intention of the setting was to provide some control over the redirect-to-SSL functionality provided by SecurityMiddleware, and it does that. I don't think SecurityMiddleware should be in the business of enforcing a canonical host for all SSL requests. It's easy enough to write your own middleware for that (and it can even use the value of SECURE_SSL_HOST if you want). The current behavior is pretty clearly documented; changing it would not be a bugfix but a change in the intended behavior.
I agree that if we were implementing this from scratch, a reasonable case could be made for the alternate behavior, but I don't think it's a strong enough case for a backwards-incompatible change.
comment:10 by , 8 years ago
Resolution: | → wontfix |
---|---|
Status: | new → closed |
Thanks, Tim and Carl.
I'm closing this ticket as wontfix. Maybe canonical URL redirection would be a better fit for CommonMiddleware
(since we have PREPEND_WWW
there) but it's easier and certainly less controversial to just implement this outside Django core.
I'll add another Django package to my long list of maintained packages then, and post the link here for posteriority :-)
comment:11 by , 8 years ago
The project is here, already deployed into production but still missing some documentation & real world testing:
PR