mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-01-21 07:55:00 +00:00
Tests:
- Config app description is as expected.
- Config form does not show domain name field anymore.
- Submitting the form with changes works.
- Names app has correct link for configuring static domain name. Clicking it
takes to page for setting domain name.
- On startup, static domian name signal is sent properly if set. Otherwise no
signal is send.
- Change domain name form shows correct value for current domain name.
- Change domain name form sets the value for domain name properly.
- Page title is correct.
- Validations works.
- Add/remove domain name signals are sent properly.
- Success message as shown expected
- /etc/hosts is updated as expected.
- Unit tests work.
- Functional tests on ejabberd, letsencrypt, matrix, email, jsxc, openvpn
- After freshly starting the service. Visiting names app shows correct list of
domains.
- ejabberd:
- Installs works as expected. Currently set domain_name is setup properly.
Copy certificate happens on proper domain.
- Changing the domain sets the domain properly in ejabberd configuration.
- Ejabberd app page shows link to name services instead of config app.
Clicking works as expected.
- letsencrypt:
- When no domains are configured, the link to 'Configure domains' is to the
names app.
- matrix-synapse:
- Domain name is properly shown in the status.
- email:
- Primary domain name is shows properly in the app page.
- Setting new primary domain works.
- When installing, domain set as static domain name is prioritized as primary
domain.
- jsxc:
- Show the current static domain name in the domain field. BOSH server is
available.
- openvpn:
- Show the current static domain in profile is set otherwise show the current
hostname.
- If domain name is not set, downloaded OpenVPN profile shows hostname.
Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org>
Reviewed-by: Veiko Aasa <veiko17@disroot.org>
64 lines
2.6 KiB
Python
64 lines
2.6 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
"""
|
|
Forms for basic system configuration
|
|
"""
|
|
|
|
from django import forms
|
|
from django.utils.translation import gettext as _
|
|
from django.utils.translation import gettext_lazy
|
|
|
|
from plinth import cfg, frontpage
|
|
from plinth.modules.apache import get_users_with_website
|
|
from plinth.utils import format_lazy
|
|
|
|
from . import home_page_url2scid
|
|
|
|
|
|
def get_homepage_choices():
|
|
"""Return list of drop down choices for home page."""
|
|
shortcuts = frontpage.Shortcut.list(web_apps_only=True)
|
|
shortcut_choices = [(shortcut.component_id, shortcut.name)
|
|
for shortcut in shortcuts if shortcut.is_enabled()]
|
|
uws_choices = \
|
|
[(home_page_url2scid(url),
|
|
format_lazy(gettext_lazy("{user}'s website"), user=user))
|
|
for user, url in get_users_with_website().items()]
|
|
apache_default = ('apache-default', _('Apache Default'))
|
|
plinth = ('plinth', _('FreedomBox Service (Plinth)'))
|
|
return [apache_default, plinth] + uws_choices + shortcut_choices
|
|
|
|
|
|
class ConfigurationForm(forms.Form):
|
|
"""Main system configuration form"""
|
|
|
|
homepage = forms.ChoiceField(
|
|
label=gettext_lazy('Webserver Home Page'), help_text=format_lazy(
|
|
gettext_lazy(
|
|
'Choose the default page that must be served when '
|
|
'someone visits your {box_name} on the web. A typical use '
|
|
'case is to set your blog or wiki as the home page when '
|
|
'someone visits the domain name. Note that once the home '
|
|
'page is set to something other than {box_name} Service '
|
|
'(Plinth), your users must explicitly type /plinth or '
|
|
'/freedombox to reach {box_name} Service (Plinth).'),
|
|
box_name=gettext_lazy(cfg.box_name)), required=False,
|
|
choices=get_homepage_choices)
|
|
|
|
advanced_mode = forms.BooleanField(
|
|
label=gettext_lazy('Show advanced apps and features'), required=False,
|
|
help_text=gettext_lazy(
|
|
'Show apps and features that require more technical '
|
|
'knowledge.'))
|
|
|
|
logging_mode = forms.ChoiceField(
|
|
label=gettext_lazy('System-wide logging'),
|
|
choices=(('none', gettext_lazy('Disable logging, for privacy')),
|
|
('volatile',
|
|
gettext_lazy('Keep some in memory until a restart, '
|
|
'for performance')),
|
|
('persistent',
|
|
gettext_lazy('Write to disk, useful for debugging'))),
|
|
help_text=gettext_lazy(
|
|
'Logs contain information about who accessed the system and debug '
|
|
'information from various services'))
|