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 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
# SPDX-License-Identifier: AGPL-3.0-or-later
"""
FreedomBox app for using Let's Encrypt.
"""
import logging
from django.contrib import messages
from django.shortcuts import redirect
from django.urls import reverse_lazy
from django.utils.translation import gettext as _
from django.views.decorators.http import require_POST
from plinth.modules import letsencrypt
from plinth.views import AppView, messages_error
logger = logging.getLogger(__name__)
class LetsEncryptAppView(AppView):
"""Show Let's Encrypt app main page."""
app_id = 'letsencrypt'
template_name = 'letsencrypt.html'
def get_context_data(self, *args, **kwargs):
"""Add additional context data for template."""
context = super().get_context_data(*args, **kwargs)
context['status'] = letsencrypt.get_status()
return context
@require_POST
def revoke(request, domain):
"""Revoke a certificate for a given domain."""
try:
letsencrypt.certificate_revoke(domain)
messages.success(
request,
_('Certificate successfully revoked for domain {domain}.'
'This may take a few moments to take effect.').format(
domain=domain))
except Exception as exception:
messages_error(
request,
_('Failed to revoke certificate for domain {domain}').format(
domain=domain), exception)
return redirect(reverse_lazy('letsencrypt:index'))
@require_POST
def obtain(request, domain):
"""Obtain and install a certificate for a given domain."""
try:
letsencrypt.certificate_obtain(domain)
messages.success(
request,
_('Certificate successfully obtained for domain {domain}').format(
domain=domain))
except Exception as exception:
messages_error(
request,
_('Failed to obtain certificate for domain {domain}').format(
domain=domain), exception)
return redirect(reverse_lazy('letsencrypt:index'))
@require_POST
def reobtain(request, domain):
"""Re-obtain a certificate for a given domain."""
try:
letsencrypt.certificate_reobtain(domain)
messages.success(
request,
_('Certificate successfully obtained for domain {domain}').format(
domain=domain))
except Exception as exception:
messages_error(
request,
_('Failed to obtain certificate for domain {domain}').format(
domain=domain), exception)
return redirect(reverse_lazy('letsencrypt:index'))
@require_POST
def delete(request, domain):
"""Delete a certificate for a given domain, and cleanup renewal config."""
try:
letsencrypt.certificate_delete(domain)
messages.success(
request,
_('Certificate successfully deleted for domain {domain}').format(
domain=domain))
except Exception as exception:
messages_error(
request,
_('Failed to delete certificate for domain {domain}').format(
domain=domain), exception)
return redirect(reverse_lazy('letsencrypt:index'))
|