mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-02-04 08:13:38 +00:00
Tests: - Initial setup: - Creates zones directory - Write default configuration - named is restarted - Forwarders - Setting forwarders works as expected. - Current list of forwarders is shown as expected - List of served domains is shown properly Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org> Reviewed-by: James Valleroy <jvalleroy@mailbox.org>
65 lines
2.0 KiB
Python
65 lines
2.0 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
"""Views for BIND module."""
|
|
|
|
from django.contrib import messages
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
from plinth.modules import names
|
|
from plinth.views import AppView
|
|
|
|
from . import privileged
|
|
from .forms import BindForm
|
|
|
|
|
|
class BindAppView(AppView): # pylint: disable=too-many-ancestors
|
|
"""A specialized view for configuring Bind."""
|
|
|
|
app_id = 'bind'
|
|
form_class = BindForm
|
|
template_name = 'bind.html'
|
|
|
|
def get_context_data(self, *args, **kwargs):
|
|
"""Get/append information for domains and additional names."""
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
served_domains = privileged.get_served_domains()
|
|
context['domains_table'] = []
|
|
for key, val in served_domains.items():
|
|
if key == 'localhost.':
|
|
continue
|
|
|
|
context['domains_table'].append({
|
|
'type': 'Domain Name',
|
|
'domain_name': key[:-1:],
|
|
'serving': 'Yes',
|
|
'ip_address': ', '.join(val),
|
|
})
|
|
|
|
for item in names.components.DomainName.list():
|
|
context['domains_table'].append({
|
|
'type': item.domain_type.display_name,
|
|
'domain_name': item.name,
|
|
'serving': '-',
|
|
'ip_address': ''
|
|
})
|
|
|
|
return context
|
|
|
|
def get_initial(self):
|
|
"""Return the values to fill in the form."""
|
|
initial = super().get_initial()
|
|
initial.update(privileged.get_config())
|
|
return initial
|
|
|
|
def form_valid(self, form):
|
|
"""Change the configurations of Bind service."""
|
|
data = form.cleaned_data
|
|
old_config = privileged.get_config()
|
|
|
|
if old_config['forwarders'] != data['forwarders'] \
|
|
or old_config['enable_dnssec'] != data['enable_dnssec']:
|
|
privileged.configure(data['forwarders'], data['enable_dnssec'])
|
|
messages.success(self.request, _('Configuration updated'))
|
|
|
|
return super().form_valid(form)
|