diff --git a/preferences/forms.py b/preferences/forms.py index 75491b05..dc16d8c0 100644 --- a/preferences/forms.py +++ b/preferences/forms.py @@ -53,7 +53,7 @@ from topologie.models import Switch class EditOptionalUserForm(ModelForm): - """Formulaire d'édition des options de l'user. (solde, telephone..)""" + """Form used to edit user preferences.""" class Meta: model = OptionalUser @@ -82,7 +82,7 @@ class EditOptionalUserForm(ModelForm): class EditOptionalMachineForm(ModelForm): - """Options machines (max de machines, etc)""" + """Form used to edit machine preferences.""" class Meta: model = OptionalMachine @@ -105,9 +105,7 @@ class EditOptionalMachineForm(ModelForm): 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""" + """Form used to edit the configuration of switches.""" automatic_provision_switchs = forms.ModelMultipleChoiceField( Switch.objects.all(), required=False @@ -135,7 +133,7 @@ class EditOptionalTopologieForm(ModelForm): class EditGeneralOptionForm(ModelForm): - """Options générales (affichages de résultats de recherche, etc)""" + """Form used to edit general preferences.""" class Meta: model = GeneralOption @@ -165,7 +163,7 @@ class EditGeneralOptionForm(ModelForm): class EditAssoOptionForm(ModelForm): - """Options de l'asso (addresse, telephone, etc)""" + """Form used to edit information about the organisation.""" class Meta: model = AssoOption @@ -189,7 +187,7 @@ class EditAssoOptionForm(ModelForm): class EditMailMessageOptionForm(ModelForm): - """Formulaire d'edition des messages de bienvenue personnalisés""" + """Form used to edit welcome email messages.""" class Meta: model = MailMessageOption @@ -207,7 +205,9 @@ class EditMailMessageOptionForm(ModelForm): class EditHomeOptionForm(ModelForm): - """Edition forms of Home options""" + """Form used to edit the social networks information displayed on the home + page. + """ class Meta: model = HomeOption @@ -222,7 +222,7 @@ class EditHomeOptionForm(ModelForm): class EditRadiusOptionForm(ModelForm): - """Edition forms for Radius options""" + """Form used to edit RADIUS preferences.""" class Meta: model = RadiusOption @@ -242,7 +242,7 @@ class EditRadiusOptionForm(ModelForm): class EditCotisationsOptionForm(ModelForm): - """Edition forms for Cotisations options""" + """Form used to edit subscription preferences.""" class Meta: model = CotisationsOption @@ -250,7 +250,7 @@ class EditCotisationsOptionForm(ModelForm): class MandateForm(ModelForm): - """Edit Mandates""" + """Form used to add and edit mandates.""" class Meta: model = Mandate @@ -319,7 +319,7 @@ class MandateForm(ModelForm): class ServiceForm(ModelForm): - """Edition, ajout de services sur la page d'accueil""" + """Form used to add and edit services displayed on the home page.""" class Meta: model = Service @@ -335,7 +335,8 @@ class ServiceForm(ModelForm): class DelServiceForm(Form): - """Suppression de services sur la page d'accueil""" + """Form used to delete one or several services displayed on the home page. + """ services = forms.ModelMultipleChoiceField( queryset=Service.objects.none(), @@ -353,7 +354,7 @@ class DelServiceForm(Form): class ReminderForm(FormRevMixin, ModelForm): - """Edition, ajout de services sur la page d'accueil""" + """Form used to add and edit reminders.""" class Meta: model = Reminder @@ -365,7 +366,7 @@ class ReminderForm(FormRevMixin, ModelForm): class RadiusKeyForm(FormRevMixin, ModelForm): - """Edition, ajout de clef radius""" + """Form used to add and edit RADIUS keys.""" members = forms.ModelMultipleChoiceField( queryset=Switch.objects.all(), required=False @@ -389,8 +390,7 @@ class RadiusKeyForm(FormRevMixin, ModelForm): class SwitchManagementCredForm(FormRevMixin, ModelForm): - """Edition, ajout de creds de management pour gestion - et interface rest des switchs""" + """Form used to add and edit switch management credentials.""" members = forms.ModelMultipleChoiceField(Switch.objects.all(), required=False) @@ -412,7 +412,7 @@ class SwitchManagementCredForm(FormRevMixin, ModelForm): class MailContactForm(ModelForm): - """Edition, ajout d'adresse de contact""" + """Form used to add and edit contact email addresses.""" class Meta: model = MailContact @@ -424,7 +424,7 @@ class MailContactForm(ModelForm): class DelMailContactForm(Form): - """Delete contact email adress""" + """Form used to delete one or several contact email addresses.""" mailcontacts = forms.ModelMultipleChoiceField( queryset=MailContact.objects.none(), @@ -442,9 +442,7 @@ class DelMailContactForm(Form): class DocumentTemplateForm(FormRevMixin, ModelForm): - """ - Form used to create a document template. - """ + """Form used to add and edit document templates.""" class Meta: model = DocumentTemplate @@ -456,10 +454,7 @@ class DocumentTemplateForm(FormRevMixin, ModelForm): 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. - """ + """Form used to delete one or several document templates.""" document_templates = forms.ModelMultipleChoiceField( queryset=DocumentTemplate.objects.none(), @@ -477,7 +472,7 @@ class DelDocumentTemplateForm(FormRevMixin, Form): class RadiusAttributeForm(ModelForm): - """Edit and add RADIUS attributes.""" + """Form used to add and edit RADIUS attributes.""" class Meta: model = RadiusAttribute @@ -489,7 +484,7 @@ class RadiusAttributeForm(ModelForm): class DelRadiusAttributeForm(Form): - """Delete RADIUS attributes""" + """Form used to delete one or several RADIUS attributes.""" attributes = forms.ModelMultipleChoiceField( queryset=RadiusAttribute.objects.none(), diff --git a/preferences/models.py b/preferences/models.py index d94b2ec8..d475498b 100644 --- a/preferences/models.py +++ b/preferences/models.py @@ -44,20 +44,22 @@ from datetime import timedelta class PreferencesModel(models.Model): - """ Base object for the Preferences objects - Defines methods to handle the cache of the settings (they should - not change a lot) """ + """Base object for the Preferences objects. + + Defines methods to handle the cache of the settings (they should not change + a lot). + """ @classmethod def set_in_cache(cls): - """ Save the preferences in a server-side cache """ + """Save the preferences in a server-side cache.""" instance, _created = cls.objects.get_or_create() cache.set(cls().__class__.__name__.lower(), instance, None) return instance @classmethod def get_cached_value(cls, key): - """ Get the preferences from the server-side cache """ + """Get the preferences from the server-side cache.""" instance = cache.get(cls().__class__.__name__.lower()) if instance is None: instance = cls.set_in_cache() @@ -68,8 +70,34 @@ class PreferencesModel(models.Model): class OptionalUser(AclMixin, PreferencesModel): - """Options pour l'user : obligation ou nom du telephone, - activation ou non du solde, autorisation du negatif, fingerprint etc""" + """User preferences: telephone number requirement, user balance activation, + creation of users by everyone etc. + + Attributes: + is_tel_mandatory: whether indicating a telephone number is mandatory. + gpg_fingerprint: whether GPG fingerprints are enabled. + all_can_create_club: whether all users can create a club. + all_can_create_adherent: whether all users can create a member. + shell_default: the default shell for users connecting to machines + managed by the organisation. + self_change_shell: whether users can edit their shell. + self_change_pseudo: whether users can edit their pseudo (username). + self_room_policy: whether users can edit the policy of their room. + local_email_accounts_enabled: whether local email accounts are enabled. + local_email_domain: the domain used for local email accounts. + max_email_address: the maximum number of local email addresses allowed + for a standard user. + delete_notyetactive: the number of days before deleting not yet active + users. + disable_emailnotyetconfirmed: the number of days before disabling users + with not yet verified email address. + self_adhesion: whether users can create their account themselves. + all_users_active: whether newly created users are active. + allow_set_password_during_user_creation: whether users can set their + password directly when creating their account. + allow_archived_connexion: whether archived users can connect on the web + interface. + """ DISABLED = "DISABLED" ONLY_INACTIVE = "ONLY_INACTIVE" @@ -158,23 +186,32 @@ class OptionalUser(AclMixin, PreferencesModel): verbose_name = _("user preferences") def clean(self): - """Clean model: - Check the mail_extension - """ + """Check the email extension.""" if self.local_email_domain[0] != "@": raise ValidationError(_("Email domain must begin with @.")) @receiver(post_save, sender=OptionalUser) def optionaluser_post_save(**kwargs): - """Ecriture dans le cache""" + """Write in the cache.""" user_pref = kwargs["instance"] user_pref.set_in_cache() class OptionalMachine(AclMixin, PreferencesModel): - """Options pour les machines : maximum de machines ou d'alias par user - sans droit, activation de l'ipv6""" + """Machines preferences: maximum number of machines per user, IPv6 + activation etc. + + Attributes: + password_machine: whether password per machine is enabled. + max_lambdauser_interfaces: the maximum number of interfaces allowed for + a standard user. + max_lambdauser_aliases: the maximum number of aliases allowed for a + standard user. + ipv6_mode: whether IPv6 mode is enabled. + create_machine: whether creation of machine is enabled. + default_dns_ttl: the default TTL for CNAME, A and AAAA records. + """ SLAAC = "SLAAC" DHCPV6 = "DHCPV6" @@ -197,7 +234,7 @@ class OptionalMachine(AclMixin, PreferencesModel): @cached_property def ipv6(self): - """ Check if the IPv6 option is activated """ + """Check if the IPv6 mode is enabled.""" return not self.get_cached_value("ipv6_mode") == "DISABLED" class Meta: @@ -207,7 +244,7 @@ class OptionalMachine(AclMixin, PreferencesModel): @receiver(post_save, sender=OptionalMachine) def optionalmachine_post_save(**kwargs): - """Synchronisation ipv6 et ecriture dans le cache""" + """Synchronise IPv6 mode and write in the cache.""" machine_pref = kwargs["instance"] machine_pref.set_in_cache() if machine_pref.ipv6_mode != "DISABLED": @@ -216,8 +253,21 @@ def optionalmachine_post_save(**kwargs): class OptionalTopologie(AclMixin, PreferencesModel): - """Reglages pour la topologie : mode d'accès radius, vlan où placer - les machines en accept ou reject""" + """Configuration of switches: automatic provision, RADIUS mode, default + VLANs etc. + + Attributes: + switchs_web_management: whether web management for automatic provision + is enabled. + switchs_web_management_ssl: whether SSL web management is required. + switchs_rest_management: whether REST management for automatic + provision is enabled. + switchs_ip_type: the IP range for the management of switches. + switchs_provision: the provision mode for switches to get their + configuration. + sftp_login: the SFTP login for switches. + sftp_pass: the SFTP password for switches. + """ MACHINE = "MACHINE" DEFINED = "DEFINED" @@ -264,7 +314,7 @@ class OptionalTopologie(AclMixin, PreferencesModel): @cached_property def provisioned_switchs(self): - """Liste des switches provisionnés""" + """Get the list of provisioned switches.""" from topologie.models import Switch return Switch.objects.filter(automatic_provision=True).order_by( @@ -273,7 +323,9 @@ class OptionalTopologie(AclMixin, PreferencesModel): @cached_property def switchs_management_interface(self): - """Return the ip of the interface that the switch have to contact to get it's config""" + """Get the interface that the switch has to contact to get its + configuration. + """ if self.switchs_ip_type: from machines.models import Role, Interface @@ -291,14 +343,16 @@ class OptionalTopologie(AclMixin, PreferencesModel): @cached_property def switchs_management_interface_ip(self): - """Same, but return the ipv4""" + """Get the IPv4 address of the interface that the switch has to contact + to get its configuration. + """ if not self.switchs_management_interface: return None return self.switchs_management_interface.ipv4 @cached_property def switchs_management_sftp_creds(self): - """Credentials des switchs pour provion sftp""" + """Get the switch credentials for SFTP provisioning.""" if self.sftp_login and self.sftp_pass: return {"login": self.sftp_login, "pass": self.sftp_pass} else: @@ -306,7 +360,9 @@ class OptionalTopologie(AclMixin, PreferencesModel): @cached_property def switchs_management_utils(self): - """Used for switch_conf, return a list of ip on vlans""" + """Get the dictionary of IP addresses for the configuration of + switches. + """ from machines.models import Role, Ipv6List, Interface def return_ips_dict(interfaces): @@ -350,8 +406,7 @@ class OptionalTopologie(AclMixin, PreferencesModel): @cached_property def provision_switchs_enabled(self): - """Return true if all settings are ok : switchs on automatic provision, - ip_type""" + """Check if all automatic provisioning settings are OK.""" return bool( self.provisioned_switchs and self.switchs_ip_type @@ -371,13 +426,20 @@ class OptionalTopologie(AclMixin, PreferencesModel): @receiver(post_save, sender=OptionalTopologie) def optionaltopologie_post_save(**kwargs): - """Ecriture dans le cache""" + """Write in the cache.""" topologie_pref = kwargs["instance"] topologie_pref.set_in_cache() class RadiusKey(AclMixin, models.Model): - """Class of a radius key""" + """Class of a RADIUS key. + + Attributes: + radius_key: the encrypted RADIUS key. + comment: a comment related to the key. + default_switch: bool, True if the key is to be used by default on + switches and False otherwise. + """ radius_key = AESEncryptedField(max_length=255, help_text=_("RADIUS key.")) comment = models.CharField( @@ -393,9 +455,7 @@ class RadiusKey(AclMixin, models.Model): verbose_name_plural = _("RADIUS keys") def clean(self): - """Clean model: - Check default switch is unique - """ + """Check if there is a unique default RADIUS key.""" if RadiusKey.objects.filter(default_switch=True).count() > 1: raise ValidationError(_("Default RADIUS key for switches already exists.")) @@ -404,7 +464,14 @@ class RadiusKey(AclMixin, models.Model): class SwitchManagementCred(AclMixin, models.Model): - """Class of a management creds of a switch, for rest management""" + """Class of a switch management credentials, for rest management. + + Attributes: + management_id: the login used to connect to switches. + management_pass: the encrypted password used to connect to switches. + default_switch: bool, True if the credentials are to be used by default + on switches and False otherwise. + """ management_id = models.CharField(max_length=63, help_text=_("Switch login.")) management_pass = AESEncryptedField(max_length=63, help_text=_("Password.")) @@ -426,9 +493,13 @@ class SwitchManagementCred(AclMixin, models.Model): class Reminder(AclMixin, models.Model): - """Options pour les mails de notification de fin d'adhésion. - Days: liste des nombres de jours pour lesquells un mail est envoyé - optionalMessage: message additionel pour le mail + """Reminder of membership's end preferences: email messages, number of days + before sending emails. + + Attributes: + days: the number of days before the membership's end to send the + reminder. + message: the content of the reminder. """ days = models.IntegerField( @@ -460,8 +531,26 @@ class Reminder(AclMixin, models.Model): class GeneralOption(AclMixin, PreferencesModel): - """Options générales : nombre de resultats par page, nom du site, - temps où les liens sont valides""" + """General preferences: number of search results per page, website name + etc. + + Attributes: + general_message_fr: general message displayed on the French version of + the website (e.g. in case of maintenance). + general_message_en: general message displayed on the English version of + the website (e.g. in case of maintenance). + search_display_page: number of results displayed (in each category) + when searching. + pagination_number: number of items per page (standard size). + pagination_large_number: number of items per page (large size). + req_expire_hrs: number of hours before expiration of the reset password + link. + site_name: website name. + email_from: email address for automatic emailing. + main_site_url: main site URL. + GTU_sum_up: summary of the General Terms of Use. + GTU: file, General Terms of Use. + """ general_message_fr = models.TextField( default="", @@ -496,14 +585,20 @@ class GeneralOption(AclMixin, PreferencesModel): @receiver(post_save, sender=GeneralOption) def generaloption_post_save(**kwargs): - """Ecriture dans le cache""" + """Write in the cache.""" general_pref = kwargs["instance"] general_pref.set_in_cache() class Service(AclMixin, models.Model): - """Liste des services affichés sur la page d'accueil : url, description, - image et nom""" + """Service displayed on the home page. + + Attributes: + name: the name of the service. + url: the URL of the service. + description: the description of the service. + image: an image to illustrate the service (e.g. logo). + """ name = models.CharField(max_length=32) url = models.URLField() @@ -520,7 +615,12 @@ class Service(AclMixin, models.Model): class MailContact(AclMixin, models.Model): - """Contact email adress with a commentary.""" + """Contact email address with a comment. + + Attributes: + address: the contact email address. + commentary: a comment used to describe the contact email address. + """ address = models.EmailField( default="contact@example.org", help_text=_("Contact email address.") @@ -549,6 +649,15 @@ class MailContact(AclMixin, models.Model): class Mandate(RevMixin, AclMixin, models.Model): + """Mandate, documenting who was the president of the organisation at a + given time. + + Attributes: + president: User, the president during the mandate. + start_date: datetime, the date when the mandate started. + end_date: datetime, the date when the mandate ended. + """ + class Meta: verbose_name = _("mandate") verbose_name_plural = _("mandates") @@ -567,7 +676,14 @@ class Mandate(RevMixin, AclMixin, models.Model): @classmethod def get_mandate(cls, date=timezone.now): - """"Find the mandate taking place at the given date.""" + """"Get the mandate taking place at the given date. + + Args: + date: the date used to find the mandate (default: timezone.now). + + Returns: + The mandate related to the given date. + """ if callable(date): date = date() mandate = ( @@ -590,7 +706,21 @@ class Mandate(RevMixin, AclMixin, models.Model): class AssoOption(AclMixin, PreferencesModel): - """Options générales de l'asso : siret, addresse, nom, etc""" + """Information about the organisation: name, address, SIRET number etc. + + Attributes: + name: the name of the organisation. + siret: the SIRET number of the organisation. + adresse1: the first line of the organisation's address, e.g. street and + number. + adresse2: the second line of the organisation's address, e.g. city and + postal code. + contact: contact email address. + telephone: contact telephone number. + pseudo: short name of the organisation. + utilisateur_asso: the user used to manage the organisation. + description: the description of the organisation. + """ name = models.CharField( default=_("Networking organisation school Something"), max_length=256 @@ -613,13 +743,20 @@ class AssoOption(AclMixin, PreferencesModel): @receiver(post_save, sender=AssoOption) def assooption_post_save(**kwargs): - """Ecriture dans le cache""" + """Write in the cache.""" asso_pref = kwargs["instance"] asso_pref.set_in_cache() class HomeOption(AclMixin, PreferencesModel): - """Settings of the home page (facebook/twitter etc)""" + """Social networks displayed on the home page (supports only Facebook and + Twitter). + + Attributes: + facebook_url: URL of the Facebook account. + twitter_url: URL of the Twitter account. + twitter_account_name: name of the Twitter account. + """ facebook_url = models.URLField(null=True, blank=True) twitter_url = models.URLField(null=True, blank=True) @@ -632,13 +769,18 @@ class HomeOption(AclMixin, PreferencesModel): @receiver(post_save, sender=HomeOption) def homeoption_post_save(**kwargs): - """Ecriture dans le cache""" + """Write in the cache.""" home_pref = kwargs["instance"] home_pref.set_in_cache() class MailMessageOption(AclMixin, models.Model): - """Reglages, mail de bienvenue et autre""" + """Welcome email messages preferences. + + Attributes: + welcome_mail_fr: the text of the welcome email in French. + welcome_mail_en: the text of the welcome email in English. + """ welcome_mail_fr = models.TextField( default="", blank=True, help_text=_("Welcome email in French.") @@ -655,6 +797,14 @@ class MailMessageOption(AclMixin, models.Model): class RadiusAttribute(RevMixin, AclMixin, models.Model): + """RADIUS attributes preferences. + + Attributes: + attribute: the name of the RADIUS attribute. + value: the value of the RADIUS attribute. + comment: the comment to document the attribute. + """ + class Meta: verbose_name = _("RADIUS attribute") verbose_name_plural = _("RADIUS attributes") @@ -677,6 +827,30 @@ class RadiusAttribute(RevMixin, AclMixin, models.Model): class RadiusOption(AclMixin, PreferencesModel): + """RADIUS preferences. + + Attributes: + radius_general_policy: the general RADIUS policy (MACHINE or DEFINED). + unknown_machine: the RADIUS policy for unknown machines. + unknown_machine_vlan: the VLAN for unknown machines if not rejected. + unknown_machine_attributes: the answer attributes for unknown machines. + unknown_port: the RADIUS policy for unknown ports. + unknown_port_vlan: the VLAN for unknown ports if not rejected; + unknown_port_attributes: the answer attributes for unknown ports. + unknown_room: the RADIUS policy for machines connecting from + unregistered rooms (relevant for ports with STRICT RADIUS mode). + unknown_room_vlan: the VLAN for unknown rooms if not rejected. + unknown_room_attributes: the answer attributes for unknown rooms. + non_member: the RADIUS policy for non members. + non_member_vlan: the VLAN for non members if not rejected. + non_member_attributes: the answer attributes for non members. + banned: the RADIUS policy for banned users. + banned_vlan: the VLAN for banned users if not rejected. + banned_attributes: the answer attributes for banned users. + vlan_decision_ok: the VLAN for accepted machines. + ok_attributes: the answer attributes for accepted machines. + """ + class Meta: verbose_name = _("RADIUS policy") verbose_name_plural = _("RADIUS policies") @@ -847,6 +1021,15 @@ def default_voucher(): class CotisationsOption(AclMixin, PreferencesModel): + """Subscription preferences. + + Attributes: + invoice_template: the template for invoices. + voucher_template: the template for vouchers. + send_voucher_mail: whether the voucher is sent by email when the + invoice is controlled. + """ + class Meta: verbose_name = _("subscription preferences") @@ -877,6 +1060,10 @@ class CotisationsOption(AclMixin, PreferencesModel): class DocumentTemplate(RevMixin, AclMixin, models.Model): """Represent a template in order to create documents such as invoice or subscription voucher. + + Attributes: + template: file, the template used to create documents. + name: the name of the template. """ template = models.FileField(upload_to="templates/", verbose_name=_("template")) @@ -892,9 +1079,8 @@ class DocumentTemplate(RevMixin, AclMixin, models.Model): @receiver(models.signals.post_delete, sender=DocumentTemplate) def auto_delete_file_on_delete(sender, instance, **kwargs): - """ - Deletes file from filesystem - when corresponding `DocumentTemplate` object is deleted. + """Delete the tempalte file from filesystem when the related + DocumentTemplate object is deleted. """ if instance.template: if os.path.isfile(instance.template.path): @@ -903,10 +1089,8 @@ def auto_delete_file_on_delete(sender, instance, **kwargs): @receiver(models.signals.pre_save, sender=DocumentTemplate) def auto_delete_file_on_change(sender, instance, **kwargs): - """ - Deletes old file from filesystem - when corresponding `DocumentTemplate` object is updated - with new file. + """Delete the previous file from filesystem when the related + DocumentTemplate object is updated with new file. """ if not instance.pk: return False diff --git a/preferences/views.py b/preferences/views.py index 25e7c009..1f8b6b2e 100644 --- a/preferences/views.py +++ b/preferences/views.py @@ -24,8 +24,8 @@ # Gabriel Détraz, Augustin Lemesle # Gplv2 """ -Vue d'affichage, et de modification des réglages (réglages machine, -topologie, users, service...) +Views to display and edit settings (preferences of machines, users, topology, +services etc.) """ from __future__ import unicode_literals @@ -88,7 +88,7 @@ from . import forms def edit_options_template_function(request, section, forms, models): - """ Edition des préférences générales""" + """View used to edit general preferences.""" model = getattr(models, section, None) form_instance = getattr(forms, "Edit" + section + "Form", None) if not (model or form_instance): @@ -127,8 +127,7 @@ def edit_options_template_function(request, section, forms, models): HomeOption, ) def display_options(request): - """Vue pour affichage des options (en vrac) classé selon les models - correspondants dans un tableau""" + """View used to display preferences sorted by model.""" useroptions, _created = OptionalUser.objects.get_or_create() machineoptions, _created = OptionalMachine.objects.get_or_create() topologieoptions, _created = OptionalTopologie.objects.get_or_create() @@ -188,7 +187,7 @@ def edit_options(request, section): @login_required @can_create(Service) def add_service(request): - """Ajout d'un service de la page d'accueil""" + """View used to add services displayed on the home page.""" service = ServiceForm(request.POST or None, request.FILES or None) if service.is_valid(): service.save() @@ -204,7 +203,7 @@ def add_service(request): @login_required @can_edit(Service) def edit_service(request, service_instance, **_kwargs): - """Edition des services affichés sur la page d'accueil""" + """View used to edit services displayed on the home page.""" service = ServiceForm( request.POST or None, request.FILES or None, instance=service_instance ) @@ -222,7 +221,7 @@ def edit_service(request, service_instance, **_kwargs): @login_required @can_delete(Service) def del_service(request, service_instance, **_kwargs): - """Suppression d'un service de la page d'accueil""" + """View used to delete services displayed on the home page.""" if request.method == "POST": service_instance.delete() messages.success(request, _("The service was deleted.")) @@ -237,7 +236,7 @@ def del_service(request, service_instance, **_kwargs): @login_required @can_create(Reminder) def add_reminder(request): - """Ajout d'un mail de rappel""" + """View used to add reminders.""" reminder = ReminderForm(request.POST or None, request.FILES or None) if reminder.is_valid(): reminder.save() @@ -253,7 +252,7 @@ def add_reminder(request): @login_required @can_edit(Reminder) def edit_reminder(request, reminder_instance, **_kwargs): - """Edition reminder""" + """View used to edit reminders.""" reminder = ReminderForm( request.POST or None, request.FILES or None, instance=reminder_instance ) @@ -271,7 +270,7 @@ def edit_reminder(request, reminder_instance, **_kwargs): @login_required @can_delete(Reminder) def del_reminder(request, reminder_instance, **_kwargs): - """Destruction d'un reminder""" + """View used to delete reminders.""" if request.method == "POST": reminder_instance.delete() messages.success(request, _("The reminder was deleted.")) @@ -286,7 +285,7 @@ def del_reminder(request, reminder_instance, **_kwargs): @login_required @can_create(RadiusKey) def add_radiuskey(request): - """Ajout d'une clef radius""" + """View used to add RADIUS keys.""" radiuskey = RadiusKeyForm(request.POST or None) if radiuskey.is_valid(): radiuskey.save() @@ -301,7 +300,7 @@ def add_radiuskey(request): @can_edit(RadiusKey) def edit_radiuskey(request, radiuskey_instance, **_kwargs): - """Edition des clefs radius""" + """View used to edit RADIUS keys.""" radiuskey = RadiusKeyForm(request.POST or None, instance=radiuskey_instance) if radiuskey.is_valid(): radiuskey.save() @@ -317,7 +316,7 @@ def edit_radiuskey(request, radiuskey_instance, **_kwargs): @login_required @can_delete(RadiusKey) def del_radiuskey(request, radiuskey_instance, **_kwargs): - """Destruction d'un radiuskey""" + """View used to delete RADIUS keys.""" if request.method == "POST": try: radiuskey_instance.delete() @@ -342,6 +341,7 @@ def del_radiuskey(request, radiuskey_instance, **_kwargs): @can_create(SwitchManagementCred) def add_switchmanagementcred(request): """Ajout de creds de management""" + """View used to add switch management credentials.""" switchmanagementcred = SwitchManagementCredForm(request.POST or None) if switchmanagementcred.is_valid(): switchmanagementcred.save() @@ -356,7 +356,7 @@ def add_switchmanagementcred(request): @can_edit(SwitchManagementCred) def edit_switchmanagementcred(request, switchmanagementcred_instance, **_kwargs): - """Edition des creds de management""" + """View used to edit switch management credentials.""" switchmanagementcred = SwitchManagementCredForm( request.POST or None, instance=switchmanagementcred_instance ) @@ -374,7 +374,7 @@ def edit_switchmanagementcred(request, switchmanagementcred_instance, **_kwargs) @login_required @can_delete(SwitchManagementCred) def del_switchmanagementcred(request, switchmanagementcred_instance, **_kwargs): - """Destruction d'un switchmanagementcred""" + """View used to delete switch management credentials.""" if request.method == "POST": try: switchmanagementcred_instance.delete() @@ -404,7 +404,7 @@ def del_switchmanagementcred(request, switchmanagementcred_instance, **_kwargs): @login_required @can_create(MailContact) def add_mailcontact(request): - """Add a contact email adress.""" + """View used to add contact email addresses.""" mailcontact = MailContactForm(request.POST or None, request.FILES or None) if mailcontact.is_valid(): mailcontact.save() @@ -420,7 +420,7 @@ def add_mailcontact(request): @login_required @can_edit(MailContact) def edit_mailcontact(request, mailcontact_instance, **_kwargs): - """Edit contact email adress.""" + """View used to edit contact email addresses.""" mailcontact = MailContactForm( request.POST or None, request.FILES or None, instance=mailcontact_instance ) @@ -438,7 +438,7 @@ def edit_mailcontact(request, mailcontact_instance, **_kwargs): @login_required @can_delete_set(MailContact) def del_mailcontact(request, instances): - """Delete an email adress""" + """View used to delete one or several contact email addresses.""" mailcontacts = DelMailContactForm(request.POST or None, instances=instances) if mailcontacts.is_valid(): mailcontacts_dels = mailcontacts.cleaned_data["mailcontacts"] @@ -456,9 +456,7 @@ def del_mailcontact(request, instances): @login_required @can_create(DocumentTemplate) def add_document_template(request): - """ - View used to add a document template. - """ + """View used to add document templates.""" document_template = DocumentTemplateForm( request.POST or None, request.FILES or None ) @@ -480,9 +478,7 @@ def add_document_template(request): @login_required @can_edit(DocumentTemplate) def edit_document_template(request, document_template_instance, **_kwargs): - """ - View used to edit a document_template. - """ + """View used to edit document templates.""" document_template = DocumentTemplateForm( request.POST or None, request.FILES or None, instance=document_template_instance ) @@ -505,9 +501,7 @@ def edit_document_template(request, document_template_instance, **_kwargs): @login_required @can_delete_set(DocumentTemplate) def del_document_template(request, instances): - """ - View used to delete a set of document template. - """ + """View used to delete one or several document templates.""" document_template = DelDocumentTemplateForm( request.POST or None, instances=instances ) @@ -545,7 +539,7 @@ def del_document_template(request, instances): @login_required @can_create(RadiusAttribute) def add_radiusattribute(request): - """Create a RADIUS attribute.""" + """View used to add RADIUS attributes.""" attribute = RadiusAttributeForm(request.POST or None) if attribute.is_valid(): attribute.save() @@ -561,7 +555,7 @@ def add_radiusattribute(request): @login_required @can_edit(RadiusAttribute) def edit_radiusattribute(request, radiusattribute_instance, **_kwargs): - """Edit a RADIUS attribute.""" + """View used to edit RADIUS attributes.""" attribute = RadiusAttributeForm( request.POST or None, instance=radiusattribute_instance ) @@ -579,7 +573,7 @@ def edit_radiusattribute(request, radiusattribute_instance, **_kwargs): @login_required @can_delete(RadiusAttribute) def del_radiusattribute(request, radiusattribute_instance, **_kwargs): - """Delete a RADIUS attribute.""" + """View used to delete RADIUS attributes.""" if request.method == "POST": radiusattribute_instance.delete() messages.success(request, _("The attribute was deleted.")) @@ -594,7 +588,7 @@ def del_radiusattribute(request, radiusattribute_instance, **_kwargs): @login_required @can_create(Mandate) def add_mandate(request): - """Create a mandate.""" + """View used to add mandates.""" mandate = MandateForm(request.POST or None) if mandate.is_valid(): mandate.save() @@ -610,7 +604,7 @@ def add_mandate(request): @login_required @can_edit(Mandate) def edit_mandate(request, mandate_instance, **_kwargs): - """Edit a mandate.""" + """View used to edit mandates.""" mandate = MandateForm(request.POST or None, instance=mandate_instance) if mandate.is_valid(): mandate.save() @@ -626,7 +620,7 @@ def edit_mandate(request, mandate_instance, **_kwargs): @login_required @can_delete(Mandate) def del_mandate(request, mandate_instance, **_kwargs): - """Delete a mandate.""" + """View used to delete mandates.""" if request.method == "POST": mandate_instance.delete() messages.success(request, _("The mandate was deleted."))