mirror of
https://github.com/freedombox/FreedomBox.git
synced 2026-05-13 10:30:16 +00:00
radicale: Minor fixes for access rights config
- Fix code style. - Keep description and util functions at module level. - Add license notice to forms file. - Internationalize and make choice descriptions more informative.
This commit is contained in:
parent
c050967c92
commit
8a6b09381f
@ -16,10 +16,13 @@ All notable changes to this project will be documented in this file.
|
|||||||
- networks: Added configuration of wireless BSSID, band, and channel.
|
- networks: Added configuration of wireless BSSID, band, and channel.
|
||||||
- networks: Added NetworkManager dispatcher script to configure
|
- networks: Added NetworkManager dispatcher script to configure
|
||||||
batman-adv mesh networking.
|
batman-adv mesh networking.
|
||||||
|
- radicale: Added access rights control.
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
- Improved Dynamic DNS status message when no update needed.
|
- Improved Dynamic DNS status message when no update needed.
|
||||||
- Improved Ikiwiki description.
|
- Improved Ikiwiki description.
|
||||||
|
- Added check if a2query is installed before using it, since apache2
|
||||||
|
is not a dependency for Plinth.
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
- Added suggested packages for ikiwiki. Removed recommends since they
|
- Added suggested packages for ikiwiki. Removed recommends since they
|
||||||
|
|||||||
@ -22,7 +22,6 @@ Configuration helper for Radicale.
|
|||||||
|
|
||||||
import argparse
|
import argparse
|
||||||
import augeas
|
import augeas
|
||||||
import subprocess
|
|
||||||
|
|
||||||
from plinth import action_utils
|
from plinth import action_utils
|
||||||
|
|
||||||
@ -38,8 +37,10 @@ def parse_arguments():
|
|||||||
subparsers.add_parser('setup', help='Setup Radicale configuration')
|
subparsers.add_parser('setup', help='Setup Radicale configuration')
|
||||||
subparsers.add_parser('enable', help='Enable Radicale service')
|
subparsers.add_parser('enable', help='Enable Radicale service')
|
||||||
subparsers.add_parser('disable', help='Disable Radicale service')
|
subparsers.add_parser('disable', help='Disable Radicale service')
|
||||||
configure = subparsers.add_parser('configure', help='configure various options')
|
configure = subparsers.add_parser('configure',
|
||||||
configure.add_argument('--rights_type', help='Set the rights type for radicale')
|
help='Configure various options')
|
||||||
|
configure.add_argument('--rights_type',
|
||||||
|
help='Set the rights type for radicale')
|
||||||
|
|
||||||
return parser.parse_args()
|
return parser.parse_args()
|
||||||
|
|
||||||
@ -73,7 +74,6 @@ def subcommand_configure(arguments):
|
|||||||
aug.save()
|
aug.save()
|
||||||
|
|
||||||
action_utils.service_restart('radicale')
|
action_utils.service_restart('radicale')
|
||||||
action_utils.webserver_enable('radicale-plinth')
|
|
||||||
|
|
||||||
|
|
||||||
def subcommand_enable(_):
|
def subcommand_enable(_):
|
||||||
|
|||||||
@ -19,12 +19,14 @@
|
|||||||
Plinth module for radicale.
|
Plinth module for radicale.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
import augeas
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
from plinth import actions
|
from plinth import actions
|
||||||
from plinth import action_utils
|
from plinth import action_utils
|
||||||
from plinth import cfg
|
from plinth import cfg
|
||||||
from plinth import service as service_module
|
from plinth import service as service_module
|
||||||
|
from plinth.utils import format_lazy
|
||||||
|
|
||||||
version = 1
|
version = 1
|
||||||
|
|
||||||
@ -38,6 +40,18 @@ managed_packages = ['radicale']
|
|||||||
|
|
||||||
title = _('Calendar and Addressbook (Radicale)')
|
title = _('Calendar and Addressbook (Radicale)')
|
||||||
|
|
||||||
|
description = [
|
||||||
|
format_lazy(
|
||||||
|
_('Radicale is a CalDAV and CardDAV server. It allows synchronization '
|
||||||
|
'and sharing of scheduling and contact data. To use Radicale, a '
|
||||||
|
'<a href="http://radicale.org/user_documentation/'
|
||||||
|
'#idcaldav-and-carddav-clients"> supported client application</a> '
|
||||||
|
'is needed. Radicale can be accessed by any user with a {box_name} '
|
||||||
|
'login.'), box_name=_(cfg.box_name)),
|
||||||
|
]
|
||||||
|
|
||||||
|
CONFIG_FILE = '/etc/radicale/config'
|
||||||
|
|
||||||
|
|
||||||
def init():
|
def init():
|
||||||
"""Initialize the radicale module."""
|
"""Initialize the radicale module."""
|
||||||
@ -67,6 +81,26 @@ def disable():
|
|||||||
actions.superuser_run('radicale', ['disable'])
|
actions.superuser_run('radicale', ['disable'])
|
||||||
|
|
||||||
|
|
||||||
|
def load_augeas():
|
||||||
|
"""Prepares the augeas."""
|
||||||
|
aug = augeas.Augeas(flags=augeas.Augeas.NO_LOAD +
|
||||||
|
augeas.Augeas.NO_MODL_AUTOLOAD)
|
||||||
|
|
||||||
|
# INI file lens
|
||||||
|
aug.set('/augeas/load/Puppet/lens', 'Puppet.lns')
|
||||||
|
aug.set('/augeas/load/Puppet/incl[last() + 1]', CONFIG_FILE)
|
||||||
|
|
||||||
|
aug.load()
|
||||||
|
return aug
|
||||||
|
|
||||||
|
|
||||||
|
def get_rights_value():
|
||||||
|
"""Returns the current Rights value."""
|
||||||
|
aug = load_augeas()
|
||||||
|
value = aug.get('/files' + CONFIG_FILE + '/rights/type')
|
||||||
|
return value
|
||||||
|
|
||||||
|
|
||||||
def diagnose():
|
def diagnose():
|
||||||
"""Run diagnostics and return the results."""
|
"""Run diagnostics and return the results."""
|
||||||
results = []
|
results = []
|
||||||
|
|||||||
@ -1,10 +1,40 @@
|
|||||||
from plinth.forms import ServiceForm
|
#
|
||||||
|
# This file is part of Plinth.
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as
|
||||||
|
# published by the Free Software Foundation, either version 3 of the
|
||||||
|
# License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
|
||||||
|
"""
|
||||||
|
Forms for radicale module.
|
||||||
|
"""
|
||||||
|
|
||||||
from django import forms
|
from django import forms
|
||||||
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
from plinth.forms import ServiceForm
|
||||||
|
|
||||||
|
CHOICES = [
|
||||||
|
('owner_only', _('Only the owner of a calendar/addressbook can view or '
|
||||||
|
'make changes.')),
|
||||||
|
('owner_write', _('Any user can view any calendar/addressbook, but only '
|
||||||
|
'the owner can make changes.')),
|
||||||
|
('authenticated', _('Any user can view or make changes to any '
|
||||||
|
'calendar/addressbook.')),
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
class RadicaleForm(ServiceForm):
|
class RadicaleForm(ServiceForm):
|
||||||
"""Specialized configuration form for radicale service."""
|
"""Specialized configuration form for radicale service."""
|
||||||
CHOICES = [('authenticated', 'Authenticated'),
|
access_rights = forms.ChoiceField(choices=CHOICES, required=True,
|
||||||
('owner_only', 'Owner Only'),
|
|
||||||
('owner_write', 'Owner Write'), ]
|
|
||||||
rights = forms.ChoiceField(choices=CHOICES, required=True,
|
|
||||||
widget=forms.RadioSelect())
|
widget=forms.RadioSelect())
|
||||||
|
|||||||
@ -15,70 +15,40 @@
|
|||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
import augeas
|
"""
|
||||||
|
Views for radicale module.
|
||||||
|
"""
|
||||||
|
|
||||||
from django.contrib import messages
|
from django.contrib import messages
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
from plinth.views import ServiceView
|
|
||||||
from plinth import cfg
|
|
||||||
from plinth.utils import format_lazy
|
|
||||||
from plinth import actions
|
from plinth import actions
|
||||||
|
from plinth.views import ServiceView
|
||||||
|
|
||||||
|
from . import description, get_rights_value, managed_services
|
||||||
from .forms import RadicaleForm
|
from .forms import RadicaleForm
|
||||||
|
|
||||||
CONFIG_FILE = '/etc/radicale/config'
|
|
||||||
DEFAULT_FILE = '/etc/default/radicale'
|
|
||||||
|
|
||||||
description = [
|
|
||||||
format_lazy(
|
|
||||||
_('Radicale is a CalDAV and CardDAV server. It allows synchronization '
|
|
||||||
'and sharing of scheduling and contact data. To use Radicale, a '
|
|
||||||
'<a href="http://radicale.org/user_documentation/'
|
|
||||||
'#idcaldav-and-carddav-clients"> supported client application</a> '
|
|
||||||
'is needed. Radicale can be accessed by any user with a {box_name} '
|
|
||||||
'login.'), box_name=_(cfg.box_name)),
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
def load_augeas():
|
|
||||||
"""Prepares the augeas"""
|
|
||||||
aug = augeas.Augeas(flags=augeas.Augeas.NO_LOAD +
|
|
||||||
augeas.Augeas.NO_MODL_AUTOLOAD)
|
|
||||||
aug.set('/augeas/load/Shellvars/lens', 'Shellvars.lns')
|
|
||||||
aug.set('/augeas/load/Shellvars/incl[last() + 1]', DEFAULT_FILE)
|
|
||||||
|
|
||||||
# INI file lens
|
|
||||||
aug.set('/augeas/load/Puppet/lens', 'Puppet.lns')
|
|
||||||
aug.set('/augeas/load/Puppet/incl[last() + 1]', CONFIG_FILE)
|
|
||||||
aug.load()
|
|
||||||
return aug
|
|
||||||
|
|
||||||
|
|
||||||
def get_rights_value():
|
|
||||||
"""Returns the current Rights value"""
|
|
||||||
aug = load_augeas()
|
|
||||||
value = aug.get('/files' + CONFIG_FILE + '/rights/type')
|
|
||||||
return value
|
|
||||||
|
|
||||||
|
|
||||||
class RadicaleServiceView(ServiceView):
|
class RadicaleServiceView(ServiceView):
|
||||||
"""A specialized view for configuring radicale service."""
|
"""A specialized view for configuring radicale service."""
|
||||||
service_id = 'radicale'
|
service_id = managed_services[0]
|
||||||
form_class = RadicaleForm
|
form_class = RadicaleForm
|
||||||
diagnostics_module_name = 'radicale'
|
diagnostics_module_name = 'radicale'
|
||||||
description = description
|
description = description
|
||||||
|
|
||||||
def get_initial(self):
|
def get_initial(self):
|
||||||
"""Return the values to fill in the form"""
|
"""Return the values to fill in the form."""
|
||||||
initial = super().get_initial()
|
initial = super().get_initial()
|
||||||
initial['rights'] = get_rights_value()
|
initial['access_rights'] = get_rights_value()
|
||||||
return initial
|
return initial
|
||||||
|
|
||||||
def form_valid(self, form):
|
def form_valid(self, form):
|
||||||
"""Change the access control of Radicale service."""
|
"""Change the access control of Radicale service."""
|
||||||
data = form.cleaned_data
|
data = form.cleaned_data
|
||||||
if get_rights_value() != data['rights']:
|
if get_rights_value() != data['access_rights']:
|
||||||
actions.superuser_run('radicale', ['configure', '--rights_type', data['rights']])
|
actions.superuser_run(
|
||||||
messages.success(self.request, _('Status Changed'))
|
'radicale',
|
||||||
|
['configure', '--rights_type', data['access_rights']])
|
||||||
|
messages.success(self.request,
|
||||||
|
_('Access rights configuration updated'))
|
||||||
return super().form_valid(form)
|
return super().form_valid(form)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user