8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2024-11-16 00:13:12 +00:00
re2o/preferences/forms.py

495 lines
17 KiB
Python
Raw Normal View History

# Re2o un logiciel d'administration développé initiallement au rezometz. Il
# se veut agnostique au réseau considéré, de manière à être installable en
# quelques clics.
#
# Copyright © 2017 Gabriel Détraz
# Copyright © 2017 Lara Kermarec
# Copyright © 2017 Augustin Lemesle
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
"""
Formulaire d'edition des réglages : user, machine, topologie, asso...
"""
from __future__ import unicode_literals
from django.forms import ModelForm, Form
2019-09-23 21:39:54 +00:00
from django.db.models import Q
from django import forms
2018-08-05 16:48:35 +00:00
from django.utils.translation import ugettext_lazy as _
from re2o.mixins import FormRevMixin
2018-04-16 03:28:27 +00:00
from .models import (
OptionalUser,
OptionalMachine,
OptionalTopologie,
GeneralOption,
AssoOption,
MailMessageOption,
2018-04-16 16:22:51 +00:00
HomeOption,
Service,
MailContact,
Reminder,
RadiusKey,
SwitchManagementCred,
2018-12-02 16:03:27 +00:00
RadiusOption,
CotisationsOption,
2019-09-09 15:04:30 +00:00
DocumentTemplate,
2019-09-21 21:10:28 +00:00
RadiusAttribute,
Mandate,
2018-04-16 03:28:27 +00:00
)
from topologie.models import Switch
class EditOptionalUserForm(ModelForm):
"""Formulaire d'édition des options de l'user. (solde, telephone..)"""
class Meta:
model = OptionalUser
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditOptionalUserForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["is_tel_mandatory"].label = _("Telephone number required")
self.fields["gpg_fingerprint"].label = _("GPG fingerprint")
self.fields["all_can_create_club"].label = _("All can create a club")
self.fields["all_can_create_adherent"].label = _("All can create a member")
self.fields["self_adhesion"].label = _("Self registration")
self.fields["shell_default"].label = _("Default shell")
class EditOptionalMachineForm(ModelForm):
"""Options machines (max de machines, etc)"""
class Meta:
model = OptionalMachine
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditOptionalMachineForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["password_machine"].label = _(
"Possibility to set a password per machine"
)
self.fields["max_lambdauser_interfaces"].label = _(
"Maximum number of interfaces allowed for a standard user"
)
self.fields["max_lambdauser_aliases"].label = _(
"Maximum number of DNS aliases allowed for a standard user"
)
self.fields["ipv6_mode"].label = _("IPv6 mode")
self.fields["create_machine"].label = _("Can create a machine")
class EditOptionalTopologieForm(ModelForm):
"""Options de topologie, formulaire d'edition (vlan par default etc)
On rajoute un champ automatic provision switchs pour gérer facilement
l'ajout de switchs au provisionning automatique"""
automatic_provision_switchs = forms.ModelMultipleChoiceField(
Switch.objects.all(), required=False
)
class Meta:
model = OptionalTopologie
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditOptionalTopologieForm, self).__init__(*args, prefix=prefix, **kwargs)
self.initial["automatic_provision_switchs"] = Switch.objects.filter(
automatic_provision=True
).order_by("interface__domain__name")
def save(self, commit=True):
instance = super().save(commit)
Switch.objects.all().update(automatic_provision=False)
self.cleaned_data["automatic_provision_switchs"].update(
automatic_provision=True
)
return instance
class EditGeneralOptionForm(ModelForm):
"""Options générales (affichages de résultats de recherche, etc)"""
class Meta:
model = GeneralOption
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditGeneralOptionForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["general_message_fr"].label = _("General message in French")
self.fields["general_message_en"].label = _("General message in English")
self.fields["search_display_page"].label = _(
"Number of results displayed when searching"
)
self.fields["pagination_number"].label = _(
"Number of items per page, standard size (e.g. users)"
)
self.fields["pagination_large_number"].label = _(
"Number of items per page, large size (e.g. machines)"
)
self.fields["req_expire_hrs"].label = _(
"Time before expiration of the reset password link (in hours)"
)
self.fields["site_name"].label = _("Website name")
self.fields["email_from"].label = _("Email address for automatic emailing")
self.fields["GTU_sum_up"].label = _("Summary of the General Terms of Use")
self.fields["GTU"].label = _("General Terms of Use")
class EditAssoOptionForm(ModelForm):
"""Options de l'asso (addresse, telephone, etc)"""
class Meta:
model = AssoOption
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditAssoOptionForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["name"].label = _("Organisation name")
self.fields["siret"].label = _("SIRET number")
self.fields["adresse1"].label = _("Address (line 1)")
self.fields["adresse2"].label = _("Address (line 2)")
self.fields["contact"].label = _("Contact email address")
self.fields["telephone"].label = _("Telephone number")
self.fields["pseudo"].label = _("Usual name")
self.fields["utilisateur_asso"].label = _(
"Account used for editing from /admin"
)
self.fields["description"].label = _("Description")
class EditMailMessageOptionForm(ModelForm):
"""Formulaire d'edition des messages de bienvenue personnalisés"""
class Meta:
model = MailMessageOption
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditMailMessageOptionForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["welcome_mail_fr"].label = _(
"Message for the French welcome email"
)
self.fields["welcome_mail_en"].label = _(
"Message for the English welcome email"
)
2018-04-16 16:22:51 +00:00
class EditHomeOptionForm(ModelForm):
"""Edition forms of Home options"""
2018-04-16 03:28:27 +00:00
class Meta:
2018-04-16 16:22:51 +00:00
model = HomeOption
fields = "__all__"
2018-04-16 03:28:27 +00:00
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(EditHomeOptionForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["facebook_url"].label = _("Facebook URL")
self.fields["twitter_url"].label = _("Twitter URL")
self.fields["twitter_account_name"].label = _("Twitter account name")
2018-04-16 03:28:27 +00:00
2018-12-02 16:03:27 +00:00
class EditRadiusOptionForm(ModelForm):
"""Edition forms for Radius options"""
2018-12-02 16:03:27 +00:00
class Meta:
model = RadiusOption
fields = "__all__"
2018-12-02 16:03:27 +00:00
def clean(self):
cleaned_data = super().clean()
ignored = ("radius_general_policy", "vlan_decision_ok")
fields = (f for f in self.fields.keys() if "vlan" not in f and f not in ignored)
for f in fields:
choice = cleaned_data.get(f)
vlan = cleaned_data.get(f + "_vlan")
if choice == RadiusOption.SET_VLAN and vlan is None:
self.add_error(f, _("You chose to set vlan but did not set any VLAN."))
self.add_error(f + "_vlan", _("Please, choose a VLAN."))
return cleaned_data
2018-12-02 16:03:27 +00:00
class EditCotisationsOptionForm(ModelForm):
"""Edition forms for Cotisations options"""
class Meta:
model = CotisationsOption
fields = "__all__"
2019-09-21 21:10:28 +00:00
class MandateForm(ModelForm):
"""Edit Mandates"""
2019-09-21 21:10:28 +00:00
class Meta:
model = Mandate
fields = "__all__"
2019-09-21 21:10:28 +00:00
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
2019-09-21 21:10:28 +00:00
super(MandateForm, self).__init__(*args, prefix=prefix, **kwargs)
2019-09-23 21:39:54 +00:00
def clean_start_date(self):
date = self.cleaned_data.get("start_date")
2019-09-23 21:39:54 +00:00
existing_mandates = Mandate.objects.filter(
start_date__gte=date, end_date__lt=date
)
if existing_mandates:
raise forms.ValidationError(
_(
"There is already a mandate taking place at the specified start date."
)
2019-09-23 21:39:54 +00:00
)
return date
def clean_end_date(self):
date = self.cleaned_data.get("end_date")
2019-09-23 21:39:54 +00:00
if date is None:
return None
existing_mandates = Mandate.objects.filter(
start_date__gte=date, end_date__lt=date
)
if existing_mandates:
raise forms.ValidationError(
_("There is already a mandate taking place at the specified end date.")
)
return date
def clean(self):
cleaned_data = super(MandateForm, self).clean()
start_date, end_date = cleaned_data["start_date"], cleaned_data["end_date"]
2019-09-28 10:38:57 +00:00
if end_date:
included_mandates = Mandate.objects.filter(
Q(start_date__gte=start_date, start_date__lt=end_date)
| Q(end_date__gt=start_date, end_date__lte=end_date)
2019-09-23 21:39:54 +00:00
)
2019-09-28 10:38:57 +00:00
if included_mandates:
raise forms.ValidationError(
_("The specified dates overlap with an existing mandate."),
code="invalid",
2019-09-28 10:38:57 +00:00
)
2019-09-23 21:39:54 +00:00
return cleaned_data
def save(self, commit=True):
"""Warning, side effect : if a mandate with a null end_date
exists, its end_date will be set to instance.start_date, no matter the
value of commit."""
instance = super(MandateForm, self).save(commit=False)
if instance.end_date is None:
try:
previous_mandate = Mandate.objects.get(end_date__isnull=True)
previous_mandate.end_date = instance.start_date
previous_mandate.save()
except Mandate.DoesNotExist:
pass
if commit:
instance.save()
return instance
2019-09-21 21:10:28 +00:00
class ServiceForm(ModelForm):
"""Edition, ajout de services sur la page d'accueil"""
class Meta:
model = Service
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(ServiceForm, self).__init__(*args, prefix=prefix, **kwargs)
self.fields["name"].label = _("Name")
self.fields["url"].label = _("URL")
self.fields["description"].label = _("Description")
self.fields["image"].label = _("Image")
class DelServiceForm(Form):
"""Suppression de services sur la page d'accueil"""
services = forms.ModelMultipleChoiceField(
queryset=Service.objects.none(),
2018-08-05 16:48:35 +00:00
label=_("Current services"),
widget=forms.CheckboxSelectMultiple,
)
def __init__(self, *args, **kwargs):
instances = kwargs.pop("instances", None)
super(DelServiceForm, self).__init__(*args, **kwargs)
if instances:
self.fields["services"].queryset = instances
else:
self.fields["services"].queryset = Service.objects.all()
class ReminderForm(FormRevMixin, ModelForm):
"""Edition, ajout de services sur la page d'accueil"""
class Meta:
model = Reminder
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(ReminderForm, self).__init__(*args, prefix=prefix, **kwargs)
class RadiusKeyForm(FormRevMixin, ModelForm):
"""Edition, ajout de clef radius"""
members = forms.ModelMultipleChoiceField(
queryset=Switch.objects.all(), required=False
)
class Meta:
model = RadiusKey
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(RadiusKeyForm, self).__init__(*args, prefix=prefix, **kwargs)
instance = kwargs.get("instance", None)
if instance:
self.initial["members"] = Switch.objects.filter(radius_key=instance)
def save(self, commit=True):
instance = super().save(commit)
instance.switch_set = self.cleaned_data["members"]
return instance
class SwitchManagementCredForm(FormRevMixin, ModelForm):
"""Edition, ajout de creds de management pour gestion
et interface rest des switchs"""
members = forms.ModelMultipleChoiceField(Switch.objects.all(), required=False)
class Meta:
model = SwitchManagementCred
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(SwitchManagementCredForm, self).__init__(*args, prefix=prefix, **kwargs)
instance = kwargs.get("instance", None)
if instance:
self.initial["members"] = Switch.objects.filter(management_creds=instance)
def save(self, commit=True):
instance = super().save(commit)
instance.switch_set = self.cleaned_data["members"]
return instance
class MailContactForm(ModelForm):
"""Edition, ajout d'adresse de contact"""
class Meta:
model = MailContact
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(MailContactForm, self).__init__(*args, prefix=prefix, **kwargs)
class DelMailContactForm(Form):
"""Delete contact email adress"""
mailcontacts = forms.ModelMultipleChoiceField(
queryset=MailContact.objects.none(),
2019-01-08 23:39:47 +00:00
label=_("Current email addresses"),
widget=forms.CheckboxSelectMultiple,
)
def __init__(self, *args, **kwargs):
instances = kwargs.pop("instances", None)
super(DelMailContactForm, self).__init__(*args, **kwargs)
if instances:
self.fields["mailcontacts"].queryset = instances
else:
self.fields["mailcontacts"].queryset = MailContact.objects.all()
2018-08-05 16:48:35 +00:00
class DocumentTemplateForm(FormRevMixin, ModelForm):
"""
Form used to create a document template.
"""
class Meta:
model = DocumentTemplate
fields = "__all__"
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
super(DocumentTemplateForm, self).__init__(*args, prefix=prefix, **kwargs)
class DelDocumentTemplateForm(FormRevMixin, Form):
"""
Form used to delete one or more document templatess.
The use must choose the one to delete by checking the boxes.
"""
document_templates = forms.ModelMultipleChoiceField(
queryset=DocumentTemplate.objects.none(),
label=_("Current document templates"),
widget=forms.CheckboxSelectMultiple,
)
def __init__(self, *args, **kwargs):
instances = kwargs.pop("instances", None)
super(DelDocumentTemplateForm, self).__init__(*args, **kwargs)
if instances:
self.fields["document_templates"].queryset = instances
else:
self.fields["document_templates"].queryset = Banque.objects.all()
2019-09-09 15:04:30 +00:00
class RadiusAttributeForm(ModelForm):
"""Edit and add RADIUS attributes."""
2019-09-09 15:04:30 +00:00
class Meta:
model = RadiusAttribute
fields = "__all__"
2019-09-09 15:04:30 +00:00
def __init__(self, *args, **kwargs):
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
2019-09-09 15:04:30 +00:00
super(RadiusAttributeForm, self).__init__(*args, prefix=prefix, **kwargs)
class DelRadiusAttributeForm(Form):
"""Delete RADIUS attributes"""
2019-09-09 15:04:30 +00:00
attributes = forms.ModelMultipleChoiceField(
queryset=RadiusAttribute.objects.none(),
label=_("Current attributes"),
widget=forms.CheckboxSelectMultiple,
2019-09-09 15:04:30 +00:00
)
def __init__(self, *args, **kwargs):
instances = kwargs.pop("instances", None)
2019-09-09 15:04:30 +00:00
super(DelServiceForm, self).__init__(*args, **kwargs)
if instances:
self.fields["attributes"].queryset = instances
2019-09-09 15:04:30 +00:00
else:
self.fields["attributes"].queryset = Attributes.objects.all()